Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cake-build/website
:earth_americas: The Cake website: https://cakebuild.net
https://github.com/cake-build/website
build-system cake cake-build hacktoberfest website
Last synced: 13 days ago
JSON representation
:earth_americas: The Cake website: https://cakebuild.net
- Host: GitHub
- URL: https://github.com/cake-build/website
- Owner: cake-build
- License: mit
- Created: 2015-06-28T20:46:39.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T12:22:44.000Z (3 months ago)
- Last Synced: 2024-10-30T00:44:45.114Z (3 months ago)
- Topics: build-system, cake, cake-build, hacktoberfest, website
- Language: HTML
- Homepage: https://cakebuild.net
- Size: 7.65 MB
- Stars: 42
- Watchers: 16
- Forks: 230
- Open Issues: 107
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Support: support/nuget/index.aspx
Awesome Lists containing this project
README
# Cake Website
This is the Cake website. It's a static site generated by [Wyam](http://wyam.io) which is hosted on Azure. Wyam is a static content toolkit and can be used to generate web sites, produce documentation, create ebooks, and much more.
## Contributing
Any contributions are appreciated, no matter how big or small. The Cake site consists of several different sections and each one is described below.
**NOTE** If you're interested in contributing please reach out to us on [GitHub Discussions](https://github.com/cake-build/cake/discussions) first.
## Documentation
The basic documentation pages can be found under `./input/docs`. The directory structure mirrors what's on the site. Most pages are written in Markdown. To add a new page, just add a new file.
## Blog
The Cake site contains a blog where important announcements and other relevant information are posted. The blog posts can be found under `./input/blog`. As with documentation pages, blog posts are written in Markdown. The file name for each blog post contains its published date in the format `YYYY-MM-DD-title.md`.
## Extensions
> PLEASE NOTE: Extension authors do not have to manually create YAML files as there is an automated process that scans nuget.org twice per day to find all extensions that follow the recommended naming convention (which is `Cake.xxx` for addins and `Cake.xxx.Module` for modules, where xxx describes the functionality provided by the extension) and generates the appropriate YAML content based on the metadata for the NuGet package.
All extensions are specified in individual YAML files under `./extensions`. Adding an extension here will trigger downloading it's NuGet Package during site generation and will include it in the "Reference" and "Extensions" sections of the Cake site.
The format of an extension file generally looks like:
```
Type: Addin
Name: Cake.Wyam
NuGet: Cake.Wyam
Assemblies:
- "/**/Cake.Wyam.dll"
Repository: https://github.com/Wyamio/Wyam
Author: Dave Glick, Gary Ewan Park
Description: "An alias that generates static sites and other content using Wyam."
Categories:
- Documentation
- Static Site Generation
````Type` can be one of the following values: `Addin`, `Module`, `Recipe`.
## Search
Search uses [Algolia DocSearch](https://docsearch.algolia.com/) as backend.
Configuration for crawler is available at https://github.com/algolia/docsearch-configs/blob/master/configs/cakebuild.json.## Building
The site is built using Cake (of course!). There are a number of different targets depending on what you're working on and how complete you want the generated site to be.
`build --target=GetSource` will download the Cake source code that the generation process uses to create the "API" section.
`build --target=GetExtensionPackages` will download new NuGet packages for all specified extensions. These packages are used to create the "Reference" and "Extensions" sections.
`build --target=GetArtifacts` will download both the Cake source code and the extension NuGet packages.
`build --target=Build` will run a complete build, downloading new copies of Cake source code and extension NuGet packages. Note that due to the number of extensions and the complexity of generating complete API documentation, the site generation may take a while (sometimes as long as 20 minutes).
`build --target=Preview` will run a build but *will not* download Cake source code or NuGet packages. This lets you shorten the build cycle by avoiding the time to obtain those resources if you've already downloaded them, or to bypass them altogether if you're just working on something like general documentation pages. This target will also launch a preview server to look at the generated site from a local web browser. The URL of the generated preview site is `http://localhost:5080/`.