about summary refs log tree commit diff stats
path: root/pkgs/by-name/tr/tree-sitter-yts/bindings/node
diff options
context:
space:
mode:
authorBenedikt Peetz <benedikt.peetz@b-peetz.de>2024-05-23 13:26:22 +0200
committerBenedikt Peetz <benedikt.peetz@b-peetz.de>2024-05-23 13:26:22 +0200
commit204731c0a69136c9cebcb54f1afecf5145e26bbe (patch)
treefc9132e5dc74e4a8e1327cdd411839a90f9410aa /pkgs/by-name/tr/tree-sitter-yts/bindings/node
parentrefactor(sys): Modularize and move to `modules/system` or `pkgs` (diff)
downloadnixos-config-204731c0a69136c9cebcb54f1afecf5145e26bbe.tar.gz
nixos-config-204731c0a69136c9cebcb54f1afecf5145e26bbe.zip
refactor(pkgs): Categorize into `by-name` shards
This might not be the perfect way to organize a package set --
especially if the set is not nearly the size of nixpkgs -- but it is
_at_ least a way of organization.
Diffstat (limited to 'pkgs/by-name/tr/tree-sitter-yts/bindings/node')
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/bindings/node/binding.cc33
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/bindings/node/index.js19
2 files changed, 52 insertions, 0 deletions
diff --git a/pkgs/by-name/tr/tree-sitter-yts/bindings/node/binding.cc b/pkgs/by-name/tr/tree-sitter-yts/bindings/node/binding.cc
new file mode 100644
index 00000000..a042be54
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/bindings/node/binding.cc
@@ -0,0 +1,33 @@
+#include "nan.h"
+#include "tree_sitter/parser.h"
+#include <node.h>
+
+using namespace v8;
+
+extern "C" TSLanguage *tree_sitter_yts ();
+
+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_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/pkgs/by-name/tr/tree-sitter-yts/bindings/node/index.js b/pkgs/by-name/tr/tree-sitter-yts/bindings/node/index.js
new file mode 100644
index 00000000..32179742
--- /dev/null
+++ b/pkgs/by-name/tr/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 (_) {}