diff --git a/src/validate/index.js b/src/validate/index.js index dbd2c0de8b78..6e34a50f8843 100644 --- a/src/validate/index.js +++ b/src/validate/index.js @@ -3,7 +3,7 @@ import validateHtml from './html/index.js'; import { getLocator } from 'locate-character'; import getCodeFrame from '../utils/getCodeFrame.js'; -export default function validate ( parsed, source, { onerror, onwarn, filename } ) { +export default function validate ( parsed, source, { onerror, onwarn, name, filename } ) { const locator = getLocator( source ); const validator = { @@ -18,11 +18,7 @@ export default function validate ( parsed, source, { onerror, onwarn, filename } error.toString = () => `${error.message} (${error.loc.line}:${error.loc.column})\n${error.frame}`; - if ( onerror ) { - onerror( error ); - } else { - throw error; - } + onerror( error ); }, warn: ( message, pos ) => { @@ -47,6 +43,11 @@ export default function validate ( parsed, source, { onerror, onwarn, filename } namespace: null }; + if ( name && !/^[a-zA-Z_$][a-zA-Z_$0-9]*$/.test( name ) ) { + const error = new Error( `options.name must be a valid identifier` ); + onerror( error ); + } + if ( parsed.js ) { validateJs( validator, parsed.js ); } diff --git a/test/validate.js b/test/validate.js index a9e68560f6d9..4f82cba06bab 100644 --- a/test/validate.js +++ b/test/validate.js @@ -58,4 +58,12 @@ describe( 'validate', () => { } }); }); + + it( 'errors if options.name is illegal', () => { + assert.throws( () => { + svelte.compile( '
', { + name: 'not.valid' + }); + }, /options\.name must be a valid identifier/ ); + }); });