allowtags

command module
v0.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 25, 2024 License: MIT Imports: 2 Imported by: 0

README

AllowTags

AllowTags is a golang linter that checks all tags on struct fields have keys matching one of the given set. Also does some validation of tag formatting.

AllowTags provides more peace of mind when working with struct tags, especially since the golang compiler won't report misspellings.

Installing

AllowTags is provided as a go module and can be installed by running go install github.com/ashmrtn/allowtags@latest

Running

AllowTags uses a similar front-end to go vet. You can run AllowTags by executing allowtags --allow-key key1 --allow-key key2 <packages> after installation. You can pass multiple packages to AllowTags by using the ... expression, just like you would with other tools. For example, to check your whole project with AllowTags just run allowtags --allow-key key1 ./....

Flags

AllowTags requires all tags that it allows be explicitly given. To specify multiple tag keys pass the --allow-key flag multiple times, each time with a different tag key, or separate different tag keys with a comma.

Limitations

AllowTags uses a different parsing method than govet and the golang standard library's tag parser. This means it may give different error messages compared to govet and the standard library when run on malformed tags. However, AllowTags is built to be fairly lenient when parsing tags and attempts to find key-value pairs where possible.

The rules that AllowTags parses by are loosely derived from documentation in the golang standard library reflect package empirical testing of the standard library's behavior, and the idea of trying to find key-value pairs where possible even if the tag is not formatted as expected.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
pkg

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL