Skip to content

Using the Code Generator

philhofer edited this page Nov 13, 2014 · 7 revisions

Intro

The msgp code generator takes Go code as input and spits out more Go code as output. More specifically, the msgp command takes the struct type definitions in a particular Go source file and outputs a number of methods for that type in order to serialize it to/from MessagePack.

Generated Methods

By default, the generator generates implementations for all of the following interfaces:

  • msgp.Marshaler
  • msgp.Unmarshaler
  • msgp.Sizer
  • msgp.Decodable
  • msgp.Encodable

Additionally, the generator will generate tests and benchmarks for the implemented methods. You can turn the generation of particular method sets and tests on and off with flags passed to the generator.

Options

The following flags are supported:

  • -o - output file name (default is {filename}_gen.go)
  • -file - input file name (default is $GOPATH/src/$GOPACKAGE/$GOFILE, which are set by the go generate command)
  • -pkg - output package name (default is $GOPACKAGE)
  • -io - satisfy the msgp.Decodable and msgp.Encodable interfaces (default is true)
  • -marshal - satisfy the msgp.Marshaler and msgp.Unmarshaler interfaces (default is true)
  • -tests - generate tests and benchmarks (default is true)

Using the Generator with go generate

If you want to run the generator with the default options, all you need to include in your source file is one commented line:

//go:generate msgp

Provided that you have msgp and the go generate tool installed, all you should have to do is run go generate in the same directory as your source file to invoke the generator.

If, for example, you wanted the output file to be called stuff.go and you didn't want to generate tests, you would instead use:

//go:generate msgp -o=stuff.go -tests=false

Invoking the Generator Manually

If you want to run the generator without using go generate, the -file and -pkg flags become non-optional. If you wanted to run the generator on my_structs.go, which was part of package main, then you would run, in the source directory (assuming msgp was installed and $GOBIN is in your $PATH):

msgp -file=my_structs.go -pkg=main
Clone this wiki locally