xref: /aosp_15_r20/external/go-cmp/cmp/report.go (revision 88d15eac089d7f20c739ff1001d56b91872b21a1)
1*88d15eacSSasha Smundak// Copyright 2017, The Go Authors. All rights reserved.
2*88d15eacSSasha Smundak// Use of this source code is governed by a BSD-style
3*88d15eacSSasha Smundak// license that can be found in the LICENSE file.
4*88d15eacSSasha Smundak
5*88d15eacSSasha Smundakpackage cmp
6*88d15eacSSasha Smundak
7*88d15eacSSasha Smundak// defaultReporter implements the reporter interface.
8*88d15eacSSasha Smundak//
9*88d15eacSSasha Smundak// As Equal serially calls the PushStep, Report, and PopStep methods, the
10*88d15eacSSasha Smundak// defaultReporter constructs a tree-based representation of the compared value
11*88d15eacSSasha Smundak// and the result of each comparison (see valueNode).
12*88d15eacSSasha Smundak//
13*88d15eacSSasha Smundak// When the String method is called, the FormatDiff method transforms the
14*88d15eacSSasha Smundak// valueNode tree into a textNode tree, which is a tree-based representation
15*88d15eacSSasha Smundak// of the textual output (see textNode).
16*88d15eacSSasha Smundak//
17*88d15eacSSasha Smundak// Lastly, the textNode.String method produces the final report as a string.
18*88d15eacSSasha Smundaktype defaultReporter struct {
19*88d15eacSSasha Smundak	root *valueNode
20*88d15eacSSasha Smundak	curr *valueNode
21*88d15eacSSasha Smundak}
22*88d15eacSSasha Smundak
23*88d15eacSSasha Smundakfunc (r *defaultReporter) PushStep(ps PathStep) {
24*88d15eacSSasha Smundak	r.curr = r.curr.PushStep(ps)
25*88d15eacSSasha Smundak	if r.root == nil {
26*88d15eacSSasha Smundak		r.root = r.curr
27*88d15eacSSasha Smundak	}
28*88d15eacSSasha Smundak}
29*88d15eacSSasha Smundakfunc (r *defaultReporter) Report(rs Result) {
30*88d15eacSSasha Smundak	r.curr.Report(rs)
31*88d15eacSSasha Smundak}
32*88d15eacSSasha Smundakfunc (r *defaultReporter) PopStep() {
33*88d15eacSSasha Smundak	r.curr = r.curr.PopStep()
34*88d15eacSSasha Smundak}
35*88d15eacSSasha Smundak
36*88d15eacSSasha Smundak// String provides a full report of the differences detected as a structured
37*88d15eacSSasha Smundak// literal in pseudo-Go syntax. String may only be called after the entire tree
38*88d15eacSSasha Smundak// has been traversed.
39*88d15eacSSasha Smundakfunc (r *defaultReporter) String() string {
40*88d15eacSSasha Smundak	assert(r.root != nil && r.curr == nil)
41*88d15eacSSasha Smundak	if r.root.NumDiff == 0 {
42*88d15eacSSasha Smundak		return ""
43*88d15eacSSasha Smundak	}
44*88d15eacSSasha Smundak	ptrs := new(pointerReferences)
45*88d15eacSSasha Smundak	text := formatOptions{}.FormatDiff(r.root, ptrs)
46*88d15eacSSasha Smundak	resolveReferences(text)
47*88d15eacSSasha Smundak	return text.String()
48*88d15eacSSasha Smundak}
49*88d15eacSSasha Smundak
50*88d15eacSSasha Smundakfunc assert(ok bool) {
51*88d15eacSSasha Smundak	if !ok {
52*88d15eacSSasha Smundak		panic("assertion failure")
53*88d15eacSSasha Smundak	}
54*88d15eacSSasha Smundak}
55