Summary: addzid automatically adds zid:"0"
, zid:"1"
, ... tags to your Go structs.
Given a set of golang (Go) source files, addzid will tag the public
struct fields with sequential zid tags. This prepares your source
so that it can be fed to the greenpack
codegen tool.
use: addzid {-o outdir} myGoSourceFile.go myGoSourceFile2.go ...
# addzid makes it easy to add Greenpack serialization[1] to Go source files.
# addzid reads .go files and adds `zid` tags to struct fields.
#
# options:
# -o="odir" specifies the directory to write to (created if need be).
# -unexported add tag to private fields of Go structs as well as public.
# -version shows build version with git commit hash.
# -debug print lots of debug info as we process.
# -OVERWRITE modify .go files in-place, adding zid tags (by default
# we write to the to -o dir).
#
# required: at least one .go source file for struct definitions.
# note: the .go source file to process must be listed last, after any options.
#
# [1] https://github.com/glycerine/greenpack
When you run addzid
, it will generate a modified copy of your go source files in the output directory.
These new versions include zid tags on all public fields of structs. You should inspect the copy of the source file in the output directory, and then replace your original source with the tagged version. Of course you can always manually add zid tags to fields, if you prefer. However addzid
simplifies this chore.
If you are feeling especially bold, addzid -OVERWRITE my.go
will replace my.go with the zid tagged version. For safety, only do this on backed-up and version controlled source files.
By default only public fields (with a Capital first letter in their name) are tagged. The -unexported flag ignores the public/private distinction, and tags all fields.
The zid tags allow the Greenpack schema evolution to function properly as you add new fields to structs.
see build.cmd
. Thanks to Klaus Post (http://klauspost.com) for contributing this.
cleanup internals: addzid
was adapted from bambam
, an earlier tool for generating CapnProto schema from Go files. Much vestigial code could be deleted as it isn't needed for addzid
's purposes.
Copyright (c) 2016, 2017 Jason E. Aten, Ph.D.