-
Notifications
You must be signed in to change notification settings - Fork 50
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
Invalid Syntax Succeeds in Compilation, but Doesn't Load at Runtime #186
Comments
I believe that the compiler is behaving as intended. I compared the following code with both the Royale compiler (as used inside vscode-as3mxml) versus compiling to SWF with the Flex SDK: <s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark" xmlns:local="*">
<fx:Declarations>
<fx:String>{bindableObject..what}</fx:String>
<fx:String>{bindableString..what}</fx:String>
</fx:Declarations>
<fx:Script>
<![CDATA[
[Bindable]
public var bindableString:String = "Hello world";
[Bindable]
public var bindableObject:Object = {};
]]>
</fx:Script>
</s:Application> In both compilers, it results in one error only (for
However, there is no error for So, if the compiler knows the type, detecting an error seems to work correctly. If the type is That's the thing about having things typed as With that in mind, I would be opposed to adding an error. However, I think that a warning would be okay, as long as it only affects variables/properties typed as |
Oh, I didn't realize my example was a bit ambiguous. "someObject" wasn't to mean the type Object, but just any object. In my case, it was strongly typed; there was no error or warning in my compilation output. That is unless I'm missing something. I am using maven to build my project. |
That's strange considering that I saw an error with It's worth noting that even if you're always using classes, the variable type or function return type is what matters here. Example:
This variable is storing an instance of Similarly, something like There are a lot of ways in AS3 to end up falling back to |
As for runtime, I've noticed some strange issues with Royale that all seem related. Things stop working at some level of execution, but do not error or warn the user in any way. Perhaps that is as designed, but it has made some development a bit difficult. Here are a couple examples. This scenario: In this case, the file that contained the ".." was not initialized. Any declaration of the component was null at runtime. No error as to why, just simply didn't appear to load. Another: Hidden NPEs either in my code, or the asjs framework stop code execution within any component with no error. Here is an easy example that I recently ran into. The following code is within a simple MXML file.
Within this file, config is bound to various fields. Because of the NPE, none of the bindings for this field fire, even though the value is set before the NPE. No error appears in the console or debugger. It's as if it's caught and suppressed at runtime. I've been seeing stuff like this for a while now when developing with Royale. As for a framework example, a VirtualList will not render unless the ListPresentationModel is added with rowHeight set. This is because VirtualListVerticalLayout uses this value without checking for its existence. No error, no warning, no rendering of the list. Simply an empty component. Why are these NPE's swallowed? Is that as designed/expected? Is any of this related to the runtime aspect of this issue? If not, I will create a new issue. |
My codebase is 99.999+% strongly typed. I would rather know before runtime that something is not correct. It's possible I may be running into cases where it's falling back for unknown reasons, and I don't have a way of seeing how or why. With the runtime suppression I've been running into, I'm not sure how to intuitively debug these issues. |
I don't claim to speak for the framework developers because I work on the compiler only. However, as I understand it, this experience is a result of Royale's PAYG (Pay As You Go) philosophy. The idea is that your final app should contain basically everything it needs to function, and no more. In other words, no error checking for edge cases that you wouldn't encounter in a final app. The idea is that you're supposed to enable the edge case stuff and other developer niceties by manually adding the appropriate beads to your application or components (I'm not necessarily guaranteeing that those beads actually exist right in Royale now, but only that this the mechanism for how that sort of functionality would be enabled). Later, you can remove some of the development-only beads, if you're confident that everything is working as intended. The "Basic" component set is the ultimate realization of the PAYG philosophy. It is really meant to be bare minimum by default, with beads to enable more and more. The "Express" component set is supposed to build on Basic by adding some of these things by default that improve the development experience, instead of being required to do it manually. However, I haven't seen anyone working on Express very much lately, so I can't say what state that is in. Jewel is sort of a separate set of components from Basic/Express, but I think the idea is that it would be a bit closer to Express than to Basic. That's just kind of my impression as someone who doesn't work on or with the framework, but have been watching discussions closely enough to have a high level idea of what's going on. Maybe a framework dev can jump in and explain in more detail. |
In the case of "{someObject..someValue}", hovering over any names before the |
I can try to look into this next week. |
I've been finding random compilation issues that should be invalid, but seem to succeed.
Steps to Reproduce
Accidentally added two dots in a binding within MXML. In my case, I performed a refactor that mistakenly left two dots; an easy mistake to make.
Expected Results
Compilation should fail, or at least throw a warning.
Actual Results
Compiles successfully, but the resulting debug JS file is not usable at runtime without any warning or error. I'm not sure if it's failing to load, or some other issue.
Workaround
None that I know of at this time.
Comments
A mistake like this is likely an edge case, but is an easy mistake to make. The cost of running into it was rather large as it was hard to track down and took significant time to find/fix as there are no errors.
FYI, I am using
vscode-as3mxml
. I'm not sure if that is relevant or not with issue.The text was updated successfully, but these errors were encountered: