7 个版本
0.3.0 | 2019 年 9 月 13 日 |
---|---|
0.2.1 | 2018 年 3 月 25 日 |
0.2.0 | 2016 年 12 月 29 日 |
0.1.3 | 2016 年 7 月 2 日 |
0.1.0 | 2015 年 11 月 14 日 |
#25 在 #customization
在 2 个 crate 中使用 (通过 gazetta)
70KB
1.5K SLoC
Gazetta 是一个用 Rust 编写的静态网站生成器。它包含四个部分
- Horrorshow,一个基于 Rust 宏的 HTML 生成器。
- 框架。这个库集包含大部分逻辑,并负责从你的网站数据文件生成模型和视图。
- 渲染器。这里是实际渲染 HTML 的逻辑所在。如果你需要精细控制网站 HTML,你应该在此仓库上创建分支。然而,99% 的情况下,你应该能够在不修改此项目的情况下充分自定义你的网站。
- 你的网站数据。这包括你的网站内容和资产(样式表/JavaScript)。你可以在这里找到我的 数据,以及一个用于引导的简单示例网站 这里。
平台
我仅在 64 位 Linux 上测试了 Gazetta,但它应该适用于所有 *nix 平台。然而,它可能无法在 Windows 上工作(我假设路径中的正斜杠)。欢迎提交补丁!
快速开始
- 下载并编译 gazetta-bin (
cargo build --release
)。除非你想要付出 15x-30x 的性能代价,否则请以发布模式进行构建。 - 创建并克隆 gazetta-bootstrap。
- 编辑配置、首页和主题,使其符合你的需求。
- 手动创建一些新页面,或者使用 gazetta 二进制文件。例如:
gazetta new blog "Hello World"
将创建一篇“Hello World”博客文章。 - 运行
gazetta render /path/to/output
(在仓库中的任何位置) 来渲染你的网站。
数据目录布局和文件格式
这是 你的 网站数据。
配置
gazetta.yaml
这是网站的内核配置。它可以用来指定在渲染网站上的任何页面时都可用的共享变量。它必须指定
- title: 网站的标题。
- base: 网站的基 URL。
如果您使用默认渲染器(gazetta-bin),则还必须指定一个author
(参见人员部分)格式
并且可以指定一组导航链接
nav:
# If relative, href is relative to the site base.
- title: href
资源
/
└── assets/
├── javascript/
│ ├── 0-example1.js
│ └── 1-example2.js
├── stylesheets/
│ ├── 0-example1.css
│ └── 1-example2.css
└── icon.png
所有文件都是可选的。
icon.png
:网站的图标。javascript
:网站的javascript文件。在构建过程中将按字典顺序连接。stylesheets
:网站的样式表。在构建过程中将按字典顺序连接。
在assets
中的所有其他文件将被忽略。
条目
一个条目由以下内容组成
- 一个必填的索引文件(
index.txt
、index.html
或index.md
)。 - 一个可选的包含静态文件的
static
目录。 - 任意数量的子条目。
所有索引文件必须有一个yaml标题。此标题必须包含一个title
以及您指定的渲染器所需的所有其他内容。默认情况下,标题还可以包括
- 日期:格式为
YYYY-MM-DD
的日期。 - 索引:这表示当前页面是一个索引。如果指定,所有子项都将作为子页面附加到页面。有关更多信息,请参阅索引。
- cc:将此页面链接到指定的索引页面,就好像它是一个子项一样。这对于使页面出现在多个标签/类别中非常有用。
如果您使用默认渲染器,标题还可以包括
- 作者:页面的作者。
- 关于:此字段表示此页面是关于某人的。提供的人员信息将在页面顶部渲染。
静态目录中的目录和文件将原样复制到输出目录。这是一个放置每页静态媒体的好地方。
索引
索引字段可以是布尔值或具有以下可选字段的表格
# The sort direction and field: [+-](date|title)
sort: date
# How many entries to list per page or false to not paginate.
paginate: false
# The directories to include in the index (in addition to explicitly CCed
# entries).
directories: .
# The maximum number of entries to include in the index or false to include all
# entries.
max: false
人员
当指定人员时,您可以直接写出他们的名字或使用以下表格
name: My Name # Mandatory
email: email
photo: photo
key: pgp_key_url
nicknames:
- first nick
- second nick
also: # A list of profiles around the web.
- "GitHub": github_url # example
- "reddit": reddit_profile_url # example
代码质量
我对整体架构很满意,但一些代码可能需要一些关爱(主要的渲染函数尤其糟糕)。再次欢迎补丁。
性能
Gazetta非常快;这就是为什么我不费心显示进度。然而,还有改进的空间
- Gazetta做了很多系统调用(文件I/O)。我们可能可以显著减少这一点。在我的机器上,超过一半的运行时间是系统时间。
- yaml-rust很慢(根据callgrind)。我曾考虑使用toml,但切换会很痛苦。
- 索引构建算法是
Θ(num_indices*num_entries)
。然而,这可以减少到Θ(num_entries)
,但num_indices
通常相当低,所以这只有在我们可以将新算法的运行时间中的常数乘数保持低的情况下才有意义。 - 我们真的在乎吗?我的网站(约75页)在我的笔记本电脑上构建只需50毫秒。
依赖关系
~4MB
~84K SLoC