2013-01-08 23:35:50 -06:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2013 Dave Collins <dave@davec.name>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
Package spew implements a deep pretty printer for Go data structures to aid in
|
|
|
|
debugging.
|
|
|
|
|
|
|
|
A quick overview of the additional features spew provides over the built-in
|
|
|
|
printing facilities for Go data types are as follows:
|
|
|
|
|
|
|
|
* Pointers are dereferenced and followed
|
|
|
|
* Circular data structures are detected and handled properly
|
2013-01-13 00:17:58 -06:00
|
|
|
* Custom Stringer/error interfaces are optionally invoked, including
|
2013-01-08 23:35:50 -06:00
|
|
|
on unexported types
|
2013-01-13 00:17:58 -06:00
|
|
|
* Custom types which only implement the Stringer/error interfaces via
|
2013-01-08 23:35:50 -06:00
|
|
|
a pointer receiver are optionally invoked when passing non-pointer
|
|
|
|
variables
|
|
|
|
|
|
|
|
There are two different approaches spew allows for dumping Go data structures:
|
|
|
|
|
|
|
|
* Dump style which prints with newlines, customizable indentation,
|
|
|
|
and additional debug information such as types and all pointer addresses
|
|
|
|
used to indirect to the final value
|
|
|
|
* A custom Formatter interface that integrates cleanly with the standard fmt
|
|
|
|
package and replaces %v and %+v to provide inline printing similar
|
|
|
|
to the default %v while providing the additional functionality outlined
|
|
|
|
above and passing unsupported format verb/flag combinations such a %x,
|
|
|
|
%q, and %#v along to fmt
|
|
|
|
|
|
|
|
Quick Start
|
|
|
|
|
|
|
|
This section demonstrates how to quickly get started with spew. See the
|
|
|
|
sections below for further details on formatting and configuration options.
|
|
|
|
|
|
|
|
To dump a variable with full newlines, indentation, type, and pointer
|
|
|
|
information use Dump or Fdump:
|
|
|
|
spew.Dump(myVar1, myVar2, ...)
|
|
|
|
spew.Fdump(someWriter, myVar1, myVar2, ...)
|
|
|
|
|
|
|
|
Alternatively, if you would prefer to use format strings with a compacted inline
|
2013-01-17 18:43:51 -06:00
|
|
|
printing style, use the convenience wrappers Printf, Fprintf, etc with
|
|
|
|
%v (most compact), %+v (adds pointer addresses), %#v (adds types), or
|
|
|
|
%#+v (adds types and pointer addresses):
|
2013-01-08 23:35:50 -06:00
|
|
|
spew.Printf("myVar1: %v -- myVar2: %+v", myVar1, myVar2)
|
2013-01-17 18:43:51 -06:00
|
|
|
spew.Printf("myVar3: %#v -- myVar4: %#+v", myVar3, myVar4)
|
2013-01-08 23:35:50 -06:00
|
|
|
spew.Fprintf(someWriter, "myVar1: %v -- myVar2: %+v", myVar1, myVar2)
|
2013-01-17 18:43:51 -06:00
|
|
|
spew.Fprintf(someWriter, "myVar3: %#v -- myVar4: %#+v", myVar3, myVar4)
|
2013-01-08 23:35:50 -06:00
|
|
|
|
|
|
|
Configuration Options
|
|
|
|
|
2013-01-12 12:06:59 -06:00
|
|
|
Configuration of spew is handled by fields in the ConfigState type. For
|
|
|
|
convenience, all of the top-level functions use a global state available
|
|
|
|
via the spew.Config global.
|
|
|
|
|
2013-01-19 19:00:25 -06:00
|
|
|
It is also possible to create a ConfigState instance that provides methods
|
2013-01-12 12:06:59 -06:00
|
|
|
equivalent to the top-level functions. This allows concurrent configuration
|
2013-01-19 19:00:25 -06:00
|
|
|
options. See the ConfigState documentation for more details.
|
2013-01-12 12:06:59 -06:00
|
|
|
|
2013-01-08 23:35:50 -06:00
|
|
|
The following configuration options are available:
|
2013-01-12 12:06:59 -06:00
|
|
|
* Indent
|
2013-01-08 23:35:50 -06:00
|
|
|
String to use for each indentation level for Dump functions.
|
|
|
|
It is a single space by default. A popular alternative is "\t".
|
|
|
|
|
2013-01-19 19:45:01 -06:00
|
|
|
* MaxDepth
|
|
|
|
Maximum number of levels to descend into nested data structures.
|
|
|
|
There is no limit by default.
|
|
|
|
|
2013-01-12 12:06:59 -06:00
|
|
|
* DisableMethods
|
2013-01-08 23:35:50 -06:00
|
|
|
Disables invocation of error and Stringer interface methods.
|
|
|
|
Method invocation is enabled by default.
|
|
|
|
|
2013-01-12 12:06:59 -06:00
|
|
|
* DisablePointerMethods
|
2013-01-08 23:35:50 -06:00
|
|
|
Disables invocation of error and Stringer interface methods on types
|
|
|
|
which only accept pointer receivers from non-pointer variables.
|
|
|
|
Pointer method invocation is enabled by default.
|
|
|
|
|
|
|
|
Dump Usage
|
|
|
|
|
|
|
|
Simply call spew.Dump with a list of variables you want to dump:
|
|
|
|
|
|
|
|
spew.Dump(myVar1, myVar2, ...)
|
|
|
|
|
|
|
|
You may also call spew.Fdump if you would prefer to output to an arbitrary
|
|
|
|
io.Writer. For example, to dump to standard error:
|
|
|
|
|
|
|
|
spew.Fdump(os.Stderr, myVar1, myVar2, ...)
|
|
|
|
|
|
|
|
Sample Dump Output
|
|
|
|
|
|
|
|
See the Dump example for details on the setup of the types and variables being
|
|
|
|
shown here.
|
|
|
|
|
|
|
|
(main.Foo) {
|
|
|
|
unexportedField: (*main.Bar)(0xf84002e210)({
|
|
|
|
flag: (main.Flag) flagTwo,
|
|
|
|
data: (uintptr) <nil>
|
|
|
|
}),
|
|
|
|
ExportedField: (map[interface {}]interface {}) {
|
|
|
|
(string) "one": (bool) true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Custom Formatter
|
|
|
|
|
|
|
|
Spew provides a custom formatter the implements the fmt.Formatter interface
|
2013-01-10 15:43:40 -06:00
|
|
|
so that it integrates cleanly with standard fmt package printing functions. The
|
2013-01-08 23:35:50 -06:00
|
|
|
formatter is useful for inline printing of smaller data types similar to the
|
|
|
|
standard %v format specifier.
|
|
|
|
|
2013-01-17 18:43:51 -06:00
|
|
|
The custom formatter only responds to the %v (most compact), %+v (adds pointer
|
|
|
|
addresses), %#v (adds types), or %#+v (adds types and pointer addresses) verb
|
|
|
|
combinations. Any other verbs such as %x and %q will be sent to the the
|
|
|
|
standard fmt package for formatting. In addition, the custom formatter ignores
|
|
|
|
the width and precision arguments (however they will still work on the format
|
|
|
|
specifiers not handled by the custom formatter).
|
2013-01-08 23:35:50 -06:00
|
|
|
|
|
|
|
Custom Formatter Usage
|
|
|
|
|
|
|
|
The simplest way to make use of the spew custom formatter is to call one of the
|
|
|
|
convenience functions such as spew.Printf, spew.Println, or spew.Printf. The
|
2013-01-17 18:43:51 -06:00
|
|
|
functions have syntax you are most likely already familiar with:
|
2013-01-08 23:35:50 -06:00
|
|
|
|
|
|
|
spew.Printf("myVar1: %v -- myVar2: %+v", myVar1, myVar2)
|
2013-01-17 18:43:51 -06:00
|
|
|
spew.Printf("myVar3: %#v -- myVar4: %#+v", myVar3, myVar4)
|
2013-01-08 23:35:50 -06:00
|
|
|
spew.Println(myVar, myVar2)
|
|
|
|
spew.Fprintf(os.Stderr, "myVar1: %v -- myVar2: %+v", myVar1, myVar2)
|
2013-01-17 18:43:51 -06:00
|
|
|
spew.Fprintf(os.Stderr, "myVar3: %#v -- myVar4: %#+v", myVar3, myVar4)
|
2013-01-08 23:35:50 -06:00
|
|
|
|
|
|
|
See the Index for the full list convenience functions.
|
|
|
|
|
|
|
|
Sample Formatter Output
|
|
|
|
|
2013-01-17 18:43:51 -06:00
|
|
|
Double pointer to a uint8:
|
|
|
|
%v: <**>5
|
|
|
|
%+v: <**>(0xf8400420d0->0xf8400420c8)5
|
|
|
|
%#v: (**uint8)5
|
|
|
|
%#+v: (**uint8)(0xf8400420d0->0xf8400420c8)5
|
|
|
|
|
|
|
|
Pointer to circular struct with a uint8 field and a pointer to itself:
|
|
|
|
%v: <*>{1 <*><shown>}
|
|
|
|
%+v: <*>(0xf84003e260){ui8:1 c:<*>(0xf84003e260)<shown>}
|
|
|
|
%#v: (*main.circular){ui8:(uint8)1 c:(*main.circular)<shown>}
|
|
|
|
%#+v: (*main.circular)(0xf84003e260){ui8:(uint8)1 c:(*main.circular)(0xf84003e260)<shown>}
|
2013-01-08 23:35:50 -06:00
|
|
|
|
|
|
|
See the Printf example for details on the setup of variables being shown
|
|
|
|
here.
|
|
|
|
|
|
|
|
Errors
|
|
|
|
|
2013-01-13 00:17:58 -06:00
|
|
|
Since it is possible for custom Stringer/error interfaces to panic, spew
|
2013-01-08 23:35:50 -06:00
|
|
|
detects them and handles them internally by printing the panic information
|
|
|
|
inline with the output. Since spew is intended to provide deep pretty printing
|
|
|
|
capabilities on structures, it intentionally does not return any errors.
|
|
|
|
*/
|
|
|
|
package spew
|