-
Notifications
You must be signed in to change notification settings - Fork 1
Tree‐sitter Integration for :TWCenter Command
The :TWCenter
command in the Typewriter plugin leverages Tree-sitter for intelligent code block detection. Tree-sitter is a powerful parsing library that generates concrete syntax trees for programming languages, allowing precise navigation and manipulation of code structures.
The configuration for which nodes to consider significant is located in the center_block_config.lua
file. This file specifies the types of syntax nodes that the :TWCenter
command will recognize and use to center the view.
This utility file lists the node types that should be considered significant when determining the current code block or function to center on the screen. Here is the content of center_block_config.lua
:
-- lua/typewriter/utils/center_block_config.lua
local M = {}
M.expand = {
["function"] = true,
["body"] = true,
["method"] = true,
["table"] = true,
["if_statement"] = true,
["class"] = true,
["block"] = true,
["module"] = true,
["namespace"] = true,
["program"] = true,
["source"] = true,
["for_loop"] = true,
["while_loop"] = true,
["conditional"] = true,
["try_statement"] = true,
["catch_clause"] = true,
["finally_clause"] = true,
["switch_statement"] = true,
["case_statement"] = true,
["else_clause"] = true,
["do_statement"] = true,
["repeat_statement"] = true,
["function_call"] = true,
["function_definition"] = true,
["arrow_function"] = true,
["function_expression"] = true,
["generator_function"] = true,
["async_function"] = true,
["object"] = true,
["array"] = true,
["property"] = true,
["field"] = true,
["parameter"] = true,
["constructor"] = true,
["decorator"] = true,
["import_statement"] = true,
["export_statement"] = true,
["try_expression"] = true,
["match_statement"] = true,
["enum_declaration"] = true,
["interface_declaration"] = true,
["type_alias"] = true,
["variable_declaration"] = true,
["lexical_declaration"] = true,
["assignment"] = true,
["expression_statement"] = true,
["return_statement"] = true,
["throw_statement"] = true,
["await_expression"] = true,
}
return M
-
Node Detection: The
:TWCenter
command uses the Tree-sitter API to parse the current buffer and identify the syntax node under the cursor. -
Significant Nodes: It checks if the node type matches any in the
M.expand
table from thecenter_block_config.lua
file. If it finds a match, it considers the node significant. - Centering Logic: Once a significant node is identified, the command calculates the center of the node's range and adjusts the view to place this center in the middle of the screen.
:TWCenter
- Enhanced Focus: By centering the view around the current code block or function, it helps maintain focus on the context you are working on.
- Intelligent Navigation: Tree-sitter provides accurate syntax tree parsing, ensuring that the command works reliably across various programming languages.
-
Customizable: The
center_block_config.lua
file allows easy customization of which syntax nodes are considered significant, making the plugin adaptable to different coding styles and needs.
By leveraging Tree-sitter, the :TWCenter
command provides a robust solution for keeping the active code block in focus, improving readability and navigation in large code files.
Thank you for exploring the Typewriter.nvim documentation. We hope you find this plugin enhances your writing and coding experience in Neovim. If you have any questions, suggestions, or contributions, please feel free to reach out or submit an issue on our GitHub repository.
Stay Connected:
Crafted with care by Josh Peterson.