query

package
v5.3.0+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 8, 2016 License: Apache-2.0 Imports: 11 Imported by: 12

Documentation

Overview

Package query implements a simple query language for Please.

Currently supported operations:

'deps': 'plz query deps //src:please'
        shows the dependency graph of this target.
'somepath': 'plz query somepath //src:please //src/parse/rules:java_rules_pyc'
            finds a route between these two targets, if there is one.
            useful for saying 'why on earth do I depend on that thing?'
'alltargets': 'plz query alltargets //src/...'
              shows all targets currently in the graph. careful in large repos!
'print': 'plz query print //src:please'
         produces a python-like function call that would define the rule.
'completions': 'plz query completions //sr'
         produces a list of possible completions for the given stem.
'affectedtargets': 'plz query affectedtargets path/to/changed_file.py'
         produces a list of test targets which have a transitive dependency on
         the given file.
'input': 'plz query input //src:label' produces a list of all the files
         (including transitive deps) that are referenced by this rule.
'output': 'plz query output //src:label' produces a list of all the files
          that are output by this rule.
'graph': 'plz query graph' produces a JSON representation of the build graph
         that other programs can interpret for their own uses.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func QueryAffectedTargets

func QueryAffectedTargets(graph *core.BuildGraph, files, include, exclude []string, tests bool)

QueryAffectedTargets walks over the build graph and identifies all targets that have a transitive dependency on the given set of files. Targets are filtered by given include / exclude labels and if 'tests' is true only test targets will be returned.

func QueryAllTargets

func QueryAllTargets(graph *core.BuildGraph, labels core.BuildLabels, showHidden bool)

QueryAllTargets simply prints all the targets according to some expression.

func QueryCompletionLabels

func QueryCompletionLabels(config *core.Configuration, args []string, repoRoot string) []core.BuildLabel

QueryCompletionLabels produces a set of labels that complete a given input.

func QueryCompletions

func QueryCompletions(graph *core.BuildGraph, labels []core.BuildLabel, binary, test bool)

Queries a set of possible completions for some build labels. If 'binary' is true it will complete only targets that are runnable binaries (but not tests). If 'test' is true it will similarly complete only targets that are tests.

func QueryDeps

func QueryDeps(graph *core.BuildGraph, labels []core.BuildLabel)

QueryDeps prints all transitive dependencies of a set of targets.

func QueryGraph

func QueryGraph(graph *core.BuildGraph, targets []core.BuildLabel)

QueryGraph prints a representation of the build graph as JSON.

func QueryPrint

func QueryPrint(graph *core.BuildGraph, labels []core.BuildLabel)

QueryPrint produces a Python call which would (hopefully) regenerate the same build rule if run. This is of course not ideal since they were almost certainly created as a java_library or some similar wrapper rule, but we've lost that information by now.

func QuerySomePath

func QuerySomePath(graph *core.BuildGraph, label1 core.BuildLabel, label2 core.BuildLabel)

QuerySomePath finds and returns a path between two targets. Useful for a "why on earth do I depend on this thing" type query.

func QueryTargetInputs

func QueryTargetInputs(graph *core.BuildGraph, labels []core.BuildLabel)

QueryTargetInputs prints all inputs for a single target.

func QueryTargetOutputs

func QueryTargetOutputs(graph *core.BuildGraph, labels []core.BuildLabel)

QueryTargetOutputs prints all output files for a set of targets.

func ReverseDeps

func ReverseDeps(graph *core.BuildGraph, labels []core.BuildLabel)

ReverseDeps For each input label, finds all targets which depend upon it.

func WhatOutputs

func WhatOutputs(graph *core.BuildGraph, files []string, printFiles bool)

WhatOutputs prints the target responsible for producing each of the provided files The targets are printed in the same order as the provided files, separated by a newline Use printFiles to additionally echo the files themselves (i.e. print <file> <target>)

Types

type JSONGraph

type JSONGraph struct {
	Packages map[string]JSONPackage `json:"packages"`
}

JSONGraph is an alternate representation of our build graph; will contain different information to the structures in core (also those ones can't be printed as JSON directly).

type JSONPackage

type JSONPackage struct {
	Targets map[string]JSONTarget `json:"targets"`
}

JSONPackage is an alternate representation of a build package

type JSONTarget

type JSONTarget struct {
	Inputs   []string `json:"inputs,omitempty" note:"declared inputs of target"`
	Outputs  []string `json:"outs,omitempty" note:"corresponds to outs in rule declaration"`
	Sources  []string `json:"srcs,omitempty" note:"corresponds to srcs in rule declaration"`
	Deps     []string `json:"deps,omitempty" note:"corresponds to deps in rule declaration"`
	Data     []string `json:"data,omitempty" note:"corresponds to data in rule declaration"`
	Labels   []string `json:"labels,omitempty" note:"corresponds to labels in rule declaration"`
	Requires []string `json:"requires,omitempty" note:"corresponds to requires in rule declaration"`
	Hash     string   `json:"hash" note:"partial hash of target, does not include source hash"`
	Test     bool     `json:"test,omitempty" note:"true if target is a test"`
	Binary   bool     `json:"binary,omitempty" note:"true if target is a binary"`
	TestOnly bool     `json:"test_only,omitempty" note:"true if target should be restricted to test code"`
}

JSONTarget is an alternate representation of a build target

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL