Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joerdav/xc
Markdown defined task runner.
https://github.com/joerdav/xc
build-tool documentation go golang task-runner
Last synced: 5 days ago
JSON representation
Markdown defined task runner.
- Host: GitHub
- URL: https://github.com/joerdav/xc
- Owner: joerdav
- License: mit
- Created: 2021-10-15T09:00:29.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2025-01-27T16:27:02.000Z (23 days ago)
- Last Synced: 2025-01-31T10:21:53.391Z (20 days ago)
- Topics: build-tool, documentation, go, golang, task-runner
- Language: Go
- Homepage: https://xcfile.dev/
- Size: 1.9 MB
- Stars: 1,244
- Watchers: 11
- Forks: 27
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-go - xc - Task runner with README.md defined tasks, executable markdown. (Build Automation)
- fucking-awesome-go - xc - Task runner with README.md defined tasks, executable markdown. (Build Automation)
- awesome-repositories - joerdav/xc - Markdown defined task runner. (Go)
- awesome-go - xc - Task runner with README.md defined tasks, executable markdown. (Build Automation)
- awesome-go - xc - Task runner with README.md defined tasks, executable markdown. Stars:`1.2K`. (Build Automation)
- awesome-go-with-stars - xc - Task runner with README.md defined tasks, executable markdown. (Build Automation)
- awesome-go-plus - xc - Task runner with README.md defined tasks, executable markdown. data:image/s3,"s3://crabby-images/cb12e/cb12e4cd3466d56578b82e6167c67f628b1da36f" alt="stars" (Build Automation)
- awesome-go-cn - xc
- awesome-go-plus - xc - Task runner with README.md defined tasks, executable markdown. (Build Automation)
README
# xc - Simple, Convenient, Markdown-based task runner.
data:image/s3,"s3://crabby-images/e1a50/e1a50ff39036af3fd277bbbd87a4ad3e9a399f98" alt="xc"
[Docs](https://xcfile.dev/) | [Getting Started](https://xcfile.dev/getting-started/) | [GitHub](https://github.com/joerdav/xc)[data:image/s3,"s3://crabby-images/910a6/910a67a5b0f4d03354aa56eac324849eae9b9c49" alt="xc compatible"](https://xcfile.dev)
[data:image/s3,"s3://crabby-images/dc159/dc15914f933ae2c9b2c9cafd40db0c85d7586373" alt="test"](https://github.com/joerdav/xc/actions/workflows/test.yaml)
[data:image/s3,"s3://crabby-images/683ba/683ba9ee23c921c425065180d1a0cc742662e57d" alt="docs"](https://github.com/joerdav/xc/actions/workflows/docs.yml)
[data:image/s3,"s3://crabby-images/c5697/c569726a3b82e4c6bc4736aed6569c1049b39522" alt="Go Reference"](https://pkg.go.dev/github.com/joerdav/xc)
[data:image/s3,"s3://crabby-images/75b7f/75b7ff52f8c5707017679a0e624cc2e4a0c58aa5" alt="Mentioned in Awesome Go"](https://github.com/avelino/awesome-go)
[data:image/s3,"s3://crabby-images/13437/134370e6ff7a360ac59ffd9ce31e120ef6562fd9" alt="Go Report Card"](https://goreportcard.com/report/github.com/joerdav/xc)
[data:image/s3,"s3://crabby-images/d7831/d78311300db396f2ed082bfa45a1b0df10adc9cc" alt="Coverage Status"](https://coveralls.io/github/joerdav/xc?branch=main)`xc` is a task runner similar to `Make` or `npm run`, that aims to be more discoverable and approachable.
The problem `xc` is intended to solve is scripts maintained separately from their documentation.
Often a `Makefile` or a `package.json` will contain some useful scripts for developing on a project,
then the `README.md` will surface and describe these scripts.
In such a case, since the documentation is separate, it may not be updated when scripts are changed or added.
`xc` aims to solve this by defining the scripts [inline with the documentation](https://en.wikipedia.org/wiki/Literate_programming).`xc` is designed to maximise convenience, and minimise complexity.
Each `xc` task is defined in simple, human-readable Markdown.
This means that even people without the `xc` tool installed can use the README.md
(or whatever Markdown file contains the tasks)
as a source of useful commands for the project.# Installation
Installation instructions are described at .
# Features
- Tasks defined in Markdown files as code blocks.
- Editor integration:
- [VSCode](https://marketplace.visualstudio.com/items?itemName=xc-vscode.xc-vscode) (list and run `xc` tasks)
data:image/s3,"s3://crabby-images/2962b/2962b74e69b4098ab56e7f564cf836ae1a16f771" alt="vscode demo"
- [Vim](https://xcfile.dev/ide-support/#vim) (recommended config for listing and running `xc` tasks)# Example
Take the `tag` task in the [README.md](https://github.com/joerdav/xc#tag) of the `xc` repository:
````
## tagDeploys a new tag for the repo.
Requires: test
```
export VERSION=`git rev-list --count HEAD`
echo Adding git tag with version v0.0.${VERSION}
git tag v0.0.${VERSION}
git push origin v0.0.${VERSION}
```
````The task could be run simply with `xc tag`, but a side-effect of it being an `xc` task is that the steps for pushing a tag without the use of `xc` are clearly documented too.
```
$ xc tag
+ go test ./...
? github.com/joerdav/xc/cmd/xc [no test files]
? github.com/joerdav/xc/models [no test files]
ok github.com/joerdav/xc/parser (cached)
ok github.com/joerdav/xc/run (cached)
+ export VERSION=78
+ echo Adding git tag with version v0.0.78
Adding git tag with version v0.0.78
+ git tag v0.0.78
+ git push origin v0.0.78 Total 0 (delta 0), reused 0 (delta 0), pack-reused 0
To github.com:joerdav/xc
* [new tag] v0.0.78 -> v0.0.78
```# Tasks
## test
Test the project.
```
go test ./...
```## lint
Run linters.
```
golangci-lint run
```## build
Builds the `xc` binary.
```
go build ./cmd/xc
```## tag
Deploys a new tag for the repo.
Specify major/minor/patch with VERSION
Inputs: VERSION
Requires: test
```
# https://github.com/unegma/bash-functions/blob/main/update.shCURRENT_VERSION=`git describe --abbrev=0 --tags 2>/dev/null`
CURRENT_VERSION_PARTS=(${CURRENT_VERSION//./ })
VNUM1=${CURRENT_VERSION_PARTS[0]}
VNUM2=${CURRENT_VERSION_PARTS[1]}
VNUM3=${CURRENT_VERSION_PARTS[2]}if [[ $VERSION == 'major' ]]
then
VNUM1=$((VNUM1+1))
VNUM2=0
VNUM3=0
elif [[ $VERSION == 'minor' ]]
then
VNUM2=$((VNUM2+1))
VNUM3=0
elif [[ $VERSION == 'patch' ]]
then
VNUM3=$((VNUM3+1))
else
echo "Invalid version"
exit 1
fiNEW_TAG="$VNUM1.$VNUM2.$VNUM3"
echo Adding git tag with version ${NEW_TAG}
git tag ${NEW_TAG}
git push origin ${NEW_TAG}
```## update-nix
Updates nix flake.
```
sh ./update-nix.sh
```## install-hugo
Install hugo via `go install`.
```sh
go install github.com/gohugoio/hugo@latest
```## run-docs
Run the hugo development server.
Directory: doc
```sh
hugo serve
```## build-docs
Build production docs site.
Directory: doc
```sh
./build.sh
```