summaryrefslogtreecommitdiffstats
path: root/parser.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2022-02-19 10:50:10 -0800
committerKaz Kylheku <kaz@kylheku.com>2022-02-19 10:50:10 -0800
commitc914063fd0eb8c02d8362b86a61933c656a938bc (patch)
treea81db16032450b5ece94b70c2d824e6bd2c79571 /parser.c
parentf20db9ab6cacd73f4276c6541d3009e731811a7e (diff)
downloadtxr-c914063fd0eb8c02d8362b86a61933c656a938bc.tar.gz
txr-c914063fd0eb8c02d8362b86a61933c656a938bc.tar.bz2
txr-c914063fd0eb8c02d8362b86a61933c656a938bc.zip
listener: restore and improve method completion.
The recent autoload changes have degraded method completion, which didn't work well in the first place. Test case: with this change you can type term.(go[Tab] to complete to term.(go-raw or term.(go-cbreak. * parser.c (find_matching_syms): Do not use the get_slot_syms function for finding method and slot symbols. Just use get_visible_syms, like for other bindings. Instead, in the switch statement in the loop, for the 'M' (method) and 'S' (slot) completion types, we use the static_slot_types and slot_types functions to inquire whether a symbol has a binding. And these two functions do something important: unlike get_slot_syms, they trigger autoload. * struct.c (get_slot_syms): Function removed. * struct.h (get_slot_syms): Declaration removed.
Diffstat (limited to 'parser.c')
-rw-r--r--parser.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/parser.c b/parser.c
index 2937ecd8..ee2ab6df 100644
--- a/parser.c
+++ b/parser.c
@@ -972,9 +972,7 @@ static void find_matching_syms(lino_completions_t *cpl,
if3(package == keyword_package && !force_qualify,
null_string,
package_name(package)));
- val syms = ((kind == 'S' || kind == 'M')
- ? hash_keys((get_slot_syms(package, is_cur, tnil(kind == 'M'))))
- : get_visible_syms(package, is_cur != nil && !qualify));
+ val syms = get_visible_syms(package, is_cur != nil && !qualify);
for ( ; syms; syms = cdr(syms)) {
val sym = car(syms);
@@ -992,7 +990,13 @@ static void find_matching_syms(lino_completions_t *cpl,
break;
continue;
case 'M':
+ if (static_slot_types(sym))
+ break;
+ continue;
case 'S':
+ if (slot_types(sym))
+ break;
+ continue;
break;
case 'Q':
if (mboundp(sym) || special_operator_p(sym))