From 676cc2b5619ecd517df42b07dbc2c22449a47179 Mon Sep 17 00:00:00 2001 From: Benedikt Peetz Date: Mon, 4 Nov 2024 20:45:29 +0100 Subject: refactor(tree-sitter-yts): Move in tree --- tree-sitter-yts/bindings/node/binding.cc | 33 ++++++++++++++++++++++++++++++++ tree-sitter-yts/bindings/node/index.js | 19 ++++++++++++++++++ 2 files changed, 52 insertions(+) create mode 100644 tree-sitter-yts/bindings/node/binding.cc create mode 100644 tree-sitter-yts/bindings/node/index.js (limited to 'tree-sitter-yts/bindings/node') diff --git a/tree-sitter-yts/bindings/node/binding.cc b/tree-sitter-yts/bindings/node/binding.cc new file mode 100644 index 0000000..a042be5 --- /dev/null +++ b/tree-sitter-yts/bindings/node/binding.cc @@ -0,0 +1,33 @@ +#include "nan.h" +#include "tree_sitter/parser.h" +#include + +using namespace v8; + +extern "C" TSLanguage *tree_sitter_yts (); + +namespace +{ + +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_yts ()); + + Nan::Set (instance, Nan::New ("name").ToLocalChecked (), + Nan::New ("yts").ToLocalChecked ()); + Nan::Set (module, Nan::New ("exports").ToLocalChecked (), instance); +} + +NODE_MODULE (tree_sitter_yts_binding, Init) + +} // namespace diff --git a/tree-sitter-yts/bindings/node/index.js b/tree-sitter-yts/bindings/node/index.js new file mode 100644 index 0000000..3217974 --- /dev/null +++ b/tree-sitter-yts/bindings/node/index.js @@ -0,0 +1,19 @@ +try { + module.exports = require("../../build/Release/tree_sitter_yts_binding"); +} catch (error1) { + if (error1.code !== "MODULE_NOT_FOUND") { + throw error1; + } + try { + module.exports = require("../../build/Debug/tree_sitter_yts_binding"); + } catch (error2) { + if (error2.code !== "MODULE_NOT_FOUND") { + throw error2; + } + throw error1; + } +} + +try { + module.exports.nodeTypeInfo = require("../../src/node-types.json"); +} catch (_) {} -- cgit 1.4.1