[emmet] Support all the features#8155
[emmet] Support all the features#8155egamma merged 12 commits intomicrosoft:masterfrom mrmlnc:emmet-full-implementation
Conversation
|
By analyzing the blame information on this pull request, we identified @egamma and @alexandrudima to be potential reviewers |
|
Hi @mrmlnc, I'm your friendly neighborhood Microsoft Pull Request Bot (You can call me MSBOT). Thanks for your contribution! The agreement was validated by Microsoft and real humans are currently evaluating your PR. TTYL, MSBOT; |
|
I'll start to digest the PR tomorrow, first scan shows that this is good work 🌹 One convention you missed is this one: |
|
@egamma, oh, sorry, i forgot about it. Now fix it 👍 |
|
@mrmlnc this is a question unrelated to the PR, but given your emmet know how I thought I'll ask you. Do you know the purpose of the gulpfile inside the emmet module? It looks like it supports to package/bundle emmet. Is any other editor using this? I ask since the startup time of emmet is significant and we look into options to reduce it. |
|
There is some duplication in the code that I introduced and that should be improved, eventually. This method can be written generically when the action is configured with the emmet action name. public runEmmetAction(_module) {
if (!_module.run('balance_outward', this.editorAccessor)) {
this.editorAccessor.noExpansionOccurred();
}
}Something like class BasicEmmetEditorAction extends EmmetEditorAction {
...
private emmetActionName: string;
constructor(descriptor: IEditorActionDescriptorData, editor: ICommonCodeEditor, actionName: string) {
super(descriptor, editor, Behaviour.TextFocus);
this.editorAccessor = new EditorAccessor(editor);
this.emmetActionName = actionName;
}
public runEmmetAction(_module) {
if (!_module.run(emmetActionName, this.editorAccessor)) {
this.editorAccessor.noExpansionOccurred();
}
} I'll first start with the PR and I'll refactor and you can review. |
Just build all files into one with Browserify. Simply launch the Gulp and get the output files. For example: And these files can be used in VS Code: Can play with the settings Browserify that to get a size smaller. For example ( Or even more, using |
|
@mrmlnc I almost forgot to say thank you 🌹. I was busy to get the PR into for the June update before we have the code freeze and start the endgame. |




Adding support for all features of Emmet.
Source: #7909
Description
Well, Emmet. Sorry, that one commit.
What include?
All the features of Emmet:
update tagworks incorrectly with single-line tag #8136)What's not included?
I am not binding keyboard keys as it can cause a conflict.