-
Notifications
You must be signed in to change notification settings - Fork 180
How to Run Tai‐e? (command‐line options)
Before running Tai-e, please finish following steps:
- Install Java 17 (or higher version) on your system (Tai-e is developed in Java, and it runs on all major operating systems including Windows/Linux/macOS).
- Clone submodule
java-benchmarks
(this repo contains the Java libraries used by the analysis; it is large and may take a while to clone):git submodule update --init --recursive
The main class (entry) of Tai-e is pascal.taie.Main
, and we classified its options into three categories:
- Program options: specifying the program to analyze.
- Analysis options: specifying the analyses to execute.
- Other options
Below we introduce these options.
These options specify the Java program (say P) and library to be analyzed.
Currently, Tai-e leverages Soot frontend to parse Java programs and help build Tai-e’s IR. Soot contains two frontends, one for parsing Java source files (.java) and the other one for bytecode files (.class). The former is outdated (only partially supports Java versions up to 7); while the latter, though quite robust (works properly for the .class files compiled by up to Java 17), cannot fully satisfy our requirements. Hence, we plan to develop our own frontend for Tai-e to address the above issues. For now, we advice using Tai-e to analyze bytecode, instead of source code, if possible.
- Class paths (-cp, --class-path):
-cp <path>[:<path>...]
- Class paths for Tai-e to locate the classes of P, and multiple paths are separated by
;
. Currently, Tai-e supports following types of paths:- Relative/Absolute path to a jar file
- Relative/Absolute path to a directory which contains
.class
(or.java
) files
- Class paths for Tai-e to locate the classes of P, and multiple paths are separated by
Note that the path separator varies on different systems: it is
:
on Unix-like systems, and;
on Windows.
-
Main class (-m, --main-class):
-m <main-class>
- The main class (entry) of P. This class must declare a method with signature
public static void main(String[])
.
- The main class (entry) of P. This class must declare a method with signature
-
Input classes (--input-classes):
--input-classes=<inputClasses>[,<inputClasses>...]
- Add classes to the closed-world of P. Some Java programs use dynamic class loading so that Tai-e cannot reference to the relevant classes from the main class. Such classes can be added to the closed world by this option.
-
Java version (-java):
-java <version>
- Default value: 6
- Specify the version of Java library used in the analyses. When this option is given, Tai-e will locate the corresponding Java library in submodule
java-benchmarks
and add it to the class paths. Currently, we provide libraries for Java versions 3, 4, 5, 6, 7, and 8. Support for newer Java versions is under development.
-
Prepend JVM Class Path (-pp, --prepend-JVM)
- Prepend the class path of the JVM (which runs Tai-e) to the analysis class path. This means that if you run Tai-e with Java 17, then you can use Tai-e to analyze the library of Java 17. Note that this option will disable
-java
option.
- Prepend the class path of the JVM (which runs Tai-e) to the analysis class path. This means that if you run Tai-e with Java 17, then you can use Tai-e to analyze the library of Java 17. Note that this option will disable
-
Allow phantom references (-ap, --allow-phantom)
- Allow Tai-e to process phantom references, i.e., the referenced classes that are not found in the class paths.
These options decide the analyses to be executed and their behaviors. We divided these options into two groups: general analysis options which affect multiple analyses, and specific analysis options which are relevant to individual analysis.
-
Build IR in advance (--pre-build-ir)
- Build IRs for all available methods before starting any analyses.
-
Analysis scope (-scope):
-scope <scope>
-
Default value:
APP
- Specify the analysis scope for class and method analyses. There are three valid choices:
-
APP
: application classes only -
ALL
: all classes -
REACHABLE
: classes that are reachable in the call graph (this scope requires analysiscg
, i.e., call graph construction)
-
-
Default value:
To execute an analysis, you need to specify its id and options (if necessary). All available analyses in Tai-e and their information (e.g., id and available options) are listed in the analysis configuration file src/main/resources/tai-e-analyses.yml
.
There are two mutually-exclusive approaches to specify the analyses, by command-line options or by file, as described below.
Specify analyses by command-line options. For running analysis with id A
, just give -a A
. For specifying some analysis options for A
, just append them to analysis id (connected by =
), and separate them by ;
, for example:
-a A=enableX:true;threshold:100;log-level:info
Note that on Unix-like systems (e.g., Linux), you may need to quote the option values when they include
;
, for example:
-a "A=enableX:true;threshold:100;log-level:info"
The option system is expressive, and it supports various types of option values, such as boolean, string, integer, and list.
Option -a
is repeatable, so that if you need to execute multiple analyses in a single run of Tai-e, say A1
and A2
, just repeat -a
like: -a A1 -a A2
.
Alternatively, you can specify the analyses to be executed (called an analysis plan) in a plan file, and use -p
to process the file. Similar to -a
, you need to specify the id and options (if necessary) for each analysis in the file. The plan file should be written in YAML.
Note that options -a
and -p
are mutually-exclusive, thus you cannot specify them simultaneously. See Analysis Management for more information about these two options.
-
Help (-h, --help)
- Print help information for all available options. This option will disable all other given options.
-
Options file (--options-file):
--options-file <optionsFile>
- You can specify the command-line options in a file and use
--options-file
to process the file. When this option is given, Tai-e ignores all other command-line options, and only processes the options in the file. The options file should be written in YAML. - Tai-e will output all options to
output/options.yml
at each run if this option is not given.
- You can specify the command-line options in a file and use
-
Generate plan file (-g, --gen-plan-file)
- Merely generate analysis plan file (the plan will not be executed) to
output/tai-e-plan.yml
. - This option works only when the analysis plan is specified by option
-a
, and it is provided to help the user compose analysis plan file.
- Merely generate analysis plan file (the plan will not be executed) to
We give an example of how to analyze a program by Tai-e. Suppose we want to analyze a program P as described below:
-
P consists of two jar files:
foo.jar
andbar.jar
-
P's main class is
baz.Main
- P is analyzed together with Java 8
- we run 2-type-sensitive pointer analysis and merge all string constants in P
Then the options would be:
java -cp tai-e-all.jar pascal.taie.Main -cp foo.jar;bar.jar -m baz.Main -java 8 -a pta=cs:2-type;merge-string-constants:true