site: Add build-site procedure.

* haunt/utils.scm (absolute-file-name, clean-directory): New procedures.
* haunt/site.scm (build-site): New procedure.
This commit is contained in:
David Thompson 2015-04-11 15:01:40 -04:00
parent 7c7b161885
commit 11a3e70657
2 changed files with 34 additions and 2 deletions

View File

@ -24,6 +24,10 @@
(define-module (haunt site)
#:use-module (srfi srfi-9)
#:use-module (srfi srfi-26)
#:use-module (haunt utils)
#:use-module (haunt reader)
#:use-module (haunt page)
#:export (site
site?
site-title
@ -31,7 +35,8 @@
site-build-directory
site-default-metadata
site-readers
site-builders))
site-builders
build-site))
(define-record-type <site>
(make-site title posts-directory build-directory default-metadata
@ -62,3 +67,16 @@ READERS: A list of reader objects for processing posts
BUILDERS: A list of procedures for building pages from posts"
(make-site title posts-directory build-directory
default-metadata readers builders))
(define (build-site site)
"Build SITE in the appropriate build directory."
(let ((posts (read-posts (site-posts-directory site)
(site-readers site)
(site-default-metadata site)))
(build-dir (absolute-file-name (site-build-directory site))))
(clean-directory build-dir)
(for-each (lambda (page)
(format #t "writing ~a" (page-file-name page))
(write-page page build-dir)
(format #t " ✓~%"))
(flat-map (cut <> site posts) (site-builders site)))))

View File

@ -29,7 +29,9 @@
#:use-module (srfi srfi-26)
#:export (flatten
flat-map
string-split-at))
string-split-at
absolute-file-name
clean-directory))
(define* (flatten lst #:optional depth)
"Return a list that recursively concatenates the sub-lists of LST,
@ -56,3 +58,15 @@ flattened."
(string-drop str (1+ i)))
(list str))))
(define (absolute-file-name file-name)
(if (absolute-file-name? file-name)
file-name
(string-append (getcwd) "/" file-name)))
(define (clean-directory dir)
(define (delete-other-files file-name stat flag)
(unless (string=? dir file-name)
(delete-file file-name))
#t)
(ftw dir delete-other-files))