Invocation Examples

The following examples illustrate how precious executes a command with different invocation options.

For these examples we will assume that the command is configured to execute for any file ending in .go. The executable is some-linter and only takes paths as argument. The file tree looks like this:

example
├── app.go
├── main.go
├── pkg1
│  ├── pkg1.go
├── pkg2
│  ├── pkg2.go
│  ├── pkg2_test.go
│  └── subpkg
│     └── subpkg.go
└── precious.toml

This is the default configuration.

[commands.some-linter]
invoke = "per-file"
working_dir = "root"
path_args = "file"
some-linter app.go
some-linter main.go
some-linter pkg1/pkg1.go
some-linter pkg2/pkg2.go
some-linter pkg2/pkg2_test.go
some-linter pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "per-file"
working_dir = "root"
path_args = "absolute-file"
some-linter /example/app.go
some-linter /example/main.go
some-linter /example/pkg1/pkg1.go
some-linter /example/pkg2/pkg2.go
some-linter /example/pkg2/pkg2_test.go
some-linter /example/pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "per-file"
working_dir = "dir"
path_args = "file"
some-linter app.go
some-linter main.go
cd /example/pkg1
some-linter pkg1.go
cd /example/pkg2
some-linter pkg2.go
some-linter pkg2_test.go
cd /example/pkg2/subpkg
some-linter subpkg.go

[commands.some-linter]
invoke = "per-file"
working_dir = "dir"
path_args = "absolute-file"
some-linter /example/app.go
some-linter /example/main.go
cd /example/pkg1
some-linter /example/pkg1/pkg1.go
cd /example/pkg2
some-linter /example/pkg2/pkg2.go
some-linter /example/pkg2/pkg2_test.go
cd /example/pkg2/subpkg
some-linter /example/pkg2/subpkg/subpkg.go

It's odd to combine working_dir = "dir" with path_args = "absolute-file", but it will work.


[commands.some-linter]
invoke = "per-file"
working_dir.chdir_to = "pkg1"
path_args = "file"
cd /example/pkg1
some-linter ../app.go
some-linter ../main.go
some-linter ../pkg2/pkg2.go
some-linter ../pkg2/pkg2_test.go
some-linter ../pkg2/subpkg/subpkg.go
some-linter pkg1.go

[commands.some-linter]
invoke = "per-file"
working_dir.chdir_to = "pkg1"
path_args = "absolute-file"
cd /example/pkg1
some-linter /example/app.go
some-linter /example/main.go
some-linter /example/pkg1/pkg1.go
some-linter /example/pkg2/pkg2.go
some-linter /example/pkg2/pkg2_test.go
some-linter /example/pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "per-dir"
working_dir = "root"
path_args = "dir"
some-linter .
some-linter pkg1
some-linter pkg2
some-linter pkg2/subpkg

[commands.some-linter]
invoke = "per-dir"
working_dir = "root"
path_args = "absolute-dir"
some-linter /example
some-linter /example/pkg1
some-linter /example/pkg2
some-linter /example/pkg2/subpkg

[commands.some-linter]
invoke = "per-dir"
working_dir = "root"
path_args = "file"
some-linter app.go main.go
some-linter pkg1/pkg1.go
some-linter pkg2/pkg2.go pkg2/pkg2_test.go
some-linter pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "per-dir"
working_dir = "root"
path_args = "absolute-file"
some-linter /example/app.go /example/main.go
some-linter /example/pkg1/pkg1.go
some-linter /example/pkg2/pkg2.go /example/pkg2/pkg2_test.go
some-linter /example/pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "per-dir"
working_dir = "dir"
path_args = "dot"
some-linter .
cd /example/pkg1
some-linter .
cd /example/pkg2
some-linter .
cd /example/pkg2/subpkg
some-linter .

[commands.some-linter]
invoke = "per-dir"
working_dir = "dir"
path_args = "none"
some-linter
cd /example/pkg1
some-linter
cd /example/pkg2
some-linter
cd /example/pkg2/subpkg
some-linter

[commands.some-linter]
invoke = "per-dir"
working_dir.chdir_to = "pkg1"
path_args = "file"
cd /example/pkg1
some-linter ../app.go ../main.go
some-linter ../pkg2/pkg2.go ../pkg2/pkg2_test.go
some-linter ../pkg2/subpkg/subpkg.go
some-linter pkg1.go

[commands.some-linter]
invoke = "per-dir"
working_dir.chdir_to = "pkg1"
path_args = "absolute-file"
cd /example/pkg1
some-linter /example/app.go /example/main.go
some-linter /example/pkg1/pkg1.go
some-linter /example/pkg2/pkg2.go /example/pkg2/pkg2_test.go
some-linter /example/pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "per-dir"
working_dir.chdir_to = "pkg1"
path_args = "dir"
cd /example/pkg1
some-linter .
some-linter ..
some-linter ../pkg2
some-linter ../pkg2/subpkg

[commands.some-linter]
invoke = "per-dir"
working_dir.chdir_to = "pkg1"
path_args = "absolute-dir"
cd /example/pkg1
some-linter /example
some-linter /example/pkg1
some-linter /example/pkg2
some-linter /example/pkg2/subpkg

[commands.some-linter]
invoke = "once"
working_dir = "root"
path_args = "file"
some-linter \
    app.go \
    main.go \
    pkg1/pkg1.go \
    pkg2/pkg2.go \
    pkg2/pkg2_test.go \
    pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "once"
working_dir = "root"
path_args = "absolute-file"
some-linter \
    /example/app.go \
    /example/main.go \
    /example/pkg1/pkg1.go \
    /example/pkg2/pkg2.go \
    /example/pkg2/pkg2_test.go \
    /example/pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "once"
working_dir = "root"
path_args = "dir"
some-linter . pkg1 pkg2 pkg2/subpkg

[commands.some-linter]
invoke = "once"
working_dir = "root"
path_args = "absolute-dir"
some-linter \
    /example \
    /example/pkg1 \
    /example/pkg2 \
    /example/pkg2/subpkg

[commands.some-linter]
invoke = "once"
working_dir = "root"
path_args = "dot"
some-linter .

[commands.some-linter]
invoke = "once"
working_dir = "root"
path_args = "none"
some-linter

[commands.some-linter]
invoke = "once"
working_dir.chdir_to = "pkg1"
path_args = "file"
cd /example/pkg1
some-linter ../app.go ../main.go pkg1.go ../pkg2/pkg2.go ../pkg2/pkg2_test.go ../pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "once"
working_dir.chdir_to = "pkg1"
path_args = "absolute-file"
cd /example/pkg1
some-linter \
    /example/app.go \
    /example/main.go \
    /example/pkg1/pkg1.go \
    /example/pkg2/pkg2.go \
    /example/pkg2/pkg2_test.go \
    /example/pkg2/subpkg/subpkg.go

[commands.some-linter]
invoke = "once"
working_dir.chdir_to = "pkg1"
path_args = "dir"
cd /example/pkg1
some-linter .. . ../pkg2 ../pkg2/subpkg

[commands.some-linter]
invoke = "once"
working_dir.chdir_to = "pkg1"
path_args = "absolute-dir"
cd /example/pkg1
some-linter /example /example/pkg1 /example/pkg2 /example/pkg2/subpkg

[commands.some-linter]
invoke = "once"
working_dir.chdir_to = "pkg1"
path_args = "dot"
cd /example/pkg1
some-linter .

[commands.some-linter]
invoke = "once"
working_dir.chdir_to = "pkg1"
path_args = "none"
cd /example/pkg1
some-linter