mirror of
https://github.com/mermaid-js/mermaid.git
synced 2025-01-14 06:43:25 +08:00
Recognizing attrubutes
This commit is contained in:
parent
567686e140
commit
d2226604e4
@ -3,20 +3,29 @@
|
||||
|
||||
%options case-insensitive
|
||||
%s group
|
||||
// %x attributes
|
||||
%x attributes
|
||||
%x attribute
|
||||
%x value
|
||||
|
||||
%%
|
||||
"{" { this.pushState('group'); return 'OPEN_GROUP'; }
|
||||
<group>"}" { this.popState('group'); return 'CLOSE_GROUP'; }
|
||||
"sankey" return 'SANKEY'
|
||||
\d+ return 'VALUE'
|
||||
\d+ return 'AMOUNT'
|
||||
"->" return 'ARROW'
|
||||
\w+ return 'NODE'
|
||||
"[" {/*this.pushState('attributes');*/ return 'OPEN_ATTRIBUTES'; }
|
||||
"]" { /* this.popState(); */ return 'CLOSE_ATTRIBUTES'; }
|
||||
(<<EOF>>|[\n;])+ return 'EOS' // end of statement
|
||||
(?:<<EOF>>|[\n;])+ { return 'EOS'; } // end of statement is ; \n or end of file
|
||||
\s+ // skip all whitespace
|
||||
// [\n]+ return 'NEWLINE';
|
||||
"{" { this.pushState('group'); return 'OPEN_GROUP'; }
|
||||
<group>"}" { this.popState('group'); return 'CLOSE_GROUP'; }
|
||||
"[" { this.pushState('attributes'); return 'OPEN_ATTRIBUTES'; }
|
||||
<attributes>"]" { this.popState(); return 'CLOSE_ATTRIBUTES'; }
|
||||
<attributes>\w+ { return 'ATTRIBUTE'; } // string followed by = sign is "attrName"
|
||||
<attributes>(?=\=s*)[\s\w] {return 'VALUE';}
|
||||
<attributes>\= { this.pushState('attribute'); return 'EQUAL'; }
|
||||
<attributes>\s+ // skip all whitespace
|
||||
<attribute>[\w]+ {this.popState(); return 'VALUE';}
|
||||
<attribute>\s+ //skip
|
||||
<attribute>\" { this.pushState('value'); return 'OPEN_VALUE'; }
|
||||
<value>\" { this.popState(); return 'CLOSE_VALUE'; }
|
||||
|
||||
// TODO: check if jison will return 2 separate tokens (for nodes) while ignoring whitespace
|
||||
|
||||
@ -33,41 +42,26 @@ start
|
||||
|
||||
document
|
||||
: line document
|
||||
| // empty
|
||||
|
|
||||
;
|
||||
|
||||
line
|
||||
// : node_with_attributes // one node with attributes
|
||||
: flow EOS
|
||||
| node_with_attributes EOS
|
||||
| EOS
|
||||
;
|
||||
|
||||
node_with_attributes: NODE OPEN_ATTRIBUTES attributes CLOSE_ATTRIBUTES;
|
||||
|
||||
node_with_attributes
|
||||
: NODE
|
||||
| NODE attributes_group
|
||||
;
|
||||
attributes: attribute attributes | ;
|
||||
attribute: ATTRIBUTE EQUAL VALUE | ATTRIBUTE;
|
||||
|
||||
attributes_group
|
||||
: OPEN_ATTRIBUTES attributes CLOSE_ATTRIBUTES
|
||||
;
|
||||
// flow
|
||||
// : NODE ARROW value_or_values_group ARROW flow
|
||||
// | NODE
|
||||
// ;
|
||||
|
||||
attributes:
|
||||
| // TODO
|
||||
;
|
||||
flow: n_chain_a;
|
||||
|
||||
flow
|
||||
: NODE ARROW value_or_values_group ARROW flow
|
||||
| NODE
|
||||
;
|
||||
|
||||
value_or_values_group
|
||||
: OPEN_GROUP values CLOSE_GROUP
|
||||
| VALUE
|
||||
;
|
||||
|
||||
values
|
||||
: values VALUE
|
||||
| /* empty */
|
||||
;
|
||||
n_chain_a: NODE ARROW a_chain_n | NODE;
|
||||
a_chain_n: AMOUNT ARROW n_chain_a | AMOUNT;
|
||||
|
@ -30,18 +30,9 @@ describe('Sankey diagram', function () {
|
||||
it('recognizes multiple flows', () => {
|
||||
const str = `
|
||||
sankey
|
||||
a -> 30 -> b -> 12 -> e
|
||||
c -> 30 -> d -> 12 -> e
|
||||
c -> 40 -> e -> 12 -> e
|
||||
`;
|
||||
|
||||
parser.parse(str);
|
||||
});
|
||||
|
||||
it('recognizes grouped values', () => {
|
||||
const str = `
|
||||
sankey
|
||||
a -> {30} -> b
|
||||
a -> 30 -> b -> 12 -> e;
|
||||
c -> 30 -> d -> 12 -> e;
|
||||
c -> 40 -> e -> 12 -> q;
|
||||
`;
|
||||
|
||||
parser.parse(str);
|
||||
@ -50,12 +41,27 @@ describe('Sankey diagram', function () {
|
||||
it('recognizes a separate node with its attributes', () => {
|
||||
const str = `
|
||||
sankey
|
||||
c[]
|
||||
a[]
|
||||
b[attr=1]
|
||||
c[attr=2]
|
||||
d[attrWithoutValue]
|
||||
d[attr = 3]
|
||||
`;
|
||||
|
||||
parser.parse(str);
|
||||
});
|
||||
|
||||
// it('recognizes grouped values', () => {
|
||||
// const str = `
|
||||
// sankey
|
||||
// a -> {30} -> b
|
||||
// `;
|
||||
|
||||
// parser.parse(str);
|
||||
// });
|
||||
|
||||
|
||||
|
||||
// it('recognizes intake group', () => {
|
||||
// const str = `
|
||||
// sankey
|
||||
|
Loading…
x
Reference in New Issue
Block a user