github.com/integration-system/go-cmp@v0.0.0-20190131081942-ac5582987a2f/README.md (about) 1 # Package for equality of Go values 2 3 [][godoc] 4 [][travis] 5 6 This package is intended to be a more powerful and safer alternative to 7 `reflect.DeepEqual` for comparing whether two values are semantically equal. 8 9 The primary features of `cmp` are: 10 11 * When the default behavior of equality does not suit the needs of the test, 12 custom equality functions can override the equality operation. 13 For example, an equality function may report floats as equal so long as they 14 are within some tolerance of each other. 15 16 * Types that have an `Equal` method may use that method to determine equality. 17 This allows package authors to determine the equality operation for the types 18 that they define. 19 20 * If no custom equality functions are used and no `Equal` method is defined, 21 equality is determined by recursively comparing the primitive kinds on both 22 values, much like `reflect.DeepEqual`. Unlike `reflect.DeepEqual`, unexported 23 fields are not compared by default; they result in panics unless suppressed 24 by using an `Ignore` option (see `cmpopts.IgnoreUnexported`) or explicitly 25 compared using the `AllowUnexported` option. 26 27 See the [GoDoc documentation][godoc] for more information. 28 29 This is not an official Google product. 30 31 [godoc]: https://godoc.org/github.com/integration-system/go-cmp/cmp 32 [travis]: https://travis-ci.org/google/go-cmp 33 34 ## Install 35 36 ``` 37 go get -u github.com/integration-system/go-cmp/cmp 38 ``` 39 40 ## License 41 42 BSD - See [LICENSE][license] file 43 44 [license]: https://github.com/integration-system/go-cmp/blob/master/LICENSE