From 384c55ede2a1f13e83d8e18dbef8f11304c379c2 Mon Sep 17 00:00:00 2001 From: Brian Ryall Date: Fri, 19 Jul 2024 23:54:59 -0400 Subject: [PATCH] fix: generate bindings --- binding.gyp | 24 +++++++++++++++++------- bindings/node/binding.cc | 36 ++++++++++++++---------------------- bindings/node/index.d.ts | 28 ++++++++++++++++++++++++++++ bindings/node/index.js | 18 +++--------------- bindings/rust/build.rs | 3 +++ 5 files changed, 65 insertions(+), 44 deletions(-) create mode 100644 bindings/node/index.d.ts diff --git a/binding.gyp b/binding.gyp index b30db8d..eafc6eb 100644 --- a/binding.gyp +++ b/binding.gyp @@ -2,19 +2,29 @@ "targets": [ { "target_name": "tree_sitter_beancount_binding", + "dependencies": [ + " -#include "nan.h" +#include -using namespace v8; +typedef struct TSLanguage TSLanguage; -extern "C" TSLanguage * tree_sitter_beancount(); +extern "C" TSLanguage *tree_sitter_beancount(); -namespace { +// "tree-sitter", "language" hashed with BLAKE2 +const napi_type_tag LANGUAGE_TYPE_TAG = { + 0x8AF2E5212AD58ABF, 0xD5006CAD83ABBA16 +}; -NAN_METHOD(New) {} - -void Init(Local exports, Local module) { - Local tpl = Nan::New(New); - tpl->SetClassName(Nan::New("Language").ToLocalChecked()); - tpl->InstanceTemplate()->SetInternalFieldCount(1); - - Local constructor = Nan::GetFunction(tpl).ToLocalChecked(); - Local instance = constructor->NewInstance(Nan::GetCurrentContext()).ToLocalChecked(); - Nan::SetInternalFieldPointer(instance, 0, tree_sitter_beancount()); - - Nan::Set(instance, Nan::New("name").ToLocalChecked(), Nan::New("beancount").ToLocalChecked()); - Nan::Set(module, Nan::New("exports").ToLocalChecked(), instance); +Napi::Object Init(Napi::Env env, Napi::Object exports) { + exports["name"] = Napi::String::New(env, "beancount"); + auto language = Napi::External::New(env, tree_sitter_beancount()); + language.TypeTag(&LANGUAGE_TYPE_TAG); + exports["language"] = language; + return exports; } -NODE_MODULE(tree_sitter_beancount_binding, Init) - -} // namespace +NODE_API_MODULE(tree_sitter_beancount_binding, Init) diff --git a/bindings/node/index.d.ts b/bindings/node/index.d.ts new file mode 100644 index 0000000..efe259e --- /dev/null +++ b/bindings/node/index.d.ts @@ -0,0 +1,28 @@ +type BaseNode = { + type: string; + named: boolean; +}; + +type ChildNode = { + multiple: boolean; + required: boolean; + types: BaseNode[]; +}; + +type NodeInfo = + | (BaseNode & { + subtypes: BaseNode[]; + }) + | (BaseNode & { + fields: { [name: string]: ChildNode }; + children: ChildNode[]; + }); + +type Language = { + name: string; + language: unknown; + nodeTypeInfo: NodeInfo[]; +}; + +declare const language: Language; +export = language; diff --git a/bindings/node/index.js b/bindings/node/index.js index 176465a..6657bcf 100644 --- a/bindings/node/index.js +++ b/bindings/node/index.js @@ -1,18 +1,6 @@ -try { - module.exports = require("../../build/Release/tree_sitter_beancount_binding"); -} catch (error1) { - if (error1.code !== 'MODULE_NOT_FOUND') { - throw error1; - } - try { - module.exports = require("../../build/Debug/tree_sitter_beancount_binding"); - } catch (error2) { - if (error2.code !== 'MODULE_NOT_FOUND') { - throw error2; - } - throw error1 - } -} +const root = require("path").join(__dirname, "..", ".."); + +module.exports = require("node-gyp-build")(root); try { module.exports.nodeTypeInfo = require("../../src/node-types.json"); diff --git a/bindings/rust/build.rs b/bindings/rust/build.rs index 1f82286..5e1ed26 100644 --- a/bindings/rust/build.rs +++ b/bindings/rust/build.rs @@ -8,6 +8,9 @@ fn main() { .flag_if_supported("-Wno-unused-but-set-variable") .flag_if_supported("-Wno-trigraphs") .flag_if_supported("-O"); + #[cfg(target_env = "msvc")] + c_config.flag("-utf-8"); + let parser_path = src_dir.join("parser.c"); c_config.file(&parser_path);