diff --git a/1034-bug-fix-bodyinterceptor-dead-assignment-eliminator-1_preview/404.html b/1034-bug-fix-bodyinterceptor-dead-assignment-eliminator-1_preview/404.html new file mode 100644 index 00000000000..33b6d712a0f --- /dev/null +++ b/1034-bug-fix-bodyinterceptor-dead-assignment-eliminator-1_preview/404.html @@ -0,0 +1,1001 @@ + + + +
+ + + + + + + + + + + + + + +i.e. What should be analyzed. An AnalysisInputLocation
points to code input SootUp can analyze.
+We ship multiple Implementations that can handle different input.
Additionally you can specify a SourceType. This determines what is considered e.g. in the CallGraphs generation. +Further you can specify a List of BodyInterceptors, which will optimize the raw Jimple IR that was transformed from the input.
+The DefaultRTJaAnalysisInputLocation
points to the rt.jar of the executing JVM.
1 +2 |
|
To include a different Java Runtime library point to any rt.jar via a JavaClassPathAnalysisInputLocation
as its a usual .jar file.
The JRTFilesystemAnalysisInputLocation
points to the jigsawed java runtime of the executing JVM.
1 +2 |
|
If you have errors like Java.lang.String, Java.lang.Object, ... you are most likely missing this AnalysisInputLocation.
+File-Extensions: .class, .jar, .war
The JavaClassPathAnalysisInputLocation
is the equivalent of the classpath you would pass to the java executable i.e. point to root(s) of package(s).
1 +2 +3 |
|
1 +2 +3 +4 +5 +6 +7 |
|
1 +2 +3 +4 +5 |
|
1 +2 +3 |
|
File-Extensions: .java
With the OTFCompileAnalysisInputLocation
you can point directly to .java files or pass a String with Java sourcecode.
+The AnalysisInputLocation delegates the data to the JavaCompiler
and transform the bytecode from the compiler to Jimple.
1 +2 |
|
1 +2 +3 |
|
1 +2 +3 |
|
JavaSourcePathInputLocation
experimental! - points to a directory that is the root source directory (containing the package directory structure).
File-Extensions: .jimple
The JimpleAnalysisInputLocation
needs a Path to a .jimple file or a directory.
1 +2 +3 |
|
File-Extensions: .apk
The ApkAnalysisInputLocation
is the APK frontend written for Sootup
1 +2 +3 |
|
File-Extensions: .apk
The ApkAnalysisInputLocation
currently uses dex2jar internally
1 +2 +3 |
|
1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 +10 +11 +12 +13 +14 +15 +16 +17 +18 |
|
A SootUp solution to directly generate Jimple is WIP!
+But what if I want to point to multiple AnalysisInputLocations?
+1 +2 +3 +4 +5 +6 +7 |
|
Of course you can combine different types of AnalysisInputLocation
s as well!
This uses mvn compile
+ JavaClassPathAnalysisInputLocation
under the hood to include a maven project.
+
1 |
|
Unfortunately its harder to extract the path of the binary result of Gradle projects in a unified way for all kinds of models - If you have a solution are looking forward to merge your contribution :-).
+We created a Utility that parses a String of java command line arguments and configures SootUp respectively.
+ + + + + + + + + + + + + +We would like to announce Soot’s successor, SootUp.
+Over more than 20 years, Soot has become one of the world’s most popular academic tool for Java and Android analysis and instrumentation. We thank all of you who have used and contributed to it over the years! It was your feedback and your contributions that helped it grow into such a versatile tool!
+However, over the years, the requirements for Soot have changed a lot, and given its original architecture, it was no longer quite up to the task. Soot was originally developed for ahead-of-time code transformation, particularly optimization, which has become very uncommon in Java. Current use cases center much more around powerful program analyses and program-understanding tasks.
+Today we are officially releasing SootUp, a new version of Soot with a completely overhauled architecture. With SootUp, we aim to keep the best things about Soot, yet overcome a lot of its drawbacks. We very much restructured Soot, particularly abolishing the heavy use of singletons. Soot now has a concept of views; each view corresponds to some version or variant of an analyzed program, and multiple views can be kept in memory at the same time. This sets the foundation, for instance, for differential or incremental program analyses.
+SootUp is a library that can easily be included in other projects, leaving those projects in control. For those who intend to use it as a framework, with inversion of control, SootUp provides additional templates that help you and novices to get started more easily. The Jimple IR has been slightly simplified, and has been made immutable by default such that internally SootUp can make use of caching where desired. Where required, Jimple transformations are still allowed, but in a systematic manner, for instance assuring that analyses depending on the transformed code are notified about its changes.
+Below is an overview of what’s new.
+SootUp is not a drop-in replacement for Soot! Due to its completely new architecture and API it is essentially an almost complete rewrite. For a while, Soot and SootUp will coexist, as many existing tools depend on Soot, yet our maintenance efforts will henceforth be focused on SootUp, not Soot, and on extending SootUp with those capabilities that people still find missing. For now, we recommend using SootUp for greenfield projects.
+For more details, check out
+This Page ;-) and The SootUp repository: https://github.com/soot-oss/SootUp/
+We are very much looking forward to your feedback and feature requests. To this end, best create appropriate issues in the repository.
+This major upgrade of Soot was made possible by generous competitive funding by the DFG, within the project “Future-proofing the Soot Framework for Program Analysis +and Transformation (FutureSoot)”. It was funded in the DFG’s program on Research Software Sustainability.
+ + + + + + + + + + + + + +