;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2019 Brant Gardner ;;; Copyright © 2019, 2020 Tobias Geerinckx-Rice ;;; Copyright © 2020 Efraim Flashner ;;; Copyright © 2023 Eric Bavier ;;; Copyright © 2024 Vitalii Koshura ;;; Copyright © 2024 Noé Lopez ;;; ;;; 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 . (define-module (gnu packages distributed) #:use-module (guix gexp) #:use-module (guix packages) #:use-module (guix utils) #:use-module (guix git-download) #:use-module (guix build-system gnu) #:use-module ((guix licenses) #:prefix license:) #:use-module (gnu packages) #:use-module (gnu packages autotools) #:use-module (gnu packages autogen) #:use-module (gnu packages base) #:use-module (gnu packages compression) #:use-module (gnu packages databases) #:use-module (gnu packages pkg-config) #:use-module (gnu packages tls) #:use-module (gnu packages curl) #:use-module (gnu packages wxwidgets) #:use-module (gnu packages gnome) #:use-module (gnu packages gtk) #:use-module (gnu packages perl) #:use-module (gnu packages sqlite) #:use-module (gnu packages python) #:use-module (gnu packages python-xyz) #:use-module (gnu packages avahi) #:use-module (gnu packages kerberos) #:use-module (gnu packages pkg-config) #:use-module (gnu packages gcc) #:use-module (gnu packages gtk) #:use-module (gnu packages popt)) (define-public boinc-client (package (name "boinc-client") (version "8.0.2") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/boinc/boinc") (commit (string-append "client_release/" (version-major+minor version) "/" version)))) (file-name (git-file-name "boinc" version)) (sha256 (base32 "1kmjxjyl32flp3k2996fvaizg5v9bxd7fin3x3ih2hbp4dvc8k3v")))) (build-system gnu-build-system) (arguments (list #:configure-flags #~(list "--disable-server"))) (inputs (list openssl curl wxwidgets gtk+ gdk-pixbuf libnotify sqlite python python-pyserial)) (native-inputs (list autoconf automake libtool pkg-config)) (synopsis "Help cutting-edge science research using your computer") (description "BOINC is a platform for high-throughput computing on a large scale (thousands or millions of computers). It can be used for volunteer computing (using consumer devices) or grid computing (using organizational resources). It supports virtualized, parallel, and GPU-based applications.") (home-page "https://boinc.berkeley.edu/") ;; BOINC is distributed as LGPL3+, with some individual modules under GPL3+. (license (list license:lgpl3+ license:gpl3+)))) (define-public boinc-server ;; XXX The server and client packages duplicate many files such as /lib. ;; TODO: consolidate them? (package (inherit boinc-client) (name "boinc-server") (arguments (list #:configure-flags #~(list "--disable-client" "--disable-manager") #:parallel-build? #f)) (inputs (list curl `(,mariadb "dev") openssl zlib)) (propagated-inputs (list perl python-wrapper)))) (define-public distcc (package (name "distcc") (version "3.4") (source (origin (method git-fetch) (uri (git-reference (url "https://github.com/distcc/distcc.git") (commit (string-append "v" version)))) (file-name (git-file-name name version)) (sha256 (base32 "0nn0wzrmm88268vay855hr8bw9im5f8kzjp7k20qav9yrckhfwab")))) (build-system gnu-build-system) (arguments (list #:tests? #f ; TODO: Tests use a hardcoded PATH called RESTRICTED_PATH #:configure-flags #~(list "--enable-rfc2553" "--with-gtk" "--with-auth"))) (native-inputs (list pkg-config autoconf automake which)) (inputs (list avahi gtk+ libiberty mit-krb5 ; for gss popt python-minimal)) (home-page "https://www.distcc.org/") (synopsis "Distributed builds for C, C++ and Objective C") (description "distcc is a program to distribute compilation of C or C++ code across several machines on a network. distcc should always generate the same results as a local compile, is simple to install and use, and is often two or more times faster than a local compile.") (license license:gpl2+)))