-
-
Notifications
You must be signed in to change notification settings - Fork 355
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add support for type inference #2873
Comments
Do you mean that you want to add data-flow analysis for type inference?
How are you going to specify the type of |
Yes.
To my knowledge, nobody is working on this at the moment.
Are you interested in contributing on this?
|
Implementing data-flow analysis is a big task. I think the best approach is to use some SMT solver as a backend for this. Getting possible types statically is pretty much the same thing as getting possible values. But even with an SMT solver, it could not be 100% accurate - we need to handle loops, virtual function calls and so on. So I was curious how do you see data-flow analyzer in Spoon. |
What other tools do you know that do this for Java? |
I was quite curious, so I made a small data-flow analyzer with Spoon and Z3 SMT solver from Microsoft: https://github.com/Egor18/jdataflow Here are just several examples of what it is able to detect right now: void f(boolean c) {
int x = 5;
int y = c ? 3 : 2;
if (x < y) {} // <= always false
} void g(int x, int y) {
if (2 * x + 3 * y == 12) {
if (5 * x - 2 * y == 11) {
if (x == 3) {} // <= always true
if (y == 2) {} // <= always true
}
}
} void h(Something x) {
if (x == null) {
x.f(); // <= null dereference
}
} void m() {
C a = new C();
a.x = 10;
C b = a;
b.x = 20;
if (a.x == 20) {} // <= always true
} At the moment it calculates values only, but it should be relatively easy to add types too. |
Hi Egor, Cool to see progress here. Your README is remarkably clear, the test runner is clever and elegant, and the tests are quite comprehensive. Overall, this is impressive. Would you be interested in having this as a submodule in the Spoon main repo? (we already have two other submodules control-flow and decompiler) |
I'm ok with putting it into the main repo, but you'd probably want some different API. |
Excellent, that will be a super interesting module. Spoon modules are exactly meant for this: to be more experimental, more exploratory than spoon-core. Do you plan to improve the API in the short term? |
In fact, it is not clear how the "better" API should look like. I mean, it works for me (i.e. for doing some static analysis with checkers). |
Then, let's import an initial version as a Spoon module. A module can be experimental, the API will
evolve over time.
What would be a good name to your opinion? spoon-dataflow? spoon-symbolic?
|
spoon-dataflow seems good |
perfect, it seems we're along the same line to make the pull-request!
|
looking forward to your PR with |
I'm working on some minor improvements. Do you want it to be maven-based project or gradle is fine? |
great! gradle is fine, we can call gradle from Travis.
|
Spoon relies on the declared static of variables and methods.
For some transformations, it would be very useful to have the actual type of a variable / expression.
For this, we could add a method
getInferredType()
in the metamodel.The text was updated successfully, but these errors were encountered: