Skip to content
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

Incompatible with Babel JavaScript #4

Open
ezhlobo opened this issue Dec 18, 2018 · 11 comments
Open

Incompatible with Babel JavaScript #4

ezhlobo opened this issue Dec 18, 2018 · 11 comments

Comments

@ezhlobo
Copy link
Contributor

ezhlobo commented Dec 18, 2018

Hey. I'm not a user of VSCode so I'm not aware of how things work there, but it looks like this plugin doesn't work when we use Babel JavaScript (mgmcdermott.vscode-language-babel) plugin.

It will be nice to make it work with commonly used plugins.

@ezhlobo
Copy link
Contributor Author

ezhlobo commented Jan 8, 2019

@kaminaly hey, do you think you have a chance to help with this issue?

@kaminaly
Copy link
Owner

kaminaly commented Jan 8, 2019

@ezhlobo Sorry, I also couldn't notice this message :(
I will check this too.

@kaminaly
Copy link
Owner

@ezhlobo Hi, I'm not sure but it seems a Babel JavaScript side problem.
vscode-react-pug is injecting pug highlighting pattern to the default js highlighting pattern.
It looks Babel JavaScript redefine js highlighting pattern.

There are a lot of extensions which are using injection. I think they don't work with Babel JavaScript. I checked some extensions with Babel JavaScript. they didn't work.
https://github.com/search?l=JSON&q=injectTo+source.js&type=Code

@ezhlobo
Copy link
Contributor Author

ezhlobo commented Jan 15, 2019

@kaminaly hm, when babel re-define the pattern, is it possible to create another plugin on top of it to re-define the pattern again? For example now we rely on punctuation.definition.string.template.begin.js, maybe with Babel we should just rely on anything different? I tried to inspect the scope, and with Babel it provides punctuation.definition.quasi.begin.js.

I'm not sure but it seems a Babel JavaScript side problem.

If that's the case, do you think we can formulate the issue and share it with its maintainers?

Sorry for lots of questions, looks like Babel is so popular so I'm trying to understand if it's possible to support it :).

@kaminaly
Copy link
Owner

@ezhlobo I found an extension which is the same type of Babel JavaScript.

https://github.com/Microsoft/vscode-js-atom-grammar

According to the readme, This extension replaces the JavaScript grammar in Visual Studio Code with the JavaScript grammar from the Atom editor.
But I could use vscode-react-pug with vscode-js-atom-grammar when I checked them.

I thought the reason for the problem was to replace grammar. that was wrong.
Now, I guess a pattern of the type of string(``) in Babel JavaScript is stronger than injected one.
I don't know how to fix it yet though...

@ezhlobo
Copy link
Contributor Author

ezhlobo commented Feb 9, 2019

@kaminaly the real fix is to turn on Atom's grammar (which is used in Babel JavaScript). We can do that by installing official plugin:

https://marketplace.visualstudio.com/items?itemName=ms-vscode.js-atom-grammar

I believe if we add this information to the README on noticeable place, it will solve the issue for people who install your package and use "Babel JavaScript" plugin.

Are you able to add this information to README? So I'll be able to point my colleagues to exact place where they will find the solution for the problem :).

@ezhlobo
Copy link
Contributor Author

ezhlobo commented Feb 9, 2019

PS. Found this advice here: michaelgmcd/vscode-language-babel#34

@kaminaly
Copy link
Owner

@ezhlobo Ok, thanks for your advice. I will add the information to the Readme.

the Readme of vscode-js-atom-grammar recommends using the built-in JavaScript grammar.
I don't know which grammar is better. However, they will choose the right grammar for them :)

@ezhlobo
Copy link
Contributor Author

ezhlobo commented Feb 12, 2019

@kaminaly I still don't have strong knowledge in how things work there, so don't know how to comment their README.

What I understood (not 100% sure though) is that we either need to patch default grammar (that is what that plugin does) or completely override existed one (that is what babel-language does).

Don't know how they both connect with each other, but that made things work for me.

@kaminaly
Copy link
Owner

@ezhlobo do you mean that vscode-react-pug works with Babel JavaScript if it's using with vscode-js-atom-grammar at same time?
if so, I couldn't understand... my poor english skills... ;(

@ezhlobo
Copy link
Contributor Author

ezhlobo commented Feb 12, 2019

@kaminaly yep, two ways to make it work:

  1. Install vscode-react-pug
  2. Install Babel JavaScript+vscode-react-pug+vscode-js-atom-grammar

All is cool ;).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants