From fbb456dda17b952c7f03ae79c8150822a2b892d1 Mon Sep 17 00:00:00 2001 From: Efraim Flashner Date: Thu, 3 Jan 2019 15:44:11 +0200 Subject: gnu: bullet: Update to 2.88. * gnu/packages/game-development.scm (bullet): Update to 2.88. [source]: Use 'git-fetch'. Add snippet to remove bundled binaries and libraries. [arguments]: Add configure-flags to prevent building demos. Add custom 'remove-failing-tests phase to skip tests which fail after removing bundled code. --- gnu/packages/game-development.scm | 55 +++++++++++++++++++++++++++++++-------- 1 file changed, 44 insertions(+), 11 deletions(-) (limited to 'gnu/packages') diff --git a/gnu/packages/game-development.scm b/gnu/packages/game-development.scm index 8a29297805..9167cee73f 100644 --- a/gnu/packages/game-development.scm +++ b/gnu/packages/game-development.scm @@ -4,7 +4,7 @@ ;;; Copyright © 2015, 2018 Ludovic Courtès ;;; Copyright © 2015, 2018 Alex Kost ;;; Copyright © 2015, 2016, 2017 David Thompson -;;; Copyright © 2016, 2017, 2018 Efraim Flashner +;;; Copyright © 2016, 2017, 2018, 2019 Efraim Flashner ;;; Copyright © 2016, 2017 Kei Kebreau ;;; Copyright © 2016, 2018 Ricardo Wurmus ;;; Copyright © 2016, 2017, 2018 Julian Graham @@ -86,21 +86,54 @@ (define-public bullet (package (name "bullet") - (version "2.87") + (version "2.88") (source (origin - (method url-fetch) - (uri (string-append "https://github.com/bulletphysics/bullet3/" - "archive/" version ".tar.gz")) - (file-name (string-append name "-" version ".tar.gz")) + (method git-fetch) + (uri (git-reference + (url "https://github.com/bulletphysics/bullet3/") + (commit version))) + (file-name (git-file-name name version)) (sha256 (base32 - "15azjc1jj8ak9ad7c5sbp9nv5gpqjsa0s9pc0bwy63w490f1b323")))) + "00qkif245yj7n2f262bgjaxv1bz3wmmcsfnjgy3qpzvlpzpns5z8")) + (modules '((guix build utils))) + (snippet + '(begin + (for-each delete-file (find-files "build3" "premake*")) + (with-directory-excursion "examples/ThirdPartyLibs" + (for-each delete-file-recursively + '("Gwen" "clsocket" "enet" "glad" "imgui" + "lua-5.2.3" "midi" "minizip" "openvr" + "optionalX11" "serial" "zlib"))) + ;; These need files from ThirdPartyLibs + (substitute* "Extras/CMakeLists.txt" + (("BulletRobotics") "") + (("obj2sdf") "")) + ;; Tests fail on linking, cannot find -lBussIK + (substitute* "test/CMakeLists.txt" + ((" InverseDynamics") + "../examples/ThirdPartyLibs/BussIK InverseDynamics")) + ; (("SharedMemory") "")) + #t)))) (build-system cmake-build-system) (arguments - '(#:configure-flags (list (string-append - "-DBUILD_SHARED_LIBS=ON " - "-DCMAKE_CXX_FLAGS=-fPIC " - (or (getenv "CXXFLAGS") ""))))) + '(#:configure-flags (list "-DBUILD_SHARED_LIBS=ON" + "-DBUILD_CPU_DEMOS=OFF" + "-DBUILD_OPENGL3_DEMOS=OFF" + "-DBUILD_BULLET2_DEMOS=OFF" + (string-append "-DCMAKE_CXX_FLAGS=-fPIC " + (or (getenv "CXXFLAGS") ""))) + #:phases + (modify-phases %standard-phases + (add-after 'unpack 'remove-failing-tests + ;; These tests fail specifically after removing 3rd party code + (lambda _ + (substitute* "test/SharedMemory/CMakeLists.txt" + (("ADD_TEST") "# ADD_TEST")) + (substitute* "test/InverseDynamics/CMakeLists.txt" + (("ADD_TEST\\(Test_BulletInverseForward") + "# ADD_TEST(Test_BulletInverseForward")) + #t))))) (inputs `(("glu" ,glu) ("libx11" ,libx11) -- cgit v1.2.3