gnu: gxtuner: Update to 2.4.
[jackhill/guix/guix.git] / Makefile.am
index 7f2281c..8fe9e35 100644 (file)
@@ -1,9 +1,10 @@
 # GNU Guix --- Functional package management for GNU
-# Copyright © 2012, 2013, 2014, 2015, 2016 Ludovic Courtès <ludo@gnu.org>
+# Copyright © 2012, 2013, 2014, 2015, 2016, 2017 Ludovic Courtès <ludo@gnu.org>
 # Copyright © 2013 Andreas Enge <andreas@enge.fr>
-# Copyright © 2015 Alex Kost <alezost@gmail.com>
+# Copyright © 2015, 2017 Alex Kost <alezost@gmail.com>
 # Copyright © 2016 Mathieu Lirzin <mthl@gnu.org>
-# Copyright © 2016 Mark H Weaver <mhw@netris.org>
+# Copyright © 2016, 2017 Mark H Weaver <mhw@netris.org>
+# Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
 #
 # This file is part of GNU Guix.
 #
@@ -27,9 +28,14 @@ nodist_noinst_SCRIPTS =                              \
   pre-inst-env                                 \
   test-env
 
+# Modules that are not compiled but are installed nonetheless, such as
+# build-side modules with unusual dependencies.
+MODULES_NOT_COMPILED =
+
 include gnu/local.mk
 
 MODULES =                                      \
+  guix/base16.scm                              \
   guix/base32.scm                              \
   guix/base64.scm                              \
   guix/cpio.scm                                        \
@@ -39,10 +45,12 @@ MODULES =                                   \
   guix/pk-crypto.scm                           \
   guix/pki.scm                                 \
   guix/combinators.scm                         \
+  guix/memoization.scm                         \
   guix/utils.scm                               \
   guix/sets.scm                                        \
   guix/modules.scm                             \
   guix/download.scm                            \
+  guix/discovery.scm                           \
   guix/git-download.scm                                \
   guix/hg-download.scm                         \
   guix/monads.scm                              \
@@ -57,11 +65,15 @@ MODULES =                                   \
   guix/upstream.scm                            \
   guix/licenses.scm                            \
   guix/graph.scm                               \
+  guix/cache.scm                               \
   guix/cve.scm                                 \
+  guix/workers.scm                             \
   guix/zlib.scm                                        \
   guix/build-system.scm                                \
   guix/build-system/ant.scm                    \
+  guix/build-system/cargo.scm                  \
   guix/build-system/cmake.scm                  \
+  guix/build-system/dub.scm                    \
   guix/build-system/emacs.scm                  \
   guix/build-system/asdf.scm                   \
   guix/build-system/glib-or-gtk.scm            \
@@ -69,6 +81,7 @@ MODULES =                                     \
   guix/build-system/haskell.scm                        \
   guix/build-system/perl.scm                   \
   guix/build-system/python.scm                 \
+  guix/build-system/ocaml.scm                  \
   guix/build-system/waf.scm                    \
   guix/build-system/r.scm                      \
   guix/build-system/ruby.scm                   \
@@ -83,7 +96,9 @@ MODULES =                                     \
   guix/ui.scm                                  \
   guix/build/ant-build-system.scm              \
   guix/build/download.scm                      \
+  guix/build/cargo-build-system.scm            \
   guix/build/cmake-build-system.scm            \
+  guix/build/dub-build-system.scm              \
   guix/build/emacs-build-system.scm            \
   guix/build/asdf-build-system.scm             \
   guix/build/git.scm                           \
@@ -93,6 +108,7 @@ MODULES =                                    \
   guix/build/gnu-dist.scm                      \
   guix/build/perl-build-system.scm             \
   guix/build/python-build-system.scm           \
+  guix/build/ocaml-build-system.scm            \
   guix/build/r-build-system.scm                        \
   guix/build/ruby-build-system.scm             \
   guix/build/waf-build-system.scm              \
@@ -112,6 +128,7 @@ MODULES =                                   \
   guix/build/graft.scm                         \
   guix/build/bournish.scm                      \
   guix/build/qt-utils.scm                      \
+  guix/build/make-bootstrap.scm                        \
   guix/search-paths.scm                                \
   guix/packages.scm                            \
   guix/import/utils.scm                                \
@@ -123,12 +140,14 @@ MODULES =                                 \
   guix/import/elpa.scm                         \
   guix/scripts.scm                             \
   guix/scripts/download.scm                    \
+  guix/scripts/perform-download.scm            \
   guix/scripts/build.scm                       \
   guix/scripts/archive.scm                     \
   guix/scripts/import.scm                      \
   guix/scripts/package.scm                     \
   guix/scripts/gc.scm                          \
   guix/scripts/hash.scm                                \
+  guix/scripts/pack.scm                                \
   guix/scripts/pull.scm                                \
   guix/scripts/substitute.scm                  \
   guix/scripts/authenticate.scm                        \
@@ -140,6 +159,7 @@ MODULES =                                   \
   guix/scripts/import/gnu.scm                  \
   guix/scripts/import/nix.scm                  \
   guix/scripts/import/hackage.scm              \
+  guix/scripts/import/stackage.scm             \
   guix/scripts/import/elpa.scm                 \
   guix/scripts/environment.scm                 \
   guix/scripts/publish.scm                     \
@@ -154,16 +174,29 @@ MODULES =                                 \
 if HAVE_GUILE_JSON
 
 MODULES +=                                     \
+  guix/docker.scm                              \
+  guix/import/cpan.scm                         \
+  guix/import/crate.scm                                \
+  guix/import/gem.scm                          \
   guix/import/github.scm                       \
   guix/import/json.scm                         \
   guix/import/pypi.scm                         \
-  guix/scripts/import/pypi.scm                 \
-  guix/import/cpan.scm                         \
+  guix/import/stackage.scm                     \
+  guix/scripts/import/crate.scm                        \
   guix/scripts/import/gem.scm                  \
-  guix/import/gem.scm
+  guix/scripts/import/pypi.scm
 
 endif
 
+if HAVE_GUILE_SSH
+
+MODULES +=                                     \
+  guix/ssh.scm                                 \
+  guix/scripts/copy.scm                                \
+  guix/store/ssh.scm
+
+endif HAVE_GUILE_SSH
+
 if BUILD_DAEMON_OFFLOAD
 
 MODULES +=                                     \
@@ -171,17 +204,20 @@ MODULES +=                                        \
 
 endif BUILD_DAEMON_OFFLOAD
 
-# Internal module with test suite support.
-dist_noinst_DATA = guix/tests.scm
-
-# Linux-Libre configurations.
-KCONFIGS =                                     \
-  gnu/packages/linux-libre-4.8-i686.conf       \
-  gnu/packages/linux-libre-4.8-x86_64.conf     \
-  gnu/packages/linux-libre-4.4-i686.conf       \
-  gnu/packages/linux-libre-4.4-x86_64.conf     \
-  gnu/packages/linux-libre-4.1-i686.conf       \
-  gnu/packages/linux-libre-4.1-x86_64.conf
+# Internal modules with test suite support.
+dist_noinst_DATA = guix/tests.scm guix/tests/http.scm
+
+# Auxiliary files for packages.
+AUX_FILES =                                            \
+  gnu/packages/aux-files/emacs/guix-emacs.el           \
+  gnu/packages/aux-files/linux-libre/4.11-i686.conf    \
+  gnu/packages/aux-files/linux-libre/4.11-x86_64.conf  \
+  gnu/packages/aux-files/linux-libre/4.9-i686.conf     \
+  gnu/packages/aux-files/linux-libre/4.9-x86_64.conf   \
+  gnu/packages/aux-files/linux-libre/4.4-i686.conf     \
+  gnu/packages/aux-files/linux-libre/4.4-x86_64.conf   \
+  gnu/packages/aux-files/linux-libre/4.1-i686.conf     \
+  gnu/packages/aux-files/linux-libre/4.1-x86_64.conf
 
 # Templates, examples.
 EXAMPLES =                                     \
@@ -189,12 +225,13 @@ EXAMPLES =                                        \
   gnu/system/examples/desktop.tmpl             \
   gnu/system/examples/lightweight-desktop.tmpl
 
-GOBJECTS = $(MODULES:%.scm=%.go) guix/config.go guix/tests.go
+GOBJECTS = $(MODULES:%.scm=%.go) guix/config.go $(dist_noinst_DATA:%.scm=%.go)
 
-nobase_dist_guilemodule_DATA =                  \
-  $(MODULES) $(KCONFIGS) $(EXAMPLES)            \
+nobase_dist_guilemodule_DATA =                                 \
+  $(MODULES) $(MODULES_NOT_COMPILED) $(AUX_FILES) $(EXAMPLES)  \
   $(MISC_DISTRO_FILES)
-nobase_nodist_guilemodule_DATA = $(GOBJECTS) guix/config.scm
+nobase_nodist_guilemodule_DATA = guix/config.scm
+nobase_nodist_guileobject_DATA = $(GOBJECTS)
 
 # Do we need to provide our own non-broken (srfi srfi-37) module?
 if INSTALL_SRFI_37
@@ -225,6 +262,7 @@ TEST_EXTENSIONS = .scm .sh
 if CAN_RUN_TESTS
 
 SCM_TESTS =                                    \
+  tests/base16.scm                             \
   tests/base32.scm                             \
   tests/base64.scm                             \
   tests/cpio.scm                               \
@@ -242,6 +280,7 @@ SCM_TESTS =                                 \
   tests/records.scm                            \
   tests/upstream.scm                           \
   tests/combinators.scm                                \
+  tests/discovery.scm                          \
   tests/utils.scm                              \
   tests/build-utils.scm                                \
   tests/packages.scm                           \
@@ -255,6 +294,7 @@ SCM_TESTS =                                 \
   tests/nar.scm                                        \
   tests/union.scm                              \
   tests/profiles.scm                           \
+  tests/search-paths.scm                       \
   tests/syscalls.scm                           \
   tests/gremlin.scm                            \
   tests/bournish.scm                           \
@@ -264,13 +304,16 @@ SCM_TESTS =                                       \
   tests/size.scm                               \
   tests/graph.scm                              \
   tests/challenge.scm                          \
+  tests/cache.scm                              \
   tests/cve.scm                                        \
+  tests/workers.scm                            \
   tests/zlib.scm                               \
   tests/file-systems.scm                       \
   tests/system.scm                             \
   tests/services.scm                           \
   tests/scripts-build.scm                      \
   tests/containers.scm                         \
+  tests/pack.scm                               \
   tests/import-utils.scm
 
 if HAVE_GUILE_JSON
@@ -278,7 +321,8 @@ if HAVE_GUILE_JSON
 SCM_TESTS +=                                   \
   tests/pypi.scm                               \
   tests/cpan.scm                               \
-  tests/gem.scm
+  tests/gem.scm                                        \
+  tests/crate.scm
 
 endif
 
@@ -341,7 +385,7 @@ check-local:
 
 endif !CAN_RUN_TESTS
 
-check-system: $(GOBJECTS)
+check-system: $(GOBJECTS) $(BOOTSTRAP_GUILE_TARBALLS)
        $(AM_V_at)$(top_builddir)/pre-inst-env                  \
           $(GUILE) --no-auto-compile                           \
           -e '(@@ (run-system-tests) run-system-tests)'        \
@@ -366,15 +410,15 @@ EXTRA_DIST =                                              \
   build-aux/compile-all.scm                            \
   build-aux/hydra/evaluate.scm                         \
   build-aux/hydra/gnu-system.scm                       \
-  build-aux/hydra/demo-os.scm                          \
   build-aux/hydra/guix.scm                             \
   build-aux/check-available-binaries.scm               \
   build-aux/check-final-inputs-self-contained.scm      \
   build-aux/download.scm                               \
-  build-aux/make-binary-tarball.scm                    \
   build-aux/generate-authors.scm                       \
   build-aux/test-driver.scm                            \
   build-aux/run-system-tests.scm                       \
+  d3.v3.js                                             \
+  graph.js                                             \
   srfi/srfi-37.scm.in                                  \
   srfi/srfi-64.scm                                     \
   srfi/srfi-64.upstream.scm                            \
@@ -407,7 +451,7 @@ CLEANFILES =                                        \
 # the whole thing.  Likewise, set 'XDG_CACHE_HOME' to avoid loading possibly
 # stale files from ~/.cache/guile/ccache.
 %.go: make-go ; @:
-make-go: $(MODULES) guix/config.scm guix/tests.scm
+make-go: $(MODULES) guix/config.scm $(dist_noinst_DATA)
        $(AM_V_at)echo "Compiling Scheme modules..." ;                  \
        unset GUILE_LOAD_COMPILED_PATH ;                                \
        XDG_CACHE_HOME=/nowhere                                         \
@@ -424,14 +468,14 @@ SUFFIXES = .go
 # files.  See
 # <http://lists.gnu.org/archive/html/guile-devel/2010-07/msg00125.html>
 # for details.
-guix_install_go_files = install-nobase_nodist_guilemoduleDATA
+guix_install_go_files = install-nobase_nodist_guileobjectDATA
 $(guix_install_go_files): install-nobase_dist_guilemoduleDATA
 
 # The above trick doesn't work for 'config.go' because both 'config.scm' and
-# 'config.go' are listed in $(nobase_nodist_guilemodule_DATA).  Thus, give it
+# 'config.go' are listed in $(nobase_nodist_guileobject_DATA).  Thus, give it
 # special treatment.
 install-data-hook: set-bootstrap-executable-permissions
-       touch "$(DESTDIR)$(guilemoduledir)/guix/config.go"
+       touch "$(DESTDIR)$(guileobjectdir)/guix/config.go"
 
 
 SUBDIRS = po/guix po/packages
@@ -456,25 +500,28 @@ AM_DISTCHECK_CONFIGURE_FLAGS =                    \
   --with-nix-prefix="$(NIX_PREFIX)"            \
   --enable-daemon
 
-dist_emacsui_DATA = emacs/guix-main.scm
-nodist_emacsui_DATA = emacs/guix-helper.scm
-include emacs/local.mk
-
-# The self-contained tarball.
+# The self-contained tarball.  Add 'glibc-utf8-locales' along with glibc just
+# so 'etc/profile' defines 'GUIX_LOCPATH' pointing to a valid set of locales.
 guix-binary.%.tar.xz:
-       $(AM_V_GEN)GUIX_PACKAGE_PATH= \
-       $(top_builddir)/pre-inst-env "$(GUILE)"                 \
-         "$(top_srcdir)/build-aux/make-binary-tarball.scm" "$*" "$@"
+       $(AM_V_GEN)GUIX_PACKAGE_PATH=                           \
+       tarball=`$(top_builddir)/pre-inst-env guix pack -C xz   \
+         -s "$*" --localstatedir guix glibc-utf8-locales       \
+         -e  '(@@ (gnu packages commencement) glibc-final)'` ; \
+       cp "$$tarball" "$@.tmp" ; mv "$@.tmp" "$@"
 
 
-dist-hook: sync-descriptions gen-ChangeLog gen-AUTHORS
+dist-hook: gen-ChangeLog gen-AUTHORS gen-tarball-version
 dist-hook: assert-no-store-file-names
 
 distcheck-hook: assert-binaries-available assert-final-inputs-self-contained
 
-sync-descriptions:
-       $(AM_V_at)GUIX_PACKAGE_PATH= \
-        $(top_builddir)/pre-inst-env guix lint --checkers=gnu-description
+EXTRA_DIST += $(top_srcdir)/.version
+BUILT_SOURCES += $(top_srcdir)/.version
+$(top_srcdir)/.version:
+       echo $(VERSION) > "$@-t" && mv "$@-t" "$@"
+
+gen-tarball-version:
+       echo $(VERSION) > "$(distdir)/.tarball-version"
 
 gen-ChangeLog:
        $(AM_V_GEN)if test -d .git; then                \
@@ -495,7 +542,11 @@ gen-AUTHORS:
 # Make sure we're not shipping a file that embeds a local /gnu/store file name.
 assert-no-store-file-names:
        $(AM_V_at)if grep -r --exclude=*.texi --exclude=*.info                  \
-            "$(storedir)/[a-z0-9]{32}-" $(distdir) ;                           \
+            --exclude=*.info-[0-9] --exclude=*.dot                             \
+            --exclude=*.eps --exclude-dir=bootstrap                            \
+            --exclude=guix-prettify.el                                         \
+            --exclude=ChangeLog                                                \
+            -E "$(storedir)/[a-z0-9]{32}-" $(distdir) ;                        \
        then                                                                    \
          echo "error: store file names embedded in the distribution" >&2 ;     \
          exit 1 ;                                                              \
@@ -519,9 +570,10 @@ hydra-jobs.scm: $(GOBJECTS)
          "$(top_srcdir)/build-aux/hydra/gnu-system.scm" > "$@.tmp"
        $(AM_V_at)mv "$@.tmp" "$@"
 
-.PHONY: sync-descriptions gen-ChangeLog gen-AUTHORS clean-go make-go
+.PHONY: gen-ChangeLog gen-AUTHORS gen-tarball-version
 .PHONY: assert-no-store-file-names assert-binaries-available
 .PHONY: assert-final-inputs-self-contained
+.PHONY: clean-go make-go
 
 ## -------------- ##
 ## Silent rules.  ##
@@ -535,10 +587,6 @@ AM_V_DOT = $(AM_V_DOT_$(V))
 AM_V_DOT_ = $(AM_V_DOT_$(AM_DEFAULT_VERBOSITY))
 AM_V_DOT_0 = @echo "  DOT     " $@;
 
-AM_V_EMACS = $(AM_V_EMACS_$(V))
-AM_V_EMACS_ = $(AM_V_EMACS_$(AM_DEFAULT_VERBOSITY))
-AM_V_EMACS_0 = @echo "  EMACS   " $@;
-
 AM_V_HELP2MAN = $(AM_V_HELP2MAN_$(V))
 AM_V_HELP2MAN_ = $(AM_V_HELP2MAN_$(AM_DEFAULT_VERBOSITY))
 AM_V_HELP2MAN_0 = @echo "  HELP2MAN" $@;