@markuplint/erb-parser 4.0.0-dev.28 → 4.0.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) 2017-2019 Yusuke Hirao
3
+ Copyright (c) 2017-2024 Yusuke Hirao
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
package/README.md CHANGED
@@ -53,13 +53,3 @@ If it doesn't nest by quotations.
53
53
  <div attr=<%= value %>></div>
54
54
  ```
55
55
  <!-- prettier-ignore-end -->
56
-
57
- If it mixes the tags and spaces.
58
-
59
- ```html
60
- <div attr=" <%= value %> "></div>
61
- ```
62
-
63
- ```html
64
- <div attr="<%= value %> <%= value2 %>"></div>
65
- ```
package/lib/index.d.ts CHANGED
@@ -1 +1 @@
1
- export { parse } from './parse.js';
1
+ export { parser } from './parser.js';
package/lib/index.js CHANGED
@@ -1 +1 @@
1
- export { parse } from './parse.js';
1
+ export { parser } from './parser.js';
@@ -0,0 +1,6 @@
1
+ import { HtmlParser } from '@markuplint/html-parser';
2
+ declare class ERubyParser extends HtmlParser {
3
+ constructor();
4
+ }
5
+ export declare const parser: ERubyParser;
6
+ export {};
package/lib/parser.js ADDED
@@ -0,0 +1,32 @@
1
+ import { HtmlParser } from '@markuplint/html-parser';
2
+ class ERubyParser extends HtmlParser {
3
+ constructor() {
4
+ super({
5
+ ignoreTags: [
6
+ {
7
+ type: 'erb-ruby-expression',
8
+ start: '<%=',
9
+ end: '%>',
10
+ },
11
+ {
12
+ type: 'erb-comment',
13
+ start: '<%#',
14
+ end: '%>',
15
+ },
16
+ {
17
+ type: 'erb-ruby-code',
18
+ start: /<%(?!%)/,
19
+ end: '%>',
20
+ },
21
+ // TODO: If it use trim_mode.
22
+ // If you need it: https://github.com/markuplint/markuplint/issues/new?assignees=%40YusukeHirao&labels=Features%3A+Proposal&projects=&template=feature.md&title=Supporting+trim_mode+for+erb-parser
23
+ // {
24
+ // type: 'erb-ruby-code-line',
25
+ // start: /(?:^|\n)\s*%(?!%)/,
26
+ // end: /\n|$/
27
+ // }
28
+ ],
29
+ });
30
+ }
31
+ }
32
+ export const parser = new ERubyParser();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@markuplint/erb-parser",
3
- "version": "4.0.0-dev.28+0131de5e",
3
+ "version": "4.0.0-rc.0",
4
4
  "description": "eRuby template parser for markuplint",
5
5
  "repository": "git@github.com:markuplint/markuplint.git",
6
6
  "author": "Yusuke Hirao <yusukehirao@me.com>",
@@ -21,9 +21,10 @@
21
21
  "clean": "tsc --build --clean"
22
22
  },
23
23
  "dependencies": {
24
- "@markuplint/html-parser": "4.0.0-dev.28+0131de5e",
25
- "@markuplint/ml-ast": "4.0.0-dev.28+0131de5e",
26
- "@markuplint/parser-utils": "4.0.0-dev.28+0131de5e"
24
+ "@markuplint/html-parser": "4.0.0-rc.0"
27
25
  },
28
- "gitHead": "0131de5ea9dd6d3fd5472d7b414b66644c758881"
26
+ "devDependencies": {
27
+ "@markuplint/parser-utils": "4.0.0-rc.0"
28
+ },
29
+ "gitHead": "3fdeb45cb69ed52b3a215a7520cea1181601443f"
29
30
  }
package/lib/parse.d.ts DELETED
@@ -1,2 +0,0 @@
1
- import type { Parse } from '@markuplint/ml-ast';
2
- export declare const parse: Parse;
package/lib/parse.js DELETED
@@ -1,30 +0,0 @@
1
- import { parse as htmlParse } from '@markuplint/html-parser';
2
- import { ignoreBlock, restoreNode } from '@markuplint/parser-utils';
3
- export const parse = (rawCode, options) => {
4
- const blocks = ignoreBlock(rawCode, [
5
- {
6
- type: 'erb-ruby-expression',
7
- start: /<%=/,
8
- end: /%>/,
9
- },
10
- {
11
- type: 'erb-comment',
12
- start: /<%#/,
13
- end: /%>/,
14
- },
15
- {
16
- type: 'erb-ruby-code',
17
- start: /<%(?!%)/,
18
- end: /%>/,
19
- },
20
- // WIP. If it use trim_mode.
21
- // {
22
- // type: 'erb-ruby-code-line',
23
- // start: /(?:^|\n)\s*%(?!%)/,
24
- // end: /\n|$/
25
- // }
26
- ]);
27
- const doc = htmlParse(blocks.replaced, options);
28
- doc.nodeList = restoreNode(doc.nodeList, blocks);
29
- return doc;
30
- };