unofficial mirror of guix-patches@gnu.org 
 help / color / mirror / code / Atom feed
* [bug#33534] [PATCH] gnu: Add arcanist.
@ 2018-11-28  1:32 Robin Templeton
  2018-11-29  9:00 ` bug#33534: " Ludovic Courtès
  0 siblings, 1 reply; 4+ messages in thread
From: Robin Templeton @ 2018-11-28  1:32 UTC (permalink / raw)
  To: 33534

* gnu/packages/phabricator.scm: New file.
* gnu/local.mk (GNU_SYSTEM_MODULES): Add it.
---
 gnu/local.mk                 |   1 +
 gnu/packages/phabricator.scm | 123 +++++++++++++++++++++++++++++++++++
 2 files changed, 124 insertions(+)
 create mode 100644 gnu/packages/phabricator.scm

diff --git a/gnu/local.mk b/gnu/local.mk
index 772002c9c..23268b73b 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -348,6 +348,7 @@ GNU_SYSTEM_MODULES =				\
   %D%/packages/perl-check.scm			\
   %D%/packages/perl-web.scm			\
   %D%/packages/photo.scm			\
+  %D%/packages/phabricator.scm 			\
   %D%/packages/php.scm				\
   %D%/packages/pkg-config.scm			\
   %D%/packages/plotutils.scm			\
diff --git a/gnu/packages/phabricator.scm b/gnu/packages/phabricator.scm
new file mode 100644
index 000000000..6834373fb
--- /dev/null
+++ b/gnu/packages/phabricator.scm
@@ -0,0 +1,123 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2018 Robin Templeton <robin@igalia.com>
+;;;
+;;; 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 phabricator)
+  #:use-module (gnu packages php)
+  #:use-module (gnu packages version-control)
+  #:use-module (guix build-system gnu)
+  #:use-module (guix git-download)
+  #:use-module ((guix licenses) #:prefix license:)
+  #:use-module (guix packages))
+
+(define-public libphutil
+  (let ((commit "b29d76e1709ef018cc5edc7c03033fd9fdebc578")
+        (revision "1"))
+    (package
+      (name "libphutil")
+      (version (git-version "0.0.0" revision commit))
+      (source (origin
+                (method git-fetch)
+                (uri (git-reference
+                      (url "https://github.com/phacility/libphutil.git")
+                      (commit commit)))
+                (file-name (git-file-name name version))
+                (sha256
+                 (base32
+                  "06j84721r9r8624fmil62b5crs2qs0v6rr3cvv2zvkvwhxwrwv1l"))))
+      (build-system gnu-build-system)
+      ;; TODO: Unbundle jsonlint and porter-stemmer.
+      (arguments
+       '(#:tests? #f
+         #:phases
+         (modify-phases %standard-phases
+           (delete 'configure)
+           (delete 'build)
+           (replace 'install
+             (lambda _
+               (let ((lib (string-append %output "/lib/libphutil")))
+                 (mkdir-p lib)
+                 (copy-recursively "." lib))
+               #t)))))
+      (inputs
+       `(("php" ,php)))
+      (home-page "https://github.com/phacility/libphutil")
+      (synopsis "PHP utility library")
+      (description
+       "@code{libphutil} is a collection of utility classes and functions for
+PHP.")
+      ;; Bundled libraries are expat-licensed.
+      (license (list license:asl2.0 license:expat)))))
+
+(define-public arcanist
+  (let ((commit "45a8d22c74a62624e69f5cd6ce901c9ab2658904")
+        (revision "1"))
+    (package
+      (name "arcanist")
+      (version (git-version "0.0.0" revision commit))
+      (source (origin
+                (method git-fetch)
+                (uri (git-reference
+                      (url "https://github.com/phacility/arcanist.git")
+                      (commit commit)))
+                (file-name (git-file-name name version))
+                (sha256
+                 (base32
+                  "13vswhqy9sap6841y93j4mj71dl27vhcivcn3rzyi0cchkhg2ac9"))))
+      (build-system gnu-build-system)
+      (arguments
+       '(#:tests? #f
+         #:phases
+         (modify-phases %standard-phases
+           (delete 'configure)
+           (delete 'build)
+           (replace 'install
+             (lambda _
+               (let ((bin (string-append %output "/bin"))
+                     (lib (string-append %output "/lib/arcanist")))
+                 (mkdir-p lib)
+                 (copy-recursively "." lib)
+                 (mkdir-p bin)
+                 (symlink (string-append lib "/bin/arc")
+                          (string-append bin "/arc"))
+                 (wrap-program (string-append bin "/arc")
+                   `("ARC_PHUTIL_PATH" =
+                     (,(string-append (assoc-ref %build-inputs "libphutil")
+                                      "/lib/libphutil")))
+                   `("PATH" ":" prefix
+                     (,@(map (lambda (i)
+                               (string-append (assoc-ref %build-inputs i) "/bin"))
+                             '("git" "mercurial" "subversion"))))))
+               #t))
+           (add-before 'reset-gzip-timestamps 'make-compressed-files-writable
+             (lambda _
+               (for-each make-file-writable
+                         (find-files %output ".*\\.t?gz$"))
+               #t)))))
+      (inputs
+       `(("php" ,php)
+         ("libphutil" ,libphutil)
+         ("git" ,git)
+         ("mercurial" ,mercurial)
+         ("subversion" ,subversion)))
+      (home-page "https://github.com/phacility/arcanist")
+      (synopsis "Command-line interface for Phabricator")
+      (description
+       "Arcanist is the command-line tool for Phabricator.  It allows you to
+interact with Phabricator installs to send code for review, download patches,
+transfer files, view status, make API calls, and various other things.")
+      (license license:asl2.0))))
-- 
2.19.2

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* bug#33534: [PATCH] gnu: Add arcanist.
  2018-11-28  1:32 [bug#33534] [PATCH] gnu: Add arcanist Robin Templeton
@ 2018-11-29  9:00 ` Ludovic Courtès
  2018-11-30  2:42   ` [bug#33534] " Robin Templeton
  0 siblings, 1 reply; 4+ messages in thread
From: Ludovic Courtès @ 2018-11-29  9:00 UTC (permalink / raw)
  To: Robin Templeton; +Cc: 33534-done

[-- Attachment #1: Type: text/plain, Size: 821 bytes --]

Hello Robin,

Robin Templeton <robin@igalia.com> skribis:

> * gnu/packages/phabricator.scm: New file.
> * gnu/local.mk (GNU_SYSTEM_MODULES): Add it.

Applied with minor changes to the description (attached), mostly to give
some context to those who do not know what Phabricator is.

BTW we traditionally write one patch for each new package, but I think
it’s okay here.

> +      (home-page "https://github.com/phacility/libphutil")
> +      (synopsis "PHP utility library")
> +      (description
> +       "@code{libphutil} is a collection of utility classes and functions for
> +PHP.")
> +      ;; Bundled libraries are expat-licensed.
> +      (license (list license:asl2.0 license:expat)))))

Do you think those libraries could be unbundled?  Would it make sense?

Thank you!

Ludo’.


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: Type: text/x-patch, Size: 875 bytes --]

diff --git a/gnu/packages/phabricator.scm b/gnu/packages/phabricator.scm
index 6834373fbc..6c94a13114 100644
--- a/gnu/packages/phabricator.scm
+++ b/gnu/packages/phabricator.scm
@@ -117,7 +117,8 @@ PHP.")
       (home-page "https://github.com/phacility/arcanist")
       (synopsis "Command-line interface for Phabricator")
       (description
-       "Arcanist is the command-line tool for Phabricator.  It allows you to
-interact with Phabricator installs to send code for review, download patches,
-transfer files, view status, make API calls, and various other things.")
+       "Arcanist is the command-line tool for the Phabricator software
+development service.  It allows you to interact with Phabricator installs to
+send code for review, download patches, transfer files, view status, make API
+calls, and various other things.")
       (license license:asl2.0))))

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [bug#33534] [PATCH] gnu: Add arcanist.
  2018-11-29  9:00 ` bug#33534: " Ludovic Courtès
@ 2018-11-30  2:42   ` Robin Templeton
  2018-11-30  8:59     ` Ludovic Courtès
  0 siblings, 1 reply; 4+ messages in thread
From: Robin Templeton @ 2018-11-30  2:42 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 33534-done

ludo@gnu.org (Ludovic Courtès) writes:

> Hello Robin,
>
> Robin Templeton <robin@igalia.com> skribis:
>
>> * gnu/packages/phabricator.scm: New file.
>> * gnu/local.mk (GNU_SYSTEM_MODULES): Add it.
>
> Applied with minor changes to the description (attached), mostly to give
> some context to those who do not know what Phabricator is.

Thanks!

> BTW we traditionally write one patch for each new package, but I think
> it’s okay here.
>
>> +      (home-page "https://github.com/phacility/libphutil")
>> +      (synopsis "PHP utility library")
>> +      (description
>> +       "@code{libphutil} is a collection of utility classes and functions for
>> +PHP.")
>> +      ;; Bundled libraries are expat-licensed.
>> +      (license (list license:asl2.0 license:expat)))))
>
> Do you think those libraries could be unbundled?  Would it make sense?

Possibly, but they seem to be maintaining their own fork of at least
jsonlint, so the upstream versions may not be 100% compatible.

^ permalink raw reply	[flat|nested] 4+ messages in thread

* [bug#33534] [PATCH] gnu: Add arcanist.
  2018-11-30  2:42   ` [bug#33534] " Robin Templeton
@ 2018-11-30  8:59     ` Ludovic Courtès
  0 siblings, 0 replies; 4+ messages in thread
From: Ludovic Courtès @ 2018-11-30  8:59 UTC (permalink / raw)
  To: Robin Templeton; +Cc: 33534-done

Hello,

Robin Templeton <rtempleton@igalia.com> skribis:

> ludo@gnu.org (Ludovic Courtès) writes:

[...]

>>> +      (home-page "https://github.com/phacility/libphutil")
>>> +      (synopsis "PHP utility library")
>>> +      (description
>>> +       "@code{libphutil} is a collection of utility classes and functions for
>>> +PHP.")
>>> +      ;; Bundled libraries are expat-licensed.
>>> +      (license (list license:asl2.0 license:expat)))))
>>
>> Do you think those libraries could be unbundled?  Would it make sense?
>
> Possibly, but they seem to be maintaining their own fork of at least
> jsonlint, so the upstream versions may not be 100% compatible.

OK, maybe something to keep in mind when we add more PHP packages in the
future.

Thank you,
Ludo’.

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2018-11-30  9:00 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-11-28  1:32 [bug#33534] [PATCH] gnu: Add arcanist Robin Templeton
2018-11-29  9:00 ` bug#33534: " Ludovic Courtès
2018-11-30  2:42   ` [bug#33534] " Robin Templeton
2018-11-30  8:59     ` Ludovic Courtès

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/guix.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).