Skip to content

Commit

Permalink
docs: Add Site generation reference documentation
Browse files Browse the repository at this point in the history
Explain at a high level what `cobalt serve` and `cobalt build` do.
Based on this, suggest how to run Cobalt in an existing site's
directory.

Add the new page to the Reference documentation navigation.
Mention the new page on the Start (getting-started) page.

Fixes #95
  • Loading branch information
skierpage committed Jul 2, 2024
1 parent a003fc0 commit a72a39f
Show file tree
Hide file tree
Showing 3 changed files with 75 additions and 1 deletion.
1 change: 1 addition & 0 deletions _layouts/docs.liquid
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
<li><a {% if page.data.route == "install"%}class="active"{%endif%} href="/docs/install">Install</a></li>
<li><a {% if page.data.route == "usage"%}class="active"{%endif%} href="/docs/usage">Usage</a></li>
<li><a {% if page.data.route == "directory"%}class="active"{%endif%} href="/docs/directory">Directory Structure</a></li>
<li><a {% if page.data.route == "site-gen"%}class="active"{%endif%} href="/docs/site-gen">Site generation</a></li>
<li><a {% if page.data.route == "config"%}class="active"{%endif%} href="/docs/config">Configuration</a></li>
</ul>
<hr align="left">
Expand Down
70 changes: 70 additions & 0 deletions docs/site-gen.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
---
title: "Docs::Site generation"
layout: docs.liquid
data:
route: site-gen
---
## Site generation

[`cobalt serve`](/docs/usage) and `cobalt build` process the entire source directory the same
way. They write assets, transformed files, and generated pages to an output
directory; `cobalt serve` writes to a temporary directory while `cobalt build`
writes to a [`destination`](/docs/config) directory (default `./_site`). `cobalt serve` also
runs a web server to serve this static content, and then continues to watch the
source directory for changes.

### Generation process

The generation process is, approximately,
1. Cobalt considers every file in the [`source`](/docs/config)directory.
2. It skips directories and file names beginning with dot `.` or underscore
`_`, and other files and directories. You can specify additional files and
directories to skip using the [`ignore`](/docs/config) configuration
variable.
3. It treats all remaining files that aren't pages and posts (see later) as
[assets](/docs/assets) and copies them to the output directory. It may
preprocess Sass files to turn them into CSS.
4. If a file has an extension in [`template_extensions`](/docs/config) (the
default extensions are `.html` and `.md`), then Cobalt treats it as a
[page](/docs/pages):
- Cobalt looks for a [frontmatter](/docs/front) section (lines between a pair
of `---`) in it, if any, and evaluates metadata settings in it.
- If the site [configuration](/docs/configuration) or the page's
frontmatter specifies a [layout](/docs/layout), Cobalt wraps the file in
that layout's Liquid template.
- Cobalt evaluates any [liquid template](https://shopify.github.io/liquid/)
expressions in the file (to simplify, directives inside curly braces `{...}`).
- Cobalt writes the transformed file to the output directory with, by
default, a `.html` extension. A file with no frontmatter or liquid
template expressions will be unchanged.
5. If a file with a template extension is in the [`posts`](/docs/posts)
directory, Cobalt processes it further, such as draft handling. A page's
frontmatter can direct Cobalt to generate a list of pages, for example a
paginated list of blog posts.
6. Cobalt may generates additional files, such as an `rss.xml` feed.

### Generating from an existing static site

You can run `cobalt serve` or `cobalt build` in your existing static site's
directory.
- They will create a lot of files in the output directory, but will not create
new files or modify existing files in your source directory. _Caution_,
`cobalt build` will overwrite files in an existing destination directory
(which defaults to `./_site`).
- The commands will complain if you don't have a `_config.yml` file or specify
the path to one, nevertheless Cobalt will do default processing.
- Even if your existng files have extensions that Cobalt treats as pages, as

Check warning on line 56 in docs/site-gen.md

View workflow job for this annotation

GitHub Actions / Spell Check with Typos

"existng" should be "existing".
explained in "Generation process" they will not be transformed if they don't
contain liquid templates and a frontmatter section, and you don't specify a
default [`layout`](/docs/config).
- Some assets that you want to appear in the output directory, such as
`.htaccess` files and the `.well-known` directory, may not appear;
conversely, unintended files may appear.

To start adjusting Cobalt's site generation you need to provide a
[configuration](/docs/config) file. Running [`cobalt init`](docs/usage/) will
create a `_config.yml` file and a few sample files and layout. If files
already exist with the same names, `cobalt init` will not overwrite them but
fail, so you could run it in your existing site directory, or you can run it
in an empty directory and copy over files as needed. You can specify the path
to your configuration file with the `--config` _\<FILE>_ command-line option.
5 changes: 4 additions & 1 deletion getting-started.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ or
$ curl -LSfs https://raw.githubusercontent.com/crate-ci/gh-install/master/v1/install.sh | sh -s -- --git cobalt-org/cobalt.rs --crate cobalt
```

### Usage
### Basic usage

#### Start

Expand Down Expand Up @@ -64,3 +64,6 @@ $ cobalt build
```

The site is sitting in `_site` and ready to be uploaded!

If you have an existing site, read [Site generation](/docs/site-gen) to better
understand Cobalt's operation so you can run it in your site directory.

0 comments on commit a72a39f

Please sign in to comment.