Skip to content

Commit

Permalink
fix bad text values in parse
Browse files Browse the repository at this point in the history
Previously sibling `text` tokens would exclude the `output` from the
first token, resulting in the referenced issues. I think this should
be a fairly safe change.

Fixes micromatch#125
Fixes micromatch#100
  • Loading branch information
connor4312 committed Dec 12, 2023
1 parent 5214db4 commit 563f534
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/parse.js
Original file line number Diff line number Diff line change
Expand Up @@ -209,8 +209,8 @@ const parse = (input, options) => {

if (tok.value || tok.output) append(tok);
if (prev && prev.type === 'text' && tok.type === 'text') {
prev.output = (prev.output || prev.value) + tok.value;
prev.value += tok.value;
prev.output = (prev.output || '') + tok.value;
return;
}

Expand Down
16 changes: 16 additions & 0 deletions test/api.picomatch.js
Original file line number Diff line number Diff line change
Expand Up @@ -345,6 +345,22 @@ describe('picomatch', () => {

assertTokens(tokens, expected);
});

it('pictomatch issue#125, issue#100', () => {
const { tokens } = picomatch.parse('foo.(m|c|)js');

const expected = [
['bos', { output: '', value: '' }],
['text', { output: 'foo.', value: 'foo.' }],
['paren', { output: undefined, value: '(' }],
['text', { output: 'm|c|', value: 'm|c|' }],
['paren', { output: ')', value: ')' }],
['text', { output: undefined, value: 'js' }]
];

const keyValuePairs = tokens.map(token => [token.type, { output: token.output, value: token.value }]);
assert.deepStrictEqual(keyValuePairs, expected);
});
});
});

Expand Down

0 comments on commit 563f534

Please sign in to comment.