Rules
sh_binary
View rule sourceopen_in_newsh_binary rule is used to declare executable shell scripts.
( sh_binary is a misnomer: its outputs aren’t necessarily binaries.) This rule ensures
that all dependencies are built, and appear in the runfiles area at execution time.
We recommend that you name your sh_binary() rules after the name of the script minus
the extension (e.g. .sh); the rule name and the file name must be distinct.
sh_binary respects shebangs, so any available interpreter may be used (eg.
#!/bin/zsh)
Example
For a simple shell script with no dependencies and some data files:Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of “library” targets to be aggregated into this target.
See general comments about deps
at Typical attributes defined bymost build rules. This attribute should be used to list other
sh_library rules that provide
interpreted program source code depended on by the code in srcs. The files
provided by these rules will be present among the runfiles of this target.
srcs
List of labels; default is []
The file containing the shell script.
This attribute must be a singleton list, whose element is the shell script.
This script must be executable, and may be a source file or a generated file.
All other files required at runtime (whether scripts or data) belong in the
data attribute.
env_inherit
List of strings; default is []
use_bash_launcher
Boolean; default is False
Use a bash launcher initializing the runfiles library
sh_library
View rule sourceopen_in_newdata attribute of one or
more sh_binary rules.
You can use the filegroup rule to aggregate data
files.
In interpreted programming languages, there’s not always a clear
distinction between “code” and “data”: after all, the program is
just “data” from the interpreter’s point of view. For this reason
this rule has three attributes which are all essentially equivalent:
srcs, deps and data.
The current implementation does not distinguish between the elements of these lists.
All three attributes accept rules, source files and generated files.
It is however good practice to use the attributes for their usual purpose (as with other rules).
Examples
Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of “library” targets to be aggregated into this target.
See general comments about deps
at Typical attributes defined bymost build rules. This attribute should be used to list other
sh_library rules that provide
interpreted program source code depended on by the code in srcs. The files
provided by these rules will be present among the runfiles of this target.
srcs
List of labels; default is []
The list of input files.
This attribute should be used to list shell script source files that belong to
this library. Scripts can load other scripts using the shell’s source
or . command.
sh_test
View rule sourceopen_in_newsh_test() rule creates a test written as a Bourne shell script.
See the attributes common to all test rules (*_test).
Examples
Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of “library” targets to be aggregated into this target.
See general comments about deps
at Typical attributes defined bymost build rules. This attribute should be used to list other
sh_library rules that provide
interpreted program source code depended on by the code in srcs. The files
provided by these rules will be present among the runfiles of this target.
srcs
List of labels; default is []
The file containing the shell script.
This attribute must be a singleton list, whose element is the shell script.
This script must be executable, and may be a source file or a generated file.
All other files required at runtime (whether scripts or data) belong in the
data attribute.
use_bash_launcher
Boolean; default is False
Use a bash launcher initializing the runfiles library