Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Option to disable the Keep Typing feature #444

Closed
gary-ruizhang opened this issue Aug 9, 2023 · 1 comment
Closed

Option to disable the Keep Typing feature #444

gary-ruizhang opened this issue Aug 9, 2023 · 1 comment
Labels

Comments

@gary-ruizhang
Copy link

Is there an option to disable the keep typing feature and limit to just two chars? Because of the keep typing feature, the selection tag candidate will exclude all the third sequential char. This will sometimes exhaust the one char tag and use a two char tag instead.

@gary-ruizhang gary-ruizhang changed the title Option to disable the Keep Typing feature or Maximum typed chars Option to disable the Keep Typing feature Aug 9, 2023
@breandan
Copy link
Collaborator

breandan commented Aug 9, 2023

Hi Gary, thank you for using AceJump and the nice suggestion. There are two reasons why two-character tags are needed. One is that there are more search results than the number of allowed tag characters, e.g., ~36(=[a-z0-9]) by default. One way to reduce the number of search results and encourage single-character tags is to disable the "search whole file" option (under Settings | AceJump | Behavior), which should only paint tags to locations which are visible in the editor.

Screenshot 2023-08-09 at 12 57 37 PM

As you mentioned, the second reason why two-character tags are necessary is that all subsequent characters from all matching words in all results are blocked (see Solver.canTagBeginWithChar(Editor, Int, Char) for the precise behavior). Although by design, in rare cases this behavior can cause all available tags to be blocked, see #355 for further discussion. While there is a solution to prevent this, it is probably not worth the trouble to implement since such scenarios are so rare.

The most reasonable behavior here would be to have a separate AceJump mode that only matches single-characters on screen, while minimizing the number of two-character tags assigned. When there are fewer than ~36 results, single-character tags could be assigned to all results. When there are between (36, 36^2] results, it should still be possible to assign single-character tags to at least some results by prioritizing single-character tags according to some likeliehood criteria, while ensuring all results are tagged. There is a feature request (#378) for single-character tags by default, which I think addresses your use case?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants