* [v2 0/1] Add peg-markdown with proper manpages
@ 2015-11-28 21:32 Leo Famulari
2015-11-28 21:32 ` [v2 1/1] gnu: Add peg-markdown Leo Famulari
0 siblings, 1 reply; 3+ messages in thread
From: Leo Famulari @ 2015-11-28 21:32 UTC (permalink / raw)
To: guix-devel
This revised patch provides peg-markdown, an extensible converter from
markdown to HTML, LaTeX, ODF, and groff_mm.
The revisions makes sure that the manpage is available for both `man
peg` and `man leg`, since it documents both programs.
Leo Famulari (1):
gnu: Add peg-markdown.
gnu/packages/markdown.scm | 63 +++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 63 insertions(+)
--
2.6.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* [v2 1/1] gnu: Add peg-markdown.
2015-11-28 21:32 [v2 0/1] Add peg-markdown with proper manpages Leo Famulari
@ 2015-11-28 21:32 ` Leo Famulari
2015-11-29 10:21 ` Ludovic Courtès
0 siblings, 1 reply; 3+ messages in thread
From: Leo Famulari @ 2015-11-28 21:32 UTC (permalink / raw)
To: guix-devel
* gnu/packages/markdown.scm (peg-markdown): New variable.
---
gnu/packages/markdown.scm | 63 +++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 63 insertions(+)
diff --git a/gnu/packages/markdown.scm b/gnu/packages/markdown.scm
index a20eef6..e90329a 100644
--- a/gnu/packages/markdown.scm
+++ b/gnu/packages/markdown.scm
@@ -23,8 +23,11 @@
#:use-module (guix packages)
#:use-module (guix build-system gnu)
#:use-module (guix build-system trivial)
+ #:use-module (gnu packages glib)
#:use-module (gnu packages perl)
+ #:use-module (gnu packages pkg-config)
#:use-module (gnu packages python)
+ #:use-module (gnu packages valgrind)
#:use-module (gnu packages web)
#:use-module (gnu packages zip))
@@ -98,3 +101,63 @@ you to write using an easy-to-read, easy-to-write plain text format, then
convert it to structurally valid XHTML (or HTML).")
(license (non-copyleft "file://License.text"
"See License.text in the distribution."))))
+
+(define-public peg-markdown
+ (package
+ (name "peg-markdown")
+ (version "0.4.14")
+ (source (origin
+ (method url-fetch)
+ (uri (string-append
+ "https://github.com/jgm/peg-markdown/archive/"
+ version ".tar.gz"))
+ (file-name (string-append name "-" version ".tar.gz"))
+ (sha256
+ (base32
+ "1019f6hy1njmiigz16rrdgncrxz235sfq6zi1a4i3vfgb1hca6qi"))))
+ (build-system gnu-build-system)
+ (arguments
+ `(#:test-target "test"
+ #:make-flags (list "CC=gcc")
+ #:phases (modify-phases %standard-phases
+ (delete 'configure)
+ ;; The Makefile offers a memory leak test using
+ ;; Valgrind.
+ (add-after 'check 'leak-check
+ (lambda _
+ (zero? (system* "make" "leak-check"))))
+ (replace
+ 'install
+ (lambda* (#:key outputs #:allow-other-keys)
+ ;; The Makefile does not check if the output paths exist.
+ (let* ((out (assoc-ref %outputs "out"))
+ (bin (string-append out "/bin"))
+ (doc (string-append out "/share/man/man1")))
+ (mkdir-p bin)
+ ;; The top-level Makefile does not have an install
+ ;; target, so we have to do this manually.
+ (zero?
+ (system* "make" "-C" "peg-0.1.4"
+ (string-append "PREFIX=" %output)
+ "CC=gcc" "install"))
+ ;; The Makefile does not install the manpage.
+ (install-file "peg-0.1.4/peg.1" doc)
+ ;; The manpage applies to both peg and leg.
+ (symlink
+ (string-append doc "/peg.1")
+ (string-append doc "/leg.1"))
+ #t))))))
+ (native-inputs
+ `(("pkg-config" ,pkg-config)
+ ("valgrind" ,valgrind)))
+ (inputs
+ `(("perl" ,perl)
+ ("glib" ,glib)))
+ (synopsis "Implementation of markdown in C, using a PEG grammar")
+ (description "This is an implementation of John Gruber's markdown in C. It
+uses a parsing expression grammar (PEG) to define the syntax. This should allow
+easy modification and extension. It currently supports output in HTML, LaTeX,
+ODF, or groff_mm formats. Both a library and a standalone program are
+provided.")
+ (home-page "https://github.com/jgm/peg-markdown")
+ (license (list gpl2+ expat)))) ; Dual-licensed
--
2.6.2
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [v2 1/1] gnu: Add peg-markdown.
2015-11-28 21:32 ` [v2 1/1] gnu: Add peg-markdown Leo Famulari
@ 2015-11-29 10:21 ` Ludovic Courtès
0 siblings, 0 replies; 3+ messages in thread
From: Ludovic Courtès @ 2015-11-29 10:21 UTC (permalink / raw)
To: Leo Famulari; +Cc: guix-devel
Leo Famulari <leo@famulari.name> skribis:
> * gnu/packages/markdown.scm (peg-markdown): New variable.
[...]
> + ;; The Makefile offers a memory leak test using
> + ;; Valgrind.
> + (add-after 'check 'leak-check
> + (lambda _
> + (zero? (system* "make" "leak-check"))))
The opening parenthesis can be aligned below the ‘d’ of ‘add-after’.
> + (replace
> + 'install
> + (lambda* (#:key outputs #:allow-other-keys)
Ditto, with ‘install’ moved to the previous line.
> + ;; The Makefile does not check if the output paths exist.
> + (let* ((out (assoc-ref %outputs "out"))
> + (bin (string-append out "/bin"))
> + (doc (string-append out "/share/man/man1")))
> + (mkdir-p bin)
> + ;; The top-level Makefile does not have an install
> + ;; target, so we have to do this manually.
> + (zero?
> + (system* "make" "-C" "peg-0.1.4"
> + (string-append "PREFIX=" %output)
> + "CC=gcc" "install"))
> + ;; The Makefile does not install the manpage.
> + (install-file "peg-0.1.4/peg.1" doc)
> + ;; The manpage applies to both peg and leg.
> + (symlink
> + (string-append doc "/peg.1")
> + (string-append doc "/leg.1"))
> + #t))))))
The return value of ‘zero?’ is ignored here.
To address this and clarify the code, what about making the
symlink-manpage thing a separate phase, added after ‘install’?
> + (synopsis "Implementation of markdown in C, using a PEG grammar")
Capitalize “Markdown” (?); I think it’s fine to remove “using a PEG
grammar”, which is more of an implementation detail and is explained in
the description.
> + (description "This is an implementation of John Gruber's markdown in C. It
> +uses a parsing expression grammar (PEG) to define the syntax. This should allow
Make sure lines are below 80 chars.
Could you send an updated patch?
Thanks,
Ludo’.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2015-11-29 10:21 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-28 21:32 [v2 0/1] Add peg-markdown with proper manpages Leo Famulari
2015-11-28 21:32 ` [v2 1/1] gnu: Add peg-markdown Leo Famulari
2015-11-29 10:21 ` 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).