-
Notifications
You must be signed in to change notification settings - Fork 335
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
this[type] is not a function #333
Comments
escodegen doesn't currently support serializing the JSX-related AST nodes. There's an old fork, but that only works with esprima-fb, which is no longer maintained. It seems like it would be possible to move escodegen-jsx forward, adapt to the AST format differences, and turn it into a PR against escodegen. @Constellation, @michaelficarra, would that be a welcome contribution? |
@papandreou Where are the JSX AST nodes specified? How stable are they? What do people use today to codegen JSX code? Are there any estree-based parsers that also support JSX? |
It looks like this is as authoritative as it gets: https://github.com/facebook/jsx/blob/master/AST.md
Historically, quite stable. Latest addition was JSXSpreadChild in June 2016. I have to admit that I'm not well informed about whether more stuff is coming up, though.
There's babel-generator. From a quick glance Prettier comes with its own code generator that supports the JSX extensions.
esprima 3.0.0+ |
Any update on this issue? |
Any update on this ? Thanks ! |
@michaelficarra, any thoughts on what I wrote in #333 (comment) wrt. whether JSX support would be a welcome addition? |
@michaelficarra bump ^^ inquiring minds want to know :) |
@papandreou @erquhart Since JSX seems to be a thing that people are continuing to do, I'm okay with having escodegen support it up to the point that it doesn't sacrifice the original goal of escodegen being able to correctly, unambiguously, and minimally generate source text for any estree format AST. I'm not volunteering to do the work to add that support, but I'll review/merge PRs to the best of my ability. |
Glad to hear you're open to it! Reviewing and merging is plenty of work on it's own, thanks for being up to it. It looks like the general test suite is against an in-repo copy of esprima 1.0.0, but JSX support requires at least 3.0. If we prefer not to test against the esprima npm dependency, we could paste in 3.0 or 4.0 and add a dedicated suite for JSX mirroring the approach in |
I'm not sure why we wouldn't just use an npm dev dependency. |
I'm not either, but your current test suites don't. Just looking to match whatever you as maintainers prefer. I assumed you were pinned to that test copy of 1.0.0 as a common denominator (and non-moving target). Should we just use npm instead of that copy, and add the JSX tests to the general suite, or leave the general suite as is and use the npm copy for a separate JSX suite? |
The only issue I'm seeing that's complicating things a bit is how esprima returns Literal nodes with their
This is also one of two test failures that surfaces when using the npm copy of esprima in the general For now I'm going to just return the |
PR is up with full support, outstanding points of discussion noted in the OP. @papandreou you're pretty great with syntax related things, if you're still interested in this and have time to give this a pass to see if I missed anything, please do! You can open a PR against my branch to address gaps as well. |
How can i resolve it , please !!! |
@AwesomeDevin, you can take @erquhart's PR for a spin and help him QA and finish it :) |
Yeah it's definitely not dead, I just got temporarily pulled away from the work that needed it. The PR does need some improvements, I noticed deficiencies compared to a prior JSX PR that was more robust, but that didn't make it through for some reason - and now I cannot find it for the life of me. Perhaps it was against another ES stringification lib. |
@papandreou @erquhart Are you still considering supporting JSX? |
I'm not actively working on it. |
Oh sorry to hear that 😞 so is it safe to say that this project is not maintained anymore? If so, i think it would be nice if it was mentioned in the readme. |
I'm not a maintainer of this project, and I was only talking about the JSX support, which @erquhart initiated work on. I think you're jumping to conclusions :) |
@papandreou Yeah sorry! I tagged the wrong person 😄 I meant to tag @michaelficarra |
Would we be able to sync this bad boy in here? https://github.com/wallabyjs/escodegen |
I'm need to modify js file. So I parse my JSX with esprima, make some changes and then I'm trying to code AST into js. But I have this error this[type] is not a function
Code
Parsing file:
Escoding:
The text was updated successfully, but these errors were encountered: