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

Fix issue #31 #32

Merged
merged 3 commits into from
Sep 26, 2019
Merged

Fix issue #31 #32

merged 3 commits into from
Sep 26, 2019

Conversation

devanshj
Copy link
Contributor

@devanshj devanshj commented Jul 21, 2019

Fixes #31
Fixes microsoft/vscode #77776

The RegEx /\{[^\}]*\(.*\)[^\{]*\}/ looks good to me...
Heh nope, doesn't allow div { a (b c } and even div { a ((( }. One fix could be to use /\{[^\}\{]*\}/ but that would allow things like div { a }(b){ c} also...

So till I figure out a good way to fix this, consider this PR as a draft.
Okay so with the second commit the fix looks good to me. I have also added a bunch of tests. It did involve a little trial-and-error but I guess the tests are covering enough cases.

Also there was a minor mistake where the condition does a /\(/.test(abbreviation) && /\)/.test(abbreviation) to check if it has parentheses but it should be || instead.

/cc @ramya-rao-a @octref

- add a RegEx in the condition to allow `(` and `)` inside `{` and `}`
- add corresponding tests
@msftclas
Copy link

msftclas commented Jul 21, 2019

CLA assistant check
All CLA requirements met.

// Grouping in abbreviation is valid only if preceeded/succeeded with one of the symbols for nesting, sibling, repeater or climb up
if (!/\(.*\)[>\+\*\^]/.test(abbreviation) && !/[>\+\*\^]\(.*\)/.test(abbreviation) && /\(/.test(abbreviation) && /\)/.test(abbreviation)) {
// Grouping in abbreviation is valid only if it's inside a text node or preceeded/succeeded with one of the symbols for nesting, sibling, repeater or climb up
if ((/\(/.test(abbreviation) || /\)/.test(abbreviation)) && !/\{[^\}\{]*[\(\)]+[^\}\{]*\}(?:[>\+\*\^]|$)/.test(abbreviation) && !/\(.*\)[>\+\*\^]/.test(abbreviation) && !/[>\+\*\^]\(.*\)/.test(abbreviation)) {
Copy link
Contributor Author

@devanshj devanshj Jul 22, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If it's not obvious then the (?:[>\+\*\^]|$) part is to invalidate abbreviations like div{ a }( b ){ c }.

@octref octref added this to the August 2019 milestone Jul 25, 2019
@octref octref self-assigned this Jul 25, 2019
@octref
Copy link
Contributor

octref commented Sep 25, 2019

I tried div{ foo ((( abc } and div{ a (b) c}+div{ a (( }, both doesn't expand on emmet doc. Why are the valid expansions with unbalanced parens?

@devanshj

This comment has been minimized.

@devanshj

This comment has been minimized.

@devanshj

This comment has been minimized.

@devanshj

This comment has been minimized.

@octref
Copy link
Contributor

octref commented Sep 26, 2019

In the cases when you can't tell, we can be more liberal than emmet in accepting inputs (as long as it can expand).

@devanshj
Copy link
Contributor Author

devanshj commented Sep 26, 2019

Sorry for the mess & spam here's a summarised answer:

  1. "div{ foo ((( abc }" is valid because parenthesis don't mean anything between {, } and thus we shouldn't require to balance them.
  2. require("./expand/expand-full.js").expand("div{ foo ((( abc }") successfully expands to <div> foo ((( abc </div>
  3. The reason it won't expand on docs.emmet.io and even in VSCode (testExpand("html", "div{ foo ((( abc }", "<div> foo ((( abc </div>") fails) is because @emmetio/extract-abbreviation doesn't recognize it.

Action point:

  1. Fix @emmetio/extract-abbreviation so that require("@emmetio/extract-abbreviation")("div{ foo ((( abc }") returns { abbreviation: "div{ foo ((( abc }" } (currently returns { abbreviation: "abc }" }
  2. I'm not sure but I guess we should merge this PR and then fix @emmetio/extract-abbreviation because this PR alone also will fix things for balanced parenthesis case.

@devanshj
Copy link
Contributor Author

devanshj commented Sep 26, 2019

In the cases when you can't tell, we can be more liberal than emmet in accepting inputs (as long as it can expand).

Yesss exactly. But now the problem is unbalanced parenthesis do expand theoretically but @emmetio/extract-abbreviation doesn't recognize them.

src/test/emmetHelper.test.ts Outdated Show resolved Hide resolved
Co-Authored-By: Pine <[email protected]>
@octref
Copy link
Contributor

octref commented Sep 26, 2019

Fix @emmetio/extract-abbreviation so that require("@emmetio/extract-abbreviation")("div{ foo ((( abc }") returns { abbreviation: "div{ foo ((( abc }" } (currently returns { abbreviation: "abc }" }

Sounds good. You can send a PR to https://github.com/emmetio/extract-abbreviation#readme. Thanks a lot for looking into this!

@octref octref merged commit 075cb17 into microsoft:master Sep 26, 2019
@octref octref modified the milestones: August 2019, September 2019 Sep 26, 2019
@devanshj
Copy link
Contributor Author

Sounds good. You can send a PR to emmetio/extract-abbreviation#readme. Thanks a lot for looking into this!

Yeah I'm looking into fixing it, once I fix it I'll send a PR till the time I would also file an issue there. Also the pleasure is all mine! :D

@devanshj
Copy link
Contributor Author

devanshj commented Oct 1, 2019

Hi @octref so now emmet PR #571, #569 that were responsible for fixing the extraction are merged.

I tried to migrate from @emmetio/extract-abbreviation & src/expand/expand-full.js to the newer [email protected] but looks like it isn't trivial.

Also I went through almost all issues on vscode repo that were labelled as emmet and a lot of them can be just fixed by updating to v2 since @sergeche has fixed a bunch of issues of @emmetio/extract-abbreviation in the newer emmet like #20 (fixes #45724), #17, #23 (fixes #52345), #24 (fixes #59172), maybe more.

Also I was kinda verifying if the newer version fixes some issues and it does here's the StackBlitz that demonstrates it. Afaict #63703, #80923, #59951, #71002 and probably more can be closed with the newer emmet.

So I guess it will be worth migrating to the newer emmet, and also the older one's are deprecated so vscode will have to migrate to newer one at some point to take advantage of further developments

Also let me know if I should create an issue for migration instead of having all this written here.

@octref
Copy link
Contributor

octref commented Oct 1, 2019

@devanshj Wow, thanks a lot for looking into this. Good work 👍

Moving to emmet v2 makes sense. It just involves a lot of effort. I remember the reason we had expand-full.js as a single file was due to bundling issues. We can look into this again.

To start, I'd create an issue in vscode repo and link to all issues that would be fixed by upgrading to v2. I'll try to get some time in Oct/Nov to help you with it.

@devanshj
Copy link
Contributor Author

devanshj commented Oct 1, 2019

@octref Thanks and welcome! 😁 And yeah I'll be down with helping with this as much as I can.

@BMBurstein
Copy link

Thanks to both of you. Is this still moving forward?

@devanshj
Copy link
Contributor Author

devanshj commented Feb 16, 2020

@BMBurstein

Thanks to both of you.

You're welcome!

Is this still moving forward?

PR #33 was ready to merge until I realised that it doesn't have full test coverage so I had to dig deeper that's when I found out it's a whole mess. I started rewriting it, even remodeling and that's when I realized we don't need this package seperately because it's not doing much. That's when I started patching the extension itself to not use this module (ie vscode-emmet-helper). Even that is still wip (I haven't pushed) and I haven't looked into it in a long time. I'll see if I can look into it soon :)

(You can see description of PR #33 on why I'm ditching this module)

So to answer your question, it's stagnant at the moment but I will work on migrating to [email protected] once I've time for it.

@devanshj devanshj mentioned this pull request Oct 16, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
4 participants