f59df1aa3c
Until now users would have to cargo cult or inspect the private %default-modules variable of (guix build-systems gnu) to discover which modules to include when extending the used modules via the #:modules argument. The renaming was automated via the command: $ git grep -l %gnu-build-system-modules | xargs sed 's/%gnu-build-system-modules/%default-gnu-imported-modules/' -i * guix/build-system/gnu.scm (%gnu-build-system-modules): Rename to... (%default-gnu-imported-modules): ... this. (%default-modules): Rename to... (%default-gnu-modules): ... this. Export. (dist-package, gnu-build, gnu-cross-build): Adjust accordingly. Change-Id: Idef307fff13cb76f3182d782b26e1cd3a5c757ee
932 lines
44 KiB
Scheme
932 lines
44 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
|
;;; Copyright © 2016, 2017, 2019, 2020, 2021, 2024 Ricardo Wurmus <rekado@elephly.net>
|
|
;;; Copyright © 2019 Tobias Geerinckx-Rice <me@tobias.gr>
|
|
;;;
|
|
;;; This file is part of GNU Guix.
|
|
;;;
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
|
;;; under the terms of the GNU General Public License as published by
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
;;; your option) any later version.
|
|
;;;
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;;; GNU General Public License for more details.
|
|
;;;
|
|
;;; You should have received a copy of the GNU General Public License
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
(define-module (gnu packages axoloti)
|
|
#:use-module (guix gexp)
|
|
#:use-module (guix utils)
|
|
#:use-module (guix packages)
|
|
#:use-module (guix download)
|
|
#:use-module (guix git-download)
|
|
#:use-module ((guix licenses) #:prefix license:)
|
|
#:use-module (guix build-system gnu)
|
|
#:use-module (guix build-system ant)
|
|
#:use-module (gnu packages)
|
|
#:use-module (gnu packages base)
|
|
#:use-module (gnu packages compression)
|
|
#:use-module (gnu packages cross-base)
|
|
#:use-module (gnu packages embedded)
|
|
#:use-module (gnu packages flashing-tools)
|
|
#:use-module (gnu packages java)
|
|
#:use-module (gnu packages java-graphics)
|
|
#:use-module (gnu packages java-xml)
|
|
#:use-module (gnu packages libusb)
|
|
#:use-module (gnu packages pkg-config)
|
|
#:use-module (gnu packages textutils)
|
|
#:use-module (gnu packages version-control))
|
|
|
|
;; XXX The patch does not apply to libusb 1.0.24.
|
|
;; See https://github.com/axoloti/axoloti/issues/464
|
|
(define libusb-for-axoloti
|
|
(package
|
|
(inherit libusb)
|
|
(version "1.0.23")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "https://github.com/libusb/libusb/"
|
|
"releases/download/v" version
|
|
"/libusb-" version ".tar.bz2"))
|
|
(sha256
|
|
(base32 "13dd2a9x290d1q8nb1lqiaf36grcvns5ripk5k2xm0lajmpc04fv"))
|
|
(patches (list (search-patch "libusb-for-axoloti.patch")))))))
|
|
|
|
(define dfu-util-for-axoloti
|
|
(package (inherit dfu-util)
|
|
(name "axoloti-dfu-util")
|
|
(version "0.8")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "http://dfu-util.sourceforge.net/releases/"
|
|
"dfu-util-" version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"0n7h08avlzin04j93m6hkq9id6hxjiiix7ff9gc2n89aw6dxxjsm"))))
|
|
(inputs
|
|
`(("libusb" ,libusb-for-axoloti)))))
|
|
|
|
(define-public axoloti-runtime
|
|
(package
|
|
(name "axoloti-runtime")
|
|
(version "1.0.12-2")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/axoloti/axoloti")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "1qffis277wshldr3i939b0r2x3a2mlr53samxqmr2nk1sfm2b4w9"))
|
|
(modules '((guix build utils)))
|
|
;; Remove pre-built Java binaries.
|
|
(snippet
|
|
'(delete-file-recursively "lib/"))))
|
|
(build-system gnu-build-system)
|
|
(arguments
|
|
(list
|
|
#:tests? #f ; no check target
|
|
#:modules '((guix build gnu-build-system)
|
|
(guix build utils)
|
|
(srfi srfi-1)
|
|
(srfi srfi-26)
|
|
(ice-9 match)
|
|
(ice-9 regex))
|
|
#:phases
|
|
#~(modify-phases %standard-phases
|
|
(add-after 'unpack 'patch-paths
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
;; prepare ChibiOS
|
|
(invoke "unzip" "-o" (assoc-ref inputs "chibios"))
|
|
(invoke "mv" "ChibiOS_2.6.9" "chibios")
|
|
(with-directory-excursion "chibios/ext"
|
|
(invoke "unzip" "-o" "fatfs-0.9-patched.zip"))
|
|
|
|
;; Remove source of non-determinism in ChibiOS
|
|
(substitute* "chibios/os/various/shell.c"
|
|
(("#ifdef __DATE__") "#if 0"))
|
|
|
|
;; Patch shell paths
|
|
(substitute* '("src/main/java/qcmds/QCmdCompileFirmware.java"
|
|
"src/main/java/qcmds/QCmdCompilePatch.java"
|
|
"src/main/java/qcmds/QCmdFlashDFU.java")
|
|
(("/bin/sh") (which "sh")))
|
|
|
|
;; Override cross compiler base name
|
|
(substitute* "firmware/Makefile.patch"
|
|
(("arm-none-eabi-(gcc|g\\+\\+|objcopy|objdump)" tool)
|
|
(which tool)))
|
|
|
|
;; XXX: for some reason the whitespace substitution does not
|
|
;; work, so we disable it.
|
|
(substitute* "firmware/Makefile.patch"
|
|
(("^BDIR=.*") "BDIR=${axoloti_home}/build\n"))
|
|
|
|
;; Hardcode full path to compiler tools
|
|
(substitute* '("firmware/Makefile"
|
|
"firmware/flasher/Makefile"
|
|
"firmware/mounter/Makefile")
|
|
(("TRGT =.*")
|
|
(string-append "TRGT = "
|
|
(assoc-ref inputs "cross-toolchain")
|
|
"/bin/arm-none-eabi-\n")))
|
|
|
|
;; Hardcode path to "make"
|
|
(substitute* '("firmware/compile_firmware_linux.sh"
|
|
"firmware/compile_patch_linux.sh")
|
|
(("make") (which "make")))
|
|
|
|
;; Hardcode path to "dfu-util"
|
|
(substitute* "platform_linux/upload_fw_dfu.sh"
|
|
(("-f \"\\$\\{platformdir\\}/bin/dfu-util\"") "-z \"\"")
|
|
(("\\./dfu-util") (which "dfu-util")))))
|
|
(delete 'configure)
|
|
(replace 'build
|
|
;; Build Axoloti firmware with cross-compiler
|
|
(lambda _
|
|
(with-directory-excursion "platform_linux"
|
|
(invoke "sh" "compile_firmware.sh"))))
|
|
(replace 'install
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(let* ((share (string-append #$output "/share/axoloti/"))
|
|
(doc (string-append share "doc"))
|
|
(dir (getcwd))
|
|
(pats '("/doc/[^/]+$"
|
|
"/patches/[^/]+/[^/]+$"
|
|
"/objects/[^/]+/[^/]+$"
|
|
"/firmware/.+"
|
|
"/chibios/[^/]+$"
|
|
"/chibios/boards/ST_STM32F4_DISCOVERY/[^/]+$"
|
|
"/chibios/(ext|os|docs)/.+"
|
|
"/CMSIS/[^/]+/[^/]+$"
|
|
"/patch/[^/]+/[^/]+$"
|
|
"/[^/]+\\.txt$"))
|
|
(pattern (string-append
|
|
"(" (string-join
|
|
(map (cut string-append dir <>)
|
|
pats)
|
|
"|") ")"))
|
|
(files (find-files dir
|
|
(lambda (file stat)
|
|
(and (eq? 'regular (stat:type stat))
|
|
(string-match pattern file))))))
|
|
(for-each (lambda (file)
|
|
(install-file file
|
|
(string-append
|
|
share
|
|
(regexp-substitute
|
|
#f
|
|
(string-match dir (dirname file))
|
|
'pre 'post))))
|
|
files)))))))
|
|
(inputs
|
|
`(("chibios"
|
|
,(origin
|
|
(method url-fetch)
|
|
(uri "mirror://sourceforge/chibios/ChibiOS%20GPL3/Version%202.6.9/ChibiOS_2.6.9.zip")
|
|
(sha256
|
|
(base32
|
|
"0lb5s8pkj80mqhsy47mmq0lqk34s2a2m3xagzihalvabwd0frhlj"))))
|
|
;; for compiling patches
|
|
("make" ,gnu-make)
|
|
;; for compiling firmware
|
|
("cross-toolchain" ,(make-arm-none-eabi-nano-toolchain-4.9))
|
|
;; for uploading compiled patches and firmware
|
|
("dfu-util" ,dfu-util-for-axoloti)))
|
|
(native-inputs
|
|
(list unzip))
|
|
(home-page "http://www.axoloti.com/")
|
|
(synopsis "Audio development environment for the Axoloti core board")
|
|
(description
|
|
"The Axoloti patcher offers a “patcher” environment similar to Pure Data
|
|
for sketching digital audio algorithms. The patches run on a standalone
|
|
powerful microcontroller board: Axoloti Core. This package provides the
|
|
runtime.")
|
|
(license license:gpl3+)))
|
|
|
|
(define-public axoloti-patcher
|
|
(package (inherit axoloti-runtime)
|
|
(name "axoloti-patcher")
|
|
(version (package-version axoloti-runtime))
|
|
(arguments
|
|
(list
|
|
#:tests? #f ; no check target
|
|
#:modules '((guix build gnu-build-system)
|
|
((guix build ant-build-system) #:prefix ant:)
|
|
(guix build utils)
|
|
(srfi srfi-1)
|
|
(srfi srfi-26)
|
|
(ice-9 match)
|
|
(ice-9 regex)
|
|
(sxml simple)
|
|
(sxml xpath)
|
|
(sxml transform))
|
|
#:imported-modules `((guix build ant-build-system)
|
|
,@%default-gnu-imported-modules)
|
|
#:phases
|
|
#~(modify-phases %standard-phases
|
|
(delete 'configure)
|
|
(replace 'build
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(setenv "JAVA_HOME" (assoc-ref inputs "icedtea"))
|
|
;; We want to use our own jar files instead of the pre-built
|
|
;; stuff in lib. So we replace the zipfileset tags in the
|
|
;; build.xml with new ones that reference our jars.
|
|
(let* ((build.xml (with-input-from-file "build.xml"
|
|
(lambda _
|
|
(xml->sxml #:trim-whitespace? #t))))
|
|
(jars (append-map (match-lambda
|
|
(((? (cut string-prefix? "java-" <>)
|
|
label) . directory)
|
|
(find-files directory "\\.jar$"))
|
|
(_ '()))
|
|
inputs))
|
|
(classpath (string-join jars ":"))
|
|
(fileset (map (lambda (jar)
|
|
`(zipfileset (@ (excludes "META-INF/*.SF")
|
|
(src ,jar))))
|
|
jars)))
|
|
(call-with-output-file "build.xml"
|
|
(lambda (port)
|
|
(sxml->xml
|
|
(pre-post-order
|
|
build.xml
|
|
`( ;; Remove all zipfileset tags from the "jar" tree and
|
|
;; inject our own tags.
|
|
(jar . ,(lambda (tag . kids)
|
|
`(jar ,@(append-map
|
|
(filter (lambda (e)
|
|
(not (eq? 'zipfileset (car e)))))
|
|
kids)
|
|
,@fileset)))
|
|
;; Skip the "bundle" target (and the "-post-jar" target
|
|
;; that depends on it), because we don't need it and it
|
|
;; confuses sxml->xml.
|
|
(target . ,(lambda (tag . kids)
|
|
(let ((name ((sxpath '(name *text*))
|
|
(car kids))))
|
|
(if (or (member "bundle" name)
|
|
(member "-post-jar" name))
|
|
'() ; skip
|
|
`(,tag ,@kids)))))
|
|
(*default* . ,(lambda (tag . kids) `(,tag ,@kids)))
|
|
(*text* . ,(lambda (_ txt)
|
|
(match txt
|
|
;; Remove timestamp.
|
|
("${TODAY}" "(unknown)")
|
|
(_ txt))))))
|
|
port)))
|
|
|
|
;; Build it!
|
|
(invoke "ant"
|
|
(string-append "-Djavac.classpath=" classpath)
|
|
"-Dbuild.runtime=true"
|
|
"-Dbuild.time=01/01/1970 00:00:00"
|
|
"-Djavac.source=1.7"
|
|
"-Djavac.target=1.7"
|
|
(string-append "-Dtag.short.version="
|
|
#$version)))))
|
|
(replace 'install
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(let ((share (string-append #$output "/share/axoloti/")))
|
|
(install-file "dist/Axoloti.jar" share)
|
|
|
|
;; We do this to ensure that this package retains references to
|
|
;; other Java packages' jar files.
|
|
(install-file "build.xml" share)
|
|
|
|
;; Create a launcher script
|
|
(mkdir (string-append #$output "/bin"))
|
|
(let ((target (string-append #$output "/bin/Axoloti")))
|
|
(with-output-to-file target
|
|
(lambda ()
|
|
(let* ((dir (string-append #$output "/share/axoloti"))
|
|
(runtime (search-input-directory inputs
|
|
"share/axoloti"))
|
|
(toolchain (assoc-ref inputs "cross-toolchain"))
|
|
(includes (string-append
|
|
toolchain
|
|
"/arm-none-eabi/include/:"
|
|
toolchain
|
|
"/arm-none-eabi/include/c++:"
|
|
toolchain
|
|
"/arm-none-eabi/include/c++/arm-none-eabi/armv7e-m")))
|
|
(display
|
|
(string-append "#!" (which "sh") "\n"
|
|
"export CROSS_CPATH=" includes "\n"
|
|
"export CROSS_CPLUS_INCLUDE_PATH=" includes "\n"
|
|
"export CROSS_LIBRARY_PATH="
|
|
toolchain "/arm-none-eabi/lib" "\n"
|
|
(which "java")
|
|
" -Daxoloti_release=" runtime
|
|
" -Daxoloti_runtime=" runtime
|
|
" -jar " dir "/Axoloti.jar")))))
|
|
(chmod target #o555)))))
|
|
(add-after 'install 'strip-jar-timestamps
|
|
(assoc-ref ant:%standard-phases 'strip-jar-timestamps)))))
|
|
(inputs
|
|
`(("icedtea" ,icedtea "jdk")
|
|
("cross-toolchain" ,(make-arm-none-eabi-nano-toolchain-4.9))
|
|
("java-simple-xml" ,java-simple-xml)
|
|
("java-rsyntaxtextarea" ,java-rsyntaxtextarea)
|
|
("java-usb4java" ,java-usb4java)
|
|
("java-jsch" ,java-jsch)
|
|
("java-slf4j-api" ,java-slf4j-api)
|
|
("java-jgit" ,java-jgit-4.2)
|
|
("axoloti-runtime" ,axoloti-runtime)))
|
|
(native-inputs
|
|
(list ant zip ; for repacking the jar
|
|
unzip))
|
|
(description
|
|
"The Axoloti patcher offers a “patcher” environment similar to Pure Data
|
|
for sketching digital audio algorithms. The patches run on a standalone
|
|
powerful microcontroller board: Axoloti Core. This package provides the
|
|
patcher application.")))
|
|
|
|
(define-public axoloti-patcher-next
|
|
(package
|
|
(name "axoloti-patcher-next")
|
|
(version "2.0.0")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/axoloti/axoloti")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "022p993wf9l9mp6vg94x592vfqd1k1sjrq5f6x45h5r16qy6bdzh"))
|
|
(modules '((guix build utils)))
|
|
;; Remove pre-built Java binaries.
|
|
(snippet
|
|
'(delete-file-recursively "lib/"))))
|
|
(build-system gnu-build-system)
|
|
(arguments
|
|
`(#:tests? #f ; there's a Java test which is run as part of the Java build.
|
|
#:modules ((guix build gnu-build-system)
|
|
((guix build ant-build-system) #:prefix ant:)
|
|
(guix build utils)
|
|
(srfi srfi-1)
|
|
(srfi srfi-26)
|
|
(ice-9 match)
|
|
(ice-9 regex)
|
|
(sxml simple)
|
|
(sxml xpath)
|
|
(sxml transform))
|
|
#:imported-modules ((guix build ant-build-system)
|
|
,@%default-gnu-imported-modules)
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(add-after 'unpack 'make-git-checkout-writable
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(copy-recursively (assoc-ref inputs "elfloader")
|
|
"firmware/elfloader")
|
|
(for-each make-file-writable (find-files "."))
|
|
#t))
|
|
(add-after 'unpack 'patch-paths
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
;; prepare ChibiOS
|
|
(invoke "7z" "x" (assoc-ref inputs "chibios"))
|
|
(with-directory-excursion "ChibiOS_19.1.3/ext"
|
|
(invoke "7z" "x" "fatfs-0.13_patched.7z"))
|
|
|
|
;; Hardcode full path to compiler tools
|
|
(substitute*
|
|
'("ChibiOS_19.1.3/os/common/startup/ARMCMx/compilers/GCC/mk/arm-none-eabi.mk"
|
|
"env/arm-none-eabi.mk")
|
|
(("TRGT =.*")
|
|
(string-append "TRGT = "
|
|
(assoc-ref inputs "cross-toolchain")
|
|
"/bin/arm-none-eabi-\n")))
|
|
|
|
;; Hardcode path to "make"
|
|
(substitute* "src/main/java/axoloti/shell/ShellTask.java"
|
|
(("return \"make\"")
|
|
(string-append "return \"" (which "make") "\"")))
|
|
|
|
;; Hardcode path to "dfu-util"
|
|
(substitute* "src/main/java/axoloti/shell/UploadFirmwareDFU.java"
|
|
(("Axoloti.getReleaseDir\\(\\) \\+ \"/platform_.+/bin/dfu-util\"")
|
|
(string-append "\"" (which "dfu-util") "\"")))
|
|
#t))
|
|
(delete 'configure)
|
|
(replace 'build
|
|
;; Build Axoloti firmware with cross-compiler
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(let* ((toolchain (assoc-ref inputs "cross-toolchain"))
|
|
(headers (string-append
|
|
toolchain
|
|
"/arm-none-eabi/include:"
|
|
toolchain
|
|
"/arm-none-eabi/include/arm-none-eabi/armv7e-m")))
|
|
(setenv "CROSS_CPATH" headers)
|
|
(setenv "CROSS_CPLUS_INCLUDE_PATH" headers)
|
|
(setenv "CROSS_LIBRARY_PATH"
|
|
(string-append toolchain
|
|
"/arm-none-eabi/lib")))
|
|
(with-directory-excursion "platform_linux"
|
|
(invoke "sh" "compile_firmware.sh"))))
|
|
(add-after 'build 'build-patcher
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(setenv "JAVA_HOME" (assoc-ref inputs "jdk"))
|
|
;; We want to use our own jar files instead of the pre-built
|
|
;; stuff in lib. So we replace the zipfileset tags in the
|
|
;; build.xml with new ones that reference our jars.
|
|
(let* ((build.xml (with-input-from-file "build.xml"
|
|
(lambda _
|
|
(xml->sxml #:trim-whitespace? #t))))
|
|
(jars (append-map (match-lambda
|
|
(((? (cut string-prefix? "java-" <>)
|
|
label) . directory)
|
|
(find-files directory "\\.jar$"))
|
|
(_ '()))
|
|
inputs))
|
|
(classpath (string-join jars ":"))
|
|
(fileset (map (lambda (jar)
|
|
`(zipfileset (@ (excludes "META-INF/*.SF")
|
|
(src ,jar))))
|
|
jars)))
|
|
(call-with-output-file "build.xml"
|
|
(lambda (port)
|
|
(sxml->xml
|
|
(pre-post-order
|
|
build.xml
|
|
`( ;; Remove all zipfileset tags from the "jar" tree and
|
|
;; inject our own tags.
|
|
(jar . ,(lambda (tag . kids)
|
|
`(jar ,@(append-map
|
|
(filter (lambda (e)
|
|
(not (eq? 'zipfileset (car e)))))
|
|
kids)
|
|
,@fileset)))
|
|
;; Skip the "bundle" target (and the "-post-jar" target
|
|
;; that depends on it), because we don't need it and it
|
|
;; confuses sxml->xml.
|
|
(target . ,(lambda (tag . kids)
|
|
(let ((name ((sxpath '(name *text*))
|
|
(car kids))))
|
|
(if (or (member "bundle" name)
|
|
(member "-post-jar" name))
|
|
'() ; skip
|
|
`(,tag ,@kids)))))
|
|
(*default* . ,(lambda (tag . kids) `(,tag ,@kids)))
|
|
(*text* . ,(lambda (_ txt)
|
|
(match txt
|
|
;; Remove timestamp.
|
|
("${TODAY}" "(unknown)")
|
|
(_ txt))))))
|
|
port)))
|
|
|
|
;; Build it!
|
|
(invoke "ant"
|
|
(string-append "-Djavac.classpath=" classpath)
|
|
"-Dbuilt_by=guix"
|
|
"-Dbuild.time=01/01/1970 00:00:00"
|
|
"-Djavac.source=1.8"
|
|
"-Djavac.target=1.8"
|
|
(string-append "-Dshort.version="
|
|
,version)
|
|
;; TODO: this is the output of:
|
|
;; git describe --long --tags --dirty --always
|
|
(string-append "-Dbuild.version="
|
|
,version "-0-g88b60feb")))))
|
|
(replace 'install
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
(share (string-append out "/share/axoloti/")))
|
|
|
|
;; TODO: don't copy *everything* from these directories.
|
|
(for-each (lambda (dir)
|
|
(copy-recursively dir (string-append share "/" dir)))
|
|
'("api"
|
|
"archive"
|
|
"doc"
|
|
"env"
|
|
"firmware"
|
|
"nbproject"
|
|
"platform_linux"))
|
|
(install-file "dist/Axoloti.jar" share)
|
|
|
|
;; Install old firmware
|
|
(let ((target (string-append share "/old_firmware/firmware-1.0.12"))
|
|
(old-firmware
|
|
(search-input-directory inputs
|
|
"share/axoloti/firmware")))
|
|
(mkdir-p target)
|
|
(install-file (string-append old-firmware
|
|
"/flasher/flasher_build/flasher.bin")
|
|
target)
|
|
;; TODO: the old file differs from the file that is included
|
|
;; in this repository as the old firmware.
|
|
(install-file (string-append old-firmware
|
|
"/build/axoloti.bin")
|
|
target))
|
|
|
|
;; We do this to ensure that this package retains references to
|
|
;; other Java packages' jar files.
|
|
(install-file "build.xml" share)
|
|
|
|
;; Create a launcher script
|
|
(mkdir (string-append out "/bin"))
|
|
(let ((target (string-append out "/bin/Axoloti")))
|
|
(with-output-to-file target
|
|
(lambda ()
|
|
(let* ((dir (string-append (assoc-ref outputs "out")
|
|
"/share/axoloti"))
|
|
(toolchain (assoc-ref inputs "cross-toolchain"))
|
|
(includes (string-append
|
|
toolchain
|
|
"/arm-none-eabi/include:"
|
|
toolchain
|
|
"/arm-none-eabi/include/arm-none-eabi/thumb/v7e-m")))
|
|
(display
|
|
(string-append "#!" (which "sh") "\n"
|
|
"export CROSS_CPATH=" includes "\n"
|
|
"export CROSS_CPLUS_INCLUDE_PATH=" includes "\n"
|
|
"export CROSS_LIBRARY_PATH="
|
|
toolchain "/arm-none-eabi/lib" "\n"
|
|
(which "java")
|
|
|
|
;; Renderer arguments
|
|
" -Xbootclasspath/a:"
|
|
(assoc-ref inputs "java-marlin-renderer")
|
|
"/lib/marlin.jar"
|
|
" -Dsun.java2d.renderer=org.marlin.pisces.MarlinRenderingEngine"
|
|
" -Daxoloti_release=" share
|
|
" -jar " dir "/Axoloti.jar")))))
|
|
(chmod target #o555)))))
|
|
(add-after 'install 'strip-jar-timestamps
|
|
(assoc-ref ant:%standard-phases 'strip-jar-timestamps)))))
|
|
(inputs
|
|
`(("jdk" ,icedtea "jdk")
|
|
("cross-toolchain" ,(make-arm-none-eabi-nano-toolchain-7-2018-q2-update))
|
|
;; for compiling patches
|
|
("make" ,gnu-make)
|
|
;; for uploading compiled patches and firmware
|
|
("dfu-util" ,dfu-util-for-axoloti)
|
|
;; for org/apache/commons/lang3/tuple/ImmutablePair
|
|
("java-commons-lang3" ,java-commons-lang3)
|
|
("java-jgit" ,java-jgit-4.2)
|
|
("java-jsch" ,java-jsch)
|
|
("java-marlin-renderer" ,java-marlin-renderer)
|
|
("java-piccolo2d-core" ,java-piccolo2d-core)
|
|
("java-piccolo2d-extras" ,java-piccolo2d-extras)
|
|
("java-rsyntaxtextarea" ,java-rsyntaxtextarea)
|
|
("java-simple-xml" ,java-simple-xml)
|
|
("java-slf4j-api" ,java-slf4j-api)
|
|
("java-usb4java" ,java-usb4java)))
|
|
(native-inputs
|
|
`(("ant" ,ant)
|
|
("axoloti-runtime" ,axoloti-runtime) ; for old firmware
|
|
("java-junit" ,java-junit)
|
|
("java-hamcrest-core" ,java-hamcrest-core)
|
|
("p7zip" ,p7zip)
|
|
("zip" ,zip) ; for repacking the jar
|
|
("elfloader"
|
|
,(let ((commit "d0f93acac6577a069b8739bf42c9500e9a862988"))
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/JohannesTaelman/elfloader")
|
|
(commit commit)))
|
|
(file-name (git-file-name "elfloader" commit))
|
|
(sha256
|
|
(base32
|
|
"0zsy6w784amfq4vr1qnx8xvy70v33gvffz1vljllwppdc8s3khmn")))))
|
|
("chibios"
|
|
,(origin
|
|
(method url-fetch)
|
|
(uri "http://rwthaachen.dl.osdn.jp/chibios/70739/ChibiOS_19.1.3.7z")
|
|
(sha256
|
|
(base32
|
|
"1090alqp1z1bhj1z8ls04a350kbs8hsjcpkfddbprds73zbnnpk9"))))))
|
|
(home-page "http://www.axoloti.com/")
|
|
(synopsis "Audio development environment for the Axoloti core board")
|
|
(description
|
|
"The Axoloti patcher offers a “patcher” environment similar to Pure Data
|
|
for sketching digital audio algorithms. The patches run on a standalone
|
|
powerful microcontroller board: Axoloti Core.")
|
|
(license (list license:gpl3+ ; the whole project and GUI
|
|
license:bsd-3)))) ; the elfloader
|
|
|
|
(define-public ksoloti-runtime
|
|
(package
|
|
(name "ksoloti-runtime")
|
|
(version "1.0.12-8")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/ksoloti/ksoloti")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "00ghkz3fhmmza24qrmhhz8n90n5q465fk9bld3hrfijf8sf4532i"))
|
|
(modules '((guix build utils)))
|
|
;; Remove pre-built Java binaries.
|
|
(snippet
|
|
'(delete-file-recursively "lib/"))))
|
|
(build-system gnu-build-system)
|
|
(arguments
|
|
(list
|
|
#:tests? #f ; no check target
|
|
#:modules '((guix build gnu-build-system)
|
|
(guix build utils)
|
|
(srfi srfi-1)
|
|
(srfi srfi-26)
|
|
(ice-9 match)
|
|
(ice-9 regex))
|
|
#:phases
|
|
#~(modify-phases %standard-phases
|
|
(add-after 'unpack 'patch-paths
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
;; prepare ChibiOS
|
|
(invoke "unzip" "-o" (assoc-ref inputs "chibios"))
|
|
(invoke "mv" "ChibiOS_2.6.9" "chibios")
|
|
(with-directory-excursion "chibios/ext"
|
|
(invoke "unzip" "-o" "fatfs-0.9-patched.zip"))
|
|
|
|
;; Remove source of non-determinism in ChibiOS
|
|
(substitute* "chibios/os/various/shell.c"
|
|
(("#ifdef __DATE__") "#if 0"))
|
|
|
|
;; Patch shell paths
|
|
(substitute* '("src/main/java/qcmds/QCmdCompileFirmware.java"
|
|
"src/main/java/qcmds/QCmdCompilePatch.java"
|
|
"src/main/java/qcmds/QCmdFlashDFU.java")
|
|
(("/bin/sh") (which "sh")))
|
|
|
|
;; Override cross compiler base name
|
|
(substitute* '("firmware/Makefile.patch"
|
|
"firmware_axoloti_legacy/Makefile.patch")
|
|
(("arm-none-eabi-(gcc|g\\+\\+|objcopy|objdump|size)" tool)
|
|
(which tool)))
|
|
|
|
;; XXX: for some reason the whitespace substitution does not
|
|
;; work, so we disable it.
|
|
(substitute* '("firmware/Makefile.patch"
|
|
"firmware_axoloti_legacy/Makefile.patch")
|
|
(("^BUILDDIR=.*") "BUILDDIR=${axoloti_libraries}/build\n"))
|
|
|
|
;; Hardcode full path to compiler tools
|
|
(substitute* '("firmware/Makefile"
|
|
"firmware/flasher/Makefile"
|
|
"firmware/mounter/Makefile"
|
|
"firmware_axoloti_legacy/Makefile"
|
|
"firmware_axoloti_legacy/flasher/Makefile"
|
|
"firmware_axoloti_legacy/mounter/Makefile")
|
|
(("TRGT =.*")
|
|
(string-append "TRGT = "
|
|
(assoc-ref inputs "cross-toolchain")
|
|
"/bin/arm-none-eabi-\n")))
|
|
|
|
;; Hardcode path to "make"
|
|
(substitute* '("firmware/compile_firmware_linux.sh"
|
|
"firmware/compile_patch_linux.sh"
|
|
"firmware_axoloti_legacy/compile_firmware_linux.sh"
|
|
"firmware_axoloti_legacy/compile_patch_linux.sh")
|
|
(("make") (which "make")))
|
|
|
|
;; Hardcode path to "dfu-util"
|
|
(substitute* "platform_linux/upload_fw_dfu.sh"
|
|
(("-f \"\\$\\{platformdir\\}/bin/dfu-util\"") "-z \"\"")
|
|
(("\\./dfu-util") (which "dfu-util")))))
|
|
(delete 'configure)
|
|
(replace 'build
|
|
;; Build Axoloti firmware with cross-compiler
|
|
(lambda _
|
|
(with-directory-excursion "platform_linux"
|
|
(substitute* "compile_firmware.sh"
|
|
(("^\"\\$\\{axoloti.*_firmware\\}/compile_firmware_linux.sh" m)
|
|
(string-append (which "bash") " " m)))
|
|
(invoke "sh" "compile_firmware.sh"))))
|
|
(replace 'install
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(let* ((share (string-append #$output "/share/ksoloti/"))
|
|
(doc (string-append share "doc"))
|
|
(dir (getcwd))
|
|
(pats '("/doc/[^/]+$"
|
|
"/patches/[^/]+/[^/]+$"
|
|
"/objects/[^/]+/[^/]+$"
|
|
"/firmware/.+"
|
|
"/firmware_axoloti_legacy/.+"
|
|
"/chibios/[^/]+$"
|
|
"/chibios/boards/ST_STM32F4_DISCOVERY/[^/]+$"
|
|
"/chibios/(ext|os|docs)/.+"
|
|
"/CMSIS/[^/]+/[^/]+$"
|
|
"/patch/[^/]+/[^/]+$"
|
|
"/[^/]+\\.txt$"))
|
|
(pattern (string-append
|
|
"(" (string-join
|
|
(map (cut string-append dir <>)
|
|
pats)
|
|
"|") ")"))
|
|
(files (find-files dir
|
|
(lambda (file stat)
|
|
(and (eq? 'regular (stat:type stat))
|
|
(string-match pattern file))))))
|
|
(for-each (lambda (file)
|
|
(install-file file
|
|
(string-append
|
|
share
|
|
(regexp-substitute
|
|
#f
|
|
(string-match dir (dirname file))
|
|
'pre 'post))))
|
|
files)))))))
|
|
(inputs
|
|
`(("chibios"
|
|
,(origin
|
|
(method url-fetch)
|
|
(uri "mirror://sourceforge/chibios/ChibiOS%20GPL3/Version%202.6.9/ChibiOS_2.6.9.zip")
|
|
(sha256
|
|
(base32
|
|
"0lb5s8pkj80mqhsy47mmq0lqk34s2a2m3xagzihalvabwd0frhlj"))))
|
|
;; for compiling patches
|
|
("make" ,gnu-make)
|
|
;; for compiling firmware
|
|
("cross-toolchain" ,(make-arm-none-eabi-nano-toolchain-4.9))
|
|
;; for uploading compiled patches and firmware
|
|
("dfu-util" ,dfu-util)))
|
|
(native-inputs (list unzip))
|
|
(home-page "https://ksoloti.github.io/")
|
|
(synopsis "Audio development environment for the Ksoloti board")
|
|
(description
|
|
"Ksoloti is an environment for generating and processing digital
|
|
audio. It can be a programmable virtual modular synthesizer, polysynth, drone
|
|
box, sequencer, chord generator, multi effect, sample player, looper, granular
|
|
sampler, MIDI generator/processor, CV or trigger generator, anything in
|
|
between, and more.
|
|
|
|
The Ksoloti Core is a rework of the discontinued Axoloti Core board. In
|
|
short, Ksoloti aims for maximum compatibility with the original Axoloti, but
|
|
with some layout changes and added features.
|
|
|
|
This package provides the runtime.")
|
|
(license license:gpl3+)))
|
|
|
|
(define-public ksoloti-patcher
|
|
(package
|
|
(inherit ksoloti-runtime)
|
|
(name "ksoloti-patcher")
|
|
(version (package-version ksoloti-runtime))
|
|
(arguments
|
|
(list
|
|
#:tests? #f ; no check target
|
|
#:modules '((guix build gnu-build-system)
|
|
((guix build ant-build-system) #:prefix ant:)
|
|
(guix build utils)
|
|
(srfi srfi-1)
|
|
(srfi srfi-26)
|
|
(ice-9 match)
|
|
(ice-9 regex)
|
|
(sxml simple)
|
|
(sxml xpath)
|
|
(sxml transform))
|
|
#:imported-modules `((guix build ant-build-system)
|
|
,@%default-gnu-imported-modules)
|
|
#:phases
|
|
#~(modify-phases %standard-phases
|
|
(delete 'configure)
|
|
(replace 'build
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(setenv "JAVA_HOME"
|
|
(dirname
|
|
(dirname (search-input-file inputs "/bin/javac"))))
|
|
;; We want to use our own jar files instead of the pre-built
|
|
;; stuff in lib. So we replace the zipfileset tags in the
|
|
;; build.xml with new ones that reference our jars.
|
|
(let* ((build.xml (with-input-from-file "build.xml"
|
|
(lambda _
|
|
(xml->sxml #:trim-whitespace? #t))))
|
|
(jars (append-map (match-lambda
|
|
(((? (cut string-prefix? "java-" <>)
|
|
label) . directory)
|
|
(find-files directory "\\.jar$"))
|
|
(_ '()))
|
|
inputs))
|
|
(all-jars (append jars (find-files "lib" "\\.jar$")))
|
|
(classpath (string-join all-jars ":"))
|
|
(fileset (map (lambda (jar)
|
|
`(zipfileset (@ (excludes "META-INF/*.SF")
|
|
(src ,jar))))
|
|
all-jars)))
|
|
(call-with-output-file "build.xml"
|
|
(lambda (port)
|
|
(sxml->xml
|
|
(pre-post-order
|
|
build.xml
|
|
`( ;; Remove all zipfileset tags from the "jar" tree and
|
|
;; inject our own tags.
|
|
(jar . ,(lambda (tag . kids)
|
|
`(jar ,@(append-map
|
|
(filter (lambda (e)
|
|
(not (eq? 'zipfileset (car e)))))
|
|
kids)
|
|
,@fileset)))
|
|
;; Skip the "bundle" target (and the "-post-jar" target
|
|
;; that depends on it), because we don't need it and it
|
|
;; confuses sxml->xml.
|
|
(target . ,(lambda (tag . kids)
|
|
(let ((name ((sxpath '(name *text*))
|
|
(car kids))))
|
|
(if (or (member "bundle" name)
|
|
(member "-post-jar" name))
|
|
'() ; skip
|
|
`(,tag ,@kids)))))
|
|
(*default* . ,(lambda (tag . kids) `(,tag ,@kids)))
|
|
(*text* . ,(lambda (_ txt)
|
|
(match txt
|
|
;; Remove timestamp.
|
|
("${TODAY}" "(unknown)")
|
|
(_ txt))))))
|
|
port)))
|
|
|
|
;; Build it!
|
|
(invoke "ant"
|
|
(string-append "-Djavac.classpath=" classpath)
|
|
"-Dbuild.runtime=true"
|
|
"-Dbuild.time=01/01/1970 00:00:00"
|
|
"-Djavac.source=1.8"
|
|
"-Djavac.target=1.8"
|
|
(string-append "-Dtag.short.version="
|
|
#$version)))))
|
|
(replace 'install
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(let ((share (string-append #$output "/share/ksoloti/")))
|
|
(install-file "dist/Ksoloti.jar" share)
|
|
|
|
;; We do this to ensure that this package retains references to
|
|
;; other Java packages' jar files.
|
|
(install-file "build.xml" share)
|
|
|
|
;; Create a launcher script
|
|
(mkdir (string-append #$output "/bin"))
|
|
(let ((target (string-append #$output "/bin/Ksoloti")))
|
|
(with-output-to-file target
|
|
(lambda ()
|
|
(let* ((dir (string-append #$output "/share/ksoloti"))
|
|
(runtime (search-input-directory inputs
|
|
"share/ksoloti"))
|
|
(toolchain (assoc-ref inputs "cross-toolchain"))
|
|
(includes (string-append
|
|
toolchain
|
|
"/arm-none-eabi/include/:"
|
|
toolchain
|
|
"/arm-none-eabi/include/c++:"
|
|
toolchain
|
|
"/arm-none-eabi/include/c++/arm-none-eabi/armv7e-m"))
|
|
(marlin.jar
|
|
(search-input-file inputs "/share/java/marlin.jar")))
|
|
(display
|
|
(string-append "#!" (which "sh") "\n"
|
|
"export CROSS_CPATH=" includes "\n"
|
|
"export CROSS_CPLUS_INCLUDE_PATH=" includes "\n"
|
|
"export CROSS_LIBRARY_PATH="
|
|
toolchain "/arm-none-eabi/lib" "\n"
|
|
(which "java")
|
|
" -Xbootclasspath/a:" marlin.jar
|
|
" -Dsun.java2d.renderer=org.marlin.pisces.MarlinRenderingEngine"
|
|
" -Dsun.java2d.dpiaware=true"
|
|
" -Daxoloti_release=" runtime
|
|
" -Daxoloti_runtime=" runtime
|
|
" -jar " dir "/Ksoloti.jar")))))
|
|
(chmod target #o555)))))
|
|
(add-after 'install 'strip-jar-timestamps
|
|
(assoc-ref ant:%standard-phases 'strip-jar-timestamps)))))
|
|
(inputs
|
|
`(("openjdk" ,openjdk11 "jdk")
|
|
("cross-toolchain" ,(make-arm-none-eabi-nano-toolchain-4.9))
|
|
("java-autocomplete" ,java-autocomplete)
|
|
("java-flatlaf" ,java-flatlaf)
|
|
("java-flatlaf-intellij-themes" ,java-flatlaf-intellij-themes)
|
|
("java-jgit" ,java-jgit-4.2)
|
|
("java-jsch" ,java-jsch)
|
|
("java-marlin-renderer" ,java-marlin-renderer)
|
|
("java-rsyntaxtextarea" ,java-rsyntaxtextarea)
|
|
("java-simple-xml" ,java-simple-xml)
|
|
("java-usb4java" ,java-usb4java)
|
|
("java-slf4j-api" ,java-slf4j-api)
|
|
("ksoloti-runtime" ,ksoloti-runtime)))
|
|
(native-inputs
|
|
(list ant zip ;for repacking the jar
|
|
unzip))
|
|
(description
|
|
"Ksoloti is an environment for generating and processing digital
|
|
audio. It can be a programmable virtual modular synthesizer, polysynth, drone
|
|
box, sequencer, chord generator, multi effect, sample player, looper, granular
|
|
sampler, MIDI generator/processor, CV or trigger generator, anything in
|
|
between, and more.
|
|
|
|
The Ksoloti Core is a rework of the discontinued Axoloti Core board. In
|
|
short, Ksoloti aims for maximum compatibility with the original Axoloti, but
|
|
with some layout changes and added features.
|
|
|
|
This package provides the patcher application.")))
|