GNU bug report logs -
#53833
[PATCH] gnu: Add qbe.
Previous Next
Reported by: jgart <jgart <at> dismail.de>
Date: Mon, 7 Feb 2022 01:21:01 UTC
Severity: normal
Tags: patch
Merged with 55150,
55151,
55605
Done: Liliana Marie Prikler <liliana.prikler <at> gmail.com>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
Your message dated Tue, 24 May 2022 21:44:26 +0200
with message-id <956d04d18e0dd7474550167906f0aadc09cac98d.camel <at> gmail.com>
and subject line Re: [PATCH v2] gnu: Add qbe.
has caused the debbugs.gnu.org bug report #53833,
regarding [PATCH 1/2] gnu: Add qbe.
to be marked as done.
(If you believe you have received this mail in error, please contact
help-debbugs <at> gnu.org.)
--
53833: https://debbugs.gnu.org/cgi/bugreport.cgi?bug=53833
GNU Bug Tracking System
Contact help-debbugs <at> gnu.org with problems
[Message part 2 (message/rfc822, inline)]
* gnu/packages/c.scm (qbe): New variable.
---
Hare + QBE builds, tested running a Hello World program using the stdlib.
gnu/packages/c.scm | 35 +++++++++++++++++++++++++++++++++++
1 file changed, 35 insertions(+)
diff --git a/gnu/packages/c.scm b/gnu/packages/c.scm
index e14e56ad71..01fd2e9a96 100644
--- a/gnu/packages/c.scm
+++ b/gnu/packages/c.scm
@@ -13,6 +13,7 @@
;;; Copyright © 2020, 2021 Greg Hogan <code <at> greghogan.com>
;;; Copyright © 2021 David Dashyan <mail <at> davie.li>
;;; Copyright © 2021 Foo Chuan Wei <chuanwei.foo <at> hotmail.com>
+;;; Copyright © 2022 Antero Mejr <antero <at> mailbox.org>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -1096,3 +1097,37 @@ (define-public utf8-h
C and C++. The functions it provides are like those from the C header
string.h, but with a utf8* prefix instead of the str* prefix.")
(license license:unlicense))))
+
+(define-public qbe
+ (let ((commit "9a3e131cf713f8619705f906caf28c5809708ad0") (revision "0"))
+ (package
+ (name "qbe")
+ (version (git-version "0.0" revision commit))
+ (source (origin
+ (method git-fetch)
+ (uri (git-reference
+ (url "git://c9x.me/qbe.git")
+ (commit commit)))
+ (file-name (git-file-name name version))
+ (sha256
+ (base32
+ "04dhdm2j84h9hlqj934wh9v456v3kzh0ayxs1gncyh4inv3b41cf"))))
+ (build-system gnu-build-system)
+ (arguments
+ `(#:tests? #f ;no test suite
+ #:make-flags
+ (list (string-append "CC="
+ ,(cc-for-target))
+ (string-append "DESTDIR="
+ (assoc-ref %outputs "out"))
+ "PREFIX=")
+ #:phases
+ (modify-phases %standard-phases
+ (delete 'configure)))) ;no configure script
+ (supported-systems (list "x86_64-linux" "aarch64-linux" "riscv64-linux"))
+ (home-page "https://c9x.me/compile/")
+ (synopsis "Compiler backend written in C")
+ (description
+ "QBE aims to be a pure C embeddable backend that provides 70% of the
+performance of advanced compilers in 10% of the code.")
+ (license license:expat))))
--
2.36.1
[Message part 3 (message/rfc822, inline)]
Am Dienstag, dem 24.05.2022 um 08:50 +0200 schrieb Liliana Marie
Prikler:
> Hi, this is mostly a reminder for myself to push this soon.
>
> Am Sonntag, dem 08.05.2022 um 21:21 +0100 schrieb (unmatched-
> parenthesis:
> > * gnu/packages/c.scm (qbe): New variable.
> >
> > Signed-off-by: (unmatched-parenthesis <paren <at> disroot.org>
> Don't add sign-off headers for your own patches, those are for
> committers signing of other people's patches :)
>
> > [...]
> > + (arguments
> > + (list #:make-flags
> > + #~(list (string-append "CC=" #$(cc-for-target))
> > + (string-append "PREFIX=" #$output)
> > + ;; `GUIXTARGET` is used instead of `TARGET` to
> > avoid changing
> > + ;; the meaning of tools/test.sh (which uses
> > `TARGET` too).
> > + (string-append "GUIXTARGET=" #$(or (%current-
> > target-system)
> > + (%current-
> > system))))
> > + #:phases
> > + #~(modify-phases %standard-phases
> > + (add-after 'unpack 'allow-cross-compilation
> > + (lambda _
> > + (substitute* "Makefile"
> > + (("`uname -m`") "$(GUIXTARGET)"))))
> Instead of going through the variable, why not inline it into the
> substitute*?
> > + (add-after 'allow-cross-compilation 'use-gcc-for-
> > tests
> > + (lambda _
> > + (substitute* "tools/test.sh"
> > + (("cc=\"cc -no-pie\"")
> > + (string-append "cc=\"${CC} -no-pie\"")))))
> > + (delete 'configure))))
> > + (supported-systems (list "x86_64-linux" "aarch64-linux"
> > "riscv64-linux"))
> > + (synopsis "Simple compiler backend")
> > + (description "QBE is a small compiler backend using an SSA-
> > based
> > intermediate
> > +language as input.")
> > + (home-page "https://c9x.me/compile/")
> > + (license license:expat))))
>
> Otherwise LGTM.
Applied with the above as well as my liberal interpretation of what
passes as `guix style'.
Cheers
This bug report was last modified 3 years and 49 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.