2017-04-15 12:17:27 -04:00
|
|
|
;;; GNU Guix --- Functional package management for GNU
|
|
|
|
;;; Copyright © 2012 Stefan Handschuh <handschuh.stefan@googlemail.com>
|
|
|
|
;;; Copyright © 2015 Kai-Chung Yan <seamlikok@gmail.com>
|
|
|
|
;;; Copyright © 2016 Marius Bakke <mbakke@fastmail.com>
|
|
|
|
;;; Copyright © 2017 Julien Lepiller <julien@lepiller.eu>
|
2017-05-07 17:40:43 -04:00
|
|
|
;;; Copyright © 2017 Hartmut Goebel <h.goebel@crazy-compilers.com>
|
2017-09-29 09:17:03 -04:00
|
|
|
;;; Copyright © 2017 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
2018-01-17 18:54:31 -05:00
|
|
|
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
2017-04-15 12:17:27 -04:00
|
|
|
;;;
|
|
|
|
;;; 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 android)
|
|
|
|
#:use-module (guix packages)
|
2018-01-20 16:45:08 -05:00
|
|
|
#:use-module (guix download)
|
2017-04-15 12:17:27 -04:00
|
|
|
#:use-module (guix git-download)
|
|
|
|
#:use-module (guix build-system gnu)
|
2017-05-07 17:40:43 -04:00
|
|
|
#:use-module (guix build-system python)
|
2017-09-29 09:17:03 -04:00
|
|
|
#:use-module (guix build-system trivial)
|
2017-04-15 12:17:27 -04:00
|
|
|
#:use-module ((guix licenses) #:prefix license:)
|
|
|
|
#:use-module (gnu packages)
|
gnu: Move testing packages from python.scm to check.scm.
* gnu/packages/python.scm (python-behave-web-api, python2-behave-web-api,
python-mock, python2-mock, python-mock-2, python-nose, python2-nose,
python-nose2, python2-nose2, python-unittest2, python2-unittest2,
python-pytest, python2-pytest, python-pytest-3.0, python2-pytest-3.0,
python-pytest-cov, python2-pytest-cov, python-pytest-runner,
python2-pytest-runner, python-pytest-mock, python2-pytest-mock,
python-pytest-xdist, python2-pytest-xdist, python-scripttest,
python2-scripttest, python-testtools, python2-testtools, python-testscenarios,
python2-testscenarios, python-testresources, python2-testresources,
python-subunit, python2-subunit, python-fixtures, python2-fixtures,
python-testrepository, python2-testrepository, python-coverage,
python2-coverage, python-cov-core, python2-cov-core, python-testpath,
python2-testpath, python-testlib, python2-testlib, python-pytest-cache,
python2-pytest-cache, python-pytest-localserver, python-pytest-xprocess,
python-pytest-subtesthack, python2-pytest-subtesthack, python-hypothesis,
python2-hypothesis, python-lit, python2-lit, python-pytest-pep8,
python2-pytest-pep8, python-pytest-flakes, python2-pytest-flakes,
python2-coverage-test-runner, python-pylint, python2-pylint,
python-paramunittest, python2-python-paramunittest, python-pytest-warnings,
python2-pytest-warnings, python-pytest-capturelog, python2-pytest-capturelog,
python-pytest-catchlog, python2-pytest-catchlog, python-nosexcover,
python2-nosexcover, python-discover, python2-discover, behave, python-rednose,
python2-rednose, python-nose-randomly, python2-nose-randomly,
python-nose-timer, python2-nose-timer): Move from here...
* gnu/packages/check.scm: ...to here.
* gnu/packages/admin.scm,
gnu/packages/android.scm,
gnu/packages/backup.scm,
gnu/packages/bioinformatics.scm,
gnu/packages/calendar.scm,
gnu/packages/dav.scm,
gnu/packages/django.scm,
gnu/packages/freedesktop.scm,
gnu/packages/haskell.scm,
gnu/packages/image.scm,
gnu/packages/irc.scm,
gnu/packages/jrnl.scm,
gnu/packages/ldc.scm,
gnu/packages/libffi.scm,
gnu/packages/mail.scm,
gnu/packages/mpd.scm,
gnu/packages/openstack.scm,
gnu/packages/package-management.scm,
gnu/packages/password-utils.scm,
gnu/packages/python-crypto.scm,
gnu/packages/python-web.scm,
gnu/packages/rdf.scm,
gnu/packages/statistics.scm,
gnu/packages/storage.scm,
gnu/packages/time.scm,
gnu/packages/tls.scm,
gnu/packages/tor.scm,
gnu/packages/tryton.scm: Adjust accordingly.
2017-11-17 15:42:23 -05:00
|
|
|
#:use-module (gnu packages check)
|
2017-05-07 17:40:43 -04:00
|
|
|
#:use-module (gnu packages gnupg)
|
|
|
|
#:use-module (gnu packages python)
|
|
|
|
#:use-module (gnu packages ssh)
|
|
|
|
#:use-module (gnu packages version-control)
|
2018-01-20 16:45:08 -05:00
|
|
|
#:use-module (gnu packages tls)
|
|
|
|
#:use-module (gnu packages linux))
|
2017-04-15 12:17:27 -04:00
|
|
|
|
|
|
|
;; The Makefiles that we add are largely based on the Debian
|
|
|
|
;; packages. They are licensed under GPL-2 and have copyright:
|
|
|
|
;; 2012, Stefan Handschuh <handschuh.stefan@googlemail.com>
|
|
|
|
;; 2015, Kai-Chung Yan <seamlikok@gmail.com>
|
|
|
|
;; Big thanks to them for laying the groundwork.
|
|
|
|
|
|
|
|
;; The version tag is consistent between all repositories.
|
|
|
|
(define (android-platform-version) "7.1.2_r6")
|
|
|
|
|
|
|
|
(define (android-platform-system-core version)
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://android.googlesource.com/platform/system/core")
|
|
|
|
(commit (string-append "android-" version))))
|
|
|
|
(file-name (string-append "android-platform-system-core-"
|
|
|
|
version "-checkout"))
|
|
|
|
(sha256
|
|
|
|
(base32
|
|
|
|
"0xc2n7jxrf1iw9cc278pijdfjix2fkiig5ws27f6rwp40zg5mrgg"))))
|
|
|
|
|
|
|
|
(define liblog
|
|
|
|
(package
|
|
|
|
(name "liblog")
|
|
|
|
(version (android-platform-version))
|
|
|
|
(source (android-platform-system-core version))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:tests? #f ; TODO.
|
|
|
|
#:make-flags '("CC=gcc")
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'enter-source
|
|
|
|
(lambda _ (chdir "liblog") #t))
|
|
|
|
(add-after 'enter-source 'create-Makefile
|
|
|
|
(lambda _
|
|
|
|
;; No useful makefile is shipped, so we create one.
|
|
|
|
(with-output-to-file "Makefile"
|
|
|
|
(lambda _
|
|
|
|
(display
|
|
|
|
(string-append
|
|
|
|
"NAME = liblog\n"
|
|
|
|
"SOURCES = log_event_list.c log_event_write.c"
|
|
|
|
" logger_write.c config_write.c logger_name.c"
|
|
|
|
" logger_lock.c fake_log_device.c fake_writer.c"
|
|
|
|
" event_tag_map.c\n"
|
|
|
|
|
|
|
|
"CFLAGS += -fvisibility=hidden -fPIC\n"
|
|
|
|
"CPPFLAGS += -I../include -DFAKE_LOG_DEVICE=1"
|
|
|
|
;; Keep these two in sync with "liblog/Android.bp".
|
|
|
|
" -DLIBLOG_LOG_TAG=1005"
|
|
|
|
" -DSNET_EVENT_LOG_TAG=1397638484\n"
|
|
|
|
"LDFLAGS += -shared -Wl,-soname,$(NAME).so.0 -lpthread\n"
|
|
|
|
|
|
|
|
"build: $(SOURCES)\n"
|
|
|
|
" $(CC) $^ -o $(NAME).so.0 $(CFLAGS) $(CPPFLAGS) $(LDFLAGS)\n"))
|
|
|
|
#t))))
|
|
|
|
(delete 'configure)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(lib (string-append out "/lib")))
|
|
|
|
(install-file "liblog.so.0" lib)
|
|
|
|
(with-directory-excursion lib
|
|
|
|
(symlink "liblog.so.0" "liblog.so"))
|
|
|
|
#t))))))
|
|
|
|
(home-page "https://developer.android.com/")
|
|
|
|
(synopsis "Logging library from the Android platform.")
|
|
|
|
(description "@code{liblog} represents an interface to the volatile Android
|
|
|
|
Logging system for NDK (Native) applications and libraries and contain
|
|
|
|
interfaces for either writing or reading logs. The log buffers are divided up
|
|
|
|
in Main, System, Radio and Events sub-logs.")
|
|
|
|
(license license:asl2.0)))
|
|
|
|
|
|
|
|
(define libbase
|
|
|
|
(package
|
|
|
|
(name "libbase")
|
|
|
|
(version (android-platform-version))
|
|
|
|
(source (origin
|
|
|
|
(inherit (android-platform-system-core version))
|
|
|
|
(patches
|
|
|
|
(search-patches "libbase-use-own-logging.patch"
|
|
|
|
"libbase-fix-includes.patch"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:tests? #f ; TODO.
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'enter-source
|
|
|
|
(lambda _ (chdir "base") #t))
|
|
|
|
(add-after 'enter-source 'create-Makefile
|
|
|
|
(lambda _
|
|
|
|
;; No useful makefile is shipped, so we create one.
|
|
|
|
(with-output-to-file "Makefile"
|
|
|
|
(lambda _
|
|
|
|
(display
|
|
|
|
(string-append
|
|
|
|
"NAME = libbase\n"
|
|
|
|
"SOURCES = file.cpp logging.cpp parsenetaddress.cpp"
|
|
|
|
" stringprintf.cpp strings.cpp errors_unix.cpp\n"
|
|
|
|
|
|
|
|
"CXXFLAGS += -std=gnu++11 -fPIC\n"
|
|
|
|
"CPPFLAGS += -Iinclude -I../include\n"
|
|
|
|
"LDFLAGS += -shared -Wl,-soname,$(NAME).so.0"
|
|
|
|
" -L.. -llog\n"
|
|
|
|
|
|
|
|
"build: $(SOURCES)\n"
|
|
|
|
" $(CXX) $^ -o $(NAME).so.0 $(CXXFLAGS) $(CPPFLAGS)"
|
|
|
|
" $(LDFLAGS)\n"))
|
|
|
|
#t))))
|
|
|
|
(delete 'configure)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(lib (string-append out "/lib")))
|
|
|
|
(install-file "libbase.so.0" lib)
|
|
|
|
(with-directory-excursion lib
|
|
|
|
(symlink "libbase.so.0" "libbase.so"))
|
|
|
|
(copy-recursively "include" out)
|
|
|
|
#t))))))
|
|
|
|
(inputs `(("liblog" ,liblog)))
|
|
|
|
(home-page "https://developer.android.com/")
|
|
|
|
(synopsis "Android platform base library")
|
|
|
|
(description "@code{libbase} is a library in common use by the
|
|
|
|
various Android core host applications.")
|
|
|
|
(license license:asl2.0)))
|
|
|
|
|
|
|
|
(define libcutils
|
|
|
|
(package
|
|
|
|
(name "libcutils")
|
|
|
|
(version (android-platform-version))
|
|
|
|
(source (android-platform-system-core version))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:tests? #f ; TODO.
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'enter-source
|
|
|
|
(lambda _ (chdir "libcutils") #t))
|
|
|
|
(add-after 'enter-source 'create-Makefile
|
|
|
|
(lambda _
|
|
|
|
;; No useful makefile is shipped, so we create one.
|
|
|
|
(with-output-to-file "Makefile"
|
|
|
|
(lambda _
|
|
|
|
(display
|
|
|
|
(string-append
|
|
|
|
"NAME = libcutils\n"
|
|
|
|
"SOURCES = load_file.o socket_local_client_unix.o"
|
|
|
|
" socket_loopback_client_unix.o socket_network_client_unix.o"
|
|
|
|
" socket_loopback_server_unix.o socket_local_server_unix.o"
|
|
|
|
" sockets_unix.o socket_inaddr_any_server_unix.o"
|
|
|
|
" sockets.o\n"
|
|
|
|
"CC = gcc\n"
|
|
|
|
|
|
|
|
"CFLAGS += -fPIC\n"
|
|
|
|
"CXXFLAGS += -std=gnu++11 -fPIC\n"
|
|
|
|
"CPPFLAGS += -Iinclude -I../include\n"
|
|
|
|
"LDFLAGS += -shared -Wl,-soname,$(NAME).so.0\n"
|
|
|
|
|
|
|
|
"build: $(SOURCES)\n"
|
|
|
|
" $(CXX) $^ -o $(NAME).so.0 $(CXXFLAGS) $(CPPFLAGS)"
|
|
|
|
" $(LDFLAGS)\n"))
|
|
|
|
#t))))
|
|
|
|
(delete 'configure)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(lib (string-append out "/lib")))
|
|
|
|
(install-file "libcutils.so.0" lib)
|
|
|
|
(with-directory-excursion lib
|
|
|
|
(symlink "libcutils.so.0" "libcutils.so"))
|
|
|
|
#t))))))
|
|
|
|
(home-page "https://developer.android.com/")
|
|
|
|
(synopsis "Android platform c utils library")
|
|
|
|
(description "@code{libcutils} is a library in common use by the
|
|
|
|
various Android core host applications.")
|
|
|
|
(license license:asl2.0)))
|
|
|
|
|
|
|
|
(define-public adb
|
|
|
|
(package
|
|
|
|
(name "adb")
|
|
|
|
(version (android-platform-version))
|
|
|
|
(source (origin
|
|
|
|
(inherit (android-platform-system-core version))
|
|
|
|
(patches
|
|
|
|
(search-patches "libbase-use-own-logging.patch"
|
|
|
|
"libbase-fix-includes.patch"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'enter-source
|
|
|
|
(lambda _ (chdir "adb") #t))
|
|
|
|
(add-before 'build 'fix-clang
|
|
|
|
(lambda _
|
|
|
|
;; adb_client.h contains _Nonnull and _Nullable attributes, that
|
|
|
|
;; are not understood by gcc.
|
|
|
|
(substitute* "adb_client.h"
|
|
|
|
(("_Nonnull") "")
|
|
|
|
(("_Nullable") ""))
|
|
|
|
#t))
|
|
|
|
(add-before 'build 'fix-main
|
|
|
|
(lambda _
|
|
|
|
;; main.cpp used to be adb_main.cpp in the current directory
|
|
|
|
;; rather than in its own subdirectory, but it was not fixed.
|
|
|
|
;; This leads to some header files not being found anymore.
|
|
|
|
(copy-file "client/main.cpp" "adb_main.cpp")
|
|
|
|
#t))
|
|
|
|
(add-after 'enter-source 'create-Makefile
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
;; No useful makefile is shipped, so we create one.
|
|
|
|
(with-output-to-file "Makefile"
|
|
|
|
(lambda _
|
|
|
|
(display
|
|
|
|
(string-append
|
|
|
|
;; Common for all components.
|
|
|
|
"CXXFLAGS += -std=gnu++14 -fpermissive\n"
|
|
|
|
"CPPFLAGS += -I../include -I../base/include -I. -DADB_HOST=1 "
|
|
|
|
"-DADB_REVISION='\"" ,version "\"' -fPIC\n"
|
|
|
|
"LDFLAGS += -lcrypto -lpthread -lbase -lcutils -L. -ladb\n"
|
|
|
|
|
|
|
|
;; Libadb specifics.
|
|
|
|
"LIBADB_SOURCES = adb.cpp adb_auth.cpp adb_io.cpp "
|
|
|
|
"adb_listeners.cpp adb_trace.cpp adb_utils.cpp fdevent.cpp "
|
|
|
|
"sockets.cpp transport.cpp transport_local.cpp transport_usb.cpp "
|
|
|
|
"get_my_path_linux.cpp sysdeps_unix.cpp usb_linux.cpp "
|
|
|
|
"adb_auth_host.cpp diagnose_usb.cpp services.cpp "
|
|
|
|
"shell_service_protocol.cpp bugreport.cpp line_printer.cpp\n"
|
|
|
|
|
|
|
|
"LIBADB_LDFLAGS += -shared -Wl,-soname,libadb.so.0 "
|
|
|
|
"-lcrypto -lpthread -lbase\n"
|
|
|
|
|
|
|
|
;; Adb specifics.
|
|
|
|
"ADB_SOURCES = adb_main.cpp console.cpp commandline.cpp "
|
|
|
|
"adb_client.cpp file_sync_client.cpp\n"
|
|
|
|
"ADB_LDFLAGS += -Wl,-rpath=" (assoc-ref outputs "out") "/lib\n"
|
|
|
|
|
|
|
|
"build: libadb $(ADB_SOURCES)\n"
|
|
|
|
" $(CXX) $(ADB_SOURCES) -o adb $(CXXFLAGS) $(CPPFLAGS) "
|
|
|
|
"$(ADB_LDFLAGS) $(LDFLAGS)\n"
|
|
|
|
|
|
|
|
"libadb: $(LIBADB_SOURCES)\n"
|
|
|
|
" $(CXX) $^ -o libadb.so.0 $(CXXFLAGS) $(CPPFLAGS) "
|
|
|
|
"$(LIBADB_LDFLAGS)\n"
|
|
|
|
" ln -sv libadb.so.0 libadb.so\n"))
|
|
|
|
#t))))
|
|
|
|
(delete 'configure)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(lib (string-append out "/lib"))
|
|
|
|
(bin (string-append out "/bin")))
|
|
|
|
(install-file "libadb.so.0" lib)
|
|
|
|
(install-file "adb" bin)
|
|
|
|
(with-directory-excursion lib
|
|
|
|
(symlink "libadb.so.0" "libadb.so"))
|
|
|
|
#t))))
|
|
|
|
;; Test suite must be run with attached devices
|
|
|
|
#:tests? #f))
|
|
|
|
(inputs
|
|
|
|
`(("libbase" ,libbase)
|
|
|
|
("libcutils" ,libcutils)
|
|
|
|
("openssl" ,openssl)))
|
|
|
|
(home-page "https://developer.android.com/studio/command-line/adb.html")
|
|
|
|
(synopsis "Android Debug Bridge")
|
|
|
|
(description
|
|
|
|
"@command{adb} is a versatile command line tool that lets you communicate
|
|
|
|
with an emulator instance or connected Android device. It facilitates a variety
|
|
|
|
of device actions, such as installing and debugging apps, and it provides access
|
|
|
|
to a Unix shell that can run commands on the connected device or emulator.")
|
|
|
|
(license license:asl2.0)))
|
2017-05-07 17:40:43 -04:00
|
|
|
|
2018-01-20 17:07:20 -05:00
|
|
|
(define-public mkbootimg
|
|
|
|
(package
|
|
|
|
(name "mkbootimg")
|
|
|
|
(version (android-platform-version))
|
|
|
|
(source (origin
|
|
|
|
(inherit (android-platform-system-core version))))
|
|
|
|
(build-system python-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:tests? #f
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'enter-source
|
|
|
|
(lambda _ (chdir "mkbootimg") #t))
|
|
|
|
(delete 'configure)
|
|
|
|
(delete 'build)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(bin (string-append out "/bin")))
|
|
|
|
(install-file "mkbootimg" bin)
|
|
|
|
#t))))))
|
|
|
|
(home-page "https://developer.android.com/studio/command-line/adb.html")
|
|
|
|
(synopsis "Tool to create Android boot images")
|
|
|
|
(description "This package provides a tool to create Android Boot
|
|
|
|
Images.")
|
|
|
|
(license license:asl2.0)))
|
|
|
|
|
2017-09-29 09:17:03 -04:00
|
|
|
(define-public android-udev-rules
|
|
|
|
(package
|
|
|
|
(name "android-udev-rules")
|
2018-01-17 18:54:31 -05:00
|
|
|
(version "20171113")
|
2017-09-29 09:17:03 -04:00
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/M0Rf30/android-udev-rules")
|
|
|
|
(commit version)))
|
|
|
|
(file-name (string-append name "-" version "-checkout"))
|
|
|
|
(sha256
|
2018-01-17 18:54:31 -05:00
|
|
|
(base32 "11gcnk6wjc2sw05hwi4xphvx9ksmkpvsdziaczymqxkaads3f1dy"))))
|
2017-09-29 09:17:03 -04:00
|
|
|
(build-system trivial-build-system)
|
|
|
|
(native-inputs `(("source" ,source)))
|
|
|
|
(arguments
|
|
|
|
'(#:modules ((guix build utils))
|
|
|
|
#:builder
|
|
|
|
(begin
|
|
|
|
(use-modules (guix build utils))
|
|
|
|
(let ((source (assoc-ref %build-inputs "source")))
|
|
|
|
(install-file (string-append source "/51-android.rules")
|
|
|
|
(string-append %output "/lib/udev/rules.d"))))))
|
|
|
|
(home-page "https://github.com/M0Rf30/android-udev-rules")
|
|
|
|
(synopsis "udev rules for Android devices")
|
|
|
|
(description "Provides a set of udev rules to allow using Android devices
|
|
|
|
with tools such as @command{adb} and @command{fastboot} without root
|
|
|
|
privileges. This package is intended to be added as a rule to the
|
|
|
|
@code{udev-service-type} in your @code{operating-system} configuration.
|
|
|
|
Additionally, an @code{adbusers} group must be defined and your user added to
|
|
|
|
it.
|
|
|
|
|
|
|
|
@emph{Simply installing this package will not have any effect.} It is meant
|
|
|
|
to be passed to the @code{udev} service.")
|
|
|
|
(license license:gpl3+)))
|
|
|
|
|
2017-05-07 17:40:43 -04:00
|
|
|
(define-public git-repo
|
|
|
|
(package
|
|
|
|
(name "git-repo")
|
|
|
|
(version "1.12.37")
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://gerrit.googlesource.com/git-repo")
|
|
|
|
(commit (string-append "v" version))))
|
|
|
|
(file-name (string-append "git-repo-" version "-checkout"))
|
|
|
|
(sha256
|
|
|
|
(base32 "0qp7jqhblv7xblfgpcq4n18dyjdv8shz7r60c3vnjxx2fngkj2jd"))))
|
|
|
|
(build-system python-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:python ,python-2 ; code says: "Python 3 support is … experimental."
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-before 'build 'set-executable-paths
|
|
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(git (assoc-ref inputs "git"))
|
|
|
|
(gpg (assoc-ref inputs "gnupg"))
|
|
|
|
(ssh (assoc-ref inputs "ssh")))
|
|
|
|
(substitute* '("repo" "git_command.py")
|
|
|
|
(("^GIT = 'git' ")
|
|
|
|
(string-append "GIT = '" git "/bin/git' ")))
|
|
|
|
(substitute* "repo"
|
|
|
|
((" cmd = \\['gpg',")
|
|
|
|
(string-append " cmd = ['" gpg "/bin/gpg',")))
|
|
|
|
(substitute* "git_config.py"
|
|
|
|
((" command_base = \\['ssh',")
|
|
|
|
(string-append " command_base = ['" ssh "/bin/ssh',")))
|
|
|
|
#t)))
|
|
|
|
(add-before 'build 'do-not-clone-this-source
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(repo-dir (string-append out "/share/" ,name)))
|
|
|
|
(substitute* "repo"
|
|
|
|
(("^def _FindRepo\\(\\):.*")
|
|
|
|
(format #f "
|
|
|
|
def _FindRepo():
|
|
|
|
'''Look for a repo installation, starting at the current directory.'''
|
|
|
|
# Use the installed version of git-repo.
|
|
|
|
repo_main = '~a/main.py'
|
|
|
|
curdir = os.getcwd()
|
|
|
|
olddir = None
|
|
|
|
while curdir != '/' and curdir != olddir:
|
|
|
|
dot_repo = os.path.join(curdir, repodir)
|
|
|
|
if os.path.isdir(dot_repo):
|
|
|
|
return (repo_main, dot_repo)
|
|
|
|
else:
|
|
|
|
olddir = curdir
|
|
|
|
curdir = os.path.dirname(curdir)
|
|
|
|
return None, ''
|
|
|
|
|
|
|
|
# The remaining of this function is dead code. It was used to
|
|
|
|
# find a git-checked-out version in the local project.\n" repo-dir))
|
|
|
|
;; Neither clone, check out, nor verify the git repository
|
|
|
|
(("(^\\s+)_Clone\\(.*\\)") "")
|
|
|
|
(("(^\\s+)_Checkout\\(.*\\)") "")
|
|
|
|
((" rev = _Verify\\(.*\\)") " rev = None"))
|
|
|
|
#t)))
|
|
|
|
(delete 'build) ; nothing to build
|
|
|
|
(replace 'check
|
|
|
|
(lambda _
|
|
|
|
(zero? (system* "python" "-m" "nose"))))
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(bin-dir (string-append out "/bin"))
|
|
|
|
(repo-dir (string-append out "/share/" ,name)))
|
|
|
|
(mkdir-p bin-dir)
|
|
|
|
(mkdir-p repo-dir)
|
|
|
|
(copy-recursively "." repo-dir)
|
|
|
|
(delete-file-recursively (string-append repo-dir "/tests"))
|
|
|
|
(symlink (string-append repo-dir "/repo")
|
|
|
|
(string-append bin-dir "/repo"))
|
|
|
|
#t))))))
|
|
|
|
(inputs
|
|
|
|
;; TODO: Add git-remote-persistent-https once it is available in guix
|
|
|
|
`(("git" ,git)
|
|
|
|
("gnupg" ,gnupg)
|
2018-03-16 11:50:14 -04:00
|
|
|
("ssh" ,openssh)))
|
2017-05-07 17:40:43 -04:00
|
|
|
(native-inputs
|
|
|
|
`(("nose" ,python2-nose)))
|
|
|
|
(home-page "https://code.google.com/p/git-repo/")
|
|
|
|
(synopsis "Helps to manage many Git repositories.")
|
|
|
|
(description "Repo is a tool built on top of Git. Repo helps manage many
|
|
|
|
Git repositories, does the uploads to revision control systems, and automates
|
|
|
|
parts of the development workflow. Repo is not meant to replace Git, only to
|
|
|
|
make it easier to work with Git. The repo command is an executable Python
|
|
|
|
script that you can put anywhere in your path.")
|
|
|
|
(license license:asl2.0)))
|
2018-01-20 16:45:08 -05:00
|
|
|
|
|
|
|
(define-public abootimg
|
|
|
|
(package
|
|
|
|
(name "abootimg")
|
|
|
|
(version "0.6")
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method url-fetch)
|
|
|
|
(uri (string-append "http://http.debian.net/debian/pool/main/a/abootimg/"
|
|
|
|
"abootimg_" version ".orig.tar.gz"))
|
|
|
|
(sha256
|
|
|
|
(base32 "0sfc2k011l1ymv97821w89391gnqdh8pp0haz4sdcm5hx0axv2ba"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:tests? #f
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(replace 'configure
|
|
|
|
(lambda _
|
|
|
|
(setenv "CC" "gcc")
|
|
|
|
#t))
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(bin (string-append out "/bin")))
|
|
|
|
(install-file "abootimg" bin)
|
|
|
|
#t))))))
|
|
|
|
(inputs
|
|
|
|
`(("libblkid" ,util-linux)))
|
|
|
|
(home-page "https://ac100.grandou.net/abootimg")
|
|
|
|
(synopsis "Tool for manipulating Android Boot Images")
|
|
|
|
(description "This package provides a tool for manipulating old Android
|
|
|
|
Boot Images. @code{abootimg} can work directly on block devices, or, the
|
|
|
|
safest way, on a file image.")
|
|
|
|
(license license:gpl2+)))
|