Merge branch 'master' into short-method-names

pull/863/head
Rich Harris 7 years ago committed by GitHub
commit d27e4734d5

@ -1,5 +1,13 @@
# Svelte changelog # Svelte changelog
## 1.39.4
* Extract shared init logic ([#855](https://github.com/sveltejs/svelte/pull/855))
* Allow `console.*` calls in event handlers ([#782](https://github.com/sveltejs/svelte/issues/782))
* Marker comments in output ([#823](https://github.com/sveltejs/svelte/issues/823))
* Use `textContent` and `innerHTML` where appropriate ([#23](https://github.com/sveltejs/svelte/issues/23))
* Various improvements to generated code
## 1.39.3 ## 1.39.3
* Allow `slot='...'` inside custom elements ([#827](https://github.com/sveltejs/svelte/issues/827)) * Allow `slot='...'` inside custom elements ([#827](https://github.com/sveltejs/svelte/issues/827))

@ -1,6 +1,6 @@
{ {
"name": "svelte", "name": "svelte",
"version": "1.39.3", "version": "1.39.4",
"description": "The magical disappearing UI framework", "description": "The magical disappearing UI framework",
"main": "compiler/svelte.js", "main": "compiler/svelte.js",
"files": [ "files": [

@ -8,8 +8,7 @@ import globalWhitelist from '../utils/globalWhitelist';
import reservedNames from '../utils/reservedNames'; import reservedNames from '../utils/reservedNames';
import namespaces from '../utils/namespaces'; import namespaces from '../utils/namespaces';
import { removeNode, removeObjectKey } from '../utils/removeNode'; import { removeNode, removeObjectKey } from '../utils/removeNode';
import getIntro from './shared/utils/getIntro'; import wrapModule from './shared/utils/wrapModule';
import getOutro from './shared/utils/getOutro';
import annotateWithScopes from '../utils/annotateWithScopes'; import annotateWithScopes from '../utils/annotateWithScopes';
import clone from '../utils/clone'; import clone from '../utils/clone';
import DomBlock from './dom/Block'; import DomBlock from './dom/Block';
@ -303,55 +302,12 @@ export default class Generator {
return (expression._dependencies = dependencies); return (expression._dependencies = dependencies);
} }
generate(result: string, options: CompileOptions, { name, format }: GenerateOptions ) { generate(result: string, options: CompileOptions, { banner = '', sharedPath, helpers, name, format }: GenerateOptions ) {
if (this.imports.length) {
const statements: string[] = [];
this.imports.forEach((declaration, i) => {
if (format === 'es') {
statements.push(
this.source.slice(declaration.start, declaration.end)
);
return;
}
const defaultImport = declaration.specifiers.find(
(x: Node) =>
x.type === 'ImportDefaultSpecifier' ||
(x.type === 'ImportSpecifier' && x.imported.name === 'default')
);
const namespaceImport = declaration.specifiers.find(
(x: Node) => x.type === 'ImportNamespaceSpecifier'
);
const namedImports = declaration.specifiers.filter(
(x: Node) =>
x.type === 'ImportSpecifier' && x.imported.name !== 'default'
);
const name = defaultImport || namespaceImport
? (defaultImport || namespaceImport).local.name
: `__import${i}`;
declaration.name = name; // hacky but makes life a bit easier later
namedImports.forEach((specifier: Node) => {
statements.push(
`var ${specifier.local.name} = ${name}.${specifier.imported.name}`
);
});
if (defaultImport) {
statements.push(
`${name} = (${name} && ${name}.__esModule) ? ${name}['default'] : ${name};`
);
}
});
result = `${statements.join('\n')}\n\n${result}`;
}
const pattern = /\[✂(\d+)-(\d+)$/; const pattern = /\[✂(\d+)-(\d+)$/;
const parts = result.split('✂]'); const module = wrapModule(result, format, name, options, banner, sharedPath, helpers, this.imports, this.source);
const parts = module.split('✂]');
const finalChunk = parts.pop(); const finalChunk = parts.pop();
const compiled = new Bundle({ separator: '' }); const compiled = new Bundle({ separator: '' });
@ -362,9 +318,6 @@ export default class Generator {
}); });
} }
const intro = getIntro(format, options, this.imports);
if (intro) addString(intro);
const { filename } = options; const { filename } = options;
// special case — the source file doesn't actually get used anywhere. we need // special case — the source file doesn't actually get used anywhere. we need
@ -391,7 +344,6 @@ export default class Generator {
}); });
addString(finalChunk); addString(finalChunk);
addString('\n\n' + getOutro(format, name, options, this.imports));
const { css, cssMap } = this.customElement ? const { css, cssMap } = this.customElement ?
{ css: null, cssMap: null } : { css: null, cssMap: null } :

@ -356,34 +356,20 @@ export default function dom(
return generator.alias(name); return generator.alias(name);
}); });
if (sharedPath) { let helpers;
const used = Array.from(usedHelpers).sort();
if (format === 'es') {
const names = used.map(name => {
const alias = generator.alias(name);
return name !== alias ? `${name} as ${alias}` : name;
});
result =
`import { ${names.join(', ')} } from ${JSON.stringify(sharedPath)};\n\n` +
result;
}
else if (format === 'cjs') {
const SHARED = '__shared';
let requires = `var ${SHARED} = require(${JSON.stringify(sharedPath)});`;
used.forEach(name => {
const alias = generator.alias(name);
requires += `\nvar ${alias} = ${SHARED}.${name};`;
});
result = `${requires}\n\n${result}`; if (sharedPath) {
} if (format !== 'es' && format !== 'cjs') {
else {
throw new Error(`Components with shared helpers must be compiled with \`format: 'es'\` or \`format: 'cjs'\``); throw new Error(`Components with shared helpers must be compiled with \`format: 'es'\` or \`format: 'cjs'\``);
} }
const used = Array.from(usedHelpers).sort();
helpers = used.map(name => {
const alias = generator.alias(name);
return { name, alias };
});
} else { } else {
let inlineHelpers = '';
usedHelpers.forEach(key => { usedHelpers.forEach(key => {
const str = shared[key]; const str = shared[key];
const code = new MagicString(str); const code = new MagicString(str);
@ -421,20 +407,27 @@ export default function dom(
// special case // special case
const global = `_svelteTransitionManager`; const global = `_svelteTransitionManager`;
result += `\n\nvar ${generator.alias('transitionManager')} = window.${global} || (window.${global} = ${code});`; inlineHelpers += `\n\nvar ${generator.alias('transitionManager')} = window.${global} || (window.${global} = ${code});\n\n`;
} else { } else {
const alias = generator.alias(expression.id.name); const alias = generator.alias(expression.id.name);
if (alias !== expression.id.name) if (alias !== expression.id.name)
code.overwrite(expression.id.start, expression.id.end, alias); code.overwrite(expression.id.start, expression.id.end, alias);
result += `\n\n${code}`; inlineHelpers += `\n\n${code}`;
} }
}); });
result += inlineHelpers;
} }
result = `/* ${options.filename ? `${options.filename} ` : ``}generated by Svelte v${version} */\n\n${result}`; const filename = options.filename && (
typeof process !== 'undefined' ? options.filename.replace(process.cwd(), '').replace(/^[\/\\]/, '') : options.filename
);
return generator.generate(result, options, { return generator.generate(result, options, {
banner: `/* ${filename ? `${filename} ` : ``}generated by Svelte v${version} */`,
sharedPath,
helpers,
name, name,
format, format,
}); });

@ -41,6 +41,13 @@ function createDebuggingComment(node: Node, generator: DomGenerator) {
return `${loc} ${source.slice(c, d)}`.replace(/\n/g, ' '); return `${loc} ${source.slice(c, d)}`.replace(/\n/g, ' ');
} }
function cannotUseInnerHTML(node: Node) {
while (node && node.canUseInnerHTML) {
node.canUseInnerHTML = false;
node = node.parent;
}
}
// Whitespace inside one of these elements will not result in // Whitespace inside one of these elements will not result in
// a whitespace node being created in any circumstances. (This // a whitespace node being created in any circumstances. (This
// list is almost certainly very incomplete) // list is almost certainly very incomplete)
@ -65,6 +72,7 @@ const preprocessors = {
componentStack: Node[], componentStack: Node[],
stripWhitespace: boolean stripWhitespace: boolean
) => { ) => {
cannotUseInnerHTML(node);
node.var = block.getUniqueName('text'); node.var = block.getUniqueName('text');
const dependencies = block.findDependencies(node.expression); const dependencies = block.findDependencies(node.expression);
@ -80,6 +88,7 @@ const preprocessors = {
componentStack: Node[], componentStack: Node[],
stripWhitespace: boolean stripWhitespace: boolean
) => { ) => {
cannotUseInnerHTML(node);
node.var = block.getUniqueName('raw'); node.var = block.getUniqueName('raw');
const dependencies = block.findDependencies(node.expression); const dependencies = block.findDependencies(node.expression);
@ -114,6 +123,8 @@ const preprocessors = {
stripWhitespace: boolean, stripWhitespace: boolean,
nextSibling: Node nextSibling: Node
) => { ) => {
cannotUseInnerHTML(node);
const blocks: Block[] = []; const blocks: Block[] = [];
let dynamic = false; let dynamic = false;
let hasIntros = false; let hasIntros = false;
@ -195,6 +206,7 @@ const preprocessors = {
stripWhitespace: boolean, stripWhitespace: boolean,
nextSibling: Node nextSibling: Node
) => { ) => {
cannotUseInnerHTML(node);
node.var = block.getUniqueName(`each`); node.var = block.getUniqueName(`each`);
const dependencies = block.findDependencies(node.expression); const dependencies = block.findDependencies(node.expression);
@ -290,10 +302,16 @@ const preprocessors = {
stripWhitespace: boolean, stripWhitespace: boolean,
nextSibling: Node nextSibling: Node
) => { ) => {
if (node.name === 'slot') {
cannotUseInnerHTML(node);
}
node.attributes.forEach((attribute: Node) => { node.attributes.forEach((attribute: Node) => {
if (attribute.type === 'Attribute' && attribute.value !== true) { if (attribute.type === 'Attribute' && attribute.value !== true) {
attribute.value.forEach((chunk: Node) => { attribute.value.forEach((chunk: Node) => {
if (chunk.type !== 'Text') { if (chunk.type !== 'Text') {
if (node.parent) cannotUseInnerHTML(node.parent);
const dependencies = block.findDependencies(chunk.expression); const dependencies = block.findDependencies(chunk.expression);
block.addDependencies(dependencies); block.addDependencies(dependencies);
@ -311,20 +329,24 @@ const preprocessors = {
} }
} }
}); });
} else if (attribute.type === 'EventHandler' && attribute.expression) { } else {
attribute.expression.arguments.forEach((arg: Node) => { if (node.parent) cannotUseInnerHTML(node.parent);
const dependencies = block.findDependencies(arg);
if (attribute.type === 'EventHandler' && attribute.expression) {
attribute.expression.arguments.forEach((arg: Node) => {
const dependencies = block.findDependencies(arg);
block.addDependencies(dependencies);
});
} else if (attribute.type === 'Binding') {
const dependencies = block.findDependencies(attribute.value);
block.addDependencies(dependencies); block.addDependencies(dependencies);
}); } else if (attribute.type === 'Transition') {
} else if (attribute.type === 'Binding') { if (attribute.intro)
const dependencies = block.findDependencies(attribute.value); generator.hasIntroTransitions = block.hasIntroMethod = true;
block.addDependencies(dependencies); if (attribute.outro) {
} else if (attribute.type === 'Transition') { generator.hasOutroTransitions = block.hasOutroMethod = true;
if (attribute.intro) block.outros += 1;
generator.hasIntroTransitions = block.hasIntroMethod = true; }
if (attribute.outro) {
generator.hasOutroTransitions = block.hasOutroMethod = true;
block.outros += 1;
} }
} }
}); });
@ -340,6 +362,8 @@ const preprocessors = {
// so that if `foo.qux` changes, we know that we need to // so that if `foo.qux` changes, we know that we need to
// mark `bar` and `baz` as dirty too // mark `bar` and `baz` as dirty too
if (node.name === 'select') { if (node.name === 'select') {
cannotUseInnerHTML(node);
const value = node.attributes.find( const value = node.attributes.find(
(attribute: Node) => attribute.name === 'value' (attribute: Node) => attribute.name === 'value'
); );
@ -359,6 +383,8 @@ const preprocessors = {
generator.components.has(node.name) || node.name === ':Self'; generator.components.has(node.name) || node.name === ':Self';
if (isComponent) { if (isComponent) {
cannotUseInnerHTML(node);
node.var = block.getUniqueName( node.var = block.getUniqueName(
(node.name === ':Self' ? generator.name : node.name).toLowerCase() (node.name === ':Self' ? generator.name : node.name).toLowerCase()
); );
@ -369,6 +395,7 @@ const preprocessors = {
} else { } else {
const slot = getStaticAttributeValue(node, 'slot'); const slot = getStaticAttributeValue(node, 'slot');
if (slot && isChildOfComponent(node, generator)) { if (slot && isChildOfComponent(node, generator)) {
cannotUseInnerHTML(node);
node.slotted = true; node.slotted = true;
// TODO validate slots — no nesting, no dynamic names... // TODO validate slots — no nesting, no dynamic names...
const component = componentStack[componentStack.length - 1]; const component = componentStack[componentStack.length - 1];
@ -442,6 +469,7 @@ function preprocessChildren(
cleaned.forEach((child: Node, i: number) => { cleaned.forEach((child: Node, i: number) => {
child.parent = node; child.parent = node;
child.canUseInnerHTML = !generator.hydratable;
const preprocessor = preprocessors[child.type]; const preprocessor = preprocessors[child.type];
if (preprocessor) preprocessor(generator, block, state, child, inEachBlock, elementStack, componentStack, stripWhitespace, cleaned[i + 1] || nextSibling); if (preprocessor) preprocessor(generator, block, state, child, inEachBlock, elementStack, componentStack, stripWhitespace, cleaned[i + 1] || nextSibling);

@ -9,6 +9,7 @@ import visitBinding from './Binding';
import visitRef from './Ref'; import visitRef from './Ref';
import * as namespaces from '../../../../utils/namespaces'; import * as namespaces from '../../../../utils/namespaces';
import getStaticAttributeValue from '../../../../utils/getStaticAttributeValue'; import getStaticAttributeValue from '../../../../utils/getStaticAttributeValue';
import isVoidElementName from '../../../../utils/isVoidElementName';
import addTransitions from './addTransitions'; import addTransitions from './addTransitions';
import { DomGenerator } from '../../index'; import { DomGenerator } from '../../index';
import Block from '../../Block'; import Block from '../../Block';
@ -94,7 +95,6 @@ export default function visitElement(
} }
// add CSS encapsulation attribute // add CSS encapsulation attribute
// TODO add a helper for this, rather than repeating it
if (node._needsCssAttribute && !generator.customElement) { if (node._needsCssAttribute && !generator.customElement) {
generator.needsEncapsulateHelper = true; generator.needsEncapsulateHelper = true;
block.builders.hydrate.addLine( block.builders.hydrate.addLine(
@ -202,9 +202,21 @@ export default function visitElement(
node.initialUpdate = node.lateUpdate = statement; node.initialUpdate = node.lateUpdate = statement;
} }
node.children.forEach((child: Node) => { if (!childState.namespace && node.canUseInnerHTML && node.children.length > 0) {
visit(generator, block, childState, child, elementStack.concat(node), componentStack); if (node.children.length === 1 && node.children[0].type === 'Text') {
}); block.builders.create.addLine(
`${name}.textContent = ${JSON.stringify(node.children[0].data)};`
);
} else {
block.builders.create.addLine(
`${name}.innerHTML = ${JSON.stringify(node.children.map(toHTML).join(''))};`
);
}
} else {
node.children.forEach((child: Node) => {
visit(generator, block, childState, child, elementStack.concat(node), componentStack);
});
}
if (node.lateUpdate) { if (node.lateUpdate) {
block.builders.update.addLine(node.lateUpdate); block.builders.update.addLine(node.lateUpdate);
@ -221,6 +233,29 @@ export default function visitElement(
block.builders.claim.addLine( block.builders.claim.addLine(
`${childState.parentNodes}.forEach(@detachNode);` `${childState.parentNodes}.forEach(@detachNode);`
); );
function toHTML(node: Node) {
if (node.type === 'Text') return node.data;
let open = `<${node.name}`;
if (node._needsCssAttribute) {
open += ` ${generator.stylesheet.id}`;
}
if (node._cssRefAttribute) {
open += ` svelte-ref-${node._cssRefAttribute}`;
}
node.attributes.forEach((attr: Node) => {
open += ` ${attr.name}${stringifyAttributeValue(attr.value)}`
});
if (isVoidElementName(node.name)) return open + '>';
if (node.children.length === 0) return open + '/>';
return `${open}>${node.children.map(toHTML).join('')}</${node.name}>`;
}
} }
function getRenderStatement( function getRenderStatement(
@ -263,3 +298,11 @@ function quoteProp(name: string, legacy: boolean) {
if (/[^a-zA-Z_$0-9]/.test(name) || isLegacyPropName) return `"${name}"`; if (/[^a-zA-Z_$0-9]/.test(name) || isLegacyPropName) return `"${name}"`;
return name; return name;
} }
function stringifyAttributeValue(value: Node | true) {
if (value === true) return '';
if (value.length === 0) return `=""`;
const data = value[0].data;
return `=${JSON.stringify(data)}`;
}

@ -1,47 +0,0 @@
import { CompileOptions, Node } from '../../../interfaces';
export default function getGlobals(imports: Node[], options: CompileOptions) {
const { globals, onerror, onwarn } = options;
const globalFn = getGlobalFn(globals);
return imports.map(x => {
let name = globalFn(x.source.value);
if (!name) {
if (x.name.startsWith('__import')) {
const error = new Error(
`Could not determine name for imported module '${x.source.value}' use options.globals`
);
if (onerror) {
onerror(error);
} else {
throw error;
}
} else {
const warning = {
message: `No name was supplied for imported module '${x.source.value}'. Guessing '${x.name}', but you should use options.globals`,
};
if (onwarn) {
onwarn(warning);
} else {
console.warn(warning); // eslint-disable-line no-console
}
}
name = x.name;
}
return name;
});
}
function getGlobalFn(globals: any): (id: string) => string {
if (typeof globals === 'function') return globals;
if (typeof globals === 'object') {
return id => globals[id];
}
return () => undefined;
}

@ -1,95 +0,0 @@
import deindent from '../../../utils/deindent';
import getGlobals from './getGlobals';
import { CompileOptions, ModuleFormat, Node } from '../../../interfaces';
export default function getIntro(
format: ModuleFormat,
options: CompileOptions,
imports: Node[]
) {
if (format === 'es') return '';
if (format === 'amd') return getAmdIntro(options, imports);
if (format === 'cjs') return getCjsIntro(options, imports);
if (format === 'iife') return getIifeIntro(options, imports);
if (format === 'umd') return getUmdIntro(options, imports);
if (format === 'eval') return getEvalIntro(options, imports);
throw new Error(`Not implemented: ${format}`);
}
function getAmdIntro(options: CompileOptions, imports: Node[]) {
const sourceString = imports.length
? `[${imports
.map(declaration => `'${removeExtension(declaration.source.value)}'`)
.join(', ')}], `
: '';
const id = options.amd && options.amd.id;
return `define(${id
? `"${id}", `
: ''}${sourceString}function(${paramString(imports)}) { 'use strict';\n\n`;
}
function getCjsIntro(options: CompileOptions, imports: Node[]) {
const requireBlock = imports
.map(
declaration =>
`var ${declaration.name} = require('${declaration.source.value}');`
)
.join('\n\n');
if (requireBlock) {
return `'use strict';\n\n${requireBlock}\n\n`;
}
return `'use strict';\n\n`;
}
function getIifeIntro(options: CompileOptions, imports: Node[]) {
if (!options.name) {
throw new Error(`Missing required 'name' option for IIFE export`);
}
return `var ${options.name} = (function(${paramString(imports)}) { 'use strict';\n\n`;
}
function getUmdIntro(options: CompileOptions, imports: Node[]) {
if (!options.name) {
throw new Error(`Missing required 'name' option for UMD export`);
}
const amdId = options.amd && options.amd.id ? `'${options.amd.id}', ` : '';
const amdDeps = imports.length
? `[${imports
.map(declaration => `'${removeExtension(declaration.source.value)}'`)
.join(', ')}], `
: '';
const cjsDeps = imports
.map(declaration => `require('${declaration.source.value}')`)
.join(', ');
const globalDeps = getGlobals(imports, options);
return (
deindent`
(function(global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(${cjsDeps}) :
typeof define === 'function' && define.amd ? define(${amdId}${amdDeps}factory) :
(global.${options.name} = factory(${globalDeps}));
}(this, (function (${paramString(imports)}) { 'use strict';` + '\n\n'
);
}
function getEvalIntro(options: CompileOptions, imports: Node[]) {
return `(function (${paramString(imports)}) { 'use strict';\n\n`;
}
function paramString(imports: Node[]) {
return imports.map(dep => dep.name).join(', ');
}
function removeExtension(file: string) {
const index = file.lastIndexOf('.');
return ~index ? file.slice(0, index) : file;
}

@ -1,37 +0,0 @@
import getGlobals from './getGlobals';
import { CompileOptions, Node } from '../../../interfaces';
export default function getOutro(
format: string,
name: string,
options: CompileOptions,
imports: Node[]
) {
if (format === 'es') {
return `export default ${name};`;
}
if (format === 'amd') {
return `return ${name};\n\n});`;
}
if (format === 'cjs') {
return `module.exports = ${name};`;
}
if (format === 'iife') {
const globals = getGlobals(imports, options);
return `return ${name};\n\n}(${globals.join(', ')}));`;
}
if (format === 'eval') {
const globals = getGlobals(imports, options);
return `return ${name};\n\n}(${globals.join(', ')}));`;
}
if (format === 'umd') {
return `return ${name};\n\n})));`;
}
throw new Error(`Not implemented: ${format}`);
}

@ -0,0 +1,306 @@
import deindent from '../../../utils/deindent';
import { CompileOptions, ModuleFormat, Node } from '../../../interfaces';
interface Dependency {
name: string;
statements: string[];
source: string;
}
const wrappers = { es, amd, cjs, iife, umd, eval: expr };
export default function wrapModule(
code: string,
format: ModuleFormat,
name: string,
options: CompileOptions,
banner: string,
sharedPath: string,
helpers: { name: string, alias: string }[],
imports: Node[],
source: string
): string {
if (format === 'es') return es(code, name, options, banner, sharedPath, helpers, imports, source);
const dependencies = imports.map((declaration, i) => {
const defaultImport = declaration.specifiers.find(
(x: Node) =>
x.type === 'ImportDefaultSpecifier' ||
(x.type === 'ImportSpecifier' && x.imported.name === 'default')
);
const namespaceImport = declaration.specifiers.find(
(x: Node) => x.type === 'ImportNamespaceSpecifier'
);
const namedImports = declaration.specifiers.filter(
(x: Node) =>
x.type === 'ImportSpecifier' && x.imported.name !== 'default'
);
const name = defaultImport || namespaceImport
? (defaultImport || namespaceImport).local.name
: `__import${i}`;
const statements: string[] = [];
namedImports.forEach((specifier: Node) => {
statements.push(
`var ${specifier.local.name} = ${name}.${specifier.imported.name};`
);
});
if (defaultImport) {
statements.push(
`${name} = (${name} && ${name}.__esModule) ? ${name}["default"] : ${name};`
);
}
return { name, statements, source: declaration.source.value };
});
if (format === 'amd') return amd(code, name, options, banner, dependencies);
if (format === 'cjs') return cjs(code, name, options, banner, sharedPath, helpers, dependencies);
if (format === 'iife') return iife(code, name, options, banner, dependencies);
if (format === 'umd') return umd(code, name, options, banner, dependencies);
if (format === 'eval') return expr(code, name, options, banner, dependencies);
throw new Error(`Not implemented: ${format}`);
}
function es(
code: string,
name: string,
options: CompileOptions,
banner: string,
sharedPath: string,
helpers: { name: string, alias: string }[],
imports: Node[],
source: string
) {
const importHelpers = helpers && (
`import { ${helpers.map(h => h.name === h.alias ? h.name : `${h.name} as ${h.alias}`).join(', ')} } from ${JSON.stringify(sharedPath)};`
);
const importBlock = imports.length > 0 && (
imports
.map((declaration: Node) => source.slice(declaration.start, declaration.end))
.join('\n')
);
return deindent`
${banner}
${importHelpers}
${importBlock}
${code}
export default ${name};`;
}
function amd(
code: string,
name: string,
options: CompileOptions,
banner: string,
dependencies: Dependency[]
) {
const sourceString = dependencies.length
? `[${dependencies.map(d => `"${removeExtension(d.source)}"`).join(', ')}], `
: '';
const id = options.amd && options.amd.id;
return deindent`
define(${id ? `"${id}", ` : ''}${sourceString}function(${paramString(dependencies)}) { "use strict";
${getCompatibilityStatements(dependencies)}
${code}
return ${name};
});`;
}
function cjs(
code: string,
name: string,
options: CompileOptions,
banner: string,
sharedPath: string,
helpers: { name: string, alias: string }[],
dependencies: Dependency[]
) {
const SHARED = '__shared';
const helperBlock = helpers && (
`var ${SHARED} = require(${JSON.stringify(sharedPath)});\n` +
helpers.map(helper => {
return `var ${helper.alias} = ${SHARED}.${helper.name};`;
}).join('\n')
);
const requireBlock = dependencies.length > 0 && (
dependencies
.map(d => `var ${d.name} = require("${d.source}");`)
.join('\n\n')
);
return deindent`
${banner}
"use strict";
${helperBlock}
${requireBlock}
${getCompatibilityStatements(dependencies)}
${code}
module.exports = ${name};`
}
function iife(
code: string,
name: string,
options: CompileOptions,
banner: string,
dependencies: Dependency[]
) {
if (!options.name) {
throw new Error(`Missing required 'name' option for IIFE export`);
}
const globals = getGlobals(dependencies, options);
return deindent`
${banner}
var ${options.name} = (function(${paramString(dependencies)}) { "use strict";
${getCompatibilityStatements(dependencies)}
${code}
return ${name};
}(${globals.join(', ')}));`;
}
function umd(
code: string,
name: string,
options: CompileOptions,
banner: string,
dependencies: Dependency[]
) {
if (!options.name) {
throw new Error(`Missing required 'name' option for UMD export`);
}
const amdId = options.amd && options.amd.id ? `'${options.amd.id}', ` : '';
const amdDeps = dependencies.length
? `[${dependencies.map(d => `"${removeExtension(d.source)}"`).join(', ')}], `
: '';
const cjsDeps = dependencies
.map(d => `require("${d.source}")`)
.join(', ');
const globals = getGlobals(dependencies, options);
return deindent`
${banner}
(function(global, factory) {
typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory(${cjsDeps}) :
typeof define === "function" && define.amd ? define(${amdId}${amdDeps}factory) :
(global.${options.name} = factory(${globals}));
}(this, (function (${paramString(dependencies)}) { "use strict";
${getCompatibilityStatements(dependencies)}
${code}
return ${name};
})));`;
}
function expr(
code: string,
name: string,
options: CompileOptions,
banner: string,
dependencies: Dependency[]
) {
const globals = getGlobals(dependencies, options);
return deindent`
(function (${paramString(dependencies)}) { "use strict";
${banner}
${getCompatibilityStatements(dependencies)}
${code}
return ${name};
}(${globals.join(', ')}))`;
}
function paramString(dependencies: Dependency[]) {
return dependencies.map(dep => dep.name).join(', ');
}
function removeExtension(file: string) {
const index = file.lastIndexOf('.');
return ~index ? file.slice(0, index) : file;
}
function getCompatibilityStatements(dependencies: Dependency[]) {
if (!dependencies.length) return null;
const statements: string[] = [];
dependencies.forEach(dependency => {
statements.push(...dependency.statements);
});
return statements.join('\n');
}
function getGlobals(dependencies: Dependency[], options: CompileOptions) {
const { globals, onerror, onwarn } = options;
const globalFn = getGlobalFn(globals);
return dependencies.map(d => {
let name = globalFn(d.source);
if (!name) {
if (d.name.startsWith('__import')) {
const error = new Error(
`Could not determine name for imported module '${d.source}' use options.globals`
);
if (onerror) {
onerror(error);
} else {
throw error;
}
} else {
const warning = {
message: `No name was supplied for imported module '${d.source}'. Guessing '${d.name}', but you should use options.globals`,
};
if (onwarn) {
onwarn(warning);
} else {
console.warn(warning); // eslint-disable-line no-console
}
}
name = d.name;
}
return name;
});
}
function getGlobalFn(globals: any): (id: string) => string {
if (typeof globals === 'function') return globals;
if (typeof globals === 'object') {
return id => globals[id];
}
return () => undefined;
}

@ -61,7 +61,7 @@ export function create(source: string, _options: CompileOptions = {}) {
} }
try { try {
return new Function('return ' + compiled.code)(); return (0,eval)(compiled.code);
} catch (err) { } catch (err) {
if (_options.onerror) { if (_options.onerror) {
_options.onerror(err); _options.onerror(err);

@ -64,6 +64,9 @@ export interface CompileOptions {
export interface GenerateOptions { export interface GenerateOptions {
name: string; name: string;
format: ModuleFormat; format: ModuleFormat;
banner?: string;
sharedPath?: string | boolean;
helpers?: { name: string, alias: string }[];
} }
export interface Visitor { export interface Visitor {

@ -190,7 +190,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
data: function () { data: function () {

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { appendNode, assign, createElement, createText, detachNode, init, insertNode, noop, proto, setAttribute } from "svelte/shared.js"; import { appendNode, assign, createElement, createText, detachNode, init, insertNode, noop, proto, setAttribute } from "svelte/shared.js";
var template = (function() { var template = (function() {
@ -69,5 +68,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -166,7 +166,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
components: { components: {

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, callAll, init, noop, proto } from "svelte/shared.js"; import { assign, callAll, init, noop, proto } from "svelte/shared.js";
var template = (function() { var template = (function() {
@ -63,5 +62,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -166,7 +166,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
computed: { computed: {

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, differs, init, noop, proto } from "svelte/shared.js"; import { assign, differs, init, noop, proto } from "svelte/shared.js";
var template = (function() { var template = (function() {
@ -47,5 +46,4 @@ SvelteComponent.prototype._recompute = function _recompute(changed, state) {
if (differs(state.b, (state.b = template.computed.b(state.x)))) changed.b = true; if (differs(state.b, (state.b = template.computed.b(state.x)))) changed.b = true;
} }
} }
export default SvelteComponent; export default SvelteComponent;

@ -186,7 +186,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function encapsulateStyles(node) { function encapsulateStyles(node) {
setAttribute(node, "svelte-2363328337", ""); setAttribute(node, "svelte-2363328337", "");
} }

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { appendNode, assign, createElement, detachNode, init, insertNode, noop, proto, setAttribute } from "svelte/shared.js"; import { appendNode, assign, createElement, detachNode, init, insertNode, noop, proto, setAttribute } from "svelte/shared.js";
function encapsulateStyles(node) { function encapsulateStyles(node) {
@ -55,5 +54,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -13,10 +13,6 @@ function assign(target) {
return target; return target;
} }
function appendNode(node, target) {
target.appendChild(node);
}
function insertNode(node, target, anchor) { function insertNode(node, target, anchor) {
target.insertBefore(node, anchor); target.insertBefore(node, anchor);
} }
@ -29,10 +25,6 @@ function createElement(name) {
return document.createElement(name); return document.createElement(name);
} }
function createText(data) {
return document.createTextNode(data);
}
function blankObject() { function blankObject() {
return Object.create(null); return Object.create(null);
} }
@ -186,19 +178,17 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div, text; var div;
return { return {
c: function create() { c: function create() {
div = createElement("div"); div = createElement("div");
text = createText("fades in"); div.textContent = "fades in";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(div, target, anchor); insertNode(div, target, anchor);
appendNode(text, div);
}, },
p: noop, p: noop,

@ -1,19 +1,17 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
import { appendNode, assign, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div, text; var div;
return { return {
c: function create() { c: function create() {
div = createElement("div"); div = createElement("div");
text = createText("fades in"); div.textContent = "fades in";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(div, target, anchor); insertNode(div, target, anchor);
appendNode(text, div);
}, },
p: noop, p: noop,
@ -62,5 +60,4 @@ assign(SvelteComponent.prototype, proto, {
this.parentNode.removeChild(this); this.parentNode.removeChild(this);
} }
}); });
export default SvelteComponent; export default SvelteComponent;

@ -198,7 +198,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var text, p, text_1; var text, p, text_1;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { appendNode, assign, createElement, createText, destroyEach, detachAfter, detachNode, init, insertNode, noop, proto } from "svelte/shared.js"; import { appendNode, assign, createElement, createText, destroyEach, detachAfter, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -153,5 +152,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -13,10 +13,6 @@ function assign(target) {
return target; return target;
} }
function appendNode(node, target) {
target.appendChild(node);
}
function insertNode(node, target, anchor) { function insertNode(node, target, anchor) {
target.insertBefore(node, anchor); target.insertBefore(node, anchor);
} }
@ -29,10 +25,6 @@ function createElement(name) {
return document.createElement(name); return document.createElement(name);
} }
function createText(data) {
return document.createTextNode(data);
}
function blankObject() { function blankObject() {
return Object.create(null); return Object.create(null);
} }
@ -186,7 +178,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
methods: { methods: {
@ -203,12 +194,12 @@ var template = (function() {
}()); }());
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var button, foo_handler, text; var button, foo_handler;
return { return {
c: function create() { c: function create() {
button = createElement("button"); button = createElement("button");
text = createText("foo"); button.textContent = "foo";
this.h(); this.h();
}, },
@ -221,7 +212,6 @@ function create_main_fragment(state, component) {
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(button, target, anchor); insertNode(button, target, anchor);
appendNode(text, button);
}, },
p: noop, p: noop,

@ -1,6 +1,5 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
import { appendNode, assign, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
var template = (function() { var template = (function() {
return { return {
@ -18,12 +17,12 @@ var template = (function() {
}()); }());
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var button, foo_handler, text; var button, foo_handler;
return { return {
c: function create() { c: function create() {
button = createElement("button"); button = createElement("button");
text = createText("foo"); button.textContent = "foo";
this.h(); this.h();
}, },
@ -36,7 +35,6 @@ function create_main_fragment(state, component) {
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(button, target, anchor); insertNode(button, target, anchor);
appendNode(text, button);
}, },
p: noop, p: noop,
@ -64,5 +62,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, template.methods, proto); assign(SvelteComponent.prototype, template.methods, proto);
export default SvelteComponent; export default SvelteComponent;

@ -13,10 +13,6 @@ function assign(target) {
return target; return target;
} }
function appendNode(node, target) {
target.appendChild(node);
}
function insertNode(node, target, anchor) { function insertNode(node, target, anchor) {
target.insertBefore(node, anchor); target.insertBefore(node, anchor);
} }
@ -29,10 +25,6 @@ function createElement(name) {
return document.createElement(name); return document.createElement(name);
} }
function createText(data) {
return document.createTextNode(data);
}
function createComment() { function createComment() {
return document.createComment(''); return document.createComment('');
} }
@ -190,7 +182,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var if_block_anchor; var if_block_anchor;
@ -231,17 +222,16 @@ function create_main_fragment(state, component) {
// (1:0) {{#if foo}} // (1:0) {{#if foo}}
function create_if_block(state, component) { function create_if_block(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("foo!"); p.textContent = "foo!";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -254,17 +244,16 @@ function create_if_block(state, component) {
// (3:0) {{else}} // (3:0) {{else}}
function create_if_block_1(state, component) { function create_if_block_1(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("not foo!"); p.textContent = "not foo!";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {

@ -1,6 +1,5 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createComment, createElement, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
import { appendNode, assign, createComment, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var if_block_anchor; var if_block_anchor;
@ -42,17 +41,16 @@ function create_main_fragment(state, component) {
// (1:0) {{#if foo}} // (1:0) {{#if foo}}
function create_if_block(state, component) { function create_if_block(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("foo!"); p.textContent = "foo!";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -65,17 +63,16 @@ function create_if_block(state, component) {
// (3:0) {{else}} // (3:0) {{else}}
function create_if_block_1(state, component) { function create_if_block_1(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("not foo!"); p.textContent = "not foo!";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -104,5 +101,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -13,10 +13,6 @@ function assign(target) {
return target; return target;
} }
function appendNode(node, target) {
target.appendChild(node);
}
function insertNode(node, target, anchor) { function insertNode(node, target, anchor) {
target.insertBefore(node, anchor); target.insertBefore(node, anchor);
} }
@ -29,10 +25,6 @@ function createElement(name) {
return document.createElement(name); return document.createElement(name);
} }
function createText(data) {
return document.createTextNode(data);
}
function createComment() { function createComment() {
return document.createComment(''); return document.createComment('');
} }
@ -190,7 +182,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var if_block_anchor; var if_block_anchor;
@ -234,17 +225,16 @@ function create_main_fragment(state, component) {
// (1:0) {{#if foo}} // (1:0) {{#if foo}}
function create_if_block(state, component) { function create_if_block(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("foo!"); p.textContent = "foo!";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {

@ -1,6 +1,5 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createComment, createElement, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
import { appendNode, assign, createComment, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var if_block_anchor; var if_block_anchor;
@ -45,17 +44,16 @@ function create_main_fragment(state, component) {
// (1:0) {{#if foo}} // (1:0) {{#if foo}}
function create_if_block(state, component) { function create_if_block(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("foo!"); p.textContent = "foo!";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -79,5 +77,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -182,7 +182,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div; var div;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, detachNode, init, insertNode, noop, proto, setStyle } from "svelte/shared.js"; import { assign, createElement, detachNode, init, insertNode, noop, proto, setStyle } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -51,5 +50,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -182,7 +182,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div; var div;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, detachNode, init, insertNode, noop, proto, setStyle } from "svelte/shared.js"; import { assign, createElement, detachNode, init, insertNode, noop, proto, setStyle } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -46,5 +45,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -182,7 +182,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div; var div;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, detachNode, init, insertNode, noop, proto, setStyle } from "svelte/shared.js"; import { assign, createElement, detachNode, init, insertNode, noop, proto, setStyle } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -46,5 +45,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -182,7 +182,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div, text, div_1, div_1_style_value; var div, text, div_1, div_1_style_value;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js"; import { assign, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -57,5 +56,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -186,7 +186,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var input; var input;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { addListener, assign, createElement, detachNode, init, insertNode, proto, removeListener } from "svelte/shared.js"; import { addListener, assign, createElement, detachNode, init, insertNode, proto, removeListener } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -53,5 +52,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -184,7 +184,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var input; var input;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, createElement, detachNode, init, insertNode, noop, proto, setInputType } from "svelte/shared.js"; import { assign, createElement, detachNode, init, insertNode, noop, proto, setInputType } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -42,5 +41,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -201,7 +201,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div; var div;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, children, claimElement, createElement, detachNode, init, insertNode, noop, proto } from "svelte/shared.js"; import { assign, children, claimElement, createElement, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -52,5 +51,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -194,7 +194,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var audio, audio_updating = false, audio_animationframe, audio_paused_value = true; var audio, audio_updating = false, audio_animationframe, audio_paused_value = true;

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { addListener, assign, callAll, createElement, detachNode, init, insertNode, proto, removeListener, timeRangesToArray } from "svelte/shared.js"; import { addListener, assign, callAll, createElement, detachNode, init, insertNode, proto, removeListener, timeRangesToArray } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
@ -128,5 +127,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -180,7 +180,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
components: { components: {

@ -1,8 +1,6 @@
import Imported from 'Imported.html';
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, callAll, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js"; import { assign, callAll, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
import Imported from 'Imported.html';
var template = (function() { var template = (function() {
return { return {
@ -76,5 +74,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -166,7 +166,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
// this test should be removed in v2 // this test should be removed in v2

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, callAll, init, noop, proto } from "svelte/shared.js"; import { assign, callAll, init, noop, proto } from "svelte/shared.js";
var template = (function() { var template = (function() {
@ -50,5 +49,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -166,7 +166,6 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
var template = (function() { var template = (function() {
return { return {
methods: { methods: {

@ -1,5 +1,4 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { assign, init, noop, proto } from "svelte/shared.js"; import { assign, init, noop, proto } from "svelte/shared.js";
var template = (function() { var template = (function() {
@ -51,5 +50,4 @@ function SvelteComponent(options) {
assign(SvelteComponent.prototype, template.methods, proto); assign(SvelteComponent.prototype, template.methods, proto);
template.setup(SvelteComponent); template.setup(SvelteComponent);
export default SvelteComponent; export default SvelteComponent;

@ -190,9 +190,8 @@ var proto = {
}; };
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div, text, p, text_1, text_2, text_3, text_4, p_1, text_5, text_6, text_8, if_block_4_anchor; var div, text, p, text_2, text_3, text_4, p_1, text_6, text_8, if_block_4_anchor;
var if_block = (state.a) && create_if_block(state, component); var if_block = (state.a) && create_if_block(state, component);
@ -210,14 +209,14 @@ function create_main_fragment(state, component) {
if (if_block) if_block.c(); if (if_block) if_block.c();
text = createText("\n\n\t"); text = createText("\n\n\t");
p = createElement("p"); p = createElement("p");
text_1 = createText("this can be used as an anchor"); p.textContent = "this can be used as an anchor";
text_2 = createText("\n\n\t"); text_2 = createText("\n\n\t");
if (if_block_1) if_block_1.c(); if (if_block_1) if_block_1.c();
text_3 = createText("\n\n\t"); text_3 = createText("\n\n\t");
if (if_block_2) if_block_2.c(); if (if_block_2) if_block_2.c();
text_4 = createText("\n\n\t"); text_4 = createText("\n\n\t");
p_1 = createElement("p"); p_1 = createElement("p");
text_5 = createText("so can this"); p_1.textContent = "so can this";
text_6 = createText("\n\n\t"); text_6 = createText("\n\n\t");
if (if_block_3) if_block_3.c(); if (if_block_3) if_block_3.c();
text_8 = createText("\n\n"); text_8 = createText("\n\n");
@ -230,14 +229,12 @@ function create_main_fragment(state, component) {
if (if_block) if_block.m(div, null); if (if_block) if_block.m(div, null);
appendNode(text, div); appendNode(text, div);
appendNode(p, div); appendNode(p, div);
appendNode(text_1, p);
appendNode(text_2, div); appendNode(text_2, div);
if (if_block_1) if_block_1.m(div, null); if (if_block_1) if_block_1.m(div, null);
appendNode(text_3, div); appendNode(text_3, div);
if (if_block_2) if_block_2.m(div, null); if (if_block_2) if_block_2.m(div, null);
appendNode(text_4, div); appendNode(text_4, div);
appendNode(p_1, div); appendNode(p_1, div);
appendNode(text_5, p_1);
appendNode(text_6, div); appendNode(text_6, div);
if (if_block_3) if_block_3.m(div, null); if (if_block_3) if_block_3.m(div, null);
insertNode(text_8, target, anchor); insertNode(text_8, target, anchor);
@ -330,17 +327,16 @@ function create_main_fragment(state, component) {
// (2:1) {{#if a}} // (2:1) {{#if a}}
function create_if_block(state, component) { function create_if_block(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("a"); p.textContent = "a";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -353,17 +349,16 @@ function create_if_block(state, component) {
// (8:1) {{#if b}} // (8:1) {{#if b}}
function create_if_block_1(state, component) { function create_if_block_1(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("b"); p.textContent = "b";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -376,17 +371,16 @@ function create_if_block_1(state, component) {
// (12:1) {{#if c}} // (12:1) {{#if c}}
function create_if_block_2(state, component) { function create_if_block_2(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("c"); p.textContent = "c";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -399,17 +393,16 @@ function create_if_block_2(state, component) {
// (18:1) {{#if d}} // (18:1) {{#if d}}
function create_if_block_3(state, component) { function create_if_block_3(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("d"); p.textContent = "d";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -422,17 +415,16 @@ function create_if_block_3(state, component) {
// (25:0) {{#if e}} // (25:0) {{#if e}}
function create_if_block_4(state, component) { function create_if_block_4(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("e"); p.textContent = "e";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {

@ -1,9 +1,8 @@
/* generated by Svelte vX.Y.Z */ /* generated by Svelte vX.Y.Z */
import { appendNode, assign, createComment, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js"; import { appendNode, assign, createComment, createElement, createText, detachNode, init, insertNode, noop, proto } from "svelte/shared.js";
function create_main_fragment(state, component) { function create_main_fragment(state, component) {
var div, text, p, text_1, text_2, text_3, text_4, p_1, text_5, text_6, text_8, if_block_4_anchor; var div, text, p, text_2, text_3, text_4, p_1, text_6, text_8, if_block_4_anchor;
var if_block = (state.a) && create_if_block(state, component); var if_block = (state.a) && create_if_block(state, component);
@ -21,14 +20,14 @@ function create_main_fragment(state, component) {
if (if_block) if_block.c(); if (if_block) if_block.c();
text = createText("\n\n\t"); text = createText("\n\n\t");
p = createElement("p"); p = createElement("p");
text_1 = createText("this can be used as an anchor"); p.textContent = "this can be used as an anchor";
text_2 = createText("\n\n\t"); text_2 = createText("\n\n\t");
if (if_block_1) if_block_1.c(); if (if_block_1) if_block_1.c();
text_3 = createText("\n\n\t"); text_3 = createText("\n\n\t");
if (if_block_2) if_block_2.c(); if (if_block_2) if_block_2.c();
text_4 = createText("\n\n\t"); text_4 = createText("\n\n\t");
p_1 = createElement("p"); p_1 = createElement("p");
text_5 = createText("so can this"); p_1.textContent = "so can this";
text_6 = createText("\n\n\t"); text_6 = createText("\n\n\t");
if (if_block_3) if_block_3.c(); if (if_block_3) if_block_3.c();
text_8 = createText("\n\n"); text_8 = createText("\n\n");
@ -41,14 +40,12 @@ function create_main_fragment(state, component) {
if (if_block) if_block.m(div, null); if (if_block) if_block.m(div, null);
appendNode(text, div); appendNode(text, div);
appendNode(p, div); appendNode(p, div);
appendNode(text_1, p);
appendNode(text_2, div); appendNode(text_2, div);
if (if_block_1) if_block_1.m(div, null); if (if_block_1) if_block_1.m(div, null);
appendNode(text_3, div); appendNode(text_3, div);
if (if_block_2) if_block_2.m(div, null); if (if_block_2) if_block_2.m(div, null);
appendNode(text_4, div); appendNode(text_4, div);
appendNode(p_1, div); appendNode(p_1, div);
appendNode(text_5, p_1);
appendNode(text_6, div); appendNode(text_6, div);
if (if_block_3) if_block_3.m(div, null); if (if_block_3) if_block_3.m(div, null);
insertNode(text_8, target, anchor); insertNode(text_8, target, anchor);
@ -141,17 +138,16 @@ function create_main_fragment(state, component) {
// (2:1) {{#if a}} // (2:1) {{#if a}}
function create_if_block(state, component) { function create_if_block(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("a"); p.textContent = "a";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -164,17 +160,16 @@ function create_if_block(state, component) {
// (8:1) {{#if b}} // (8:1) {{#if b}}
function create_if_block_1(state, component) { function create_if_block_1(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("b"); p.textContent = "b";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -187,17 +182,16 @@ function create_if_block_1(state, component) {
// (12:1) {{#if c}} // (12:1) {{#if c}}
function create_if_block_2(state, component) { function create_if_block_2(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("c"); p.textContent = "c";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -210,17 +204,16 @@ function create_if_block_2(state, component) {
// (18:1) {{#if d}} // (18:1) {{#if d}}
function create_if_block_3(state, component) { function create_if_block_3(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("d"); p.textContent = "d";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -233,17 +226,16 @@ function create_if_block_3(state, component) {
// (25:0) {{#if e}} // (25:0) {{#if e}}
function create_if_block_4(state, component) { function create_if_block_4(state, component) {
var p, text; var p;
return { return {
c: function create() { c: function create() {
p = createElement("p"); p = createElement("p");
text = createText("e"); p.textContent = "e";
}, },
m: function mount(target, anchor) { m: function mount(target, anchor) {
insertNode(p, target, anchor); insertNode(p, target, anchor);
appendNode(text, p);
}, },
u: function unmount() { u: function unmount() {
@ -267,5 +259,4 @@ function SvelteComponent(options) {
} }
assign(SvelteComponent.prototype, proto); assign(SvelteComponent.prototype, proto);
export default SvelteComponent; export default SvelteComponent;

@ -73,11 +73,12 @@ describe("runtime", () => {
); );
const { code } = svelte.compile(source, compileOptions); const { code } = svelte.compile(source, compileOptions);
const startIndex = code.indexOf("function create_main_fragment"); // may change! const startIndex = code.indexOf("function create_main_fragment"); // may change!
if (startIndex === -1) if (startIndex === -1) throw new Error("missing create_main_fragment");
throw new Error("missing create_main_fragment"); const endIndex = code.lastIndexOf("export default");
const es5 = const es5 =
code.slice(0, startIndex).split('\n').map(x => spaces(x.length)).join('\n') + code.slice(0, startIndex).split('\n').map(x => spaces(x.length)).join('\n') +
code.slice(startIndex).replace(/export default .+/, ""); code.slice(startIndex, endIndex);
acorn.parse(es5, { ecmaVersion: 5 }); acorn.parse(es5, { ecmaVersion: 5 });
if (/Object\.assign/.test(es5)) { if (/Object\.assign/.test(es5)) {

@ -1,7 +1,8 @@
export function test ({ assert, smc, locateInSource, locateInGenerated }) { export function test({ assert, code, smc, locateInSource, locateInGenerated }) {
const expected = locateInSource( 'each' ); const startIndex = code.indexOf('create_main_fragment');
const loc = locateInGenerated( 'length' ); const expected = locateInSource('each');
const loc = locateInGenerated('length', startIndex );
const actual = smc.originalPositionFor({ const actual = smc.originalPositionFor({
line: loc.line + 1, line: loc.line + 1,

Loading…
Cancel
Save