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

perf(ts-context): limit max_lines to 3 #1075

Merged
merged 1 commit into from
Nov 23, 2023
Merged

Conversation

Jint-lzxy
Copy link
Collaborator

It appears that when navigating through syntax trees of great intricacy, ts-context would expend an excessive amount of time collecting (and rendering) all "candidate nodes" from here to the root of the tree when the cursor goes deep into a particular "branch", given our current settings. This PR limited max_lines to 3, as IMO we seldom need hierarchical information about nodes that are too distant from the current one in practice, and 3 is also the optimal value I've found in recent trials that strikes a balance between the amount of practical information and performance penalties lol

It appears that when navigating through syntax trees of great intricacy,
`ts-context` would expend an excessive amount of time collecting _(and
rendering)_ all "candidate nodes" from here to the root of the tree when the
cursor goes deep into a particular "branch", given our current settings. This
PR limited `max_lines` to 3, as IMO we seldom need hierarchical information
about nodes that are _too_ distant from the current one in practice, and `3`
is also the optimal value I've found in recent trials that strikes a balance
between the amount of practical information and performance penalties lol
@ayamir ayamir merged commit de10eee into main Nov 23, 2023
4 checks passed
@ayamir ayamir deleted the perf/limit-ts-context-max-lines branch November 23, 2023 12:52
singlemancombat pushed a commit to singlemancombat/nvim-config that referenced this pull request Nov 27, 2023
It appears that when navigating through syntax trees of great intricacy,
`ts-context` would expend an excessive amount of time collecting _(and
rendering)_ all "candidate nodes" from here to the root of the tree when the
cursor goes deep into a particular "branch", given our current settings. This
PR limited `max_lines` to 3, as IMO we seldom need hierarchical information
about nodes that are _too_ distant from the current one in practice, and `3`
is also the optimal value I've found in recent trials that strikes a balance
between the amount of practical information and performance penalties lol
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants