aboutsummaryrefslogtreecommitdiffstats
path: root/golang/kati/query.go
diff options
context:
space:
mode:
authorDan Willemsen <dwillemsen@google.com>2020-06-26 19:20:26 -0700
committerGitHub <noreply@github.com>2020-06-26 19:20:26 -0700
commit10cc982b563c19890872b73e6d8fb44aeda646ae (patch)
tree6b5075e832cbdf2a7996a25a26659363527b6e4c /golang/kati/query.go
parent003cf51e9b6da48063c90cf4c6710fde103c9c4a (diff)
parent979e7ae6e417ae4ee45e835104b66191ae16a14c (diff)
downloadplatform_build_kati-10cc982b563c19890872b73e6d8fb44aeda646ae.tar.gz
platform_build_kati-10cc982b563c19890872b73e6d8fb44aeda646ae.tar.bz2
platform_build_kati-10cc982b563c19890872b73e6d8fb44aeda646ae.zip
Merge pull request #199 from danw/refactor
Refactor source tree into directories
Diffstat (limited to 'golang/kati/query.go')
-rw-r--r--golang/kati/query.go99
1 files changed, 99 insertions, 0 deletions
diff --git a/golang/kati/query.go b/golang/kati/query.go
new file mode 100644
index 0000000..5da1f61
--- /dev/null
+++ b/golang/kati/query.go
@@ -0,0 +1,99 @@
+// Copyright 2015 Google Inc. All rights reserved
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package kati
+
+import (
+ "fmt"
+ "io"
+)
+
+func showDeps(w io.Writer, n *DepNode, indent int, seen map[string]int) {
+ id, present := seen[n.Output]
+ if !present {
+ id = len(seen)
+ seen[n.Output] = id
+ }
+ fmt.Fprintf(w, "%*c%s (%d)\n", indent, ' ', n.Output, id)
+ if present {
+ return
+ }
+ for _, d := range n.Deps {
+ showDeps(w, d, indent+1, seen)
+ }
+ if len(n.OrderOnlys) > 0 {
+ fmt.Fprintf(w, "%*corder_onlys:\n", indent, ' ')
+ for _, d := range n.OrderOnlys {
+ showDeps(w, d, indent+1, seen)
+ }
+ }
+}
+
+func showNode(w io.Writer, n *DepNode) {
+ fmt.Fprintf(w, "%s:", n.Output)
+ for _, i := range n.ActualInputs {
+ fmt.Fprintf(w, " %s", i)
+ }
+ fmt.Fprintf(w, "\n")
+ for _, c := range n.Cmds {
+ fmt.Fprintf(w, "\t%s\n", c)
+ }
+ for k, v := range n.TargetSpecificVars {
+ fmt.Fprintf(w, "%s: %s=%s\n", n.Output, k, v.String())
+ }
+
+ fmt.Fprintf(w, "\n")
+ fmt.Fprintf(w, "location: %s:%d\n", n.Filename, n.Lineno)
+ if n.IsPhony {
+ fmt.Fprintf(w, "phony: true\n")
+ }
+
+ seen := make(map[string]int)
+ fmt.Fprintf(w, "dependencies:\n")
+ showDeps(w, n, 1, seen)
+}
+
+func handleNodeQuery(w io.Writer, q string, nodes []*DepNode) {
+ for _, n := range nodes {
+ if n.Output == q {
+ showNode(w, n)
+ break
+ }
+ }
+}
+
+// Query queries q in g.
+func Query(w io.Writer, q string, g *DepGraph) {
+ if q == "$MAKEFILE_LIST" {
+ for _, mk := range g.accessedMks {
+ fmt.Fprintf(w, "%s: state=%d\n", mk.Filename, mk.State)
+ }
+ return
+ }
+
+ if q == "$*" {
+ for k, v := range g.vars {
+ fmt.Fprintf(w, "%s=%s\n", k, v.String())
+ }
+ return
+ }
+
+ if q == "*" {
+ for _, n := range g.nodes {
+ fmt.Fprintf(w, "%s\n", n.Output)
+ }
+ return
+ }
+ handleNodeQuery(w, q, g.nodes)
+}