diff options
| author | Thomas Voss <mail@thomasvoss.com> | 2023-09-28 03:44:06 +0200 | 
|---|---|---|
| committer | Thomas Voss <mail@thomasvoss.com> | 2023-09-28 03:44:52 +0200 | 
| commit | 94b1b4ad12c8bb04fc9ff84b1b9c0a707ad675a6 (patch) | |
| tree | f0e2bfad824935c2eb2e9fe22bec07164d038df2 /bindings | |
Genesis commit
Diffstat (limited to 'bindings')
| -rw-r--r-- | bindings/node/binding.cc | 28 | ||||
| -rw-r--r-- | bindings/node/index.js | 19 | ||||
| -rw-r--r-- | bindings/rust/build.rs | 40 | ||||
| -rw-r--r-- | bindings/rust/lib.rs | 52 | 
4 files changed, 139 insertions, 0 deletions
| diff --git a/bindings/node/binding.cc b/bindings/node/binding.cc new file mode 100644 index 0000000..81881bf --- /dev/null +++ b/bindings/node/binding.cc @@ -0,0 +1,28 @@ +#include "tree_sitter/parser.h" +#include <node.h> +#include "nan.h" + +using namespace v8; + +extern "C" TSLanguage * tree_sitter_gsp(); + +namespace { + +NAN_METHOD(New) {} + +void Init(Local<Object> exports, Local<Object> module) { +  Local<FunctionTemplate> tpl = Nan::New<FunctionTemplate>(New); +  tpl->SetClassName(Nan::New("Language").ToLocalChecked()); +  tpl->InstanceTemplate()->SetInternalFieldCount(1); + +  Local<Function> constructor = Nan::GetFunction(tpl).ToLocalChecked(); +  Local<Object> instance = constructor->NewInstance(Nan::GetCurrentContext()).ToLocalChecked(); +  Nan::SetInternalFieldPointer(instance, 0, tree_sitter_gsp()); + +  Nan::Set(instance, Nan::New("name").ToLocalChecked(), Nan::New("gsp").ToLocalChecked()); +  Nan::Set(module, Nan::New("exports").ToLocalChecked(), instance); +} + +NODE_MODULE(tree_sitter_gsp_binding, Init) + +}  // namespace diff --git a/bindings/node/index.js b/bindings/node/index.js new file mode 100644 index 0000000..d0bc87e --- /dev/null +++ b/bindings/node/index.js @@ -0,0 +1,19 @@ +try { +  module.exports = require("../../build/Release/tree_sitter_gsp_binding"); +} catch (error1) { +  if (error1.code !== 'MODULE_NOT_FOUND') { +    throw error1; +  } +  try { +    module.exports = require("../../build/Debug/tree_sitter_gsp_binding"); +  } catch (error2) { +    if (error2.code !== 'MODULE_NOT_FOUND') { +      throw error2; +    } +    throw error1 +  } +} + +try { +  module.exports.nodeTypeInfo = require("../../src/node-types.json"); +} catch (_) {} diff --git a/bindings/rust/build.rs b/bindings/rust/build.rs new file mode 100644 index 0000000..c6061f0 --- /dev/null +++ b/bindings/rust/build.rs @@ -0,0 +1,40 @@ +fn main() { +    let src_dir = std::path::Path::new("src"); + +    let mut c_config = cc::Build::new(); +    c_config.include(&src_dir); +    c_config +        .flag_if_supported("-Wno-unused-parameter") +        .flag_if_supported("-Wno-unused-but-set-variable") +        .flag_if_supported("-Wno-trigraphs"); +    let parser_path = src_dir.join("parser.c"); +    c_config.file(&parser_path); + +    // If your language uses an external scanner written in C, +    // then include this block of code: + +    /* +    let scanner_path = src_dir.join("scanner.c"); +    c_config.file(&scanner_path); +    println!("cargo:rerun-if-changed={}", scanner_path.to_str().unwrap()); +    */ + +    c_config.compile("parser"); +    println!("cargo:rerun-if-changed={}", parser_path.to_str().unwrap()); + +    // If your language uses an external scanner written in C++, +    // then include this block of code: + +    /* +    let mut cpp_config = cc::Build::new(); +    cpp_config.cpp(true); +    cpp_config.include(&src_dir); +    cpp_config +        .flag_if_supported("-Wno-unused-parameter") +        .flag_if_supported("-Wno-unused-but-set-variable"); +    let scanner_path = src_dir.join("scanner.cc"); +    cpp_config.file(&scanner_path); +    cpp_config.compile("scanner"); +    println!("cargo:rerun-if-changed={}", scanner_path.to_str().unwrap()); +    */ +} diff --git a/bindings/rust/lib.rs b/bindings/rust/lib.rs new file mode 100644 index 0000000..d058c81 --- /dev/null +++ b/bindings/rust/lib.rs @@ -0,0 +1,52 @@ +//! This crate provides gsp language support for the [tree-sitter][] parsing library. +//! +//! Typically, you will use the [language][language func] 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_gsp::language()).expect("Error loading gsp grammar"); +//! let tree = parser.parse(code, None).unwrap(); +//! ``` +//! +//! [Language]: https://docs.rs/tree-sitter/*/tree_sitter/struct.Language.html +//! [language func]: fn.language.html +//! [Parser]: https://docs.rs/tree-sitter/*/tree_sitter/struct.Parser.html +//! [tree-sitter]: https://tree-sitter.github.io/ + +use tree_sitter::Language; + +extern "C" { +    fn tree_sitter_gsp() -> Language; +} + +/// Get the tree-sitter [Language][] for this grammar. +/// +/// [Language]: https://docs.rs/tree-sitter/*/tree_sitter/struct.Language.html +pub fn language() -> Language { +    unsafe { tree_sitter_gsp() } +} + +/// The content of the [`node-types.json`][] file for this grammar. +/// +/// [`node-types.json`]: https://tree-sitter.github.io/tree-sitter/using-parsers#static-node-types +pub const NODE_TYPES: &'static str = include_str!("../../src/node-types.json"); + +// Uncomment these to include any queries that this grammar contains + +// pub const HIGHLIGHTS_QUERY: &'static str = include_str!("../../queries/highlights.scm"); +// pub const INJECTIONS_QUERY: &'static str = include_str!("../../queries/injections.scm"); +// pub const LOCALS_QUERY: &'static str = include_str!("../../queries/locals.scm"); +// pub const TAGS_QUERY: &'static str = include_str!("../../queries/tags.scm"); + +#[cfg(test)] +mod tests { +    #[test] +    fn test_can_load_grammar() { +        let mut parser = tree_sitter::Parser::new(); +        parser +            .set_language(super::language()) +            .expect("Error loading gsp language"); +    } +} |