summaryrefslogtreecommitdiff
path: root/gnu/packages/c2rust.scm
diff options
context:
space:
mode:
Diffstat (limited to 'gnu/packages/c2rust.scm')
-rw-r--r--gnu/packages/c2rust.scm203
1 files changed, 107 insertions, 96 deletions
diff --git a/gnu/packages/c2rust.scm b/gnu/packages/c2rust.scm
index 1b249716e7..e416f71532 100644
--- a/gnu/packages/c2rust.scm
+++ b/gnu/packages/c2rust.scm
@@ -1,5 +1,6 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2024 Danny Milosavljevic <[email protected]>
+;;; Copyright © 2024 Efraim Flashner <[email protected]>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -21,62 +22,79 @@
#:use-module (guix download)
#:use-module (guix git-download)
#:use-module (guix build-system cargo)
- #:use-module (guix build-system gnu)
- #:use-module (guix gexp)
#:use-module (guix utils)
#:use-module (gnu packages)
#:use-module (gnu packages cmake)
#:use-module (gnu packages crates-io)
#:use-module (gnu packages crates-vcs)
- #:use-module (gnu packages pkg-config)
- #:use-module (gnu packages qt)
#:use-module (gnu packages llvm)
#:use-module ((guix licenses) #:prefix license:))
-(define-public rust-c2rust-bitfields-derive-0.18
+
+(define-public rust-c2rust-ast-builder-0.18
(package
- (name "rust-c2rust-bitfields-derive")
+ (name "rust-c2rust-ast-builder")
(version "0.18.0")
(source
(origin
(method url-fetch)
- (uri (crate-uri "c2rust-bitfields-derive" version))
+ (uri (crate-uri "c2rust-ast-builder" version))
(file-name (string-append name "-" version ".tar.gz"))
(sha256
- (base32 "0i95j6q1d61h1m1pk84i3ih00hsmbn8ib35xr129fz2rw81c3jyk"))))
+ (base32 "0w63rp66g6axkymxd16avxp3gjnphy3mg9938gsh52p4aak83nq5"))))
(build-system cargo-build-system)
(arguments
- `(#:skip-build? #t
- #:cargo-inputs (("rust-proc-macro2" ,rust-proc-macro2-1)
- ("rust-quote" ,rust-quote-1)
+ `(#:cargo-inputs (("rust-proc-macro2" ,rust-proc-macro2-1)
("rust-syn" ,rust-syn-1))))
(home-page "https://c2rust.com/")
- (synopsis
- "C-compatible struct bitfield derive implementation used in the C2Rust project")
+ (synopsis "Rust AST builder support crate for the C2Rust project")
(description
- "This package provides C-compatible struct bitfield derive implementation used in the C2Rust project.")
+ "This package provides the rust AST builder support crate for the
+C2Rust project.")
(license license:bsd-3)))
-(define-public rust-c2rust-bitfields-0.18
+(define-public rust-c2rust-ast-exporter-0.18
(package
- (name "rust-c2rust-bitfields")
+ (name "rust-c2rust-ast-exporter")
(version "0.18.0")
(source
(origin
(method url-fetch)
- (uri (crate-uri "c2rust-bitfields" version))
+ (uri (crate-uri "c2rust-ast-exporter" version))
(file-name (string-append name "-" version ".tar.gz"))
(sha256
- (base32 "0h9cnyijk65zypv8dqbmr5r238pqq9pa8njrdzx09xhfmc3kyg5l"))))
+ (base32 "1m589a7jld5mi7zv9z179p5j90zh7mkhbmj05mgx6bbp6m45kx7p"))
+ (patches (search-patches "c2rust-ast-exporter-local-search.patch"))
+ (modules '((guix build utils)))))
(build-system cargo-build-system)
+ (native-inputs
+ (list cmake-minimal clang))
+ (inputs
+ `(("llvm" ,llvm)
+ ("tinycbor-src" ,%tinycbor-source)))
(arguments
- `(#:skip-build? #t
- #:cargo-inputs (("rust-c2rust-bitfields-derive" ,rust-c2rust-bitfields-derive-0.18))))
+ `(#:phases
+ (modify-phases %standard-phases
+ (add-after 'unpack 'bundle-tinycbor
+ (lambda* (#:key inputs #:allow-other-keys)
+ ;; The build process will slightly patch the sources.
+ (copy-recursively (assoc-ref inputs "tinycbor-src")
+ "/tmp/tinycbor")
+ (setenv "GUIX_TINYCBOR_SOURCE_DIR" "/tmp/tinycbor"))))
+ #:cargo-inputs (("rust-bindgen" ,rust-bindgen-0.65)
+ ("rust-c2rust-build-paths" ,rust-c2rust-build-paths-0.18)
+ ("rust-clang-sys" ,rust-clang-sys-1)
+ ("rust-cmake" ,rust-cmake-0.1)
+ ("rust-env-logger" ,rust-env-logger-0.10)
+ ("rust-libc" ,rust-libc-0.2)
+ ("rust-serde" ,rust-serde-1)
+ ("rust-serde-bytes" ,rust-serde-bytes-0.11)
+ ("rust-serde-cbor" ,rust-serde-cbor-0.11))))
(home-page "https://c2rust.com/")
- (synopsis
- "C-compatible struct bitfield implementation used in the C2Rust project")
+ (synopsis "Clang AST extraction API for use in the C2Rust project")
(description
- "This package provides C-compatible struct bitfield implementation used in the C2Rust project.")
+ "This package provides the Clang AST extraction API for use in the
+C2Rust project.")
(license license:bsd-3)))
(define-public rust-c2rust-ast-printer-0.18
@@ -92,37 +110,63 @@
(base32 "1a02bnnxn1difq917c2rv8b7654ni65lyk37hdyklv9n96inr07r"))))
(build-system cargo-build-system)
(arguments
- `(#:skip-build? #t
- #:cargo-inputs (("rust-log" ,rust-log-0.4)
+ `(#:cargo-inputs (("rust-log" ,rust-log-0.4)
("rust-prettyplease" ,rust-prettyplease-0.1)
("rust-proc-macro2" ,rust-proc-macro2-1)
("rust-syn" ,rust-syn-1))))
(home-page "https://c2rust.com/")
(synopsis "Customized version of libsyntax rust pretty-printer")
(description
- "This package provides Customized version of libsyntax rust pretty-printer.")
+ "This package provides a customized version of libsyntax rust pretty-printer.")
(license (list license:expat license:asl2.0))))
-(define-public rust-c2rust-ast-builder-0.18
+(define-public rust-c2rust-bitfields-0.18
(package
- (name "rust-c2rust-ast-builder")
+ (name "rust-c2rust-bitfields")
(version "0.18.0")
(source
(origin
(method url-fetch)
- (uri (crate-uri "c2rust-ast-builder" version))
+ (uri (crate-uri "c2rust-bitfields" version))
(file-name (string-append name "-" version ".tar.gz"))
(sha256
- (base32 "0w63rp66g6axkymxd16avxp3gjnphy3mg9938gsh52p4aak83nq5"))))
+ (base32 "0h9cnyijk65zypv8dqbmr5r238pqq9pa8njrdzx09xhfmc3kyg5l"))))
(build-system cargo-build-system)
(arguments
- `(#:skip-build? #t
- #:cargo-inputs (("rust-proc-macro2" ,rust-proc-macro2-1)
+ (list #:cargo-inputs
+ (list rust-c2rust-bitfields-derive-0.18)
+ #:cargo-development-inputs
+ (list rust-libc-0.2)))
+ (home-page "https://c2rust.com/")
+ (synopsis
+ "C-compatible struct bitfield implementation used in the C2Rust project")
+ (description
+ "This package provides a C-compatible struct bitfield implementation used
+in the C2Rust project.")
+ (license license:bsd-3)))
+
+(define-public rust-c2rust-bitfields-derive-0.18
+ (package
+ (name "rust-c2rust-bitfields-derive")
+ (version "0.18.0")
+ (source
+ (origin
+ (method url-fetch)
+ (uri (crate-uri "c2rust-bitfields-derive" version))
+ (file-name (string-append name "-" version ".tar.gz"))
+ (sha256
+ (base32 "0i95j6q1d61h1m1pk84i3ih00hsmbn8ib35xr129fz2rw81c3jyk"))))
+ (build-system cargo-build-system)
+ (arguments
+ `(#:cargo-inputs (("rust-proc-macro2" ,rust-proc-macro2-1)
+ ("rust-quote" ,rust-quote-1)
("rust-syn" ,rust-syn-1))))
(home-page "https://c2rust.com/")
- (synopsis "Rust AST builder support crate for the C2Rust project")
+ (synopsis
+ "C-compatible struct bitfield derive implementation used in the C2Rust project")
(description
- "This package provides Rust AST builder support crate for the C2Rust project.")
+ "This package provides a C-compatible struct bitfield derive implementation
+used in the C2Rust project.")
(license license:bsd-3)))
(define-public rust-c2rust-build-paths-0.18
@@ -138,13 +182,12 @@
(base32 "0b2liaxbqksgfbsmr6hacdia6czlq7m0pyqx3l2rrcfcnb2ksgv0"))))
(build-system cargo-build-system)
(arguments
- `(#:skip-build? #t
- #:cargo-inputs (("rust-print-bytes" ,rust-print-bytes-1))))
+ `(#:cargo-inputs (("rust-print-bytes" ,rust-print-bytes-1))))
(home-page "https://c2rust.com/")
- (synopsis
- "C2Rust utilities related to build paths, primarily at build time")
+ (synopsis "C2Rust utilities related to build paths, primarily at build time")
(description
- "This package provides C2Rust utilities related to build paths, primarily at build time.")
+ "This package provides C2Rust utilities related to build paths, primarily
+at build time.")
(license license:bsd-3)))
;; Note: It has expat license.
@@ -159,51 +202,6 @@
(base32
"0w38lzj0rz36skc1cn3shllc82c7nn32h88frb8f164a8haq3hkw"))))
-(define-public rust-c2rust-ast-exporter-0.18
- (package
- (name "rust-c2rust-ast-exporter")
- (version "0.18.0")
- (source
- (origin
- (method url-fetch)
- (uri (crate-uri "c2rust-ast-exporter" version))
- (file-name (string-append name "-" version ".tar.gz"))
- (sha256
- (base32 "1m589a7jld5mi7zv9z179p5j90zh7mkhbmj05mgx6bbp6m45kx7p"))
- (patches (search-patches "c2rust-ast-exporter-local-search.patch"))
- (modules '((guix build utils)))))
- (build-system cargo-build-system)
- (native-inputs
- `(("cmake" ,cmake)
- ("clang" ,clang)))
- (inputs
- `(("llvm" ,llvm)
- ("tinycbor-src" ,%tinycbor-source)))
- (arguments
- `(#:phases
- (modify-phases %standard-phases
- (add-after 'unpack 'bundle-tinycbor
- (lambda* (#:key inputs #:allow-other-keys)
- ;; The build process will slightly patch the sources.
- (copy-recursively (assoc-ref inputs "tinycbor-src")
- "/tmp/tinycbor")
- (setenv "GUIX_TINYCBOR_SOURCE_DIR" "/tmp/tinycbor"))))
- #:skip-build? #f
- #:cargo-inputs (("rust-bindgen" ,rust-bindgen-0.65)
- ("rust-c2rust-build-paths" ,rust-c2rust-build-paths-0.18)
- ("rust-clang-sys" ,rust-clang-sys-1.8)
- ("rust-cmake" ,rust-cmake-0.1)
- ("rust-env-logger" ,rust-env-logger-0.10)
- ("rust-libc" ,rust-libc-0.2)
- ("rust-serde" ,rust-serde-1)
- ("rust-serde-bytes" ,rust-serde-bytes-0.11)
- ("rust-serde-cbor" ,rust-serde-cbor-0.11))))
- (home-page "https://c2rust.com/")
- (synopsis "Clang AST extraction API for use in the C2Rust project")
- (description
- "This package provides Clang AST extraction API for use in the C2Rust project.")
- (license license:bsd-3)))
-
(define-public rust-c2rust-transpile-0.18
(package
(name "rust-c2rust-transpile")
@@ -217,8 +215,7 @@
(base32 "09fvi2id0qjhfvsqcz9222ac81lyl2j6rbq280dhn06y1nvy000c"))))
(build-system cargo-build-system)
(arguments
- `(#:skip-build? #t
- #:cargo-inputs (("rust-c2rust-ast-builder" ,rust-c2rust-ast-builder-0.18)
+ `(#:cargo-inputs (("rust-c2rust-ast-builder" ,rust-c2rust-ast-builder-0.18)
("rust-c2rust-ast-exporter" ,rust-c2rust-ast-exporter-0.18)
("rust-c2rust-ast-printer" ,rust-c2rust-ast-printer-0.18)
("rust-c2rust-bitfields" ,rust-c2rust-bitfields-0.18)
@@ -243,10 +240,23 @@
("rust-smallvec" ,rust-smallvec-1)
("rust-strum" ,rust-strum-0.24)
("rust-strum-macros" ,rust-strum-macros-0.24)
- ("rust-syn" ,rust-syn-1))))
+ ("rust-syn" ,rust-syn-1))
+ #:phases
+ (modify-phases %standard-phases
+ (add-before 'build 'patch
+ (lambda* (#:key inputs #:allow-other-keys)
+ ;; The build process will slightly patch the sources.
+ (copy-recursively (assoc-ref inputs "tinycbor-src")
+ "/tmp/tinycbor")
+ (setenv "GUIX_TINYCBOR_SOURCE_DIR" "/tmp/tinycbor"))))))
+ (native-inputs
+ `(("clang" ,clang)
+ ("cmake" ,cmake-minimal)
+ ("tinycbor-src" ,%tinycbor-source)))
+ (inputs (list llvm))
(home-page "https://c2rust.com/")
(synopsis "C2Rust transpiler implementation")
- (description "This package provides C2Rust transpiler implementation.")
+ (description "This package provides the C2Rust transpiler implementation.")
(license license:bsd-3)))
(define-public c2rust
@@ -259,15 +269,21 @@
(uri (crate-uri "c2rust" version))
(file-name (string-append name "-" version ".tar.gz"))
(sha256
- (base32 "1rg9cvvmh9zw89mz2bpyvqlwbfhzl5dw2hab9z6d5rasr8mir7nh"))))
+ (base32 "1rg9cvvmh9zw89mz2bpyvqlwbfhzl5dw2hab9z6d5rasr8mir7nh"))
+ (modules '((guix build utils)))
+ (snippet
+ '(begin (substitute* "Cargo.toml"
+ (("\"= ?([[:digit:]]+(\\.[[:digit:]]+)*)" _ version)
+ (string-append "\"^" version)))))))
(build-system cargo-build-system)
(native-inputs
`(("tinycbor-src" ,%tinycbor-source)
- ("cmake" ,cmake)
+ ("cmake" ,cmake-minimal)
("clang" ,clang)))
(inputs (list llvm))
(arguments
- `(#:cargo-inputs (("rust-anyhow" ,rust-anyhow-1)
+ `(#:install-source? #f
+ #:cargo-inputs (("rust-anyhow" ,rust-anyhow-1)
("rust-c2rust-build-paths" ,rust-c2rust-build-paths-0.18)
("rust-c2rust-transpile" ,rust-c2rust-transpile-0.18)
("rust-clap" ,rust-clap-3)
@@ -280,11 +296,6 @@
("rust-time-macros" ,rust-time-macros-0.2))
#:phases
(modify-phases %standard-phases
- (add-after 'unpack 'patch-deps
- (lambda _
- ;; This is incorrect in the release to begin with.
- (substitute* "Cargo.toml"
- (("=0.2.6") "=0.2.18"))))
(add-before 'build 'patch
(lambda* (#:key inputs #:allow-other-keys)
;; The build process will slightly patch the sources.