summary refs log tree commit diff
diff options
context:
space:
mode:
authorAndrew Tropin <andrew@trop.in>2023-02-12 10:14:07 +0400
committerAndrew Tropin <andrew@trop.in>2023-02-12 11:32:23 +0400
commit2419a1636546cf993bafbf5a6ba6b6e48994c246 (patch)
treef593dcff9e8e4e64787d7cf562d88a601d6a2ab5
parent5401b5822a91d407d7041aef6625e0fe6a57bbae (diff)
downloadguix-2419a1636546cf993bafbf5a6ba6b6e48994c246.tar.gz
gnu: tree-sitter-grammar: Migrate to tree-sitter-build-system.
gnu/packages/tree-sitter.scm (tree-sitter-delete-generated-files): New
variable.
(tree-sitter-grammar): Remove source-directory argument, add inputs argument,
change package names, remove custom build code, update build system to
tree-sitter-build-system.
(tree-sitter-grammar-html): Rename to tree-sitter-html.
-rw-r--r--gnu/packages/tree-sitter.scm53
1 files changed, 20 insertions, 33 deletions
diff --git a/gnu/packages/tree-sitter.scm b/gnu/packages/tree-sitter.scm
index d70d579762..bf6cd55b40 100644
--- a/gnu/packages/tree-sitter.scm
+++ b/gnu/packages/tree-sitter.scm
@@ -29,6 +29,7 @@
   #:use-module (gnu packages node)
   #:use-module (guix build-system cargo)
   #:use-module (guix build-system gnu)
+  #:use-module (guix build-system tree-sitter)
   #:use-module (guix gexp)
   #:use-module (guix git-download)
   #:use-module (guix packages)
@@ -187,17 +188,26 @@ can be embedded in any application.
 This package includes the @command{tree-sitter} command-line tool.")
     (license license:expat)))
 
+(define tree-sitter-delete-generated-files
+  #~(begin
+      (use-modules (guix build utils))
+      (delete-file "binding.gyp")
+      (delete-file-recursively "bindings")
+      (delete-file "src/grammar.json")
+      (delete-file "src/node-types.json")
+      (delete-file "src/parser.c")
+      (delete-file-recursively "src/tree_sitter")))
+
 (define* (tree-sitter-grammar
           language language-for-synopsis version commit hash
           #:key
           (repository-url
-           (format #f "https://github.com/tree-sitter/tree-sitter-~a" language))
-          (source-directory ""))
+           (format #f "https://github.com/tree-sitter/tree-sitter-~a"
+                   language))
+          (inputs '()))
   (let ((synopsis (string-append language-for-synopsis
                                  " grammar for tree-sitter"))
-        (name (string-append "tree-sitter-grammar-" language))
-        (src-dir source-directory)
-        (lib (format #f "libtree-sitter-~a.so" language)))
+        (name (string-append "tree-sitter-" language)))
     (package
       (name name)
       (version version)
@@ -208,38 +218,15 @@ This package includes the @command{tree-sitter} command-line tool.")
                       (url repository-url)
                       (commit commit)))
                 (file-name (git-file-name name version))
-                (sha256 (base32 hash))))
-      (build-system gnu-build-system)
-      (arguments
-       (list
-        #:phases
-        #~(modify-phases %standard-phases
-            (delete 'configure)
-            (replace 'build
-              (lambda _
-                (with-directory-excursion (string-append #$src-dir "src")
-                  (let* ((scanner? (or (file-exists? "scanner.c")
-                                       (file-exists? "scanner.cc")))
-                         (CC (if (file-exists? "scanner.cc") "g++" "gcc"))
-                         (compile (lambda (f) (invoke CC "-fPIC" "-c" "-I." f)))
-                         (link-args `("-fPIC" "-shared" "parser.o"
-                                      ,@(if scanner? '("scanner.o") '())
-                                      "-o" ,#$lib)))
-                    (invoke "gcc" "-fPIC" "-c" "-I." "parser.c")
-                    (for-each
-                     (lambda (f) (when (file-exists? f) (compile f)))
-                     '("scanner.c" "scanner.cc"))
-                    (apply invoke CC link-args)))))
-            (delete 'check)
-            (replace 'install
-              (lambda _
-                (install-file (string-append #$src-dir "src/" #$lib)
-                              (string-append #$output "/lib/tree-sitter")))))))
+                (sha256 (base32 hash))
+                (snippet tree-sitter-delete-generated-files)))
+      (build-system tree-sitter-build-system)
+      (inputs inputs)
       (synopsis synopsis)
       (description (string-append synopsis "."))
       (license license:expat))))
 
-(define-public tree-sitter-grammar-html
+(define-public tree-sitter-html
   (tree-sitter-grammar
    "html" "HTML"
    "0.19.0" "v0.19.0"