From 2faff242ffd4faf7c8c53e4a9317d5d9c930ad09 Mon Sep 17 00:00:00 2001 From: David Thompson Date: Sun, 12 Nov 2023 12:45:23 -0500 Subject: Remove obsolete website. The official Haunt page is hosted on my blog now. --- Makefile.am | 3 +- configure.ac | 2 +- website/Makefile.am | 28 -- website/css/main.css | 254 ---------- website/css/reset.css | 427 ---------------- website/haunt.scm | 230 --------- website/images/haunt.png | Bin 8027 -> 0 bytes website/js/piwik.js | 30 -- website/manual/Assets.html | 115 ----- website/manual/Atom.html | 130 ----- website/manual/Blog.html | 145 ------ website/manual/Builders.html | 89 ---- website/manual/Building.html | 82 --- website/manual/Command_002dline-Interface.html | 87 ---- website/manual/CommonMark.html | 100 ---- website/manual/Concept-Index.html | 73 --- website/manual/Contributing.html | 73 --- website/manual/Downloading.html | 77 --- website/manual/GNU-Free-Documentation-License.html | 547 --------------------- website/manual/Installation.html | 82 --- website/manual/Introduction.html | 137 ------ website/manual/Invoking-haunt-build.html | 92 ---- website/manual/Invoking-haunt-serve.html | 107 ---- website/manual/Pages.html | 114 ----- website/manual/Posts.html | 151 ------ website/manual/Programming-Index.html | 215 -------- website/manual/Programming-Interface.html | 91 ---- website/manual/Reader.html | 179 ------- website/manual/Readers.html | 84 ---- website/manual/Requirements.html | 89 ---- website/manual/Sites.html | 176 ------- website/manual/Skribe.html | 104 ---- website/manual/Static-Assets.html | 86 ---- website/manual/Texinfo.html | 101 ---- website/manual/Tutorial.html | 169 ------- website/manual/index.html | 170 ------- website/posts/0.1-release.sxml | 41 -- website/posts/0.2-release.skr | 38 -- website/posts/0.2.1-release.md | 24 - 39 files changed, 2 insertions(+), 4740 deletions(-) delete mode 100644 website/Makefile.am delete mode 100644 website/css/main.css delete mode 100644 website/css/reset.css delete mode 100644 website/haunt.scm delete mode 100644 website/images/haunt.png delete mode 100644 website/js/piwik.js delete mode 100644 website/manual/Assets.html delete mode 100644 website/manual/Atom.html delete mode 100644 website/manual/Blog.html delete mode 100644 website/manual/Builders.html delete mode 100644 website/manual/Building.html delete mode 100644 website/manual/Command_002dline-Interface.html delete mode 100644 website/manual/CommonMark.html delete mode 100644 website/manual/Concept-Index.html delete mode 100644 website/manual/Contributing.html delete mode 100644 website/manual/Downloading.html delete mode 100644 website/manual/GNU-Free-Documentation-License.html delete mode 100644 website/manual/Installation.html delete mode 100644 website/manual/Introduction.html delete mode 100644 website/manual/Invoking-haunt-build.html delete mode 100644 website/manual/Invoking-haunt-serve.html delete mode 100644 website/manual/Pages.html delete mode 100644 website/manual/Posts.html delete mode 100644 website/manual/Programming-Index.html delete mode 100644 website/manual/Programming-Interface.html delete mode 100644 website/manual/Reader.html delete mode 100644 website/manual/Readers.html delete mode 100644 website/manual/Requirements.html delete mode 100644 website/manual/Sites.html delete mode 100644 website/manual/Skribe.html delete mode 100644 website/manual/Static-Assets.html delete mode 100644 website/manual/Texinfo.html delete mode 100644 website/manual/Tutorial.html delete mode 100644 website/manual/index.html delete mode 100644 website/posts/0.1-release.sxml delete mode 100644 website/posts/0.2-release.skr delete mode 100644 website/posts/0.2.1-release.md diff --git a/Makefile.am b/Makefile.am index 13cd01e..555d2bc 100644 --- a/Makefile.am +++ b/Makefile.am @@ -118,8 +118,7 @@ EXTRA_DIST += \ $(TESTS) SUBDIRS = \ - example \ - website + example CLEANFILES = \ $(GOBJECTS) \ diff --git a/configure.ac b/configure.ac index 1ccbb7a..d5bee60 100644 --- a/configure.ac +++ b/configure.ac @@ -6,7 +6,7 @@ AC_CONFIG_AUX_DIR([build-aux]) AM_INIT_AUTOMAKE([color-tests -Wall -Wno-portability foreign]) AM_SILENT_RULES([yes]) -AC_CONFIG_FILES([Makefile example/Makefile website/Makefile haunt/config.scm]) +AC_CONFIG_FILES([Makefile example/Makefile haunt/config.scm]) AC_CONFIG_FILES([pre-inst-env], [chmod +x pre-inst-env]) AC_CONFIG_FILES([test-env], [chmod +x test-env]) AC_CONFIG_FILES([scripts/haunt], [chmod +x scripts/haunt]) diff --git a/website/Makefile.am b/website/Makefile.am deleted file mode 100644 index a1dc031..0000000 --- a/website/Makefile.am +++ /dev/null @@ -1,28 +0,0 @@ -## Haunt --- Static site generator for GNU Guile -## Copyright © 2015 David Thompson -## -## 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 . - -dist_noinst_DATA = \ - haunt.scm \ - css/main.css \ - css/reset.css \ - images/haunt.png \ - js/piwik.js \ - posts/0.1-release.sxml - -publish: - rsync -P -rvz --delete site/ blog@dthompson.us:/var/www/haunt --cvs-exclude diff --git a/website/css/main.css b/website/css/main.css deleted file mode 100644 index 3469ba4..0000000 --- a/website/css/main.css +++ /dev/null @@ -1,254 +0,0 @@ -html { - font-size: 10px; - - -webkit-tap-highlight-color: rgba(0, 0, 0, 0); -} - -body { - font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; - font-size: 14px; - line-height: 1.42857143; - color: #333; - background-color: #fff; -} - -.container { - padding-right: 15px; - padding-left: 15px; - margin-right: auto; - margin-left: auto; -} - -@media (min-width: 768px) { - .container { - width: 750px; - } -} - -@media (min-width: 992px) { - .container { - width: 970px; - } -} - -@media (min-width: 1200px) { - .container { - width: 1170px; - } -} - -.text-center { - text-align: center; -} - -.full-width { - width: 100%; -} - -.center { - margin-left: auto; - margin-right: auto; -} - -.navbar { - padding: 0; - min-height: 40px; - margin-bottom: 20px; - background-color: #333; - border-top: 1px solid #a1a1a1; - border-bottom: 1px solid #a1a1a1; -} - -.navbar .container { - padding: 0; - position: relative; - min-height: 40px; -} - -.navbar ul { - padding: 0; - height: 100%; -} - -.navbar li { - display: inline; - text-decoration: none; - padding-right: 30px; - font-size: 20px; - height: 100%; -} - -.navbar .logo { - float: left; -} - -.navbar a { - color: #fff; - text-decoration: none; -} - -.jumbotron { - padding: 30px; - margin-bottom: 30px; - color: inherit; - background-color: #eee; - font-size: 20px; -} - -.row { - display: table; - margin-right: -15px; - margin-left: -15px; - width: 100%; -} - -.column-logo, .column-info { - position: relative; - min-height: 1px; - padding-left: 15px; - padding-right: 15px; -} - -.column-logo { - width: 40%; - float: left; -} - -.column-info { - width: 50%; - float: left; -} - -.big-logo { - display: block; - margin-left: auto; - margin-right: auto; -} - -.btn { - display: inline-block; - padding: 6px 12px; - margin-bottom: 0; - font-size: 14px; - font-weight: normal; - line-height: 1.42857143; - text-align: center; - white-space: nowrap; - vertical-align: middle; - cursor: pointer; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - background-image: none; - border: 1px solid transparent; - border-radius: 4px; - text-decoration: none; -} - -.btn:focus, -.btn:active:focus, -.btn.active:focus { - outline: thin dotted; - outline: 5px auto -webkit-focus-ring-color; - outline-offset: -2px; -} - -.btn:hover, -.btn:focus { - color: #286090; - text-decoration: none; -} - -.btn:active, -.btn.active { - background-image: none; - outline: 0; - -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125); - box-shadow: inset 0 3px 5px rgba(0, 0, 0, .125); -} - -.btn-primary { - color: #fff; - background-color: #428bca; - border-color: #357ebd; -} - -.btn-primary:hover, -.btn-primary:focus, -.btn-primary:active, -.btn-primary.active { - color: #fff; - background-color: #3071a9; - border-color: #285e8e; -} - -.btn-primary:active, -.btn-primary.active { - background-image: none; -} - -.btn-lg, -.btn-group-lg > .btn { - padding: 10px 16px; - font-size: 18px; - line-height: 1.33; - border-radius: 6px; -} - -pre, -blockquote { - border: 1px solid #999; - - page-break-inside: avoid; -} - -pre { - display: block; - padding: 9.5px; - margin: 0 0 10px; - font-size: 13px; - line-height: 1.42857143; - color: #333; - word-break: break-all; - word-wrap: break-word; - background-color: #f5f5f5; - border: 1px solid #ccc; - border-radius: 4px; -} - -th { - text-align: left; -} - -.table { - width: 100%; - max-width: 100%; - margin-bottom: 20px; -} - -.table > thead > tr > th, -.table > tbody > tr > th, -.table > tfoot > tr > th, -.table > thead > tr > td, -.table > tbody > tr > td, -.table > tfoot > tr > td { - padding: 8px; - line-height: 1.42857143; - vertical-align: top; - border-top: 1px solid #ddd; -} - -.table > thead > tr > th { - vertical-align: bottom; - border-bottom: 2px solid #ddd; -} - -.table > caption + thead > tr:first-child > th, -.table > colgroup + thead > tr:first-child > th, -.table > thead:first-child > tr:first-child > th, -.table > caption + thead > tr:first-child > td, -.table > colgroup + thead > tr:first-child > td, -.table > thead:first-child > tr:first-child > td { - border-top: 0; -} diff --git a/website/css/reset.css b/website/css/reset.css deleted file mode 100644 index 458eea1..0000000 --- a/website/css/reset.css +++ /dev/null @@ -1,427 +0,0 @@ -/*! normalize.css v3.0.2 | MIT License | git.io/normalize */ - -/** - * 1. Set default font family to sans-serif. - * 2. Prevent iOS text size adjust after orientation change, without disabling - * user zoom. - */ - -html { - font-family: sans-serif; /* 1 */ - -ms-text-size-adjust: 100%; /* 2 */ - -webkit-text-size-adjust: 100%; /* 2 */ -} - -/** - * Remove default margin. - */ - -body { - margin: 0; -} - -/* HTML5 display definitions - ========================================================================== */ - -/** - * Correct `block` display not defined for any HTML5 element in IE 8/9. - * Correct `block` display not defined for `details` or `summary` in IE 10/11 - * and Firefox. - * Correct `block` display not defined for `main` in IE 11. - */ - -article, -aside, -details, -figcaption, -figure, -footer, -header, -hgroup, -main, -menu, -nav, -section, -summary { - display: block; -} - -/** - * 1. Correct `inline-block` display not defined in IE 8/9. - * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. - */ - -audio, -canvas, -progress, -video { - display: inline-block; /* 1 */ - vertical-align: baseline; /* 2 */ -} - -/** - * Prevent modern browsers from displaying `audio` without controls. - * Remove excess height in iOS 5 devices. - */ - -audio:not([controls]) { - display: none; - height: 0; -} - -/** - * Address `[hidden]` styling not present in IE 8/9/10. - * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22. - */ - -[hidden], -template { - display: none; -} - -/* Links - ========================================================================== */ - -/** - * Remove the gray background color from active links in IE 10. - */ - -a { - background-color: transparent; -} - -/** - * Improve readability when focused and also mouse hovered in all browsers. - */ - -a:active, -a:hover { - outline: 0; -} - -/* Text-level semantics - ========================================================================== */ - -/** - * Address styling not present in IE 8/9/10/11, Safari, and Chrome. - */ - -abbr[title] { - border-bottom: 1px dotted; -} - -/** - * Address style set to `bolder` in Firefox 4+, Safari, and Chrome. - */ - -b, -strong { - font-weight: bold; -} - -/** - * Address styling not present in Safari and Chrome. - */ - -dfn { - font-style: italic; -} - -/** - * Address variable `h1` font-size and margin within `section` and `article` - * contexts in Firefox 4+, Safari, and Chrome. - */ - -h1 { - font-size: 2em; - margin: 0.67em 0; -} - -/** - * Address styling not present in IE 8/9. - */ - -mark { - background: #ff0; - color: #000; -} - -/** - * Address inconsistent and variable font size in all browsers. - */ - -small { - font-size: 80%; -} - -/** - * Prevent `sub` and `sup` affecting `line-height` in all browsers. - */ - -sub, -sup { - font-size: 75%; - line-height: 0; - position: relative; - vertical-align: baseline; -} - -sup { - top: -0.5em; -} - -sub { - bottom: -0.25em; -} - -/* Embedded content - ========================================================================== */ - -/** - * Remove border when inside `a` element in IE 8/9/10. - */ - -img { - border: 0; -} - -/** - * Correct overflow not hidden in IE 9/10/11. - */ - -svg:not(:root) { - overflow: hidden; -} - -/* Grouping content - ========================================================================== */ - -/** - * Address margin not present in IE 8/9 and Safari. - */ - -figure { - margin: 1em 40px; -} - -/** - * Address differences between Firefox and other browsers. - */ - -hr { - -moz-box-sizing: content-box; - box-sizing: content-box; - height: 0; -} - -/** - * Contain overflow in all browsers. - */ - -pre { - overflow: auto; -} - -/** - * Address odd `em`-unit font size rendering in all browsers. - */ - -code, -kbd, -pre, -samp { - font-family: monospace, monospace; - font-size: 1em; -} - -/* Forms - ========================================================================== */ - -/** - * Known limitation: by default, Chrome and Safari on OS X allow very limited - * styling of `select`, unless a `border` property is set. - */ - -/** - * 1. Correct color not being inherited. - * Known issue: affects color of disabled elements. - * 2. Correct font properties not being inherited. - * 3. Address margins set differently in Firefox 4+, Safari, and Chrome. - */ - -button, -input, -optgroup, -select, -textarea { - color: inherit; /* 1 */ - font: inherit; /* 2 */ - margin: 0; /* 3 */ -} - -/** - * Address `overflow` set to `hidden` in IE 8/9/10/11. - */ - -button { - overflow: visible; -} - -/** - * Address inconsistent `text-transform` inheritance for `button` and `select`. - * All other form control elements do not inherit `text-transform` values. - * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. - * Correct `select` style inheritance in Firefox. - */ - -button, -select { - text-transform: none; -} - -/** - * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` - * and `video` controls. - * 2. Correct inability to style clickable `input` types in iOS. - * 3. Improve usability and consistency of cursor style between image-type - * `input` and others. - */ - -button, -html input[type="button"], /* 1 */ -input[type="reset"], -input[type="submit"] { - -webkit-appearance: button; /* 2 */ - cursor: pointer; /* 3 */ -} - -/** - * Re-set default cursor for disabled elements. - */ - -button[disabled], -html input[disabled] { - cursor: default; -} - -/** - * Remove inner padding and border in Firefox 4+. - */ - -button::-moz-focus-inner, -input::-moz-focus-inner { - border: 0; - padding: 0; -} - -/** - * Address Firefox 4+ setting `line-height` on `input` using `!important` in - * the UA stylesheet. - */ - -input { - line-height: normal; -} - -/** - * It's recommended that you don't attempt to style these elements. - * Firefox's implementation doesn't respect box-sizing, padding, or width. - * - * 1. Address box sizing set to `content-box` in IE 8/9/10. - * 2. Remove excess padding in IE 8/9/10. - */ - -input[type="checkbox"], -input[type="radio"] { - box-sizing: border-box; /* 1 */ - padding: 0; /* 2 */ -} - -/** - * Fix the cursor style for Chrome's increment/decrement buttons. For certain - * `font-size` values of the `input`, it causes the cursor style of the - * decrement button to change from `default` to `text`. - */ - -input[type="number"]::-webkit-inner-spin-button, -input[type="number"]::-webkit-outer-spin-button { - height: auto; -} - -/** - * 1. Address `appearance` set to `searchfield` in Safari and Chrome. - * 2. Address `box-sizing` set to `border-box` in Safari and Chrome - * (include `-moz` to future-proof). - */ - -input[type="search"] { - -webkit-appearance: textfield; /* 1 */ - -moz-box-sizing: content-box; - -webkit-box-sizing: content-box; /* 2 */ - box-sizing: content-box; -} - -/** - * Remove inner padding and search cancel button in Safari and Chrome on OS X. - * Safari (but not Chrome) clips the cancel button when the search input has - * padding (and `textfield` appearance). - */ - -input[type="search"]::-webkit-search-cancel-button, -input[type="search"]::-webkit-search-decoration { - -webkit-appearance: none; -} - -/** - * Define consistent border, margin, and padding. - */ - -fieldset { - border: 1px solid #c0c0c0; - margin: 0 2px; - padding: 0.35em 0.625em 0.75em; -} - -/** - * 1. Correct `color` not being inherited in IE 8/9/10/11. - * 2. Remove padding so people aren't caught out if they zero out fieldsets. - */ - -legend { - border: 0; /* 1 */ - padding: 0; /* 2 */ -} - -/** - * Remove default vertical scrollbar in IE 8/9/10/11. - */ - -textarea { - overflow: auto; -} - -/** - * Don't inherit the `font-weight` (applied by a rule above). - * NOTE: the default cannot safely be changed in Chrome and Safari on OS X. - */ - -optgroup { - font-weight: bold; -} - -/* Tables - ========================================================================== */ - -/** - * Remove most spacing between table cells. - */ - -table { - border-collapse: collapse; - border-spacing: 0; -} - -td, -th { - padding: 0; -} diff --git a/website/haunt.scm b/website/haunt.scm deleted file mode 100644 index c3becb4..0000000 --- a/website/haunt.scm +++ /dev/null @@ -1,230 +0,0 @@ -;;; Haunt --- Static site generator for GNU Guile -;;; Copyright © 2016 David Thompson -;;; -;;; 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 . - -(use-modules (haunt site) - (haunt reader) - (haunt reader skribe) - (haunt reader commonmark) - (haunt asset) - (haunt page) - (haunt post) - (haunt html) - (haunt utils) - (haunt builder blog) - (haunt builder atom) - (haunt builder assets) - (srfi srfi-19) - (ice-9 rdelim) - (ice-9 match) - (web uri)) - -(define %releases - '(("0.2.1" #t) - ("0.2" #t) - ("0.1" #f))) - -(define (tarball-url version) - (string-append "http://files.dthompson.us/haunt/haunt-" - version ".tar.gz")) - -(define (tarball-signature-url version) - (string-append "http://files.dthompson.us/haunt/haunt-" - version ".tar.gz.sig")) - -(define %download-button - (match %releases - (((version _) . _) - `(a (@ (class "btn btn-primary btn-lg") - (role "button") - (href ,(tarball-url version))) - "Download Haunt " ,version)))) - -(define (stylesheet name) - `(link (@ (rel "stylesheet") - (href ,(string-append "/css/" name ".css"))))) - -(define (anchor content uri) - `(a (@ (href ,uri)) ,content)) - -(define (logo src) - `(img (@ (class "logo") (src ,(string-append "/images/" src))))) - -(define (jumbotron content) - `(div (@ (class "jumbotron")) - (div (@ (class "row")) - (div (@ (class "column-logo")) - (img (@ (class "big-logo") - (src "/images/haunt.png")))) - (div (@ (class "column-info")) ,content)))) - -(define %cc-by-sa-link - '(a (@ (href "https://creativecommons.org/licenses/by-sa/4.0/")) - "Creative Commons Attribution Share-Alike 4.0 International")) - -(define %piwik-code - '((script (@ (type "text/javascript") (src "/js/piwik.js"))) - (noscript - (p (img (@ (src "//stats.dthompson.us/piwik.php?idsite=3") - (style "border:0;") - (alt ""))))))) - -(define haunt-theme - (theme #:name "Haunt" - #:layout - (lambda (site title body) - `((doctype "html") - (head - (meta (@ (charset "utf-8"))) - (title ,(string-append title " — " (site-title site))) - ,(stylesheet "reset") - ,(stylesheet "main") - ,%piwik-code) - (body - (header (@ (class "navbar")) - (div (@ (class "container")) - (ul - (li ,(anchor "home" "/")) - (li ,(anchor "downloads" "/downloads.html")) - (li ,(anchor "docs" "/manual/index.html")) - (li ,(anchor "git" - "https://git.dthompson.us/haunt.git"))))) - (div (@ (class "container")) - ,body - (footer (@ (class "text-center")) - (p (small "Copyright © 2016 David Thompson")) - (p - (small "The text and images on this site are free -culture works available under the " ,%cc-by-sa-link " license."))))))) - #:post-template - (lambda (post) - `((h2 ,(post-ref post 'title)) - (h3 "by " ,(post-ref post 'author) - " — " ,(date->string* (post-date post))) - (div ,(post-sxml post)))) - #:collection-template - (lambda (site title posts prefix) - (define (post-uri post) - (string-append "/" (or prefix "") - (site-post-slug site post) ".html")) - - `(,(jumbotron - `((p "Haunt is a simple, functional, hackable static site -generator written in Guile Scheme that gives authors the ability to -treat websites as programs.") - ,%download-button)) - - (p "Haunt isn't your average static site generator. Its -mission is to give authors the full expressive power of Scheme to -define every aspect of their websites are generated. Haunt uses a -simple, functional build system that allows any type of web page to be -built by writing procedures that return page objects.") - (p "Haunt has no opinion about what markup language -authors should use to write posts. Just write the relevant reader -procedure and Haunt will happily work with that format. Likewise, -Haunt has no opinion about how authors structure their sites. Haunt -ships with helpful builder procedures that generate simple blogs or -Atom feeds, but authors should feel empowered to tweak them, write -replacements, or add new builders to do things that the Haunt hackers -didn't think of.") - (p "Here's what a simple Haunt configuration looks -like:") - (pre - ,(call-with-input-file "../example/haunt.scm" read-string)) - - (p "With the above saved into a file named " - (code "haunt.scm") - " and a " - (code "posts") - " directory populated with the articles to publish, -the site can be built by running " - (code "haunt build") - ". Once the site is built, running " - (code "haunt serve") - " and visiting " - (code "localhost:8080") - " in a web browser will show the results of the build -without needing to upload the generated files to a web server.") - - (h2 "News") - (ul - ,@(map (lambda (post) - `(li - (a (@ (href ,(post-uri post))) - ,(post-ref post 'title) - " — " - ,(date->string* (post-date post))))) - (posts/reverse-chronological posts))) - - (h2 "License") - (p "Haunt is " - (a (@ (href "https://www.gnu.org/philosophy/free-sw.html")) - "Free Software") - " available under the " - (a (@ (href "https://www.gnu.org/licenses/gpl.html")) - "GNU General Public License") - " version 3 or later.") - - (h2 "Contributing") - (p "Patches to fix bugs or add new functionality are -highly encouraged. In lieu of a mailing list, please send patches -to " - (code "davet") " at " (code "gnu") " dot " (code "org") - " for now.") - (p "To get the latest version of the source code, clone -the official git repository:") - (pre "git clone git://dthompson.us/haunt.git"))))) - -(define (downloads-page site posts) - (define body - `((h2 "Downloads") - (table (@ (class "table")) - (thead - (tr (th "Source") (th "GPG signature"))) - (tbody - ,(map (match-lambda - ((version signature?) - (let ((tarball-name (string-append "haunt-" version ".tar.gz"))) - `(tr - (td (a (@ (href ,(tarball-url version))) ,tarball-name)) - (td ,(if signature? - `(a (@ (href ,(tarball-signature-url version))) - ,(string-append tarball-name ".sig")) - "")))))) - %releases))))) - - (make-page "downloads.html" - (with-layout haunt-theme site "Downloads" body) - sxml->html)) - -(define %collections - `(("Home" "index.html" ,posts/reverse-chronological))) - -(site #:title "Haunt" - #:domain "dthompson.us" - #:default-metadata - '((author . "David Thompson") - (email . "davet@gnu.org")) - #:readers (list sxml-reader skribe-reader commonmark-reader) - #:builders (list (blog #:theme haunt-theme #:collections %collections) - (atom-feed) - (atom-feeds-by-tag) - downloads-page - (static-directory "images") - (static-directory "css") - (static-directory "js") - (static-directory "manual"))) diff --git a/website/images/haunt.png b/website/images/haunt.png deleted file mode 100644 index 4e18300..0000000 Binary files a/website/images/haunt.png and /dev/null differ diff --git a/website/js/piwik.js b/website/js/piwik.js deleted file mode 100644 index a092f58..0000000 --- a/website/js/piwik.js +++ /dev/null @@ -1,30 +0,0 @@ -/* - * |@licstart The following is the entire license notice for the JavaScript code in this page.| - * - * Copyright 2012 Matthieu Aubry. - * - * This program 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. - * - * This program 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 this program. If not, see http://www.gnu.org/licenses/. - * - * |@licend The above is the entire license notice for the JavaScript code in this page.| - */ -var _paq = _paq || []; -_paq.push(['trackPageView']); -_paq.push(['enableLinkTracking']); -(function() { - var u="//stats.dthompson.us/"; - _paq.push(['setTrackerUrl', u+'piwik.php']); - _paq.push(['setSiteId', 3]); - var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; - g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'piwik.js'; s.parentNode.insertBefore(g,s); -})(); diff --git a/website/manual/Assets.html b/website/manual/Assets.html deleted file mode 100644 index 166dee4..0000000 --- a/website/manual/Assets.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - -Haunt Reference Manual: Assets - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Programming Interface   [Contents][Index]

-
-
- -

5.5 Assets

- -
-
(use-modules (haunt asset))
-
- -

Assets represent files on disk that should be copied verbatim to a -site’s output directory. Common types of assets include CSS, -JavaScript, images, and fonts. -

-
-
Scheme Procedure: make-asset source target
-

Create a new asset object. The source and target -arguments are file names that are relative to a site source and target -directory, respectively (see Sites). -

- -
-
Scheme Procedure: asset? object
-

Return #t if object is an asset object. -

- -
-
Scheme Procedure: asset-source asset
-

Return the source file name for asset. -

- -
-
Scheme Procedure: asset-target asset
-

Return the target file name for asset. -

- -
-
Scheme Procedure: install-asset asset prefix
-

Install the source file of asset into the target directory -within prefix. -

- -
-
Scheme Procedure: directory-assets directory keep? dest
-

Create a list of asset objects to be stored within dest for all -files in directory that match keep?, recursively. -

- - - - - - diff --git a/website/manual/Atom.html b/website/manual/Atom.html deleted file mode 100644 index a279137..0000000 --- a/website/manual/Atom.html +++ /dev/null @@ -1,130 +0,0 @@ - - - - - -Haunt Reference Manual: Atom - - - - - - - - - - - - - - - - - - - - -
-

-Previous: , Up: Builders   [Contents][Index]

-
-
- -

5.6.3 Atom

- -
-
(use-modules (haunt builder atom))
-
- -
-
Scheme Procedure: atom-feed [#:file-name #:subtitle #:filter #:max-entries #:blog-prefix]
-

Return a builder procedure that renders a site’s posts as an Atom -feed. All arguments are optional: -

-
-
file-name:
-

The page file name. The default is feed.xml. -

-
-
subtitle
-

The feed subtitle. The default is “Recent Posts”. -

-
-
filter
-

The procedure called to manipulate the posts list before rendering. -The default is to keep all posts and sort them in reverse -chronological order. -

-
-
max-entries
-

The maximum number of posts to render in the feed. The default is 20. -

-
- -
- -
-
Scheme Procedure: atom-feeds-by-tag [#:prefix #:filter #:max-entries #:blog-prefix]
-

Return a builder procedure that renders an atom feed for every tag -used in a post. All arguments are optional: -

-
-
prefix
-

The directory in which to write the feeds. The default is -feeds/tags. -

-
-
filter
-

The procedure called to manipulate the posts list before rendering. -The default is to keep all posts and sort them in reverse -chronological order. -

-
-
max-entries
-

The maximum number of posts to render in each feed. The default is -20. -

-
-
- -
- - - - - - diff --git a/website/manual/Blog.html b/website/manual/Blog.html deleted file mode 100644 index 9e4a1f2..0000000 --- a/website/manual/Blog.html +++ /dev/null @@ -1,145 +0,0 @@ - - - - - -Haunt Reference Manual: Blog - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Builders   [Contents][Index]

-
-
- -

5.6.2 Blog

- -
-
(use-modules (haunt builder blog))
-
- -
-
Scheme Procedure: theme [#:name #:layout #:post-template #:collection-template]
-

Create a new theme named name. -

-

The procedure layout accepts three arguments: a site, a page -title string, and an SXML tree. Its purpose is to wrap the contents -of a post with the theme’s header/footer and return the complete SXML -tree for a web page. -

-

The procedure post-template accepts a single argument: a post. -Its purpose is to return an SXML tree containing the contents of the -post, applying any desired post-processing operations. The values -returned from this procedure will be wrapped in the theme’s layout. -

-

The procedure collection-template accepts four arguments: a -site, a title string, a list of posts, and a URL prefix string. Its -purpose is to return an SXML tree containing the body of the -collection page. The values returned from this procedure will be -wrapped in the theme’s layout. -

- -
-
Scheme Procedure: theme? object
-

Return #t if object is a theme object. -

- -
-
Scheme Procedure: blog [#:theme #:prefix #:collections]
-

Create a builder procedure that transforms a list of posts into pages -decorated by theme, a theme object, whose URLs start with -prefix. -

-

Additionally, this builder creates pages that aggregate previews of -many posts corresponding to what is specified in the list -collections. Each collection is a three element list in the -form (title file-name filter). -

-
-
title
-

The human readable name of the collection. -

-
-
file-name
-

The HTML file that will contain the rendered collection. -

-
-
filter
-

A procedure that accepts a list of posts as its only argument and -returns a new list of posts. The filter procedure is used to remove -and/or sort the posts into the desired form for the collection. For -example, a filter could sort posts in reverse chronological order or -select all posts that are written by a particular author. -

-
-
- -

By default, a single collection is created that lists posts in reverse -chronological order and writes to index.html. -

-

The default theme is intended only for testing purposes. -

-
- -
-
-

-Next: , Previous: , Up: Builders   [Contents][Index]

-
- - - - - diff --git a/website/manual/Builders.html b/website/manual/Builders.html deleted file mode 100644 index bcba9c1..0000000 --- a/website/manual/Builders.html +++ /dev/null @@ -1,89 +0,0 @@ - - - - - -Haunt Reference Manual: Builders - - - - - - - - - - - - - - - - - - - - -
-

-Previous: , Up: Programming Interface   [Contents][Index]

-
-
- -

5.6 Builders

- - - - - - - -

Builders are procedures that return one or more page objects -(see Pages) when applied. A builder accepts two arguments: A site -(see Sites and a list of posts (see Posts). -

-

Haunt comes with a few convenient builders to help users who want to -create a simple blog with an Atom feed. -

- - - - - diff --git a/website/manual/Building.html b/website/manual/Building.html deleted file mode 100644 index 11b1428..0000000 --- a/website/manual/Building.html +++ /dev/null @@ -1,82 +0,0 @@ - - - - - -Haunt Reference Manual: Building - - - - - - - - - - - - - - - - - - - - -
-

-Previous: , Up: Installation   [Contents][Index]

-
-
- -

2.3 Building

- -

Haunt uses the standard GNU build system, so the basic installation -procedure looks like this: -

-
-
./configure
-make
-make install
-
- - - - - - diff --git a/website/manual/Command_002dline-Interface.html b/website/manual/Command_002dline-Interface.html deleted file mode 100644 index 4b08cf8..0000000 --- a/website/manual/Command_002dline-Interface.html +++ /dev/null @@ -1,87 +0,0 @@ - - - - - -Haunt Reference Manual: Command-line Interface - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
-
- -

4 Command-line Interface

- - - - - - -

The Haunt command-line interface is composed of many subcommands. The -general syntax for all Haunt commands is: -

-
-
haunt subcommand options…
-
- - - - - - diff --git a/website/manual/CommonMark.html b/website/manual/CommonMark.html deleted file mode 100644 index 6eda562..0000000 --- a/website/manual/CommonMark.html +++ /dev/null @@ -1,100 +0,0 @@ - - - - - -Haunt Reference Manual: CommonMark - - - - - - - - - - - - - - - - - - - - -
-

-Previous: , Up: Readers   [Contents][Index]

-
-
- -

5.3.4 CommonMark

-
-
(use-modules (haunt reader commonmark))
-
- -
-
Scheme Procedure: commonmark-reader
-

A reader for posts written in CommonMark, a fully specified variant of -Markdown. Metadata is encoded as key: value pairs, one per line, -at the beginning of the file. A line with the --- sentinel marks -the end of the metadata section and the rest of the file is encoded as HTML. -

-

Example: -

-
-
title: Hello, CommonMark!
-date: 2016-08-20 12:00
-tags: markdown, commonmark
----
-
-## This is a CommonMark post
-
-CommonMark is a **strongly** defined, *highly* compatible
-specification of Markdown, learn more about CommomMark
-[here](http://commonmark.org/).
-
- -
- - - - - - diff --git a/website/manual/Concept-Index.html b/website/manual/Concept-Index.html deleted file mode 100644 index 6b382d9..0000000 --- a/website/manual/Concept-Index.html +++ /dev/null @@ -1,73 +0,0 @@ - - - - - -Haunt Reference Manual: Concept Index - - - - - - - - - - - - - - - - - - - - - -
- -

Concept Index

- - - - - - diff --git a/website/manual/Contributing.html b/website/manual/Contributing.html deleted file mode 100644 index c9bd532..0000000 --- a/website/manual/Contributing.html +++ /dev/null @@ -1,73 +0,0 @@ - - - - - -Haunt Reference Manual: Contributing - - - - - - - - - - - - - - - - - - - - - -
- -

6 Contributing

- - - - - - diff --git a/website/manual/Downloading.html b/website/manual/Downloading.html deleted file mode 100644 index b56c84e..0000000 --- a/website/manual/Downloading.html +++ /dev/null @@ -1,77 +0,0 @@ - - - - - -Haunt Reference Manual: Downloading - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Up: Installation   [Contents][Index]

-
-
- -

2.1 Downloading

- -

Official Haunt source code release tarballs can be found on the -downloads page of -Haunt’s website, along with their associated checksums. -

- - - - - diff --git a/website/manual/GNU-Free-Documentation-License.html b/website/manual/GNU-Free-Documentation-License.html deleted file mode 100644 index 5da31f2..0000000 --- a/website/manual/GNU-Free-Documentation-License.html +++ /dev/null @@ -1,547 +0,0 @@ - - - - - -Haunt Reference Manual: GNU Free Documentation License - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
-
- -

Appendix A GNU Free Documentation License

- -
Version 1.3, 3 November 2008 -
- -
-
Copyright © 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
-http://fsf.org/
-
-Everyone is permitted to copy and distribute verbatim copies
-of this license document, but changing it is not allowed.
-
- -
    -
  1. PREAMBLE - -

    The purpose of this License is to make a manual, textbook, or other -functional and useful document free in the sense of freedom: to -assure everyone the effective freedom to copy and redistribute it, -with or without modifying it, either commercially or noncommercially. -Secondarily, this License preserves for the author and publisher a way -to get credit for their work, while not being considered responsible -for modifications made by others. -

    -

    This License is a kind of “copyleft”, which means that derivative -works of the document must themselves be free in the same sense. It -complements the GNU General Public License, which is a copyleft -license designed for free software. -

    -

    We have designed this License in order to use it for manuals for free -software, because free software needs free documentation: a free -program should come with manuals providing the same freedoms that the -software does. But this License is not limited to software manuals; -it can be used for any textual work, regardless of subject matter or -whether it is published as a printed book. We recommend this License -principally for works whose purpose is instruction or reference. -

    -
  2. APPLICABILITY AND DEFINITIONS - -

    This License applies to any manual or other work, in any medium, that -contains a notice placed by the copyright holder saying it can be -distributed under the terms of this License. Such a notice grants a -world-wide, royalty-free license, unlimited in duration, to use that -work under the conditions stated herein. The “Document”, below, -refers to any such manual or work. Any member of the public is a -licensee, and is addressed as “you”. You accept the license if you -copy, modify or distribute the work in a way requiring permission -under copyright law. -

    -

    A “Modified Version” of the Document means any work containing the -Document or a portion of it, either copied verbatim, or with -modifications and/or translated into another language. -

    -

    A “Secondary Section” is a named appendix or a front-matter section -of the Document that deals exclusively with the relationship of the -publishers or authors of the Document to the Document’s overall -subject (or to related matters) and contains nothing that could fall -directly within that overall subject. (Thus, if the Document is in -part a textbook of mathematics, a Secondary Section may not explain -any mathematics.) The relationship could be a matter of historical -connection with the subject or with related matters, or of legal, -commercial, philosophical, ethical or political position regarding -them. -

    -

    The “Invariant Sections” are certain Secondary Sections whose titles -are designated, as being those of Invariant Sections, in the notice -that says that the Document is released under this License. If a -section does not fit the above definition of Secondary then it is not -allowed to be designated as Invariant. The Document may contain zero -Invariant Sections. If the Document does not identify any Invariant -Sections then there are none. -

    -

    The “Cover Texts” are certain short passages of text that are listed, -as Front-Cover Texts or Back-Cover Texts, in the notice that says that -the Document is released under this License. A Front-Cover Text may -be at most 5 words, and a Back-Cover Text may be at most 25 words. -

    -

    A “Transparent” copy of the Document means a machine-readable copy, -represented in a format whose specification is available to the -general public, that is suitable for revising the document -straightforwardly with generic text editors or (for images composed of -pixels) generic paint programs or (for drawings) some widely available -drawing editor, and that is suitable for input to text formatters or -for automatic translation to a variety of formats suitable for input -to text formatters. A copy made in an otherwise Transparent file -format whose markup, or absence of markup, has been arranged to thwart -or discourage subsequent modification by readers is not Transparent. -An image format is not Transparent if used for any substantial amount -of text. A copy that is not “Transparent” is called “Opaque”. -

    -

    Examples of suitable formats for Transparent copies include plain -ASCII without markup, Texinfo input format, LaTeX input -format, SGML or XML using a publicly available -DTD, and standard-conforming simple HTML, -PostScript or PDF designed for human modification. Examples -of transparent image formats include PNG, XCF and -JPG. Opaque formats include proprietary formats that can be -read and edited only by proprietary word processors, SGML or -XML for which the DTD and/or processing tools are -not generally available, and the machine-generated HTML, -PostScript or PDF produced by some word processors for -output purposes only. -

    -

    The “Title Page” means, for a printed book, the title page itself, -plus such following pages as are needed to hold, legibly, the material -this License requires to appear in the title page. For works in -formats which do not have any title page as such, “Title Page” means -the text near the most prominent appearance of the work’s title, -preceding the beginning of the body of the text. -

    -

    The “publisher” means any person or entity that distributes copies -of the Document to the public. -

    -

    A section “Entitled XYZ” means a named subunit of the Document whose -title either is precisely XYZ or contains XYZ in parentheses following -text that translates XYZ in another language. (Here XYZ stands for a -specific section name mentioned below, such as “Acknowledgements”, -“Dedications”, “Endorsements”, or “History”.) To “Preserve the Title” -of such a section when you modify the Document means that it remains a -section “Entitled XYZ” according to this definition. -

    -

    The Document may include Warranty Disclaimers next to the notice which -states that this License applies to the Document. These Warranty -Disclaimers are considered to be included by reference in this -License, but only as regards disclaiming warranties: any other -implication that these Warranty Disclaimers may have is void and has -no effect on the meaning of this License. -

    -
  3. VERBATIM COPYING - -

    You may copy and distribute the Document in any medium, either -commercially or noncommercially, provided that this License, the -copyright notices, and the license notice saying this License applies -to the Document are reproduced in all copies, and that you add no other -conditions whatsoever to those of this License. You may not use -technical measures to obstruct or control the reading or further -copying of the copies you make or distribute. However, you may accept -compensation in exchange for copies. If you distribute a large enough -number of copies you must also follow the conditions in section 3. -

    -

    You may also lend copies, under the same conditions stated above, and -you may publicly display copies. -

    -
  4. COPYING IN QUANTITY - -

    If you publish printed copies (or copies in media that commonly have -printed covers) of the Document, numbering more than 100, and the -Document’s license notice requires Cover Texts, you must enclose the -copies in covers that carry, clearly and legibly, all these Cover -Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on -the back cover. Both covers must also clearly and legibly identify -you as the publisher of these copies. The front cover must present -the full title with all words of the title equally prominent and -visible. You may add other material on the covers in addition. -Copying with changes limited to the covers, as long as they preserve -the title of the Document and satisfy these conditions, can be treated -as verbatim copying in other respects. -

    -

    If the required texts for either cover are too voluminous to fit -legibly, you should put the first ones listed (as many as fit -reasonably) on the actual cover, and continue the rest onto adjacent -pages. -

    -

    If you publish or distribute Opaque copies of the Document numbering -more than 100, you must either include a machine-readable Transparent -copy along with each Opaque copy, or state in or with each Opaque copy -a computer-network location from which the general network-using -public has access to download using public-standard network protocols -a complete Transparent copy of the Document, free of added material. -If you use the latter option, you must take reasonably prudent steps, -when you begin distribution of Opaque copies in quantity, to ensure -that this Transparent copy will remain thus accessible at the stated -location until at least one year after the last time you distribute an -Opaque copy (directly or through your agents or retailers) of that -edition to the public. -

    -

    It is requested, but not required, that you contact the authors of the -Document well before redistributing any large number of copies, to give -them a chance to provide you with an updated version of the Document. -

    -
  5. MODIFICATIONS - -

    You may copy and distribute a Modified Version of the Document under -the conditions of sections 2 and 3 above, provided that you release -the Modified Version under precisely this License, with the Modified -Version filling the role of the Document, thus licensing distribution -and modification of the Modified Version to whoever possesses a copy -of it. In addition, you must do these things in the Modified Version: -

    -
      -
    1. Use in the Title Page (and on the covers, if any) a title distinct -from that of the Document, and from those of previous versions -(which should, if there were any, be listed in the History section -of the Document). You may use the same title as a previous version -if the original publisher of that version gives permission. - -
    2. List on the Title Page, as authors, one or more persons or entities -responsible for authorship of the modifications in the Modified -Version, together with at least five of the principal authors of the -Document (all of its principal authors, if it has fewer than five), -unless they release you from this requirement. - -
    3. State on the Title page the name of the publisher of the -Modified Version, as the publisher. - -
    4. Preserve all the copyright notices of the Document. - -
    5. Add an appropriate copyright notice for your modifications -adjacent to the other copyright notices. - -
    6. Include, immediately after the copyright notices, a license notice -giving the public permission to use the Modified Version under the -terms of this License, in the form shown in the Addendum below. - -
    7. Preserve in that license notice the full lists of Invariant Sections -and required Cover Texts given in the Document’s license notice. - -
    8. Include an unaltered copy of this License. - -
    9. Preserve the section Entitled “History”, Preserve its Title, and add -to it an item stating at least the title, year, new authors, and -publisher of the Modified Version as given on the Title Page. If -there is no section Entitled “History” in the Document, create one -stating the title, year, authors, and publisher of the Document as -given on its Title Page, then add an item describing the Modified -Version as stated in the previous sentence. - -
    10. Preserve the network location, if any, given in the Document for -public access to a Transparent copy of the Document, and likewise -the network locations given in the Document for previous versions -it was based on. These may be placed in the “History” section. -You may omit a network location for a work that was published at -least four years before the Document itself, or if the original -publisher of the version it refers to gives permission. - -
    11. For any section Entitled “Acknowledgements” or “Dedications”, Preserve -the Title of the section, and preserve in the section all the -substance and tone of each of the contributor acknowledgements and/or -dedications given therein. - -
    12. Preserve all the Invariant Sections of the Document, -unaltered in their text and in their titles. Section numbers -or the equivalent are not considered part of the section titles. - -
    13. Delete any section Entitled “Endorsements”. Such a section -may not be included in the Modified Version. - -
    14. Do not retitle any existing section to be Entitled “Endorsements” or -to conflict in title with any Invariant Section. - -
    15. Preserve any Warranty Disclaimers. -
    - -

    If the Modified Version includes new front-matter sections or -appendices that qualify as Secondary Sections and contain no material -copied from the Document, you may at your option designate some or all -of these sections as invariant. To do this, add their titles to the -list of Invariant Sections in the Modified Version’s license notice. -These titles must be distinct from any other section titles. -

    -

    You may add a section Entitled “Endorsements”, provided it contains -nothing but endorsements of your Modified Version by various -parties—for example, statements of peer review or that the text has -been approved by an organization as the authoritative definition of a -standard. -

    -

    You may add a passage of up to five words as a Front-Cover Text, and a -passage of up to 25 words as a Back-Cover Text, to the end of the list -of Cover Texts in the Modified Version. Only one passage of -Front-Cover Text and one of Back-Cover Text may be added by (or -through arrangements made by) any one entity. If the Document already -includes a cover text for the same cover, previously added by you or -by arrangement made by the same entity you are acting on behalf of, -you may not add another; but you may replace the old one, on explicit -permission from the previous publisher that added the old one. -

    -

    The author(s) and publisher(s) of the Document do not by this License -give permission to use their names for publicity for or to assert or -imply endorsement of any Modified Version. -

    -
  6. COMBINING DOCUMENTS - -

    You may combine the Document with other documents released under this -License, under the terms defined in section 4 above for modified -versions, provided that you include in the combination all of the -Invariant Sections of all of the original documents, unmodified, and -list them all as Invariant Sections of your combined work in its -license notice, and that you preserve all their Warranty Disclaimers. -

    -

    The combined work need only contain one copy of this License, and -multiple identical Invariant Sections may be replaced with a single -copy. If there are multiple Invariant Sections with the same name but -different contents, make the title of each such section unique by -adding at the end of it, in parentheses, the name of the original -author or publisher of that section if known, or else a unique number. -Make the same adjustment to the section titles in the list of -Invariant Sections in the license notice of the combined work. -

    -

    In the combination, you must combine any sections Entitled “History” -in the various original documents, forming one section Entitled -“History”; likewise combine any sections Entitled “Acknowledgements”, -and any sections Entitled “Dedications”. You must delete all -sections Entitled “Endorsements.” -

    -
  7. COLLECTIONS OF DOCUMENTS - -

    You may make a collection consisting of the Document and other documents -released under this License, and replace the individual copies of this -License in the various documents with a single copy that is included in -the collection, provided that you follow the rules of this License for -verbatim copying of each of the documents in all other respects. -

    -

    You may extract a single document from such a collection, and distribute -it individually under this License, provided you insert a copy of this -License into the extracted document, and follow this License in all -other respects regarding verbatim copying of that document. -

    -
  8. AGGREGATION WITH INDEPENDENT WORKS - -

    A compilation of the Document or its derivatives with other separate -and independent documents or works, in or on a volume of a storage or -distribution medium, is called an “aggregate” if the copyright -resulting from the compilation is not used to limit the legal rights -of the compilation’s users beyond what the individual works permit. -When the Document is included in an aggregate, this License does not -apply to the other works in the aggregate which are not themselves -derivative works of the Document. -

    -

    If the Cover Text requirement of section 3 is applicable to these -copies of the Document, then if the Document is less than one half of -the entire aggregate, the Document’s Cover Texts may be placed on -covers that bracket the Document within the aggregate, or the -electronic equivalent of covers if the Document is in electronic form. -Otherwise they must appear on printed covers that bracket the whole -aggregate. -

    -
  9. TRANSLATION - -

    Translation is considered a kind of modification, so you may -distribute translations of the Document under the terms of section 4. -Replacing Invariant Sections with translations requires special -permission from their copyright holders, but you may include -translations of some or all Invariant Sections in addition to the -original versions of these Invariant Sections. You may include a -translation of this License, and all the license notices in the -Document, and any Warranty Disclaimers, provided that you also include -the original English version of this License and the original versions -of those notices and disclaimers. In case of a disagreement between -the translation and the original version of this License or a notice -or disclaimer, the original version will prevail. -

    -

    If a section in the Document is Entitled “Acknowledgements”, -“Dedications”, or “History”, the requirement (section 4) to Preserve -its Title (section 1) will typically require changing the actual -title. -

    -
  10. TERMINATION - -

    You may not copy, modify, sublicense, or distribute the Document -except as expressly provided under this License. Any attempt -otherwise to copy, modify, sublicense, or distribute it is void, and -will automatically terminate your rights under this License. -

    -

    However, if you cease all violation of this License, then your license -from a particular copyright holder is reinstated (a) provisionally, -unless and until the copyright holder explicitly and finally -terminates your license, and (b) permanently, if the copyright holder -fails to notify you of the violation by some reasonable means prior to -60 days after the cessation. -

    -

    Moreover, your license from a particular copyright holder is -reinstated permanently if the copyright holder notifies you of the -violation by some reasonable means, this is the first time you have -received notice of violation of this License (for any work) from that -copyright holder, and you cure the violation prior to 30 days after -your receipt of the notice. -

    -

    Termination of your rights under this section does not terminate the -licenses of parties who have received copies or rights from you under -this License. If your rights have been terminated and not permanently -reinstated, receipt of a copy of some or all of the same material does -not give you any rights to use it. -

    -
  11. FUTURE REVISIONS OF THIS LICENSE - -

    The Free Software Foundation may publish new, revised versions -of the GNU Free Documentation License from time to time. Such new -versions will be similar in spirit to the present version, but may -differ in detail to address new problems or concerns. See -http://www.gnu.org/copyleft/. -

    -

    Each version of the License is given a distinguishing version number. -If the Document specifies that a particular numbered version of this -License “or any later version” applies to it, you have the option of -following the terms and conditions either of that specified version or -of any later version that has been published (not as a draft) by the -Free Software Foundation. If the Document does not specify a version -number of this License, you may choose any version ever published (not -as a draft) by the Free Software Foundation. If the Document -specifies that a proxy can decide which future versions of this -License can be used, that proxy’s public statement of acceptance of a -version permanently authorizes you to choose that version for the -Document. -

    -
  12. RELICENSING - -

    “Massive Multiauthor Collaboration Site” (or “MMC Site”) means any -World Wide Web server that publishes copyrightable works and also -provides prominent facilities for anybody to edit those works. A -public wiki that anybody can edit is an example of such a server. A -“Massive Multiauthor Collaboration” (or “MMC”) contained in the -site means any set of copyrightable works thus published on the MMC -site. -

    -

    “CC-BY-SA” means the Creative Commons Attribution-Share Alike 3.0 -license published by Creative Commons Corporation, a not-for-profit -corporation with a principal place of business in San Francisco, -California, as well as future copyleft versions of that license -published by that same organization. -

    -

    “Incorporate” means to publish or republish a Document, in whole or -in part, as part of another Document. -

    -

    An MMC is “eligible for relicensing” if it is licensed under this -License, and if all works that were first published under this License -somewhere other than this MMC, and subsequently incorporated in whole -or in part into the MMC, (1) had no cover texts or invariant sections, -and (2) were thus incorporated prior to November 1, 2008. -

    -

    The operator of an MMC Site may republish an MMC contained in the site -under CC-BY-SA on the same site at any time before August 1, 2009, -provided the MMC is eligible for relicensing. -

    -
- - -

ADDENDUM: How to use this License for your documents

- -

To use this License in a document you have written, include a copy of -the License in the document and put the following copyright and -license notices just after the title page: -

-
-
  Copyright (C)  year  your name.
-  Permission is granted to copy, distribute and/or modify this document
-  under the terms of the GNU Free Documentation License, Version 1.3
-  or any later version published by the Free Software Foundation;
-  with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
-  Texts.  A copy of the license is included in the section entitled ``GNU
-  Free Documentation License''.
-
- -

If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts, -replace the “with…Texts.” line with this: -

-
-
    with the Invariant Sections being list their titles, with
-    the Front-Cover Texts being list, and with the Back-Cover Texts
-    being list.
-
- -

If you have Invariant Sections without Cover Texts, or some other -combination of the three, merge those two alternatives to suit the -situation. -

-

If your document contains nontrivial examples of program code, we -recommend releasing these examples in parallel under your choice of -free software license, such as the GNU General Public License, -to permit their use in free software. -

- -
-
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
- - - - - diff --git a/website/manual/Installation.html b/website/manual/Installation.html deleted file mode 100644 index 7d9ef4e..0000000 --- a/website/manual/Installation.html +++ /dev/null @@ -1,82 +0,0 @@ - - - - - -Haunt Reference Manual: Installation - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
-
- -

2 Installation

- - - - - - - - - - - - diff --git a/website/manual/Introduction.html b/website/manual/Introduction.html deleted file mode 100644 index e6f3255..0000000 --- a/website/manual/Introduction.html +++ /dev/null @@ -1,137 +0,0 @@ - - - - - -Haunt Reference Manual: Introduction - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
-
- -

1 Introduction

- -

Haunt is a hackable static site generator written in Guile Scheme. A -static site generator assists an author with generating the HTML pages -that they publish on the web. Unlike “content management systems” -such as Wordpress or Drupal, static site generators are not dynamic -web applications (complete with a relational database) that build -pages on-the-fly. Instead, web pages are built in advance, on the -author’s computer, and copied to a web server when it is time to -publish changes. The consequence of this design is that the web -server no longer needs to run a complex, potentially insecure web -application that connects to a database to retrieve data. Static -files can be served easily by any generic web server. Since there is -no web application or database server to deal with, static websites -are easier to maintain, more secure, and resistant to high web traffic -(“slashdotting.”) Furthermore, the entire website is stored in -plain text, which allows the files to be version-controlled rather -than kept in a relational database with no concept of history that -needs to be backed up regularly. -

-

At the time that Haunt was conceived, there existed literally hundreds -of other static site generators. Why add another one? Haunt -differentiates itself from most other static site generators in that -it aspires to the Emacs philosophy of “practical software freedom.” -Not only is the source code available under a Free Software license, -as most static site generators are, it is designed to be easily hacked -and extended without altering the core source code. Haunt -purposefully blurs the line between document and program, author and -programmer, by embracing the notion of data as code. A Haunt-based -website is not simply data, but a computer program. This design -strategy encourages authors to automate repetitive tasks and empowers -them to extend the software with their own ideas. -

-

To make such a system work well, a general-purpose, extensible -programming language is needed. A traditional configuration file -format simply will not do. The programming language that we feel is -best suited to this task is Scheme, a clean and elegant dialect of -Lisp. We believe that by giving authors the full expressive power of -Scheme, they will be able to produce better websites and make better -use of their time than with less programmable systems and less capable -programming languages. Authors should feel empowered to hack the -system to make it do what they want rather than what some programmer -decided they should want. And perhaps most importantly, building -websites with Haunt should be fun. -

-

Websites written in Haunt are described as purely functional programs -that accept “posts”, text documents containing arbitrary metadata, -as input and transform them into complete HTML pages using Scheme -procedures. Haunt has no opinion about what markup language authors -should use to write their posts and will happily work with any format -for which a “reader” procedure exists. Likewise, Haunt also has no -opinion about how authors should structure their sites, but has sane -defaults. Currently, there exist helpful “builder” procedures that -do common tasks such as generating a blog or Atom feed. While the -built-in features may be enough for some, they surely will not be -enough for all. Haunt’s Scheme API empowers authors to easily tweak -existing components, write replacements, or add entirely new features -that do things no else has thought to do yet. -

-

Happy haunting! -

-
-
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
- - - - - diff --git a/website/manual/Invoking-haunt-build.html b/website/manual/Invoking-haunt-build.html deleted file mode 100644 index 33fba87..0000000 --- a/website/manual/Invoking-haunt-build.html +++ /dev/null @@ -1,92 +0,0 @@ - - - - - -Haunt Reference Manual: Invoking haunt build - - - - - - - - - - - - - - - - - - - - - -
- -

4.1 Invoking haunt build

- -

The haunt build command realizes a Haunt site configuration -file by compiling web pages and copying static assets to the output -directory. For details on how to configure a Haunt site, -see Sites. -

-

Example: -

-
-
haunt build --config=haunt.scm
-
- -
-
--config=configuration-file
-
-c configuration-file
-

Load the Haunt site declaration from configuration-file. -

-
-
- - - - - - diff --git a/website/manual/Invoking-haunt-serve.html b/website/manual/Invoking-haunt-serve.html deleted file mode 100644 index 19e0b63..0000000 --- a/website/manual/Invoking-haunt-serve.html +++ /dev/null @@ -1,107 +0,0 @@ - - - - - -Haunt Reference Manual: Invoking haunt serve - - - - - - - - - - - - - - - - - - - - - -
- -

4.2 Invoking haunt serve

- -

The haunt serve command allows one to quickly view a local -preview of the generated website before publishing the finished -product to a remote web server. When haunt serve runs, a -local HTTP server is spawned. Visit the server using a web browser to -inspect the results of the build. By default, the web server listens -on port 8080, so the URL to visit would be -http://localhost:8080. -

-

While developing, it is common to rebuild the site frequently to view -the results of incremental changes. Rather than manually running -haunt build (Invoking haunt build) each time changes -are made, the --watch flag can be used to automatically rebuild -the site when a source file changes on disk. -

-
-
--config=configuration-file
-
-c configuration-file
-

Load the Haunt site declaration from configuration-file. -

-
-
--port=port
-
-p port
-
-

Listen for HTTP requests on port. -

-
-
--watch
-
-w
-
-

Automatically rebuild the site when source files change. -

-
-
- - - - - - diff --git a/website/manual/Pages.html b/website/manual/Pages.html deleted file mode 100644 index 5089622..0000000 --- a/website/manual/Pages.html +++ /dev/null @@ -1,114 +0,0 @@ - - - - - -Haunt Reference Manual: Pages - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Programming Interface   [Contents][Index]

-
-
- -

5.4 Pages

- -
-
(use-modules (haunt page))
-
- -

Page objects represent files that have yet to be written to disk. -Their contents may be any arbitrary object that their writer procedure -knows how to serialize. In practice, pages are almost always written -to disk as HTML or XML. -

-
-
Scheme Procedure: make-page file-name contents writer
-

Create a new page object. The string file-name specifies where -the page should be written to in the file system. The procedure -writer is responsible for serializing contents. -

- -
-
Scheme Procedure: page? object
-

Return #t if object is a page object. -

- -
-
Scheme Procedure: page-file-name page
-

Return the file name string for page. -

- -
-
Scheme Procedure: page-contents page
-

Return the contents of page. -

- -
-
Scheme Procedure: page-writer page
-

Return the writer procedure page. -

- -
-
Scheme Procedure: write-page page output-directory
-

Write page to output-directory. -

- - - - - - diff --git a/website/manual/Posts.html b/website/manual/Posts.html deleted file mode 100644 index 66383ed..0000000 --- a/website/manual/Posts.html +++ /dev/null @@ -1,151 +0,0 @@ - - - - - -Haunt Reference Manual: Posts - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Programming Interface   [Contents][Index]

-
-
- -

5.2 Posts

- -
-
(use-modules (haunt post))
-
- -

Posts represent the articles that are kept in a site’s post directory -and written in a markup format that Haunt can -understand. see Readers) for how files on disk can be transformed -into posts. -

-
-
Scheme Procedure: make-post file-name metadata sxml
-

Create a new post object that represents the contents of the file -file-name. The body of the post, sxml, is represented as -an SXML tree (see SXML in GNU Guile Reference Manual) -and the metadata is an association list (see Association Lists in GNU Guile Reference Manual) of arbitrary -key/value pairs. -

- -
-
Scheme Procedure: post? object
-

Return #t if object is a post. -

- -
-
Scheme Procedure: post-file-name post
-

Return the file name for post. -

- -
-
Scheme Procedure: post-metadata post
-

Return the metadata association list for post. -

- -
-
Scheme Procedure: post-sxml post
-

Return the SXML tree for post. -

- -
-
Scheme Procedure: post-ref post key
-

Return the metadata value corresponding to key within -post. -

- -
-
Scheme Procedure: post-slug post
-

Transform the title of post into a URL slug suitable for the -file name of a web page. -

- -
-
Scheme Variable: %default-date
-

The default date of a post when no other date is specified in the -metadata association list. -

- -
-
Scheme Procedure: post-date post
-

Return the date for post, or %default-date if no date is -specified. -

- -
-
Scheme Procedure: posts/reverse-chronological posts
-

Sort posts, a list of posts, in reverse chronological order. -

- -
-
Scheme Procedure: posts/group-by-tag posts
-

Create an association list of tags mapped to the posts in the list -posts that used them. -

- -
-
-

-Next: , Previous: , Up: Programming Interface   [Contents][Index]

-
- - - - - diff --git a/website/manual/Programming-Index.html b/website/manual/Programming-Index.html deleted file mode 100644 index dc682a8..0000000 --- a/website/manual/Programming-Index.html +++ /dev/null @@ -1,215 +0,0 @@ - - - - - -Haunt Reference Manual: Programming Index - - - - - - - - - - - - - - - - - - - -
-

-Previous: , Up: Top   [Contents][Index]

-
-
- -

Programming Index

-
Jump to:   % -   -
-A -   -B -   -C -   -D -   -H -   -I -   -M -   -P -   -R -   -S -   -T -   -W -   -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Index Entry  Section

%
%default-date: Posts

A
asset-source: Assets
asset-target: Assets
asset?: Assets
atom-feed: Atom
atom-feeds-by-tag: Atom

B
blog: Blog

C
commonmark-reader: CommonMark

D
directory-assets: Assets

H
html-reader: Reader

I
install-asset: Assets

M
make-asset: Assets
make-file-extension-matcher: Reader
make-page: Pages
make-post: Posts
make-reader: Reader

P
page-contents: Pages
page-file-name: Pages
page-writer: Pages
page?: Pages
post-date: Posts
post-file-name: Posts
post-metadata: Posts
post-ref: Posts
post-slug: Posts
post-sxml: Posts
post?: Posts
posts/group-by-tag: Posts
posts/reverse-chronological: Posts

R
read-post: Reader
read-posts: Reader
reader-match?: Reader
reader-matcher: Reader
reader-proc: Reader
reader?: Reader

S
site: Sites
site-build-directory: Sites
site-builders: Sites
site-domain: Sites
site-file-filter: Sites
site-make-slug: Sites
site-posts-directory: Sites
site-readers: Sites
site-title: Sites
site?: Sites
skribe-reader: Skribe
static-directory: Static Assets
sxml-reader: Reader

T
texinfo-reader: Texinfo
theme: Blog
theme?: Blog

W
write-page: Pages

-
Jump to:   % -   -
-A -   -B -   -C -   -D -   -H -   -I -   -M -   -P -   -R -   -S -   -T -   -W -   -
- -
-
-

-Previous: , Up: Top   [Contents][Index]

-
- - - - - diff --git a/website/manual/Programming-Interface.html b/website/manual/Programming-Interface.html deleted file mode 100644 index 7739aaa..0000000 --- a/website/manual/Programming-Interface.html +++ /dev/null @@ -1,91 +0,0 @@ - - - - - -Haunt Reference Manual: Programming Interface - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
-
- -

5 Programming Interface

- - - - - - - - - - -

Haunt is a fully-programmable system composed of several Guile Scheme -modules. This section documents the public API. -

- - - - - diff --git a/website/manual/Reader.html b/website/manual/Reader.html deleted file mode 100644 index a25ba11..0000000 --- a/website/manual/Reader.html +++ /dev/null @@ -1,179 +0,0 @@ - - - - - -Haunt Reference Manual: Reader - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Up: Readers   [Contents][Index]

-
-
- -

5.3.1 Reader

-
-
(use-modules (haunt reader))
-
- -

The purpose of a reader is to translate the markup within a post file -into an SXML tree representing the HTML structure and associate some -metadata with it. -

-
-
Scheme Procedure: make-reader matcher proc
-

Create a new reader. The reader is to be activated when -matcher, a procedure that accepts a file name as its only -argument, returns #t. When a post file matches, the procedure -proc, which also accepts a file name as its only argument, reads -the contents and returns a post object (see Posts). -

- -
-
Scheme Procedure: reader? object
-

Return #t if object is a reader. -

- -
-
Scheme Procedure: reader-matcher reader
-

Return the match procedure for reader. -

- -
-
Scheme Procedure: reader-proc reader
-

Return the read procedure for reader. -

- -
-
Scheme Procedure: reader-match? reader file-name
-

Return #t if file-name is a file supported by -reader. -

- -
-
Scheme Procedure: read-post reader file-name [default-metadata]
-

Read a post object from file-name using reader, merging -its metadata with default-metadata, or the empty list if not -specified. -

- -
-
Scheme Procedure: read-posts directory keep? readers [default-metadata]
-

Read all of the files in directory that match keep? as -post objects. The readers list must contain a matching reader -for every post. -

- -
-
Scheme Procedure: make-file-extension-matcher ext
-

Create a procedure that returns #t when a file name ends with -“.ext”. -

- -
-
Scheme Procedure: sxml-reader
-

A basic reader for posts written as Scheme code that evaluates to an -an association list. The special key content contains the post -body as an SXML tree. -

-

Example: -

-
-
(use-modules (haunt utils))
-
-`((title . "Hello, world!")
-  (date . ,(string->date* "2015-04-10 23:00"))
-  (tags "foo" "bar")
-  (summary . "Just a test")
-  (content
-   ((h2 "Hello!")
-    (p "This is Haunt.  A static site generator for GNU Guile."))))
-
- -
- -
-
Scheme Procedure: html-reader
-

A basic reader for posts written in plain ol’ HTML. Metadata is -encoded as the key: value pairs, one per line, at the beginning -of the file. A line with the --- sentinel marks the end of the -metadata section and the rest of the file is encoded as HTML. -

-

Example: -

-
-
title: A Foo Walks Into a Bar
-date: 2015-04-11 20:00
-tags: bar
----
-<p>
-  This is an example using raw HTML, because Guile doesn't have a
-  Markdown parser.
-</p>
-
- -
- -
-
-

-Next: , Up: Readers   [Contents][Index]

-
- - - - - diff --git a/website/manual/Readers.html b/website/manual/Readers.html deleted file mode 100644 index d120a38..0000000 --- a/website/manual/Readers.html +++ /dev/null @@ -1,84 +0,0 @@ - - - - - -Haunt Reference Manual: Readers - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Programming Interface   [Contents][Index]

-
-
- -

5.3 Readers

- - - - - - - - - - - - - diff --git a/website/manual/Requirements.html b/website/manual/Requirements.html deleted file mode 100644 index 501d7b5..0000000 --- a/website/manual/Requirements.html +++ /dev/null @@ -1,89 +0,0 @@ - - - - - -Haunt Reference Manual: Requirements - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Installation   [Contents][Index]

-
-
- -

2.2 Requirements

- -

Haunt depends on the following packages: -

- - -

The following dependencies are optional: -

- - - - - - - diff --git a/website/manual/Sites.html b/website/manual/Sites.html deleted file mode 100644 index 2b38905..0000000 --- a/website/manual/Sites.html +++ /dev/null @@ -1,176 +0,0 @@ - - - - - -Haunt Reference Manual: Sites - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Up: Programming Interface   [Contents][Index]

-
-
- -

5.1 Sites

- -
-
(use-modules (haunt site))
-
- -

A site object defines all of the properties for a Haunt website: The -site name, domain name, where blog posts are found, what post formats -are understood, which procedures are used to build the site, where the -output files are written to, etc. -

-
-
Scheme Procedure: site [#:title "This Place is Haunted"] [#:domain "example.com"] [#:posts-directory "posts"] [#:file-filter default-file-filter] [#:build-directory "site"] [#:default-metadata '()] [#:make-slug post-slug] [#:readers '()] [#:builders '()]
-

Create a new site object. All arguments are optional: -

-
-
title
-

The name of the site. -

-
-
posts-directory
-

The directory where posts are found. -

-
-
file-filter
-

A predicate procedure that returns #f when a post file should -be ignored, and #t otherwise. Emacs temporary files are -ignored by default. -

-
-
build-directory
-

The directory that generated pages are stored in. -

-
-
default-metadata
-

An alist of arbitrary default metadata for posts whose keys are -symbols. -

-
-
make-slug
-

A procedure generating a file name slug from a post. -

-
-
readers
-

A list of reader objects for processing posts. -

-
-
builders
-

A list of procedures for building pages from posts. -

-
-
- -
- -
-
Scheme Procedure: site? obj
-

Return #t if obj is a site object. -

- -
-
Scheme Procedure: site-title site
-

Return the title of site. -

- -
-
Scheme Procedure: site-domain site
-

Return the domain of site. -

- -
-
Scheme Procedure: site-posts-directory site
-

Return the posts directory for site. -

- -
-
Scheme Procedure: site-file-filter site
-

Return the file filter procedure for site. -

- -
-
Scheme Procedure: site-build-directory site
-

Return the build directory of site. -

- -
-
Scheme Procedure: site-make-slug site
-

Return the slug constructor for site. -

- -
-
Scheme Procedure: site-readers site
-

Return the list of reader procedures for site. -

- -
-
Scheme Procedure: site-builders site
-

Return the list of builder procedures for site. -

- -
-
-

-Next: , Up: Programming Interface   [Contents][Index]

-
- - - - - diff --git a/website/manual/Skribe.html b/website/manual/Skribe.html deleted file mode 100644 index f0cad2b..0000000 --- a/website/manual/Skribe.html +++ /dev/null @@ -1,104 +0,0 @@ - - - - - -Haunt Reference Manual: Skribe - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Readers   [Contents][Index]

-
-
- -

5.3.3 Skribe

-
-
(use-modules (haunt reader skribe))
-
- -
-
Scheme Procedure: skribe-reader
-

A reader for posts written in Skribe, a markup language with the full power -of Scheme. Skribe posts are created with the post expression with -metadata encoded as :key expression pairs at the beginning of the -post expression. After the metadata section, the rest of the post -expression is encoded as HTML. -

-

Example: -

-
-
(post
- :title "Hello, Skribe!"
- :date (make-date* 2016 08 20 12 00)
- :tags '("skribe" "foo" "baz")
-
- (h2 [This is a Skribe post])
-
- (p [Skribe is a ,(em [really]) cool document authoring format
-     that provides all the power of Scheme whilst giving the user
-     a means to write literal text without stuffing it into a
-     string literal. If this sort of thing suits you, be sure to
-     check out ,(anchor "Skribilo"
-                        "http://www.nongnu.org/skribilo/"), too.]))
-
- -
- - - - - - diff --git a/website/manual/Static-Assets.html b/website/manual/Static-Assets.html deleted file mode 100644 index 6301194..0000000 --- a/website/manual/Static-Assets.html +++ /dev/null @@ -1,86 +0,0 @@ - - - - - -Haunt Reference Manual: Static Assets - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Up: Builders   [Contents][Index]

-
-
- -

5.6.1 Static Assets

- -
-
(use-modules (haunt builder assets))
-
- -
-
Scheme Procedure: static-directory directory [dest directory]
-
-

Create a builder procedure that recursively copies all of the files in -directory, a file names relative to a site’s source directory, -and copies them into dest, a prefix relative to a site’s target -output directory. By default, dest is directory. -

- - - - - - diff --git a/website/manual/Texinfo.html b/website/manual/Texinfo.html deleted file mode 100644 index 9d36050..0000000 --- a/website/manual/Texinfo.html +++ /dev/null @@ -1,101 +0,0 @@ - - - - - -Haunt Reference Manual: Texinfo - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Readers   [Contents][Index]

-
-
- -

5.3.2 Texinfo

-
-
(use-modules (haunt reader texinfo))
-
- -
-
Scheme Procedure: texinfo-reader
-

A reader for posts written in texinfo, the official documentation format -of the GNU project. Metadata is encoded as key: value pairs, one -per line, at the beginning of the file. A line with the --- -sentinel marks the end of the metadata section and the rest of the file -is encoded as HTML. -

-

Example: -

-
-
title: Hello, Texi!
-date: 2016-08-20 12:00
-tags: texinfo, foo
----
-
-@emph{Texinfo} is the official documentation format of the
-@url{http://www.gnu.org/, GNU project}.  It was invented by Richard
-Stallman and Bob Chassell many years ago, loosely based on Brian
-Reid's Scribe and other formatting languages of the time.  It is
-used by many non-GNU projects as well.
-
- -
- - - - - - diff --git a/website/manual/Tutorial.html b/website/manual/Tutorial.html deleted file mode 100644 index 116a77f..0000000 --- a/website/manual/Tutorial.html +++ /dev/null @@ -1,169 +0,0 @@ - - - - - -Haunt Reference Manual: Tutorial - - - - - - - - - - - - - - - - - - - - -
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
-
- -

3 Tutorial

- -

The goal of this tutorial is to quickly create a barebones blog with -Haunt in order to demonstrate the basic workflow and key concepts. -

-

First, create a directory for the new site: -

-
-
mkdir haunt-tutorial
-cd haunt-tutorial
-
- -

Next, create the site configuration file haunt.scm. This is -where all of the code for building the website will go. -

-

Here’s what a simple Haunt configuration looks like: -

-
-
(use-modules (haunt asset)
-             (haunt site)
-             (haunt builder blog)
-             (haunt builder atom)
-             (haunt reader skribe))
-
-(site #:title "My First Haunt Site"
-      #:domain "example.com"
-      #:default-metadata
-      '((author . "Eva Luator")
-        (email  . "eva@example.com"))
-      #:readers (list skribe-reader)
-      #:builders (list (blog)
-                       (atom-feed)
-                       (atom-feeds-by-tag)))
-
- -

Haunt represents the full configuration of the website using the -site procedure. Site objects specify things like the site -title, the default metadata to use for posts, which markup formats are -supported, and which builders are used to generate web pages. -

-

With the above code saved into the haunt.scm file, the next -step is to create a posts directory and populate it with -articles to publish. Put the text below into a file named -posts/hello.skr: -

-
-
(post
- :title "Hello, World!"
- :date (make-date* 2015 10 15)
- :tags '("hello")
-
- (h1 [Hello, World!])
-
- (p [This is my very first Skribe document!]))
-
- -

This is a -Skribe document. Skribe is one of the built-in languages that Haunt -knows how to work with. It’s basically Scheme, but with support for -writing literal text without quoting it all by enclosing it in square -brackets. The code above defines a post named “Hello, World!” with -a publishing date of 2015-10-15, whose contents are just a single -heading and a paragraph. -

-

To build the site, run haunt build to compile all of the -HTML pages. To view the results, run haunt serve and visit -http://localhost:8080 in a web browser. haunt serve -is a handy utility that serves the contents of the website using -Guile’s built-in HTTP server. Since the blog builder was specified in -haunt.scm, the default index page is a simple listing of all -posts, which for now is a single post. Clicking on the post title -will display a page with only that post’s contents. -

-

In addition to the basic blog builder, the haunt.scm file -specifies two additional builders for Atom feeds. The -atom-feed builder creates a feed of all posts located at -http://localhost:8080/feed.xml. The atom-feeds-by-tag -builder creates one feed for each unique tag specified in the post -metadata. There’s only one tag right now, “hello”, and its feed is -located at http://localhost/feeds/tags/hello.xml. -

-

Tweaking a post, rebuilding the site, and viewing the results in a web -browser is the typical Haunt workflow. However, having to run -haunt build every after each edit is tedious. To address -this, run haunt serve --watch. The Haunt web server, in -addition to serving web pages, will now watch for changes to important -files and automatically rebuild the site when they are edited. This -streamlines the workflow into an edit, save, view loop. -

-

Now that we’ve introduced the basic utilities and concepts, continue -reading this manual to learn more about Haunt’s command-line and -programming interfaces. -

-
-
-

-Next: , Previous: , Up: Top   [Contents][Index]

-
- - - - - diff --git a/website/manual/index.html b/website/manual/index.html deleted file mode 100644 index 5bedd0a..0000000 --- a/website/manual/index.html +++ /dev/null @@ -1,170 +0,0 @@ - - - - - -Haunt Reference Manual: Top - - - - - - - - - - - - - - - - - - -

Haunt Reference Manual

- - - - - - -

Table of Contents

- - - - - -
-

-Next: , Up: (dir)   [Contents][Index]

-
-
- -

Haunt

- -

This document describes Haunt version 0.2.1, an extensible, -functional static site generator. -

- - - - - - - - - - - - - - - -
-
-

-Next: , Up: (dir)   [Contents][Index]

-
- - - - - diff --git a/website/posts/0.1-release.sxml b/website/posts/0.1-release.sxml deleted file mode 100644 index 17d18ca..0000000 --- a/website/posts/0.1-release.sxml +++ /dev/null @@ -1,41 +0,0 @@ -;;; -*- scheme -*- - -(use-modules (haunt utils)) - -`((title . "Introducing Haunt") - (date . ,(string->date* "2015-08-08 10:00")) - (tags "news" "releases") - (summary . "Haunt 0.1 released") - (content - ((p "I am pleased to announce the first alpha release of Haunt, yet -another static site generator. Does the world really need another one -of those? No, but Haunt is special because it is written in Guile -Scheme, a clean and elegant Lisp dialect, which allows users to -compose their websites using functional programming techniques. Using -a general-purpose, extensible programming language to build websites -allows Haunt users to view their website as not just mere data, but a -program. Haunt empowers the user to build the abstractions they need -to make a great static website without getting in the way.") - (p "At its core, Haunt is a very simple program. To build your -site, Haunt takes your posts and static assets as input, passes them -to a series of user-defined building procedures that return one or -more pages, and outputs all of the generated pages to the file system. -That's all there is to it. All of the \"good stuff\" is implemented -in the builder procedures. Haunt 0.1 comes with simple blog and Atom -feed generators.") - (p "Naturally, this website is built with Haunt. You can see its -complete source code in the " - (code "website") " directory in Haunt's " - (a (@ (href "https://git.dthompson.us/haunt.git/tree/HEAD:/website")) - "official git repository") - ".") - (p "The Haunt 0.1 release tarball URL can be found on the " - (a (@ (href "/downloads.html")) "downloads page") - ".") - (p "Haunt is built to be as hackable as possible, and patches to -improve it are very much welcome. In particular, new post readers for -common formats such as org-mode and Markdown are desired, along with a -more robust blog builder and theme engine. In lieu of a mailing list, -patches may be sent to " - (code "davet") " at " (code "gnu.org") ".") - (p "Happy haunting!")))) diff --git a/website/posts/0.2-release.skr b/website/posts/0.2-release.skr deleted file mode 100644 index d18ff8b..0000000 --- a/website/posts/0.2-release.skr +++ /dev/null @@ -1,38 +0,0 @@ -(post - :title "Haunt 0.2 released" - :date (make-date* 2016 04 24) - :tags '("release") - :summary "Haunt 0.2 released" - - (p [I am pleased to announce the release of Haunt version 0.2. This -release features new readers for the ] - (anchor "Texinfo" "http://www.gnu.org/software/texinfo/") - [ and ] (anchor "Skribe" "http://www.nongnu.org/skribilo/") - [ markup formats, an Info manual, small improvements to the Atom -and blog builders, and bug fixes.]) - - (p [New reader modules:] - (ul (li (code [(haunt reader skribe)])) - (li (code [(haunt reader texinfo)])))) - - (p [Bug fixes:] - (ul (li (anchor "builder: atom: Allow atom feeds to correctly set the blog prefix." - "https://git.dthompson.us/haunt.git/commit/ed1602dc36444bcf1023926854a2cb01b5199e7e")) - (li (anchor "build: Allow building with Guile 2.2." - "https://git.dthompson.us/haunt.git/commit/5373877f989689209616109b13fd471b2d093b5f")) - (li (anchor "post: Allow dashes in slugs." - "https://git.dthompson.us/haunt.git/commit/a37c3cd58525be76705ea930551f3935a232790e")) - (li (anchor "serve: Catch exceptions when rebuilding site." - "https://git.dthompson.us/haunt.git/commit/0d67128c3da6413546015fa9092a0017f50d46b9")))) - - (p [A special thank you to Christopher Webber and Mathieu Lirzin for -contributing to this release!]) - - (p [Source tarball: ] - (anchor "haunt-0.2.tar.gz" - "https://files.dthompson.us/haunt/haunt-0.2.tar.gz")) - (p [GPG signature: ] - (anchor "haunt-0.2.tar.gz.sig" - "https://files.dthompson.us/haunt/haunt-0.2.tar.gz.sig")) - - (p [Happy haunting!])) diff --git a/website/posts/0.2.1-release.md b/website/posts/0.2.1-release.md deleted file mode 100644 index 16f85d8..0000000 --- a/website/posts/0.2.1-release.md +++ /dev/null @@ -1,24 +0,0 @@ -title: Haunt 0.2.1 released -date: 2017-01-23 08:00:00 -tags: release -summary: Haunt 0.2.1 released ---- - -I am pleased to announce the release of Haunt version 0.2.1. This -release features a new reader for the -[Markdown](http://commonmark.org/) format via -[guile-commonmark](https://github.com/OrangeShark/guile-commonmark) as -well as small improvements to the Atom feed generator and -documentation. - -The new Commonmark reader can be found in the `(haunt reader -commonmark)` module. - -Thank you to Erik Edrosa, Ludovic Courtès, and Vladimir Zhbanov for -contributing to this release. - -Source tarball: [haunt-0.2.1.tar.gz](https://files.dthompson.us/haunt/haunt-0.2.1.tar.gz.sig) - -GPG signature [haunt-0.2.1.tar.gz.sig](https://files.dthompson.us/haunt/haunt-0.2.1.tar.gz.sig) - -Happy haunting! -- cgit v1.2.3