#ssh-client #client-config #config-parser #ssh #parser #client #incremental

tree-sitter-ssh-client-config

SSH client config grammar for the tree-sitter parsing library

47 stable releases

new 2024.7.25 Jul 25, 2024
2024.6.27 Jun 27, 2024
2024.3.28 Mar 28, 2024
2023.12.21 Dec 21, 2023
1.0.3 Mar 30, 2022

#83 in Text editors

Download history 192/week @ 2024-04-01 152/week @ 2024-04-08 266/week @ 2024-04-15 184/week @ 2024-04-22 196/week @ 2024-04-29 175/week @ 2024-05-06 2/week @ 2024-05-13 156/week @ 2024-05-20 189/week @ 2024-06-03 178/week @ 2024-06-10 175/week @ 2024-06-17 168/week @ 2024-06-24 189/week @ 2024-07-01 120/week @ 2024-07-08 110/week @ 2024-07-15

592 downloads per month

CC0 license

6MB
120K SLoC

C 119K SLoC JavaScript 852 SLoC Scheme 230 SLoC Rust 33 SLoC // 0.4% comments

tree-sitter-ssh-client-config

SSH client config grammar for tree-sitter.

Usage

This grammar is available at crates.io, and you can use it together with the Rust language binding.

use tree_sitter::{Parser, Language};

let mut parser = Parser::new();
parser.set_language(tree_sitter_ssh_client_config::language()).expect("Error loading SSH client config grammar");
let config = "\
Host example.com
  User your-name
  Port 12345";
let tree = parser.parse(config, None).unwrap();
assert_eq!(tree.root_node().to_sexp(), "(client_config (host (host_value)) (user (user_value)) (port (port_value)))");

References


lib.rs:

This crate provides ssh-client-config language support for the tree-sitter parsing library.

Typically, you will use the language function to add this language to a tree-sitter Parser, and then use the parser to parse some code:

let code = "";
let mut parser = tree_sitter::Parser::new();
parser.set_language(tree_sitter_ssh_client_config::language()).expect("Error loading ssh-client-config grammar");
let tree = parser.parse(code, None).unwrap();

Dependencies

~2.7–4MB
~71K SLoC