1
0
mirror of https://github.com/danog/gojekyll.git synced 2025-01-23 10:31:16 +01:00
gojekyll/CONTRIBUTING.md

58 lines
1.8 KiB
Markdown
Raw Normal View History

2017-07-05 11:18:00 -04:00
# Contributing
2017-07-05 14:27:24 -04:00
Here's some ways to help:
2017-07-05 11:18:00 -04:00
2017-07-07 09:36:10 -04:00
* Try using gojekyll on your site. Use this as fodder for test cases.
* Choose an item to work on from one of the [project boards](https://github.com/osteele/gojekyll/projects). Convert it to an Issue and assign it to yourself, so we know you're working on it.
* Search the sources for FIXME and TODO comments.
2017-07-05 14:27:24 -04:00
* Improve the [code coverage](https://coveralls.io/github/osteele/gojekyll?branch=master).
2017-07-05 11:18:00 -04:00
2017-07-05 14:33:41 -04:00
If you choose to contribute code, please review the [pull request template](https://github.com/osteele/gojekyll/blob/master/.github/PULL_REQUEST_TEMPLATE.md) before you get too far along.
2017-07-05 11:18:00 -04:00
## Developer Cookbook
### Set up your machine
Fork and clone the repo.
[Install go](https://golang.org/doc/install#install). On macOS running Homebrew, `brew install go` is easier than the linked instructions.
Install package dependencies and development tools:
```bash
make install_dev_tools
go get -t ./...
```
### Test and Lint
```bash
make test
make lint
```
### Debugging tools
```bash
gojekyll -s path/to/site render index.md # render a file to stdout
gojekyll -s path/to/site render page.md # render a file to stdout
gojekyll -s path/to/site render / # render a URL to stdout
gojekyll -s path/to/site variables / # print a file or URL's variables
gojekyll -s path/to/site variables site # print the site variables
gojekyll -s path/to/site variables site.twitter.name # print a specific site variable
```
`./scripts/gojekyll` is an alternative to the `gojekyll` executable, that uses `go run` each time it's invoked.
### Coverage
```bash
./scripts/coverage && go tool cover -html=coverage.out
```
### Profiling
```bash
gojekyll -s path/to/site benchmark && go tool pprof gojekyll gojekyll.prof
```