See user documentation at https://senforsce.com/t1/guide
Build a local version.
go run ./get-version > .version
cd cmd/t1
go build
Build and install current version.
# Remove t1 from the non-standard ~/bin/t1 path
# that this command previously used.
rm -f ~/bin/t1
# Clear LSP logs.
rm -f cmd/t1/lspcmd/*.txt
# Update version.
go run ./get-version > .version
# Install to $GOPATH/bin or $HOME/go/bin
cd cmd/t1 && go install
Use goreleaser to build the command line binary using goreleaser.
goreleaser build --snapshot --clean
Run t1 generate using local version.
go run ./cmd/t1 generate -include-version=false
Run Go tests.
go run ./get-version > .version
go run ./cmd/t1 generate -include-version=false
go test ./...
Run Go tests.
# Create test profile directories.
mkdir -p coverage/fmt
mkdir -p coverage/generate
mkdir -p coverage/version
mkdir -p coverage/unit
# Build the test binary.
go build -cover -o ./coverage/t1-cover ./cmd/t1
# Run the covered generate command.
GOCOVERDIR=coverage/fmt ./coverage/t1-cover fmt .
GOCOVERDIR=coverage/generate ./coverage/t1-cover generate -include-version=false
GOCOVERDIR=coverage/version ./coverage/t1-cover version
# Run the unit tests.
go test -cover ./... -args -test.gocoverdir="$PWD/coverage/unit"
# Display the combined percentage.
go tool covdata percent -i=./coverage/fmt,./coverage/generate,./coverage/version,./coverage/unit
# Generate a text coverage profile for tooling to use.
go tool covdata textfmt -i=./coverage/fmt,./coverage/generate,./coverage/version,./coverage/unit -o coverage.out
# Print total
go tool cover -func coverage.out | grep total
Run benchmarks.
go run ./cmd/t1 generate -include-version=false && go test ./... -bench=. -benchmem
Format all Go and t1 code.
gofmt -s -w .
go run ./cmd/t1 fmt .
golangci-lint run --verbose
Create production build with goreleaser.
if [ "${GITHUB_TOKEN}" == "" ]; then echo "No github token, run:"; echo "export GITHUB_TOKEN=`pass github.com/goreleaser_access_token`"; exit 1; fi
./push-tag.sh
goreleaser --clean
Run the development server.
Directory: docs
npm run start
Build production docs site.
Directory: docs
npm run build