1
0
mirror of https://github.com/danog/gojekyll.git synced 2025-01-22 12:31:18 +01:00
2017-06-18 22:24:10 -04:00
2017-06-18 16:54:36 -04:00
2017-06-18 17:00:33 -04:00
2017-06-18 18:54:08 -04:00
2017-06-13 12:45:33 -04:00
2017-06-18 16:55:52 -04:00
2017-06-11 19:18:10 -04:00
2017-06-18 22:24:10 -04:00
2017-06-18 16:54:36 -04:00
2017-06-18 19:12:22 -04:00
2017-06-18 22:24:10 -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.

It's currently ~50x faster than Jekyll using an embedded Liquid engine (that isn't very completely); and about 5x faster using an un-optimized connection to the harttle/shopify-liquid JavaScript library (documentation TBD) to render Liquid templates.

  • Content
    • Front Matter
    • Posts
      • Categories
      • Tags
      • Drafts
      • Future
      • Related
    • Creating pages
    • Static Files
    • Variables
    • Collections -- rendered, but not available as variables
    • Data Files
    • Assets
      • Coffeescript
      • Sass/SCSS
  • Customization
    • Templates
      • link tag
      • include tag
      • Remaining Jekyll Liquid tags
      • Jekyll Liquid filters
    • Includes
    • Permalinks
    • Pagination
    • Themes
    • Layouts
  • Server
    • Directory watch
    • Live reload
  • Other
    • LINUX, macOS
    • Windows -- not tested

Install

go install 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.)

Run

gojekyll build            # builds into ./_site
gojekyll serve            # serves from memory, w/ live reload
gojekyll render index.md  # render a file to stdout
gojekyll render /         # render a URL to stdout
gojekyll data /           # print a file or URL's variables
gojekyll --remote-liquid  # use a local Liquid engine server
gojekyll help

For development, ./scripts/gojekyll uses go run each time it's invoked.

Credits

For rendering Liquid templates: the acstech/liquid fork of karlseguin/liquid; or, harttle/shopify-liquid via JSON-RPC.

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.

License

MIT

Alternate Naming Possibilities

  • "Gekyll". (Hard or soft "g"? See gif.)
  • "Gekko"
Description
No description provided
Readme 1.1 MiB
Languages
Go 95.9%
CSS 2%
HTML 1%
Makefile 0.6%
Shell 0.3%
Other 0.2%