Review Request 117458: Support for function expressions
Denis Steckelmacher
steckdenis at yahoo.fr
Fri Apr 11 14:38:33 UTC 2014
> On April 10, 2014, 3:12 p.m., Sven Brauch wrote:
> > duchain/declarationbuilder.cpp, line 162
> > <https://git.reviewboard.kde.org/r/117458/diff/3/?file=263994#file263994line162>
> >
> > Did you try this in some real-world JS code? Judging from what it is like in Python, something like this might have so many false positives that it's likely to do more harm than good ...
> > Instead, I would merge the old and new return type into an unsure type.
Can I do that in a future patch? As you said, this one is already fairly big (I'm sorry for that but I could not help but add features until I was sure the infrastructure was solid and future-proof). I have two patches that I would like post for review after this one: the one add support for UnsureTypes in return statements, and one that already works and that allows the type of variable to be determined after its declaration (like in "var a; a = 3;", where a becomes an int). I would also like to be able to infer that the parameter a in "function foo(a) {}; foo(3.14);" is of type int. I have ideas but I still need to experiment.
> On April 10, 2014, 3:12 p.m., Sven Brauch wrote:
> > duchain/helper.h, line 50
> > <https://git.reviewboard.kde.org/r/117458/diff/3/?file=263997#file263997line50>
> >
> > Do you really need to treat void as useless? void is a valid type, it might be the correct guess. And the information that e.g. a function returns void is useful (while "it returns mixed" is not).
isWeakTypes does not mean that a type is useless, but that the information it carries is less important that the one of other types. For instance, a function is by default declared as returning void. If a return statement is found, and because void is weak, the return statement's type will replace "void" as the return type of the function. If the function already has a non-weak return type (int, string, struct, etc), then a return statement having a weak type (for instance "mixed", when the type could not be inferred) will be ignored, the current return type of the function taking precedence.
If the return statement is of type "mixed" and the function currently returns "void", then its return type is set to "mixed" (because, actually, the function returns something).
If the function's return type and the type of the return statement are both strong and different, then I raise a warning (that will later be changed to an Unsure type).
- Denis
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/117458/#review55388
-----------------------------------------------------------
On April 11, 2014, 2:38 p.m., Denis Steckelmacher wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/117458/
> -----------------------------------------------------------
>
> (Updated April 11, 2014, 2:38 p.m.)
>
>
> Review request for KDevelop.
>
>
> Repository: kdev-qmljs
>
>
> Description
> -------
>
> This patch adds support for function expressions to the QML/JS plugin. This support required the following changes:
>
> * ExpressionVisitor stops visiting when it encounters a type (no need to traverse the AST down to its bottom if the top-most expression is enough to determine a type). This gives it a O(1) time complexity.
> * When DeclarationBuilder wants to know the type of an expression, it first visits this expression (to build any needed declaration), then only starts an ExpressionVisitor. This way, ExpressionVisitor knows all the declarations that may occur in the expression and is able to return its complete type. Moreover, if DeclarationBuilder has called getType (and has visited an expression), then will not enter the node it is visiting (as it already did so). This way, DeclarationBuilder keeps an O(n) time complexity.
> * These two changes are illustrated by the support of "var f = function() { return true; }" statements.
> * This patch also adds support for binary operators ("a == b" is always a boolean, "a << 2" is always an int, etc). This fixes a bug where the type of "(a == 5)" was wrongly guessed as "int"
>
> The support for function expressions is split between DeclarationBuilder and ExpressionVisitor. DeclarationBuilder, when it encounters a function expression, creates a declaration for it, giving it a name built from the hexadecimal representation of its FunctionExpression* node pointer. When DeclarationBuilder sees a return statement, it sets the type of the enclosing function (whether it is a function declaration or a function expression has no importance here). When ExpressionVisitor is used to find the type of an expression, and this expression is a function expression, then ExpressionVisitor will build the hexadecimal name of the function and use getDeclaration to find its type.
>
>
> Diffs
> -----
>
> duchain/CMakeLists.txt 9fab69c
> duchain/contextbuilder.h d53b2fe
> duchain/contextbuilder.cpp d38da2d
> duchain/declarationbuilder.h 001c3b2
> duchain/declarationbuilder.cpp 98da341
> duchain/expressionvisitor.h b4f0851
> duchain/expressionvisitor.cpp 766435d
> duchain/helper.h 23a6d0e
> duchain/helper.cpp 3ffdd56
> duchain/parsesession.h 0eb2762
> duchain/parsesession.cpp dbc4d90
> duchain/tests/testdeclarations.cpp 668efaa
> tests/files/helloworld.js ff40f1c
>
> Diff: https://git.reviewboard.kde.org/r/117458/diff/
>
>
> Testing
> -------
>
> All the unit tests of the QML/JS plugin pass with this patch. Three tests have been added:
>
> * The test for type inference is not expected to fail anymore, as the plugin is able to infer simple types
> * New test for "(a == b)" expressions
> * New test for "function() {}" expressions
>
> Manual testing shows that syntax highlighting is correct, and also the "outline" view. Building the anonymous declarations by passing them an empty range (RangeInRevision()) removes the anonymous function from the outline view and disables any highlighting related to this declaration in the source view. The function can still have a name which can be freely chosen by the plugin.
>
>
> Thanks,
>
> Denis Steckelmacher
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kdevelop-devel/attachments/20140411/37addd04/attachment-0001.html>
More information about the KDevelop-devel
mailing list