diff options
author | David Thompson <dthompson2@worcester.edu> | 2015-04-10 23:36:36 -0400 |
---|---|---|
committer | David Thompson <dthompson2@worcester.edu> | 2015-04-10 23:37:27 -0400 |
commit | 18a0b7ce6b6149cef351242def70a8fda0e85a84 (patch) | |
tree | de784dc39e12cd5138f7a803e6f254f634706af6 | |
parent | 2a878fd9ee2d99cf3112768449e4a0c4c3e77d8b (diff) |
Add post module.
* haunt/post.scm: New file.
* Makefile.am (SOURCES): Add it.
-rw-r--r-- | Makefile.am | 1 | ||||
-rw-r--r-- | haunt/post.scm | 43 |
2 files changed, 44 insertions, 0 deletions
diff --git a/Makefile.am b/Makefile.am index 65d1d81..bf205e6 100644 --- a/Makefile.am +++ b/Makefile.am @@ -41,6 +41,7 @@ godir=$(libdir)/guile/2.0/ccache SOURCES = \ haunt/config.scm \ + haunt/post.scm \ haunt/ui.scm \ haunt/ui/serve.scm \ haunt/serve/mime-types.scm \ diff --git a/haunt/post.scm b/haunt/post.scm new file mode 100644 index 0000000..a9d03ea --- /dev/null +++ b/haunt/post.scm @@ -0,0 +1,43 @@ +;;; Haunt --- Static site generator for GNU Guile +;;; Copyright © 2015 David Thompson <davet@gnu.org> +;;; +;;; This file is part of Haunt. +;;; +;;; Haunt 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. +;;; +;;; Haunt 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 Haunt. If not, see <http://www.gnu.org/licenses/>. + +;;; Commentary: +;; +;; Post data type. +;; +;;; Code: + +(define-module (haunt post) + #:use-module (srfi srfi-9) + #:export (make-post + post? + post-file-name + post-sxml + post-metadata + post-ref)) + +(define-record-type <post> + (make-post file-name metadata sxml) + post? + (file-name post-file-name) + (metadata post-metadata) + (sxml post-sxml)) + +(define (post-ref post key) + "Return the metadata corresponding to KEY within POST." + (assq-ref (post-metadata post) key)) |