Skip to content

wreulicke/patchr

Repository files navigation

patchr

This is patch tool using comment directive.

Motivation

This aims to make scaffolding more easily and safely.

Sometimes we can see some templates that don't work after generating from them. We should build and test those templates on CI pipelines, but, it is hard to test templates correctness because templates usually does'nt work before generation. So, this patchr aims to create a living scaffolding template.

Installation

Download from Releases

# Mac
curl -o patchr -sL "https://github.com/wreulicke/patchr/releases/download/v0.0.1/patchr_0.0.1_darwin_arm64"
curl -o patchr -sL "https://github.com/wreulicke/patchr/releases/download/v0.0.1/patchr_0.0.1_darwin_amd64"

# Linux
curl -o patchr -sL "https://github.com/wreulicke/patchr/releases/download/v0.0.1/patchr_0.0.1_linux_amd64"
curl -o patchr -sL "https://github.com/wreulicke/patchr/releases/download/v0.0.1/patchr_0.0.1_linux_arm64"

# Windows
curl -o patchr -sL https://github.com/wreulicke/patchr/releases/download/v0.0.1/patchr_0.0.1_windows_amd64.exe
curl -o patchr -sL https://github.com/wreulicke/patchr/releases/download/v0.0.1/patchr_0.0.1_windows_arm64.exe

chmod +x patchr
mv patchr /usr/local/bin

Usage

$ patchr
patchr is a tool to apply patches to source code using comment directives

Usage:
  patchr [file or directory] [flags]
  patchr [command]

Available Commands:
  completion  Generate the autocompletion script for the specified shell
  help        Help about any command
  version     show version

Flags:
  -p, --comment-prefix string   overrides comment prefix
  -d, --dry-run                 dry run
  -h, --help                    help for patchr
  -v, --values string           values file for template

Use "patchr [command] --help" for more information about a command.

Directives

Currently, we have 5 directives.

  1. replace
  • repalce next line
  1. add
  • add next line
  1. remove
  • remove next line
  1. template
  • expand template using go/template
  1. cut
  • cut a whole block
func main() {
  // You can use go text/template in replace/add/template directives
  
  // `replace` directive replace next line
	// patchr:replace fmt.Println("Hello, {{ .Name }}!")
  fmt.Println("Hello World!")

  // `add` directive add next line
  // patchr:add fmt.Println("Hello, {{ .Name }}!")

  // `template` directive can expand text/template here
  // patchr:template-start
  // {{ if .Enabled }}
  // fmt.Println("Enabled!")
  // {{ end }}
  // patchr:template-end

  // `remove` directive remove next line
  // patchr:remove
  fmt.Println("this will be removed")
  
  // `cut` directive cut the whole block
  // patchr:cut-start
  panic("this will be cut")
  // patchr:cut-end
}

Example

See testdata.

License

MIT License

About

Apply patch using comment directive

Resources

License

Stars

Watchers

Forks

Packages

No packages published