From 849cd60632c2da99a4035e614266b0aa86612f4f Mon Sep 17 00:00:00 2001 From: Soispha Date: Fri, 19 Jan 2024 18:55:21 +0100 Subject: feat(hm/conf/nvim/plgs/treesitter): Add custom parser for `yts` --- .../pkgs/tree-sitter-yts/bindings/node/binding.cc | 28 ++++++++++++++++++++++ .../pkgs/tree-sitter-yts/bindings/node/index.js | 19 +++++++++++++++ 2 files changed, 47 insertions(+) create mode 100644 sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/binding.cc create mode 100644 sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/index.js (limited to 'sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node') diff --git a/sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/binding.cc b/sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/binding.cc new file mode 100644 index 00000000..de7d0497 --- /dev/null +++ b/sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/binding.cc @@ -0,0 +1,28 @@ +#include "tree_sitter/parser.h" +#include +#include "nan.h" + +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/sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/index.js b/sys/nixpkgs/pkgs/tree-sitter-yts/bindings/node/index.js new file mode 100644 index 00000000..32179742 --- /dev/null +++ b/sys/nixpkgs/pkgs/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