1
0
mirror of https://github.com/danog/gojekyll.git synced 2024-11-27 06:44:40 +01:00
Go to file
2017-06-22 08:35:18 -04:00
cmd/gojekyll Implement --open-url 2017-06-21 19:19:08 -04:00
example New file site_config.go; honor site config layouts_dir 2017-06-16 21:53:14 -04:00
helpers Read YAML lists 2017-06-21 09:43:26 -04:00
liquid Recognize remote render errors 2017-06-21 09:43:26 -04:00
scripts Rename package main -> gojekyll; move commands to subdirectory 2017-06-17 10:51:32 -04:00
.gitignore Add benchmark subcommand 2017-06-18 18:54:08 -04:00
.gometalinter.json Add a gometalinter config file 2017-06-21 10:53:50 -04:00
.travis.yml Add explicit go get to travis 2017-06-21 12:51:53 -04:00
build.go Implement page.content 2017-06-20 16:17:59 -04:00
collection.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
dynamic_page.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
layout.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
LICENSE Create LICENSE 2017-06-11 19:18:10 -04:00
Makefile Makefile gets test dependencies too 2017-06-22 08:33:09 -04:00
markdown.go Rename package main -> gojekyll; move commands to subdirectory 2017-06-17 10:51:32 -04:00
page.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
permalinks_test.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
permalinks.go Consolidate PathWithoutExtension -> TrimExt 2017-06-21 09:43:26 -04:00
README.md Update README 2017-06-22 08:34:37 -04:00
sass.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
server.go server -o reports errors 2017-06-22 08:34:56 -04:00
site_config.go Read yaml site data files 2017-06-19 14:44:34 -04:00
site_test.go Rename package main -> gojekyll; move commands to subdirectory 2017-06-17 10:51:32 -04:00
site_variables.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
site.go Page depends on a Container interface, not a Site struct 2017-06-22 08:35:18 -04:00
variable_map_test.go Rename package main -> gojekyll; move commands to subdirectory 2017-06-17 10:51:32 -04:00
variable_map.go Rename package main -> gojekyll; move commands to subdirectory 2017-06-17 10:51:32 -04:00

Go Jekyll

When I grow up, I want to be a Go implementation of Jekyll.

Status

Build Status Go Report Card

This project is missing more functionality than it implements. It may accidentally work on tiny or simple sites.

  • Content
    • Front Matter
    • Posts
      • Categories
      • Tags
      • Drafts
      • Future
      • Related
    • Static Files
    • Variables
    • Collections
    • Data Files
      • CSV
      • JSON
      • YAML
    • Assets
      • Coffeescript
      • Sass/SCSS
        • Sass caching
  • Customization
    • Templates
      • link tag
      • include tag
      • Remaining Jekyll Liquid tags
      • Jekyll Liquid filters
    • Includes
    • Permalinks
    • Pagination
    • Themes
    • Layouts
  • Server
    • Directory watch
    • Live reload
  • Windows -- not tested

Install

go get -u osteele/gojekyll/cmd/gojekyll

Sometimes this package benefits from my unmerged improvements to the acstech/liquid library. If you want to use my fork instead:

cd $(go env GOPATH)/src/github.com/acstech/liquid
git remote add osteele https://github.com/osteele/liquid.git
git pull -f osteele

(See articles by Shlomi Noach and Francesc Campoy for how this works and why it is necessary.)

Usage

gojekyll build                # builds into ./_site
gojekyll serve                # serves from memory, w/ live reload
gojekyll help

Liquid Template Server

The embedded Liquid server isn't very compliant with Shopfiy Liquid syntax.

You can run a "Liquid Template Server" on the same machine, and tell gojekyll to use this instead. This is currently about 10x slower than using the embedded engine, but still 5x faster than Ruby jekyll.

  1. Download and run (liquid-template-server)[https://github.com/osteele/liquid-template-server].
  2. Invoke gojekyll with the --use-liquid-server option; e.g.:
gojekyll --use-liquid-server build
gojekyll --use-liquid-server serve

Neither the embedded Liquid server nor the Liquid Template Server implements very many Jekyll Liquid filters or tags. I'm adding to these as necessary to support my own sites.

Develop

Install package dependencies and development tools:

make setup

Test:

make test
make lint
gojekyll render index.md      # render a file to stdout
gojekyll render /             # render a URL to stdout
gojekyll variables /          # print a file or URL's variables

./scripts/gojekyll is an alternative to the gojekyll executable, that uses go run each time it's invoked.

Profiling:

gojekyll --remote-liquid profile
go tool pprof gojekyll gojekyll.prof

Credits

For rendering Liquid templates: ACS Technologies's fork acstech/liquid of Karl Seguin's karlseguin/liquid Go implementation; or, Jun Yang's JavaScript implementation harttle/shopify-liquid via JSON-RPC.

Jascha Ephraim's jaschaephraim/lrserver Live Reload server.

https://github.com/pkg/browser to open the URL in a browser.

The gopher image in the test directory is from Wikimedia Commons. It is used under the Creative Commons Attribution-Share Alike 3.0 Unported license.

Hugo isn't Jekyll-compatible (-), but actually works (+++).

Jekyll, of course.

This project is a clean-room implementation of Jekyll, based solely on Jekyll's documentation and testing a few sites.

License

MIT

Alternate Naming Possibilities

  • "Gekyll". (Hard or soft "g"? See gif.)
  • "Gekko"