Documentation source for Lisp Flavoured Erlang
Introduction ↟
When I first came here, this was all yak hair. Everyone said I was daft to build a yurt on the Endless High Plain of Yak, but I built in all the same, just to show them. It sank into the Plains of Yak. So I built a second one. That sank into the Plains of Yak. So I built a third. That burned down, fell over, then sank into the Plains of Yak. But the fourth one stayed up. And that's what you're going to get, the strongest yak hair yurt on the Endless High Plain of Yak.
Build for failure? No! Build to burn down, fall over, and sink into the Plains of Yak!
This is the source code that generates the site for the LFE documentation. The last stable release is always available here:
And the current development work on the docs is published here:
Note that the latest dev version provides a drop-down menu in the top-nav for accessing previous releases of the LFE Documentation.
Goals ↟
The aim of this project is twofold:
- Maintain the content for the LFE documentation site
- Maintain a tool (written in LFE) for generating the LFE docs site
The next release of the docs site and tooling is v3.1. All tickets for the release are ulimately linked here:
Dependencies ↟
- Erlang
rebar3
If you want to regenerate the CSS, you'll need sass
:
sass
(usemake sass
to install; requires Ruby +gem
to be installed)
There are two supported ways of building the LFE docs site and CSS:
- using
make
targets (which call erlang under the hood) - running
docs
functions from the LFE REPL
With make
↟
To (re)generate the static files:
$ make docs-dev
That will build both the HTML files as well as the CSS.
To only build the HTML:
$ make docs-dev-only
To only build the CSS:
$ make css-dev
Additionally, a make
target is provided which compiles everything fresh,
starts up a local dev HTTP server, and watches for changes in CSS, HTML
templates, and LFE code:
$ make serve-dev-watch
The CSS watcher is a backgrounded sass
process, and not native LFE, so you
will need to kill it when you are done:
$ make css-unwatch
In the REPL ↟
To (re)generate the static files, start up an LFE REPL:
$ make repl
Erlang/OTP 18 [erts-7.3] [source] [64-bit] [smp:4:4] [async-threads:10] ...
..-~.~_~---..
( \\ ) | A Lisp-2+ on the Erlang VM
|`-.._/_\\_.-': | Type (help) for usage info.
| g |_ \ |
| n | | | Docs: http://docs.lfe.io/
| a / / | Source: http://github.com/rvirding/lfe
\ l |_/ |
\ r / | LFE v1.3-dev (abort with ^G)
`-E___.-'
lfe> (docs:start)
ok
To generate the docs to dev:
lfe> (docs:gen-dev)
Created docs/dev/index.html.
...
ok
Or to generate the static files to prod (the current
directory; this is
only done when promoting dev to stable):
lfe> (docs:gen)
Created docs/current/index.html.
...
ok
To run a local copy of the development server and view your work at http://localhost:8080, run the following:
lfe> (docs:httpd)
ok
The CSS files are managed with sass. After changing
values in the priv/sass/lfe*.scss
files or in the
priv/sass/lfe-sass/
subdirectories, you'll need to rebuild:
$ make css
Contributing Content ↟
This part of the documentation (and code, for that matter) is under very active development and is changing regularly, but as it stands right now, the following steps outline how to add new content to the LFE Documentation site.
Preparation
- Fork this repository.
git clone
your fork to your local machine andcd
to the working directory of your clone. If you will be making CSS changes, you'll need thebootstrap-sass
submodule. In that case, you'll want to usegit clone --recursive
.- If you plan on making content additions, you'll want to select the
template you want to base your page on (e.g.,
priv/templates/base.html
).
Content Creation
- Create a new template that extends your selected template, overriding the block with content in your new template (see the other templates for examples of this).
- Update the
docs-pages:get-page
function with a clause that will match your page- If you need a custom data function that sets variables that need to be
substituted in your template, be sure to call it here in the
get-page
function (after you add it todocs-data
). - Also, in the
get-page
function is where you will call your template'srender
function. - Make sure your
get-page
code extracts the results of therender
function (e.g., using the providedget-content
function in the same module).
- If you need a custom data function that sets variables that need to be
substituted in your template, be sure to call it here in the
CSS Updates
- Make sure that your clone of
lfe/docs
has the submodule populated (check thepriv/sass/bootstrap-sass/
directory). - Make updates to the file
priv/sass/lfe-sass/bootstrap/_theme.scss
. - If you need to create some new variables, you'll want to edit
priv/sass/lfe-sass/bootstrap/_variables.scss
. - Commit your changes to the sass files.
- Regenerate the dev CSS with
make css-dev
.
Generation & Testing
- Start up the LFE REPL (e.g.,
make repl
). - Generate the static content with
(docs:gen-dev)
. - Serve the newly generated content with
(docs:httpd)
. - Or do all of those with one target:
make serve-dev
. - Visit http://localhost:8080/dev/index.html and any other pages you need to test.
- Once you are sure it's good, commit the changes.
Caution: Do not run (docs:gen)
, as that will generate an updated stable
version of the docs (the contents of the current
) directory. That is only
done prior to a new release of LFE and/or the documentation site. Any PRs that
update current
will not be approved until those changes are removed (modulo
typo fixes and the like).
If you have called (docs:gen)
by accident, simply do a git checkout
of the
current
dir to undo the docs regen.
Submission
- Push to your fork on Github.
- Open a PR.
License ↟
Copyright © 2013-2017 LFE Community
Distributed under the Apache License, Version 2.0.