about summary refs log tree commit diff stats
path: root/pkgs/by-name/tr
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
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')
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/.editorconfig21
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/.envrc1
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/.gitignore3
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/Cargo.toml21
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/binding.gyp19
-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
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/bindings/rust/build.rs40
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/bindings/rust/lib.rs52
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/corpus/comments.txt51
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/corpus/comments_correct.txt27
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/corpus/duration.txt84
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/corpus/url.txt84
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/flake.lock97
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/flake.nix82
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/grammar.js26
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/highlight.yts4
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/package.json31
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/package.nix59
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/queries/highlights.scm11
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/src/grammar.json238
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/src/node-types.json200
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/src/parser.c1108
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/src/tree_sitter/parser.h241
-rw-r--r--pkgs/by-name/tr/tree-sitter-yts/treefmt.toml35
25 files changed, 2587 insertions, 0 deletions
diff --git a/pkgs/by-name/tr/tree-sitter-yts/.editorconfig b/pkgs/by-name/tr/tree-sitter-yts/.editorconfig
new file mode 100644
index 00000000..919c78fa
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/.editorconfig
@@ -0,0 +1,21 @@
+root = true
+
+[*]
+end_of_line = lf
+insert_final_newline = true
+trim_trailing_whitespace = false
+
+# for testing purposes, the corpus may have trailing whitespace
+# and may have mixed EOL.
+# Still want a final newline though, as that makes no semantic difference.
+[corpus/*]
+trim_trailing_whitespace = false
+end_of_line = unset
+
+[**.{js,json,cc,css}]
+indent_style = space
+indent_size = 2
+
+# tree-sitter generate emits json with no trailing newline
+[src/node-types.json]
+insert_final_newline = false
diff --git a/pkgs/by-name/tr/tree-sitter-yts/.envrc b/pkgs/by-name/tr/tree-sitter-yts/.envrc
new file mode 100644
index 00000000..3550a30f
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/.envrc
@@ -0,0 +1 @@
+use flake
diff --git a/pkgs/by-name/tr/tree-sitter-yts/.gitignore b/pkgs/by-name/tr/tree-sitter-yts/.gitignore
new file mode 100644
index 00000000..c4e2e389
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/.gitignore
@@ -0,0 +1,3 @@
+/.direnv
+/result
+/node_modules
diff --git a/pkgs/by-name/tr/tree-sitter-yts/Cargo.toml b/pkgs/by-name/tr/tree-sitter-yts/Cargo.toml
new file mode 100644
index 00000000..5287c420
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/Cargo.toml
@@ -0,0 +1,21 @@
+[package]
+name = "tree-sitter-yts"
+description = "yts grammar for the tree-sitter parsing library"
+version = "0.0.1"
+keywords = ["incremental", "parsing", "yts"]
+categories = ["parsing", "text-editors"]
+repository = "https://github.com/tree-sitter/tree-sitter-yts"
+edition = "2018"
+license = "MIT"
+
+build = "bindings/rust/build.rs"
+include = ["bindings/rust/*", "grammar.js", "queries/*", "src/*"]
+
+[lib]
+path = "bindings/rust/lib.rs"
+
+[dependencies]
+tree-sitter = "~0.20.10"
+
+[build-dependencies]
+cc = "1.0"
diff --git a/pkgs/by-name/tr/tree-sitter-yts/binding.gyp b/pkgs/by-name/tr/tree-sitter-yts/binding.gyp
new file mode 100644
index 00000000..b05038b4
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/binding.gyp
@@ -0,0 +1,19 @@
+{
+  "targets": [
+    {
+      "target_name": "tree_sitter_yts_binding",
+      "include_dirs": [
+        "<!(node -e \"require('nan')\")",
+        "src"
+      ],
+      "sources": [
+        "bindings/node/binding.cc",
+        "src/parser.c",
+        # If your language uses an external scanner, add it here.
+      ],
+      "cflags_c": [
+        "-std=c99",
+      ]
+    }
+  ]
+}
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 (_) {}
diff --git a/pkgs/by-name/tr/tree-sitter-yts/bindings/rust/build.rs b/pkgs/by-name/tr/tree-sitter-yts/bindings/rust/build.rs
new file mode 100644
index 00000000..c6061f09
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/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/pkgs/by-name/tr/tree-sitter-yts/bindings/rust/lib.rs b/pkgs/by-name/tr/tree-sitter-yts/bindings/rust/lib.rs
new file mode 100644
index 00000000..f1868b2d
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/bindings/rust/lib.rs
@@ -0,0 +1,52 @@
+//! This crate provides yts 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_yts::language()).expect("Error loading yts 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_yts() -> 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_yts() }
+}
+
+/// 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 yts language");
+    }
+}
diff --git a/pkgs/by-name/tr/tree-sitter-yts/corpus/comments.txt b/pkgs/by-name/tr/tree-sitter-yts/corpus/comments.txt
new file mode 100644
index 00000000..0070baf8
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/corpus/comments.txt
@@ -0,0 +1,51 @@
+================================================================================
+Parse multiple lines
+================================================================================
+
+pick 6221 "Name" "2024-01-17" "A" "[0m 0s]" "url"
+pick 6181 "Name2" "2024-01-16" "A2" "[0m 0s]" "url"
+
+# This is a comment
+# it contains information
+
+--------------------------------------------------------------------------------
+
+(source_file
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (comment)
+  (comment))
diff --git a/pkgs/by-name/tr/tree-sitter-yts/corpus/comments_correct.txt b/pkgs/by-name/tr/tree-sitter-yts/corpus/comments_correct.txt
new file mode 100644
index 00000000..40cdab7d
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/corpus/comments_correct.txt
@@ -0,0 +1,27 @@
+================================================================================
+Disregard comments in title
+================================================================================
+
+pick 6094 "#100 Name" "2024-01-12" "A" "[133m 29s]" "url"
+
+--------------------------------------------------------------------------------
+
+(source_file
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote))))
diff --git a/pkgs/by-name/tr/tree-sitter-yts/corpus/duration.txt b/pkgs/by-name/tr/tree-sitter-yts/corpus/duration.txt
new file mode 100644
index 00000000..59476b98
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/corpus/duration.txt
@@ -0,0 +1,84 @@
+================================================================================
+Parse multiple lines with different durations
+================================================================================
+
+pick 6221 "Name" "2024-01-17" "A" "[1h 0m]" "url"
+pick 6181 "Name2" "2024-01-16" "A2" "[20m 02s]" "url2"
+pick 6184 "Name3" "2024-01-16" "A3" "[20h 0m]" "url3"
+pick 6206 "Name4" "2024-01-16" "A4" "[No Duration]" "url4"
+
+--------------------------------------------------------------------------------
+
+(source_file
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote))))
diff --git a/pkgs/by-name/tr/tree-sitter-yts/corpus/url.txt b/pkgs/by-name/tr/tree-sitter-yts/corpus/url.txt
new file mode 100644
index 00000000..1ae3d106
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/corpus/url.txt
@@ -0,0 +1,84 @@
+================================================================================
+Parse multiple lines with url
+================================================================================
+
+pick 6221 "Name" "2024-01-17" "A" "[0h 0m]" "url"
+pick 6181 "Name2" "2024-01-16" "A2" "[0h 0m]" "url2"
+pick 6184 "Name3" "2024-01-16" "A3" "[0h 0m]" "url3"
+pick 6206 "Name4" "2024-01-16" "A4" "[0h 0m]" "url4"
+
+--------------------------------------------------------------------------------
+
+(source_file
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote)))
+  (line
+    (command)
+    (id)
+    (title
+      (quote)
+      (quote))
+    (date
+      (quote)
+      (quote))
+    (author
+      (quote)
+      (quote))
+    (duration
+      (quote)
+      (quote))
+    (url
+      (quote)
+      (quote))))
diff --git a/pkgs/by-name/tr/tree-sitter-yts/flake.lock b/pkgs/by-name/tr/tree-sitter-yts/flake.lock
new file mode 100644
index 00000000..bff9f1fa
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/flake.lock
@@ -0,0 +1,97 @@
+{
+  "nodes": {
+    "crane": {
+      "inputs": {
+        "nixpkgs": ["nixpkgs"]
+      },
+      "locked": {
+        "lastModified": 1704819371,
+        "narHash": "sha256-oFUfPWrWGQTZaCM3byxwYwrMLwshDxVGOrMH5cVP/X8=",
+        "owner": "ipetkov",
+        "repo": "crane",
+        "rev": "5c234301a1277e4cc759c23a2a7a00a06ddd7111",
+        "type": "github"
+      },
+      "original": {
+        "owner": "ipetkov",
+        "repo": "crane",
+        "type": "github"
+      }
+    },
+    "flake-utils": {
+      "inputs": {
+        "systems": "systems"
+      },
+      "locked": {
+        "lastModified": 1701680307,
+        "narHash": "sha256-kAuep2h5ajznlPMD9rnQyffWG8EM/C73lejGofXvdM8=",
+        "owner": "numtide",
+        "repo": "flake-utils",
+        "rev": "4022d587cbbfd70fe950c1e2083a02621806a725",
+        "type": "github"
+      },
+      "original": {
+        "owner": "numtide",
+        "repo": "flake-utils",
+        "type": "github"
+      }
+    },
+    "nixpkgs": {
+      "locked": {
+        "lastModified": 1705133751,
+        "narHash": "sha256-rCIsyE80jgiOU78gCWN3A0wE0tR2GI5nH6MlS+HaaSQ=",
+        "owner": "NixOS",
+        "repo": "nixpkgs",
+        "rev": "9b19f5e77dd906cb52dade0b7bd280339d2a1f3d",
+        "type": "github"
+      },
+      "original": {
+        "owner": "NixOS",
+        "ref": "nixos-unstable",
+        "repo": "nixpkgs",
+        "type": "github"
+      }
+    },
+    "npmlock2nix": {
+      "flake": false,
+      "locked": {
+        "lastModified": 1673447413,
+        "narHash": "sha256-sJM82Sj8yfQYs9axEmGZ9Evzdv/kDcI9sddqJ45frrU=",
+        "owner": "nix-community",
+        "repo": "npmlock2nix",
+        "rev": "9197bbf397d76059a76310523d45df10d2e4ca81",
+        "type": "github"
+      },
+      "original": {
+        "owner": "nix-community",
+        "repo": "npmlock2nix",
+        "type": "github"
+      }
+    },
+    "root": {
+      "inputs": {
+        "crane": "crane",
+        "flake-utils": "flake-utils",
+        "nixpkgs": "nixpkgs",
+        "npmlock2nix": "npmlock2nix"
+      }
+    },
+    "systems": {
+      "locked": {
+        "lastModified": 1681028828,
+        "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
+        "owner": "nix-systems",
+        "repo": "default",
+        "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
+        "type": "github"
+      },
+      "original": {
+        "owner": "nix-systems",
+        "repo": "default",
+        "type": "github"
+      }
+    }
+  },
+  "root": "root",
+  "version": 7
+}
diff --git a/pkgs/by-name/tr/tree-sitter-yts/flake.nix b/pkgs/by-name/tr/tree-sitter-yts/flake.nix
new file mode 100644
index 00000000..1b6f8ab0
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/flake.nix
@@ -0,0 +1,82 @@
+{
+  description = "tree-sitter-yts";
+
+  inputs = {
+    nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
+
+    flake-utils.url = "github:numtide/flake-utils";
+
+    npmlock2nix = {
+      url = "github:nix-community/npmlock2nix";
+      flake = false;
+    };
+
+    crane = {
+      url = "github:ipetkov/crane";
+      inputs.nixpkgs.follows = "nixpkgs";
+    };
+  };
+
+  outputs = {
+    self,
+    nixpkgs,
+    flake-utils,
+    npmlock2nix,
+    crane,
+  }: (flake-utils.lib.eachDefaultSystem (system: let
+    pkgs = nixpkgs.legacyPackages.${system};
+    inherit (pkgs) lib;
+
+    npmlock2nix' = pkgs.callPackage npmlock2nix {};
+    craneLib = crane.lib.${system};
+  in {
+    build = self.packages.${system}.tree-sitter-nix;
+
+    rust-bindings = craneLib.buildPackage {
+      src = self;
+    };
+
+    # Requires xcode
+    node-bindings = npmlock2nix'.v2.build {
+      src = self;
+      inherit (self.devShells.${system}.default) nativeBuildInputs;
+      inherit (pkgs) nodejs;
+
+      buildCommands = [
+        "${pkgs.nodePackages.node-gyp}/bin/node-gyp configure"
+        "npm run build"
+      ];
+
+      installPhase = ''
+        touch $out
+      '';
+    };
+
+    packages.tree-sitter-yts = (pkgs.callPackage ./grammar.nix {}) {
+      language = "yts";
+      version = "1.0";
+      src = self;
+    };
+
+    packages.default = self.packages.${system}.tree-sitter-yts;
+    devShells.default = pkgs.mkShell {
+      packages = [
+        pkgs.nodejs
+        pkgs.python3
+
+        pkgs.tree-sitter
+        pkgs.editorconfig-checker
+
+        pkgs.rustc
+        pkgs.cargo
+
+        # Formatters
+        pkgs.treefmt
+        pkgs.nixpkgs-fmt
+        pkgs.nodePackages.prettier
+        pkgs.rustfmt
+        pkgs.clang-tools
+      ];
+    };
+  }));
+}
diff --git a/pkgs/by-name/tr/tree-sitter-yts/grammar.js b/pkgs/by-name/tr/tree-sitter-yts/grammar.js
new file mode 100644
index 00000000..655f6dea
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/grammar.js
@@ -0,0 +1,26 @@
+module.exports = grammar({
+  name: "yts",
+
+  rules: {
+    source_file: ($) => repeat(choice($.line, $.comment)),
+    line: ($) =>
+      seq($.command, $.id, $.title, $.date, $.author, $.duration, $.url, "\n"),
+
+    command: ($) => choice("pick", "p", "watch", "w", "drop", "d", "url", "u"),
+    id: ($) => /[0-9]+/,
+    title: ($) => seq($._q, /[^"]+/, $._q),
+    date: ($) => seq($._q, /\d{4}-\d{2}-\d{2}/, $._q),
+    author: ($) => seq($._q, /[^"]+/, $._q),
+    duration: ($) =>
+      seq(
+        $._q,
+        seq("[", choice("No Duration", /\d+m \d+s/, /\d+h \d+m/), "]"),
+        $._q,
+      ),
+    url: ($) => seq($._q, /[^"]+/, $._q),
+    comment: ($) => /#.*/,
+    _q: ($) => $.quote,
+    quote: ($) => /"/,
+  },
+  extras: ($) => [/\s/, /\\\r?\n/],
+});
diff --git a/pkgs/by-name/tr/tree-sitter-yts/highlight.yts b/pkgs/by-name/tr/tree-sitter-yts/highlight.yts
new file mode 100644
index 00000000..319ee95c
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/highlight.yts
@@ -0,0 +1,4 @@
+pick 6221 "Name" "2024-01-17" "A" "0:00" "url"
+pick 6181 "Name2" "2024-01-16" "A2" "0:00" "url2"
+pick 6184 "Name3" "2024-01-16" "A3" "0:00" "url3"
+pick 6206 "Name4" "2024-01-16" "A4" "299:36" "url4"
diff --git a/pkgs/by-name/tr/tree-sitter-yts/package.json b/pkgs/by-name/tr/tree-sitter-yts/package.json
new file mode 100644
index 00000000..2511ccb7
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/package.json
@@ -0,0 +1,31 @@
+{
+  "name": "tree-sitter-yts",
+  "version": "0.0.1",
+  "description": "yts grammar for tree-sitter",
+  "main": "bindings/node",
+  "keywords": [
+    "parsing",
+    "incremental"
+  ],
+  "dependencies": {
+    "nan": "^2.12.1"
+  },
+  "devDependencies": {
+    "tree-sitter-cli": "^0.20.8"
+  },
+  "scripts": {
+    "test": "tree-sitter test"
+  },
+  "tree-sitter": [
+    {
+      "scope": "source.yts",
+      "file-types": [
+        "yts"
+      ],
+      "highlights": [
+        "queries/highlights.scm"
+      ],
+      "injection-regex": "^(yts)$"
+    }
+  ]
+}
diff --git a/pkgs/by-name/tr/tree-sitter-yts/package.nix b/pkgs/by-name/tr/tree-sitter-yts/package.nix
new file mode 100644
index 00000000..11ab5a8d
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/package.nix
@@ -0,0 +1,59 @@
+# taken from nixpgks: pkgs/development/tools/parsing/tree-sitter/grammar.nix
+{
+  stdenv,
+  nodejs,
+  tree-sitter,
+  lib,
+}:
+# # Build a parser grammar and put the resulting shared object in `$out/parser`
+# {
+#   # language name
+#   language ? "yts",
+#   version ? "1.0.0",
+#   src ? ./.,
+#   location ? null,
+#   generate ? false,
+#   ...
+# } @ args:
+stdenv.mkDerivation {
+  pname = "yts-grammar";
+  version = "1.0.0";
+
+  src = ./.;
+
+  nativeBuildInputs = [nodejs tree-sitter];
+
+  CFLAGS = ["-Isrc" "-O2"];
+  CXXFLAGS = ["-Isrc" "-O2"];
+
+  stripDebugList = ["parser"];
+
+  configurePhase = ''
+    tree-sitter generate
+  '';
+
+  # When both scanner.{c,cc} exist, we should not link both since they may be the same but in
+  # different languages. Just randomly prefer C++ if that happens.
+  buildPhase = ''
+    runHook preBuild
+    if [[ -e src/scanner.cc ]]; then
+      $CXX -fPIC -c src/scanner.cc -o scanner.o $CXXFLAGS
+    elif [[ -e src/scanner.c ]]; then
+      $CC -fPIC -c src/scanner.c -o scanner.o $CFLAGS
+    fi
+    $CC -fPIC -c src/parser.c -o parser.o $CFLAGS
+    rm -rf parser
+    $CXX -shared -o parser *.o
+    runHook postBuild
+  '';
+
+  installPhase = ''
+    runHook preInstall
+    mkdir $out
+    mv parser $out/
+    if [[ -d queries ]]; then
+      cp -r queries $out
+    fi
+    runHook postInstall
+  '';
+}
diff --git a/pkgs/by-name/tr/tree-sitter-yts/queries/highlights.scm b/pkgs/by-name/tr/tree-sitter-yts/queries/highlights.scm
new file mode 100644
index 00000000..674cbf18
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/queries/highlights.scm
@@ -0,0 +1,11 @@
+(command) @keyword
+(id) @constant
+(title) @text.title
+(date) @number
+(author) @operator
+(duration) @property
+((url) @conceal (#set! conceal ""))
+
+
+((quote) @conceal (#set! conceal ""))
+(comment) @comment @spell
diff --git a/pkgs/by-name/tr/tree-sitter-yts/src/grammar.json b/pkgs/by-name/tr/tree-sitter-yts/src/grammar.json
new file mode 100644
index 00000000..a35a5464
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/src/grammar.json
@@ -0,0 +1,238 @@
+{
+  "name": "yts",
+  "rules": {
+    "source_file": {
+      "type": "REPEAT",
+      "content": {
+        "type": "CHOICE",
+        "members": [
+          {
+            "type": "SYMBOL",
+            "name": "line"
+          },
+          {
+            "type": "SYMBOL",
+            "name": "comment"
+          }
+        ]
+      }
+    },
+    "line": {
+      "type": "SEQ",
+      "members": [
+        {
+          "type": "SYMBOL",
+          "name": "command"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "id"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "title"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "date"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "author"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "duration"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "url"
+        },
+        {
+          "type": "STRING",
+          "value": "\n"
+        }
+      ]
+    },
+    "command": {
+      "type": "CHOICE",
+      "members": [
+        {
+          "type": "STRING",
+          "value": "pick"
+        },
+        {
+          "type": "STRING",
+          "value": "p"
+        },
+        {
+          "type": "STRING",
+          "value": "watch"
+        },
+        {
+          "type": "STRING",
+          "value": "w"
+        },
+        {
+          "type": "STRING",
+          "value": "drop"
+        },
+        {
+          "type": "STRING",
+          "value": "d"
+        },
+        {
+          "type": "STRING",
+          "value": "url"
+        },
+        {
+          "type": "STRING",
+          "value": "u"
+        }
+      ]
+    },
+    "id": {
+      "type": "PATTERN",
+      "value": "[0-9]+"
+    },
+    "title": {
+      "type": "SEQ",
+      "members": [
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        },
+        {
+          "type": "PATTERN",
+          "value": "[^\"]+"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        }
+      ]
+    },
+    "date": {
+      "type": "SEQ",
+      "members": [
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        },
+        {
+          "type": "PATTERN",
+          "value": "\\d{4}-\\d{2}-\\d{2}"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        }
+      ]
+    },
+    "author": {
+      "type": "SEQ",
+      "members": [
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        },
+        {
+          "type": "PATTERN",
+          "value": "[^\"]+"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        }
+      ]
+    },
+    "duration": {
+      "type": "SEQ",
+      "members": [
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        },
+        {
+          "type": "SEQ",
+          "members": [
+            {
+              "type": "STRING",
+              "value": "["
+            },
+            {
+              "type": "CHOICE",
+              "members": [
+                {
+                  "type": "STRING",
+                  "value": "No Duration"
+                },
+                {
+                  "type": "PATTERN",
+                  "value": "\\d+m \\d+s"
+                },
+                {
+                  "type": "PATTERN",
+                  "value": "\\d+h \\d+m"
+                }
+              ]
+            },
+            {
+              "type": "STRING",
+              "value": "]"
+            }
+          ]
+        },
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        }
+      ]
+    },
+    "url": {
+      "type": "SEQ",
+      "members": [
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        },
+        {
+          "type": "PATTERN",
+          "value": "[^\"]+"
+        },
+        {
+          "type": "SYMBOL",
+          "name": "_q"
+        }
+      ]
+    },
+    "comment": {
+      "type": "PATTERN",
+      "value": "#.*"
+    },
+    "_q": {
+      "type": "SYMBOL",
+      "name": "quote"
+    },
+    "quote": {
+      "type": "PATTERN",
+      "value": "\""
+    }
+  },
+  "extras": [
+    {
+      "type": "PATTERN",
+      "value": "\\s"
+    },
+    {
+      "type": "PATTERN",
+      "value": "\\\\\\r?\\n"
+    }
+  ],
+  "conflicts": [],
+  "precedences": [],
+  "externals": [],
+  "inline": [],
+  "supertypes": []
+}
+
diff --git a/pkgs/by-name/tr/tree-sitter-yts/src/node-types.json b/pkgs/by-name/tr/tree-sitter-yts/src/node-types.json
new file mode 100644
index 00000000..1a63a552
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/src/node-types.json
@@ -0,0 +1,200 @@
+[
+  {
+    "type": "author",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": true,
+      "types": [
+        {
+          "type": "quote",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "command",
+    "named": true,
+    "fields": {}
+  },
+  {
+    "type": "date",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": true,
+      "types": [
+        {
+          "type": "quote",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "duration",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": true,
+      "types": [
+        {
+          "type": "quote",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "line",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": true,
+      "types": [
+        {
+          "type": "author",
+          "named": true
+        },
+        {
+          "type": "command",
+          "named": true
+        },
+        {
+          "type": "date",
+          "named": true
+        },
+        {
+          "type": "duration",
+          "named": true
+        },
+        {
+          "type": "id",
+          "named": true
+        },
+        {
+          "type": "title",
+          "named": true
+        },
+        {
+          "type": "url",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "source_file",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": false,
+      "types": [
+        {
+          "type": "comment",
+          "named": true
+        },
+        {
+          "type": "line",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "title",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": true,
+      "types": [
+        {
+          "type": "quote",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "url",
+    "named": true,
+    "fields": {},
+    "children": {
+      "multiple": true,
+      "required": true,
+      "types": [
+        {
+          "type": "quote",
+          "named": true
+        }
+      ]
+    }
+  },
+  {
+    "type": "\n",
+    "named": false
+  },
+  {
+    "type": "No Duration",
+    "named": false
+  },
+  {
+    "type": "[",
+    "named": false
+  },
+  {
+    "type": "]",
+    "named": false
+  },
+  {
+    "type": "comment",
+    "named": true
+  },
+  {
+    "type": "d",
+    "named": false
+  },
+  {
+    "type": "drop",
+    "named": false
+  },
+  {
+    "type": "id",
+    "named": true
+  },
+  {
+    "type": "p",
+    "named": false
+  },
+  {
+    "type": "pick",
+    "named": false
+  },
+  {
+    "type": "quote",
+    "named": true
+  },
+  {
+    "type": "u",
+    "named": false
+  },
+  {
+    "type": "url",
+    "named": false
+  },
+  {
+    "type": "w",
+    "named": false
+  },
+  {
+    "type": "watch",
+    "named": false
+  }
+]
\ No newline at end of file
diff --git a/pkgs/by-name/tr/tree-sitter-yts/src/parser.c b/pkgs/by-name/tr/tree-sitter-yts/src/parser.c
new file mode 100644
index 00000000..ded5c342
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/src/parser.c
@@ -0,0 +1,1108 @@
+#include <tree_sitter/parser.h>
+
+#if defined(__GNUC__) || defined(__clang__)
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wmissing-field-initializers"
+#endif
+
+#define LANGUAGE_VERSION 14
+#define STATE_COUNT 31
+#define LARGE_STATE_COUNT 2
+#define SYMBOL_COUNT 30
+#define ALIAS_COUNT 0
+#define TOKEN_COUNT 20
+#define EXTERNAL_TOKEN_COUNT 0
+#define FIELD_COUNT 0
+#define MAX_ALIAS_SEQUENCE_LENGTH 8
+#define PRODUCTION_ID_COUNT 1
+
+enum
+{
+  anon_sym_LF = 1,
+  anon_sym_pick = 2,
+  anon_sym_p = 3,
+  anon_sym_watch = 4,
+  anon_sym_w = 5,
+  anon_sym_drop = 6,
+  anon_sym_d = 7,
+  anon_sym_url = 8,
+  anon_sym_u = 9,
+  sym_id = 10,
+  aux_sym_title_token1 = 11,
+  aux_sym_date_token1 = 12,
+  anon_sym_LBRACK = 13,
+  anon_sym_NoDuration = 14,
+  aux_sym_duration_token1 = 15,
+  aux_sym_duration_token2 = 16,
+  anon_sym_RBRACK = 17,
+  sym_comment = 18,
+  sym_quote = 19,
+  sym_source_file = 20,
+  sym_line = 21,
+  sym_command = 22,
+  sym_title = 23,
+  sym_date = 24,
+  sym_author = 25,
+  sym_duration = 26,
+  sym_url = 27,
+  sym__q = 28,
+  aux_sym_source_file_repeat1 = 29,
+};
+
+static const char *const ts_symbol_names[] = {
+  [ts_builtin_sym_end] = "end",
+  [anon_sym_LF] = "\n",
+  [anon_sym_pick] = "pick",
+  [anon_sym_p] = "p",
+  [anon_sym_watch] = "watch",
+  [anon_sym_w] = "w",
+  [anon_sym_drop] = "drop",
+  [anon_sym_d] = "d",
+  [anon_sym_url] = "url",
+  [anon_sym_u] = "u",
+  [sym_id] = "id",
+  [aux_sym_title_token1] = "title_token1",
+  [aux_sym_date_token1] = "date_token1",
+  [anon_sym_LBRACK] = "[",
+  [anon_sym_NoDuration] = "No Duration",
+  [aux_sym_duration_token1] = "duration_token1",
+  [aux_sym_duration_token2] = "duration_token2",
+  [anon_sym_RBRACK] = "]",
+  [sym_comment] = "comment",
+  [sym_quote] = "quote",
+  [sym_source_file] = "source_file",
+  [sym_line] = "line",
+  [sym_command] = "command",
+  [sym_title] = "title",
+  [sym_date] = "date",
+  [sym_author] = "author",
+  [sym_duration] = "duration",
+  [sym_url] = "url",
+  [sym__q] = "_q",
+  [aux_sym_source_file_repeat1] = "source_file_repeat1",
+};
+
+static const TSSymbol ts_symbol_map[] = {
+  [ts_builtin_sym_end] = ts_builtin_sym_end,
+  [anon_sym_LF] = anon_sym_LF,
+  [anon_sym_pick] = anon_sym_pick,
+  [anon_sym_p] = anon_sym_p,
+  [anon_sym_watch] = anon_sym_watch,
+  [anon_sym_w] = anon_sym_w,
+  [anon_sym_drop] = anon_sym_drop,
+  [anon_sym_d] = anon_sym_d,
+  [anon_sym_url] = anon_sym_url,
+  [anon_sym_u] = anon_sym_u,
+  [sym_id] = sym_id,
+  [aux_sym_title_token1] = aux_sym_title_token1,
+  [aux_sym_date_token1] = aux_sym_date_token1,
+  [anon_sym_LBRACK] = anon_sym_LBRACK,
+  [anon_sym_NoDuration] = anon_sym_NoDuration,
+  [aux_sym_duration_token1] = aux_sym_duration_token1,
+  [aux_sym_duration_token2] = aux_sym_duration_token2,
+  [anon_sym_RBRACK] = anon_sym_RBRACK,
+  [sym_comment] = sym_comment,
+  [sym_quote] = sym_quote,
+  [sym_source_file] = sym_source_file,
+  [sym_line] = sym_line,
+  [sym_command] = sym_command,
+  [sym_title] = sym_title,
+  [sym_date] = sym_date,
+  [sym_author] = sym_author,
+  [sym_duration] = sym_duration,
+  [sym_url] = sym_url,
+  [sym__q] = sym__q,
+  [aux_sym_source_file_repeat1] = aux_sym_source_file_repeat1,
+};
+
+static const TSSymbolMetadata ts_symbol_metadata[] = {
+  [ts_builtin_sym_end] = {
+    .visible = false,
+    .named = true,
+  },
+  [anon_sym_LF] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_pick] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_p] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_watch] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_w] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_drop] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_d] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_url] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_u] = {
+    .visible = true,
+    .named = false,
+  },
+  [sym_id] = {
+    .visible = true,
+    .named = true,
+  },
+  [aux_sym_title_token1] = {
+    .visible = false,
+    .named = false,
+  },
+  [aux_sym_date_token1] = {
+    .visible = false,
+    .named = false,
+  },
+  [anon_sym_LBRACK] = {
+    .visible = true,
+    .named = false,
+  },
+  [anon_sym_NoDuration] = {
+    .visible = true,
+    .named = false,
+  },
+  [aux_sym_duration_token1] = {
+    .visible = false,
+    .named = false,
+  },
+  [aux_sym_duration_token2] = {
+    .visible = false,
+    .named = false,
+  },
+  [anon_sym_RBRACK] = {
+    .visible = true,
+    .named = false,
+  },
+  [sym_comment] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_quote] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_source_file] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_line] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_command] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_title] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_date] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_author] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_duration] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym_url] = {
+    .visible = true,
+    .named = true,
+  },
+  [sym__q] = {
+    .visible = false,
+    .named = true,
+  },
+  [aux_sym_source_file_repeat1] = {
+    .visible = false,
+    .named = false,
+  },
+};
+
+static const TSSymbol ts_alias_sequences[PRODUCTION_ID_COUNT]
+                                        [MAX_ALIAS_SEQUENCE_LENGTH]
+    = {
+        [0] = { 0 },
+      };
+
+static const uint16_t ts_non_terminal_alias_map[] = {
+  0,
+};
+
+static const TSStateId ts_primary_state_ids[STATE_COUNT] = {
+  [0] = 0,   [1] = 1,   [2] = 2,   [3] = 3,   [4] = 4,   [5] = 5,   [6] = 6,
+  [7] = 7,   [8] = 8,   [9] = 9,   [10] = 10, [11] = 11, [12] = 12, [13] = 13,
+  [14] = 14, [15] = 15, [16] = 16, [17] = 17, [18] = 18, [19] = 19, [20] = 20,
+  [21] = 21, [22] = 22, [23] = 23, [24] = 24, [25] = 25, [26] = 26, [27] = 27,
+  [28] = 28, [29] = 29, [30] = 30,
+};
+
+static bool
+ts_lex (TSLexer *lexer, TSStateId state)
+{
+  START_LEXER ();
+  eof = lexer->eof (lexer);
+  switch (state)
+    {
+    case 0:
+      if (eof)
+        ADVANCE (47);
+      if (lookahead == '"')
+        ADVANCE (74);
+      if (lookahead == '#')
+        ADVANCE (73);
+      if (lookahead == 'N')
+        ADVANCE (30);
+      if (lookahead == '[')
+        ADVANCE (68);
+      if (lookahead == '\\')
+        SKIP (46)
+      if (lookahead == ']')
+        ADVANCE (72);
+      if (lookahead == 'd')
+        ADVANCE (54);
+      if (lookahead == 'p')
+        ADVANCE (50);
+      if (lookahead == 'u')
+        ADVANCE (56);
+      if (lookahead == 'w')
+        ADVANCE (52);
+      if (lookahead == '\t' || lookahead == '\n' || lookahead == '\r'
+          || lookahead == ' ')
+        SKIP (0)
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (60);
+      END_STATE ();
+    case 1:
+      if (lookahead == '\n')
+        SKIP (14)
+      END_STATE ();
+    case 2:
+      if (lookahead == '\n')
+        SKIP (14)
+      if (lookahead == '\r')
+        SKIP (1)
+      END_STATE ();
+    case 3:
+      if (lookahead == '\n')
+        SKIP (16)
+      END_STATE ();
+    case 4:
+      if (lookahead == '\n')
+        SKIP (16)
+      if (lookahead == '\r')
+        SKIP (3)
+      END_STATE ();
+    case 5:
+      if (lookahead == '\n')
+        SKIP (7)
+      END_STATE ();
+    case 6:
+      if (lookahead == '\n')
+        SKIP (7)
+      if (lookahead == '\r')
+        SKIP (5)
+      END_STATE ();
+    case 7:
+      if (lookahead == '\n')
+        ADVANCE (48);
+      if (lookahead == '\\')
+        SKIP (6)
+      if (lookahead == '\t' || lookahead == '\r' || lookahead == ' ')
+        SKIP (7)
+      END_STATE ();
+    case 8:
+      if (lookahead == ' ')
+        ADVANCE (13);
+      END_STATE ();
+    case 9:
+      if (lookahead == ' ')
+        ADVANCE (39);
+      END_STATE ();
+    case 10:
+      if (lookahead == ' ')
+        ADVANCE (40);
+      END_STATE ();
+    case 11:
+      if (lookahead == '-')
+        ADVANCE (43);
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (24);
+      END_STATE ();
+    case 12:
+      if (lookahead == '-')
+        ADVANCE (44);
+      END_STATE ();
+    case 13:
+      if (lookahead == 'D')
+        ADVANCE (38);
+      END_STATE ();
+    case 14:
+      if (lookahead == 'N')
+        ADVANCE (30);
+      if (lookahead == '\\')
+        SKIP (2)
+      if (lookahead == '\t' || lookahead == '\n' || lookahead == '\r'
+          || lookahead == ' ')
+        SKIP (14)
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (23);
+      END_STATE ();
+    case 15:
+      if (lookahead == '\\')
+        ADVANCE (63);
+      if (lookahead == '\t' || lookahead == '\n' || lookahead == '\r'
+          || lookahead == ' ')
+        ADVANCE (65);
+      if (lookahead != 0 && lookahead != '"')
+        ADVANCE (66);
+      END_STATE ();
+    case 16:
+      if (lookahead == '\\')
+        SKIP (4)
+      if (lookahead == '\t' || lookahead == '\n' || lookahead == '\r'
+          || lookahead == ' ')
+        SKIP (16)
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (62);
+      END_STATE ();
+    case 17:
+      if (lookahead == 'a')
+        ADVANCE (36);
+      END_STATE ();
+    case 18:
+      if (lookahead == 'c')
+        ADVANCE (26);
+      END_STATE ();
+    case 19:
+      if (lookahead == 'c')
+        ADVANCE (20);
+      END_STATE ();
+    case 20:
+      if (lookahead == 'h')
+        ADVANCE (51);
+      END_STATE ();
+    case 21:
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (11);
+      END_STATE ();
+    case 22:
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (21);
+      END_STATE ();
+    case 23:
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (22);
+      END_STATE ();
+    case 24:
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (24);
+      END_STATE ();
+    case 25:
+      if (lookahead == 'i')
+        ADVANCE (32);
+      END_STATE ();
+    case 26:
+      if (lookahead == 'k')
+        ADVANCE (49);
+      END_STATE ();
+    case 27:
+      if (lookahead == 'l')
+        ADVANCE (55);
+      END_STATE ();
+    case 28:
+      if (lookahead == 'm')
+        ADVANCE (71);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (28);
+      END_STATE ();
+    case 29:
+      if (lookahead == 'n')
+        ADVANCE (69);
+      END_STATE ();
+    case 30:
+      if (lookahead == 'o')
+        ADVANCE (8);
+      END_STATE ();
+    case 31:
+      if (lookahead == 'o')
+        ADVANCE (33);
+      END_STATE ();
+    case 32:
+      if (lookahead == 'o')
+        ADVANCE (29);
+      END_STATE ();
+    case 33:
+      if (lookahead == 'p')
+        ADVANCE (53);
+      END_STATE ();
+    case 34:
+      if (lookahead == 'r')
+        ADVANCE (17);
+      END_STATE ();
+    case 35:
+      if (lookahead == 's')
+        ADVANCE (70);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (35);
+      END_STATE ();
+    case 36:
+      if (lookahead == 't')
+        ADVANCE (25);
+      END_STATE ();
+    case 37:
+      if (lookahead == 't')
+        ADVANCE (19);
+      END_STATE ();
+    case 38:
+      if (lookahead == 'u')
+        ADVANCE (34);
+      END_STATE ();
+    case 39:
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (28);
+      END_STATE ();
+    case 40:
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (35);
+      END_STATE ();
+    case 41:
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (12);
+      END_STATE ();
+    case 42:
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (67);
+      END_STATE ();
+    case 43:
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (41);
+      END_STATE ();
+    case 44:
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (42);
+      END_STATE ();
+    case 45:
+      if (eof)
+        ADVANCE (47);
+      if (lookahead == '\n')
+        SKIP (0)
+      END_STATE ();
+    case 46:
+      if (eof)
+        ADVANCE (47);
+      if (lookahead == '\n')
+        SKIP (0)
+      if (lookahead == '\r')
+        SKIP (45)
+      END_STATE ();
+    case 47:
+      ACCEPT_TOKEN (ts_builtin_sym_end);
+      END_STATE ();
+    case 48:
+      ACCEPT_TOKEN (anon_sym_LF);
+      if (lookahead == '\n')
+        ADVANCE (48);
+      END_STATE ();
+    case 49:
+      ACCEPT_TOKEN (anon_sym_pick);
+      END_STATE ();
+    case 50:
+      ACCEPT_TOKEN (anon_sym_p);
+      if (lookahead == 'i')
+        ADVANCE (18);
+      END_STATE ();
+    case 51:
+      ACCEPT_TOKEN (anon_sym_watch);
+      END_STATE ();
+    case 52:
+      ACCEPT_TOKEN (anon_sym_w);
+      if (lookahead == 'a')
+        ADVANCE (37);
+      END_STATE ();
+    case 53:
+      ACCEPT_TOKEN (anon_sym_drop);
+      END_STATE ();
+    case 54:
+      ACCEPT_TOKEN (anon_sym_d);
+      if (lookahead == 'r')
+        ADVANCE (31);
+      END_STATE ();
+    case 55:
+      ACCEPT_TOKEN (anon_sym_url);
+      END_STATE ();
+    case 56:
+      ACCEPT_TOKEN (anon_sym_u);
+      if (lookahead == 'r')
+        ADVANCE (27);
+      END_STATE ();
+    case 57:
+      ACCEPT_TOKEN (sym_id);
+      if (lookahead == '-')
+        ADVANCE (43);
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (61);
+      END_STATE ();
+    case 58:
+      ACCEPT_TOKEN (sym_id);
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (57);
+      END_STATE ();
+    case 59:
+      ACCEPT_TOKEN (sym_id);
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (58);
+      END_STATE ();
+    case 60:
+      ACCEPT_TOKEN (sym_id);
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (59);
+      END_STATE ();
+    case 61:
+      ACCEPT_TOKEN (sym_id);
+      if (lookahead == 'h')
+        ADVANCE (9);
+      if (lookahead == 'm')
+        ADVANCE (10);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (61);
+      END_STATE ();
+    case 62:
+      ACCEPT_TOKEN (sym_id);
+      if (('0' <= lookahead && lookahead <= '9'))
+        ADVANCE (62);
+      END_STATE ();
+    case 63:
+      ACCEPT_TOKEN (aux_sym_title_token1);
+      if (lookahead == '\n')
+        ADVANCE (65);
+      if (lookahead == '\r')
+        ADVANCE (64);
+      if (lookahead != 0 && lookahead != '"')
+        ADVANCE (66);
+      END_STATE ();
+    case 64:
+      ACCEPT_TOKEN (aux_sym_title_token1);
+      if (lookahead == '\n')
+        ADVANCE (65);
+      if (lookahead != 0 && lookahead != '"')
+        ADVANCE (66);
+      END_STATE ();
+    case 65:
+      ACCEPT_TOKEN (aux_sym_title_token1);
+      if (lookahead == '\\')
+        ADVANCE (63);
+      if (lookahead == '\t' || lookahead == '\n' || lookahead == '\r'
+          || lookahead == ' ')
+        ADVANCE (65);
+      if (lookahead != 0 && lookahead != '"')
+        ADVANCE (66);
+      END_STATE ();
+    case 66:
+      ACCEPT_TOKEN (aux_sym_title_token1);
+      if (lookahead != 0 && lookahead != '"')
+        ADVANCE (66);
+      END_STATE ();
+    case 67:
+      ACCEPT_TOKEN (aux_sym_date_token1);
+      END_STATE ();
+    case 68:
+      ACCEPT_TOKEN (anon_sym_LBRACK);
+      END_STATE ();
+    case 69:
+      ACCEPT_TOKEN (anon_sym_NoDuration);
+      END_STATE ();
+    case 70:
+      ACCEPT_TOKEN (aux_sym_duration_token1);
+      END_STATE ();
+    case 71:
+      ACCEPT_TOKEN (aux_sym_duration_token2);
+      END_STATE ();
+    case 72:
+      ACCEPT_TOKEN (anon_sym_RBRACK);
+      END_STATE ();
+    case 73:
+      ACCEPT_TOKEN (sym_comment);
+      if (lookahead != 0 && lookahead != '\n')
+        ADVANCE (73);
+      END_STATE ();
+    case 74:
+      ACCEPT_TOKEN (sym_quote);
+      END_STATE ();
+    default:
+      return false;
+    }
+}
+
+static const TSLexMode ts_lex_modes[STATE_COUNT] = {
+  [0] = { .lex_state = 0 },   [1] = { .lex_state = 0 },
+  [2] = { .lex_state = 0 },   [3] = { .lex_state = 0 },
+  [4] = { .lex_state = 0 },   [5] = { .lex_state = 0 },
+  [6] = { .lex_state = 0 },   [7] = { .lex_state = 0 },
+  [8] = { .lex_state = 14 },  [9] = { .lex_state = 0 },
+  [10] = { .lex_state = 0 },  [11] = { .lex_state = 0 },
+  [12] = { .lex_state = 0 },  [13] = { .lex_state = 0 },
+  [14] = { .lex_state = 0 },  [15] = { .lex_state = 0 },
+  [16] = { .lex_state = 15 }, [17] = { .lex_state = 0 },
+  [18] = { .lex_state = 0 },  [19] = { .lex_state = 16 },
+  [20] = { .lex_state = 0 },  [21] = { .lex_state = 7 },
+  [22] = { .lex_state = 15 }, [23] = { .lex_state = 14 },
+  [24] = { .lex_state = 0 },  [25] = { .lex_state = 15 },
+  [26] = { .lex_state = 16 }, [27] = { .lex_state = 0 },
+  [28] = { .lex_state = 7 },  [29] = { .lex_state = 0 },
+  [30] = { .lex_state = 0 },
+};
+
+static const uint16_t ts_parse_table[LARGE_STATE_COUNT][SYMBOL_COUNT] = {
+  [0] = {
+    [ts_builtin_sym_end] = ACTIONS(1),
+    [anon_sym_pick] = ACTIONS(1),
+    [anon_sym_p] = ACTIONS(1),
+    [anon_sym_watch] = ACTIONS(1),
+    [anon_sym_w] = ACTIONS(1),
+    [anon_sym_drop] = ACTIONS(1),
+    [anon_sym_d] = ACTIONS(1),
+    [anon_sym_url] = ACTIONS(1),
+    [anon_sym_u] = ACTIONS(1),
+    [sym_id] = ACTIONS(1),
+    [aux_sym_date_token1] = ACTIONS(1),
+    [anon_sym_LBRACK] = ACTIONS(1),
+    [anon_sym_NoDuration] = ACTIONS(1),
+    [aux_sym_duration_token1] = ACTIONS(1),
+    [aux_sym_duration_token2] = ACTIONS(1),
+    [anon_sym_RBRACK] = ACTIONS(1),
+    [sym_comment] = ACTIONS(1),
+    [sym_quote] = ACTIONS(1),
+  },
+  [1] = {
+    [sym_source_file] = STATE(29),
+    [sym_line] = STATE(2),
+    [sym_command] = STATE(26),
+    [aux_sym_source_file_repeat1] = STATE(2),
+    [ts_builtin_sym_end] = ACTIONS(3),
+    [anon_sym_pick] = ACTIONS(5),
+    [anon_sym_p] = ACTIONS(7),
+    [anon_sym_watch] = ACTIONS(5),
+    [anon_sym_w] = ACTIONS(7),
+    [anon_sym_drop] = ACTIONS(5),
+    [anon_sym_d] = ACTIONS(7),
+    [anon_sym_url] = ACTIONS(5),
+    [anon_sym_u] = ACTIONS(7),
+    [sym_comment] = ACTIONS(9),
+  },
+};
+
+static const uint16_t ts_small_parse_table[] = {
+  [0] = 6,
+  ACTIONS (11),
+  1,
+  ts_builtin_sym_end,
+  ACTIONS (13),
+  1,
+  sym_comment,
+  STATE (26),
+  1,
+  sym_command,
+  STATE (3),
+  2,
+  sym_line,
+  aux_sym_source_file_repeat1,
+  ACTIONS (5),
+  4,
+  anon_sym_pick,
+  anon_sym_watch,
+  anon_sym_drop,
+  anon_sym_url,
+  ACTIONS (7),
+  4,
+  anon_sym_p,
+  anon_sym_w,
+  anon_sym_d,
+  anon_sym_u,
+  [26] = 6,
+  ACTIONS (15),
+  1,
+  ts_builtin_sym_end,
+  ACTIONS (23),
+  1,
+  sym_comment,
+  STATE (26),
+  1,
+  sym_command,
+  STATE (3),
+  2,
+  sym_line,
+  aux_sym_source_file_repeat1,
+  ACTIONS (17),
+  4,
+  anon_sym_pick,
+  anon_sym_watch,
+  anon_sym_drop,
+  anon_sym_url,
+  ACTIONS (20),
+  4,
+  anon_sym_p,
+  anon_sym_w,
+  anon_sym_d,
+  anon_sym_u,
+  [52] = 2,
+  ACTIONS (28),
+  4,
+  anon_sym_p,
+  anon_sym_w,
+  anon_sym_d,
+  anon_sym_u,
+  ACTIONS (26),
+  6,
+  ts_builtin_sym_end,
+  anon_sym_pick,
+  anon_sym_watch,
+  anon_sym_drop,
+  anon_sym_url,
+  sym_comment,
+  [67] = 3,
+  ACTIONS (30),
+  1,
+  sym_quote,
+  STATE (21),
+  1,
+  sym_url,
+  STATE (22),
+  1,
+  sym__q,
+  [77] = 3,
+  ACTIONS (32),
+  1,
+  sym_quote,
+  STATE (7),
+  1,
+  sym_title,
+  STATE (25),
+  1,
+  sym__q,
+  [87] = 3,
+  ACTIONS (34),
+  1,
+  sym_quote,
+  STATE (9),
+  1,
+  sym_date,
+  STATE (23),
+  1,
+  sym__q,
+  [97] = 1,
+  ACTIONS (36),
+  3,
+  anon_sym_NoDuration,
+  aux_sym_duration_token1,
+  aux_sym_duration_token2,
+  [103] = 3,
+  ACTIONS (38),
+  1,
+  sym_quote,
+  STATE (10),
+  1,
+  sym_author,
+  STATE (16),
+  1,
+  sym__q,
+  [113] = 3,
+  ACTIONS (40),
+  1,
+  sym_quote,
+  STATE (5),
+  1,
+  sym_duration,
+  STATE (18),
+  1,
+  sym__q,
+  [123] = 2,
+  ACTIONS (42),
+  1,
+  sym_quote,
+  STATE (30),
+  1,
+  sym__q,
+  [130] = 2,
+  ACTIONS (44),
+  1,
+  sym_quote,
+  STATE (28),
+  1,
+  sym__q,
+  [137] = 2,
+  ACTIONS (46),
+  1,
+  sym_quote,
+  STATE (24),
+  1,
+  sym__q,
+  [144] = 2,
+  ACTIONS (48),
+  1,
+  sym_quote,
+  STATE (17),
+  1,
+  sym__q,
+  [151] = 2,
+  ACTIONS (50),
+  1,
+  sym_quote,
+  STATE (20),
+  1,
+  sym__q,
+  [158] = 1,
+  ACTIONS (52),
+  1,
+  aux_sym_title_token1,
+  [162] = 1,
+  ACTIONS (54),
+  1,
+  sym_quote,
+  [166] = 1,
+  ACTIONS (56),
+  1,
+  anon_sym_LBRACK,
+  [170] = 1,
+  ACTIONS (58),
+  1,
+  sym_id,
+  [174] = 1,
+  ACTIONS (60),
+  1,
+  sym_quote,
+  [178] = 1,
+  ACTIONS (62),
+  1,
+  anon_sym_LF,
+  [182] = 1,
+  ACTIONS (64),
+  1,
+  aux_sym_title_token1,
+  [186] = 1,
+  ACTIONS (66),
+  1,
+  aux_sym_date_token1,
+  [190] = 1,
+  ACTIONS (68),
+  1,
+  sym_quote,
+  [194] = 1,
+  ACTIONS (70),
+  1,
+  aux_sym_title_token1,
+  [198] = 1,
+  ACTIONS (72),
+  1,
+  sym_id,
+  [202] = 1,
+  ACTIONS (74),
+  1,
+  anon_sym_RBRACK,
+  [206] = 1,
+  ACTIONS (76),
+  1,
+  anon_sym_LF,
+  [210] = 1,
+  ACTIONS (78),
+  1,
+  ts_builtin_sym_end,
+  [214] = 1,
+  ACTIONS (80),
+  1,
+  sym_quote,
+};
+
+static const uint32_t ts_small_parse_table_map[] = {
+  [SMALL_STATE (2)] = 0,    [SMALL_STATE (3)] = 26,   [SMALL_STATE (4)] = 52,
+  [SMALL_STATE (5)] = 67,   [SMALL_STATE (6)] = 77,   [SMALL_STATE (7)] = 87,
+  [SMALL_STATE (8)] = 97,   [SMALL_STATE (9)] = 103,  [SMALL_STATE (10)] = 113,
+  [SMALL_STATE (11)] = 123, [SMALL_STATE (12)] = 130, [SMALL_STATE (13)] = 137,
+  [SMALL_STATE (14)] = 144, [SMALL_STATE (15)] = 151, [SMALL_STATE (16)] = 158,
+  [SMALL_STATE (17)] = 162, [SMALL_STATE (18)] = 166, [SMALL_STATE (19)] = 170,
+  [SMALL_STATE (20)] = 174, [SMALL_STATE (21)] = 178, [SMALL_STATE (22)] = 182,
+  [SMALL_STATE (23)] = 186, [SMALL_STATE (24)] = 190, [SMALL_STATE (25)] = 194,
+  [SMALL_STATE (26)] = 198, [SMALL_STATE (27)] = 202, [SMALL_STATE (28)] = 206,
+  [SMALL_STATE (29)] = 210, [SMALL_STATE (30)] = 214,
+};
+
+static const TSParseActionEntry ts_parse_actions[] = {
+  [0] = { .entry = { .count = 0, .reusable = false } },
+  [1] = { .entry = { .count = 1, .reusable = false } },
+  RECOVER (),
+  [3] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_source_file, 0),
+  [5] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (19),
+  [7] = { .entry = { .count = 1, .reusable = false } },
+  SHIFT (19),
+  [9] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (2),
+  [11] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_source_file, 1),
+  [13] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (3),
+  [15] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (aux_sym_source_file_repeat1, 2),
+  [17] = { .entry = { .count = 2, .reusable = true } },
+  REDUCE (aux_sym_source_file_repeat1, 2),
+  SHIFT_REPEAT (19),
+  [20] = { .entry = { .count = 2, .reusable = false } },
+  REDUCE (aux_sym_source_file_repeat1, 2),
+  SHIFT_REPEAT (19),
+  [23] = { .entry = { .count = 2, .reusable = true } },
+  REDUCE (aux_sym_source_file_repeat1, 2),
+  SHIFT_REPEAT (3),
+  [26] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_line, 8),
+  [28] = { .entry = { .count = 1, .reusable = false } },
+  REDUCE (sym_line, 8),
+  [30] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (22),
+  [32] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (25),
+  [34] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (23),
+  [36] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (27),
+  [38] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (16),
+  [40] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (18),
+  [42] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (30),
+  [44] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (28),
+  [46] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (24),
+  [48] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (17),
+  [50] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (20),
+  [52] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (13),
+  [54] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_title, 3),
+  [56] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (8),
+  [58] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_command, 1),
+  [60] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_date, 3),
+  [62] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (4),
+  [64] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (12),
+  [66] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (15),
+  [68] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_author, 3),
+  [70] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (14),
+  [72] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (6),
+  [74] = { .entry = { .count = 1, .reusable = true } },
+  SHIFT (11),
+  [76] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_url, 3),
+  [78] = { .entry = { .count = 1, .reusable = true } },
+  ACCEPT_INPUT (),
+  [80] = { .entry = { .count = 1, .reusable = true } },
+  REDUCE (sym_duration, 5),
+};
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+#ifdef _WIN32
+#define extern __declspec (dllexport)
+#endif
+
+  extern const TSLanguage *
+  tree_sitter_yts (void)
+  {
+    static const TSLanguage language = {
+      .version = LANGUAGE_VERSION,
+      .symbol_count = SYMBOL_COUNT,
+      .alias_count = ALIAS_COUNT,
+      .token_count = TOKEN_COUNT,
+      .external_token_count = EXTERNAL_TOKEN_COUNT,
+      .state_count = STATE_COUNT,
+      .large_state_count = LARGE_STATE_COUNT,
+      .production_id_count = PRODUCTION_ID_COUNT,
+      .field_count = FIELD_COUNT,
+      .max_alias_sequence_length = MAX_ALIAS_SEQUENCE_LENGTH,
+      .parse_table = &ts_parse_table[0][0],
+      .small_parse_table = ts_small_parse_table,
+      .small_parse_table_map = ts_small_parse_table_map,
+      .parse_actions = ts_parse_actions,
+      .symbol_names = ts_symbol_names,
+      .symbol_metadata = ts_symbol_metadata,
+      .public_symbol_map = ts_symbol_map,
+      .alias_map = ts_non_terminal_alias_map,
+      .alias_sequences = &ts_alias_sequences[0][0],
+      .lex_modes = ts_lex_modes,
+      .lex_fn = ts_lex,
+      .primary_state_ids = ts_primary_state_ids,
+    };
+    return &language;
+  }
+#ifdef __cplusplus
+}
+#endif
diff --git a/pkgs/by-name/tr/tree-sitter-yts/src/tree_sitter/parser.h b/pkgs/by-name/tr/tree-sitter-yts/src/tree_sitter/parser.h
new file mode 100644
index 00000000..972913cf
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/src/tree_sitter/parser.h
@@ -0,0 +1,241 @@
+#ifndef TREE_SITTER_PARSER_H_
+#define TREE_SITTER_PARSER_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+#include <stdbool.h>
+#include <stdint.h>
+#include <stdlib.h>
+
+#define ts_builtin_sym_error ((TSSymbol)-1)
+#define ts_builtin_sym_end 0
+#define TREE_SITTER_SERIALIZATION_BUFFER_SIZE 1024
+
+  typedef uint16_t TSStateId;
+
+#ifndef TREE_SITTER_API_H_
+  typedef uint16_t TSSymbol;
+  typedef uint16_t TSFieldId;
+  typedef struct TSLanguage TSLanguage;
+#endif
+
+  typedef struct
+  {
+    TSFieldId field_id;
+    uint8_t child_index;
+    bool inherited;
+  } TSFieldMapEntry;
+
+  typedef struct
+  {
+    uint16_t index;
+    uint16_t length;
+  } TSFieldMapSlice;
+
+  typedef struct
+  {
+    bool visible;
+    bool named;
+    bool supertype;
+  } TSSymbolMetadata;
+
+  typedef struct TSLexer TSLexer;
+
+  struct TSLexer
+  {
+    int32_t lookahead;
+    TSSymbol result_symbol;
+    void (*advance) (TSLexer *, bool);
+    void (*mark_end) (TSLexer *);
+    uint32_t (*get_column) (TSLexer *);
+    bool (*is_at_included_range_start) (const TSLexer *);
+    bool (*eof) (const TSLexer *);
+  };
+
+  typedef enum
+  {
+    TSParseActionTypeShift,
+    TSParseActionTypeReduce,
+    TSParseActionTypeAccept,
+    TSParseActionTypeRecover,
+  } TSParseActionType;
+
+  typedef union
+  {
+    struct
+    {
+      uint8_t type;
+      TSStateId state;
+      bool extra;
+      bool repetition;
+    } shift;
+    struct
+    {
+      uint8_t type;
+      uint8_t child_count;
+      TSSymbol symbol;
+      int16_t dynamic_precedence;
+      uint16_t production_id;
+    } reduce;
+    uint8_t type;
+  } TSParseAction;
+
+  typedef struct
+  {
+    uint16_t lex_state;
+    uint16_t external_lex_state;
+  } TSLexMode;
+
+  typedef union
+  {
+    TSParseAction action;
+    struct
+    {
+      uint8_t count;
+      bool reusable;
+    } entry;
+  } TSParseActionEntry;
+
+  struct TSLanguage
+  {
+    uint32_t version;
+    uint32_t symbol_count;
+    uint32_t alias_count;
+    uint32_t token_count;
+    uint32_t external_token_count;
+    uint32_t state_count;
+    uint32_t large_state_count;
+    uint32_t production_id_count;
+    uint32_t field_count;
+    uint16_t max_alias_sequence_length;
+    const uint16_t *parse_table;
+    const uint16_t *small_parse_table;
+    const uint32_t *small_parse_table_map;
+    const TSParseActionEntry *parse_actions;
+    const char *const *symbol_names;
+    const char *const *field_names;
+    const TSFieldMapSlice *field_map_slices;
+    const TSFieldMapEntry *field_map_entries;
+    const TSSymbolMetadata *symbol_metadata;
+    const TSSymbol *public_symbol_map;
+    const uint16_t *alias_map;
+    const TSSymbol *alias_sequences;
+    const TSLexMode *lex_modes;
+    bool (*lex_fn) (TSLexer *, TSStateId);
+    bool (*keyword_lex_fn) (TSLexer *, TSStateId);
+    TSSymbol keyword_capture_token;
+    struct
+    {
+      const bool *states;
+      const TSSymbol *symbol_map;
+      void *(*create) (void);
+      void (*destroy) (void *);
+      bool (*scan) (void *, TSLexer *, const bool *symbol_whitelist);
+      unsigned (*serialize) (void *, char *);
+      void (*deserialize) (void *, const char *, unsigned);
+    } external_scanner;
+    const TSStateId *primary_state_ids;
+  };
+
+  /*
+   *  Lexer Macros
+   */
+
+#define START_LEXER()                                                         \
+  bool result = false;                                                        \
+  bool skip = false;                                                          \
+  bool eof = false;                                                           \
+  int32_t lookahead;                                                          \
+  goto start;                                                                 \
+  next_state:                                                                 \
+  lexer->advance (lexer, skip);                                               \
+  start:                                                                      \
+  skip = false;                                                               \
+  lookahead = lexer->lookahead;
+
+#define ADVANCE(state_value)                                                  \
+  {                                                                           \
+    state = state_value;                                                      \
+    goto next_state;                                                          \
+  }
+
+#define SKIP(state_value)                                                     \
+  {                                                                           \
+    skip = true;                                                              \
+    state = state_value;                                                      \
+    goto next_state;                                                          \
+  }
+
+#define ACCEPT_TOKEN(symbol_value)                                            \
+  result = true;                                                              \
+  lexer->result_symbol = symbol_value;                                        \
+  lexer->mark_end (lexer);
+
+#define END_STATE() return result;
+
+  /*
+   *  Parse Table Macros
+   */
+
+#define SMALL_STATE(id) id - LARGE_STATE_COUNT
+
+#define STATE(id) id
+
+#define ACTIONS(id) id
+
+#define SHIFT(state_value)                                                    \
+  {                                                                           \
+    {                                                                         \
+      .shift = {.type = TSParseActionTypeShift, .state = state_value }        \
+    }                                                                         \
+  }
+
+#define SHIFT_REPEAT(state_value)                                             \
+  {                                                                           \
+    {                                                                         \
+      .shift                                                                  \
+          = {.type = TSParseActionTypeShift,                                  \
+             .state = state_value,                                            \
+             .repetition = true }                                             \
+    }                                                                         \
+  }
+
+#define SHIFT_EXTRA()                                                         \
+  {                                                                           \
+    {                                                                         \
+      .shift = {.type = TSParseActionTypeShift, .extra = true }               \
+    }                                                                         \
+  }
+
+#define REDUCE(symbol_val, child_count_val, ...)                              \
+  {                                                                           \
+    {                                                                         \
+      .reduce = { .type = TSParseActionTypeReduce,                            \
+                  .symbol = symbol_val,                                       \
+                  .child_count = child_count_val,                             \
+                  __VA_ARGS__ },                                              \
+    }                                                                         \
+  }
+
+#define RECOVER()                                                             \
+  {                                                                           \
+    {                                                                         \
+      .type = TSParseActionTypeRecover                                        \
+    }                                                                         \
+  }
+
+#define ACCEPT_INPUT()                                                        \
+  {                                                                           \
+    {                                                                         \
+      .type = TSParseActionTypeAccept                                         \
+    }                                                                         \
+  }
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif // TREE_SITTER_PARSER_H_
diff --git a/pkgs/by-name/tr/tree-sitter-yts/treefmt.toml b/pkgs/by-name/tr/tree-sitter-yts/treefmt.toml
new file mode 100644
index 00000000..3d604b40
--- /dev/null
+++ b/pkgs/by-name/tr/tree-sitter-yts/treefmt.toml
@@ -0,0 +1,35 @@
+[formatter.nix]
+command = "nixpkgs-fmt"
+includes = ["*.nix"]
+excludes = ["test/**.nix"]
+
+[formatter.prettier]
+command = "prettier"
+options = ["--write"]
+includes = [
+  "*.css",
+  "*.html",
+  "*.js",
+  "*.json",
+  "*.jsx",
+  "*.md",
+  "*.mdx",
+  "*.scss",
+  "*.ts",
+]
+excludes = ["src/**.json"]
+
+[formatter.rust]
+command = "rustfmt"
+options = ["--edition", "2018"]
+includes = ["*.rs"]
+
+[formatter.c]
+command = "clang-format"
+options = ["-i"]
+includes = ["*.c", "*.cpp", "*.cc", "*.h", "*.hpp"]
+excludes = [
+  "bindings/node/binding.cc",
+  "src/parser.c",
+  "src/tree_sitter/parser.h",
+]