36 lines
1.1 KiB
Go
36 lines
1.1 KiB
Go
// Copyright 2018, The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE.md file.
|
|
|
|
package cmpopts
|
|
|
|
import (
|
|
"github.com/google/go-cmp/cmp"
|
|
)
|
|
|
|
type xformFilter struct{ xform cmp.Option }
|
|
|
|
func (xf xformFilter) filter(p cmp.Path) bool {
|
|
for _, ps := range p {
|
|
if t, ok := ps.(cmp.Transform); ok && t.Option() == xf.xform {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// AcyclicTransformer returns a Transformer with a filter applied that ensures
|
|
// that the transformer cannot be recursively applied upon its own output.
|
|
//
|
|
// An example use case is a transformer that splits a string by lines:
|
|
// AcyclicTransformer("SplitLines", func(s string) []string{
|
|
// return strings.Split(s, "\n")
|
|
// })
|
|
//
|
|
// Had this been an unfiltered Transformer instead, this would result in an
|
|
// infinite cycle converting a string to []string to [][]string and so on.
|
|
func AcyclicTransformer(name string, xformFunc interface{}) cmp.Option {
|
|
xf := xformFilter{cmp.Transformer(name, xformFunc)}
|
|
return cmp.FilterPath(xf.filter, xf.xform)
|
|
}
|