mirror of
https://github.com/svg/svgo.git
synced 2025-07-31 07:44:22 +03:00
Fix scientific notation parsing in paths
This commit is contained in:
@ -58,7 +58,7 @@ const readNumber = (string, cursor) => {
|
||||
continue;
|
||||
}
|
||||
if (state === 'e') {
|
||||
state === 'exponent_sign';
|
||||
state = 'exponent_sign';
|
||||
value += c;
|
||||
continue;
|
||||
}
|
||||
@ -216,7 +216,7 @@ const stringifyNumber = ({ number, precision }) => {
|
||||
} else {
|
||||
result = number.toFixed(precision);
|
||||
if (result.includes('.')) {
|
||||
result = result.replace(/\.?0+$/, '')
|
||||
result = result.replace(/\.?0+$/, '');
|
||||
}
|
||||
}
|
||||
// remove zero whole from decimal number
|
||||
|
@ -47,6 +47,11 @@ describe('parse path data', () => {
|
||||
expect(parsePathData('L 10 20')).to.deep.equal([]);
|
||||
expect(parsePathData('10 20')).to.deep.equal([]);
|
||||
});
|
||||
it('should stop on invalid scientific notation', () => {
|
||||
expect(parsePathData('M 0 5e++1 L 0 0')).to.deep.equal([
|
||||
{ command: 'M', args: [0, 5] },
|
||||
]);
|
||||
});
|
||||
it('should stop on invalid numbers', () => {
|
||||
expect(parsePathData('M ...')).to.deep.equal([]);
|
||||
});
|
||||
|
Reference in New Issue
Block a user