refactor(nvim): build grammar with ts func
This commit is contained in:
parent
fa36366409
commit
e55026a65a
2 changed files with 3 additions and 73 deletions
|
@ -11,15 +11,6 @@
|
||||||
inherit src;
|
inherit src;
|
||||||
};
|
};
|
||||||
|
|
||||||
buildGrammar = name: grammar:
|
|
||||||
pkgs.callPackage ./grammar.nix {} {
|
|
||||||
language = grammar.language or name;
|
|
||||||
version = grammar.src.rev;
|
|
||||||
src = grammar.src;
|
|
||||||
location = grammar.location or null;
|
|
||||||
generate = grammar.generate or false;
|
|
||||||
};
|
|
||||||
|
|
||||||
fileContents = lib.strings.fileContents;
|
fileContents = lib.strings.fileContents;
|
||||||
in {
|
in {
|
||||||
# TODO: make a gradle module and have java in device-vars.nix
|
# TODO: make a gradle module and have java in device-vars.nix
|
||||||
|
@ -154,8 +145,10 @@ in {
|
||||||
|
|
||||||
tree-sitter-hypr = plugin hypr-src;
|
tree-sitter-hypr = plugin hypr-src;
|
||||||
|
|
||||||
hypr-grammar = buildGrammar "hypr" {
|
hypr-grammar = pkgs.tree-sitter.buildGrammar {
|
||||||
|
language = "hypr";
|
||||||
src = hypr-src;
|
src = hypr-src;
|
||||||
|
version = hypr-src.rev;
|
||||||
generate = true;
|
generate = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,63 +0,0 @@
|
||||||
{
|
|
||||||
stdenv,
|
|
||||||
nodejs,
|
|
||||||
tree-sitter,
|
|
||||||
lib,
|
|
||||||
}:
|
|
||||||
# https://github.com/NixOS/nixpkgs/blob/master/pkgs/development/tools/parsing/tree-sitter/grammar.nix
|
|
||||||
# Build a parser grammar and put the resulting shared object in `$out/parser`
|
|
||||||
{
|
|
||||||
# language name
|
|
||||||
language,
|
|
||||||
version,
|
|
||||||
src,
|
|
||||||
location ? null,
|
|
||||||
generate ? false,
|
|
||||||
...
|
|
||||||
} @ args:
|
|
||||||
stdenv.mkDerivation ({
|
|
||||||
pname = "${language}-grammar";
|
|
||||||
|
|
||||||
inherit src version;
|
|
||||||
|
|
||||||
nativeBuildInputs = lib.optionals generate [nodejs tree-sitter];
|
|
||||||
|
|
||||||
CFLAGS = ["-Isrc" "-O2"];
|
|
||||||
CXXFLAGS = ["-Isrc" "-O2"];
|
|
||||||
|
|
||||||
stripDebugList = ["parser"];
|
|
||||||
|
|
||||||
configurePhase =
|
|
||||||
lib.optionalString (location != null) ''
|
|
||||||
cd ${location}
|
|
||||||
''
|
|
||||||
+ lib.optionalString generate ''
|
|
||||||
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
|
|
||||||
'';
|
|
||||||
}
|
|
||||||
// removeAttrs args ["language" "location" "generate"])
|
|
Loading…
Reference in a new issue