reader: Add read-posts procedure.
* haunt/reader.scm (read-posts): New procedure.
This commit is contained in:
		@@ -27,6 +27,7 @@
 | 
				
			|||||||
  #:use-module (srfi srfi-9)
 | 
					  #:use-module (srfi srfi-9)
 | 
				
			||||||
  #:use-module (srfi srfi-11)
 | 
					  #:use-module (srfi srfi-11)
 | 
				
			||||||
  #:use-module (srfi srfi-26)
 | 
					  #:use-module (srfi srfi-26)
 | 
				
			||||||
 | 
					  #:use-module (ice-9 ftw)
 | 
				
			||||||
  #:use-module (ice-9 match)
 | 
					  #:use-module (ice-9 match)
 | 
				
			||||||
  #:use-module (ice-9 regex)
 | 
					  #:use-module (ice-9 regex)
 | 
				
			||||||
  #:use-module (ice-9 rdelim)
 | 
					  #:use-module (ice-9 rdelim)
 | 
				
			||||||
@@ -38,6 +39,7 @@
 | 
				
			|||||||
            reader-proc
 | 
					            reader-proc
 | 
				
			||||||
            reader-match?
 | 
					            reader-match?
 | 
				
			||||||
            read-post
 | 
					            read-post
 | 
				
			||||||
 | 
					            read-posts
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            make-file-extension-matcher
 | 
					            make-file-extension-matcher
 | 
				
			||||||
            sxml-reader))
 | 
					            sxml-reader))
 | 
				
			||||||
@@ -60,6 +62,25 @@ metadata with DEFAULT-METADATA."
 | 
				
			|||||||
               (append metadata default-metadata)
 | 
					               (append metadata default-metadata)
 | 
				
			||||||
               sxml)))
 | 
					               sxml)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define* (read-posts directory readers #:optional (default-metadata '()))
 | 
				
			||||||
 | 
					  "Read all of the files in DIRECTORY as post objects.  The READERS
 | 
				
			||||||
 | 
					list must contain a matching reader for every post."
 | 
				
			||||||
 | 
					  (define enter? (const #t))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  (define (leaf file-name stat memo)
 | 
				
			||||||
 | 
					    (let ((reader (find (cut reader-match? <> file-name) readers)))
 | 
				
			||||||
 | 
					      (if reader
 | 
				
			||||||
 | 
					          (cons (read-post reader file-name default-metadata) memo)
 | 
				
			||||||
 | 
					          (error "no reader available for post: " file-name))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  (define (noop file-name stat result)
 | 
				
			||||||
 | 
					    result)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  (define (err file-name stat errno result)
 | 
				
			||||||
 | 
					    (error "file processing failed with errno: " file-name errno))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  (file-system-fold enter? leaf noop noop noop err '() directory))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
;;;
 | 
					;;;
 | 
				
			||||||
;;; Simple readers
 | 
					;;; Simple readers
 | 
				
			||||||
;;;
 | 
					;;;
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user