move vars out of stats

pull/2102/head
Richard Harris 6 years ago
parent fd39e9505b
commit b2f371a3d1

@ -1,5 +1,3 @@
import Component from './compile/Component';
const now = (typeof process !== 'undefined' && process.hrtime) const now = (typeof process !== 'undefined' && process.hrtime)
? () => { ? () => {
const t = process.hrtime(); const t = process.hrtime();
@ -63,41 +61,13 @@ export default class Stats {
this.currentChildren = this.currentTiming ? this.currentTiming.children : this.timings; this.currentChildren = this.currentTiming ? this.currentTiming.children : this.timings;
} }
render(component: Component) { render() {
const timings = Object.assign({ const timings = Object.assign({
total: now() - this.startTime total: now() - this.startTime
}, collapseTimings(this.timings)); }, collapseTimings(this.timings));
// TODO would be good to have this info even
// if options.generate is false
const imports = component && component.imports.map(node => {
return {
source: node.source.value,
specifiers: node.specifiers.map(specifier => {
return {
name: (
specifier.type === 'ImportDefaultSpecifier' ? 'default' :
specifier.type === 'ImportNamespaceSpecifier' ? '*' :
specifier.imported.name
),
as: specifier.local.name
};
})
}
});
return { return {
timings, timings
vars: component.vars.filter(variable => !variable.global && !variable.implicit && !variable.internal).map(variable => ({
name: variable.name,
export_name: variable.export_name || null,
injected: variable.injected || false,
module: variable.module || false,
mutated: variable.mutated || false,
reassigned: variable.reassigned || false,
referenced: variable.referenced || false,
writable: variable.writable || false
}))
}; };
} }
} }

@ -217,6 +217,10 @@ export default class Component {
} }
generate(result: string) { generate(result: string) {
let js = null;
let css = null;
if (result) {
const { compileOptions, name } = this; const { compileOptions, name } = this;
const { format = 'esm' } = compileOptions; const { format = 'esm' } = compileOptions;
@ -299,24 +303,35 @@ export default class Component {
addString(finalChunk); addString(finalChunk);
const css = compileOptions.customElement ? css = compileOptions.customElement ?
{ code: null, map: null } : { code: null, map: null } :
this.stylesheet.render(compileOptions.cssOutputFilename, true); this.stylesheet.render(compileOptions.cssOutputFilename, true);
const js = { js = {
code: compiled.toString(), code: compiled.toString(),
map: compiled.generateMap({ map: compiled.generateMap({
includeContent: true, includeContent: true,
file: compileOptions.outputFilename, file: compileOptions.outputFilename,
}) })
}; };
}
return { return {
js, js,
css, css,
ast: this.ast, ast: this.ast,
warnings: this.warnings, warnings: this.warnings,
stats: this.stats.render(this) vars: this.vars.filter(v => !v.global && !v.implicit && !v.internal).map(v => ({
name: v.name,
export_name: v.export_name || null,
injected: v.injected || false,
module: v.module || false,
mutated: v.mutated || false,
reassigned: v.reassigned || false,
referenced: v.referenced || false,
writable: v.writable || false
})),
stats: this.stats.render()
}; };
} }

@ -95,11 +95,9 @@ export default function compile(source: string, options: CompileOptions = {}) {
); );
stats.stop('create component'); stats.stop('create component');
if (options.generate === false) { const js = options.generate === false
return { ast, warnings, stats: stats.render(component), js: null, css: null }; ? null
} : options.generate === 'ssr'
const js = options.generate === 'ssr'
? renderSSR(component, options) ? renderSSR(component, options)
: renderDOM(component, options); : renderDOM(component, options);

@ -1,5 +0,0 @@
export default {
test(assert, stats) {
assert.deepEqual(stats.vars, []);
},
};

@ -1,5 +0,0 @@
export default {
test(assert, stats) {
assert.deepEqual(stats.vars, []);
},
};

@ -1,5 +0,0 @@
export default {
test(assert, stats) {
assert.deepEqual(stats.vars, []);
},
};

@ -1,5 +0,0 @@
export default {
test(assert, stats) {
assert.deepEqual(stats.vars, []);
},
};

@ -1,5 +0,0 @@
export default {
test(assert, stats) {
assert.deepEqual(stats.vars, []);
},
};

@ -0,0 +1,60 @@
import * as fs from 'fs';
import * as assert from 'assert';
import { svelte, loadConfig, tryToLoadJson } from '../helpers.js';
describe('vars', () => {
fs.readdirSync('test/vars/samples').forEach(dir => {
if (dir[0] === '.') return;
// add .solo to a sample directory name to only run that test
const solo = /\.solo/.test(dir);
const skip = /\.skip/.test(dir);
if (solo && process.env.CI) {
throw new Error('Forgot to remove `solo: true` from test');
}
(solo ? it.only : skip ? it.skip : it)(dir, () => {
const config = loadConfig(`./vars/samples/${dir}/_config.js`);
const filename = `test/vars/samples/${dir}/input.svelte`;
const input = fs.readFileSync(filename, 'utf-8').replace(/\s+$/, '');
const expectedError = tryToLoadJson(
`test/vars/samples/${dir}/error.json`
);
let result;
let error;
try {
result = svelte.compile(input, config.options);
config.test(assert, result.vars);
} catch (e) {
error = e;
}
if (error || expectedError) {
if (error && !expectedError) {
throw error;
}
if (expectedError && !error) {
throw new Error(`Expected an error: ${expectedError.message}`);
}
assert.equal(error.message, expectedError.message);
assert.deepEqual(error.start, expectedError.start);
assert.deepEqual(error.end, expectedError.end);
assert.equal(error.pos, expectedError.pos);
}
});
});
it('returns a vars object when options.generate is false', () => {
const { vars } = svelte.compile('', {
generate: false
});
assert.ok(Array.isArray(vars));
});
});

@ -0,0 +1,5 @@
export default {
test(assert, vars) {
assert.deepEqual(vars, []);
},
};

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'console', name: 'console',
injected: false, injected: false,

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'foo', name: 'foo',
injected: false, injected: false,

@ -0,0 +1,5 @@
export default {
test(assert, vars) {
assert.deepEqual(vars, []);
},
};

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'a', name: 'a',
injected: false, injected: false,

@ -0,0 +1,5 @@
export default {
test(assert, vars) {
assert.deepEqual(vars, []);
},
};

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'x', name: 'x',
export_name: null, export_name: null,

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'count', name: 'count',
export_name: null, export_name: null,

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'count', name: 'count',
export_name: null, export_name: null,

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'name', name: 'name',
export_name: 'name', export_name: 'name',

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'foo', name: 'foo',
export_name: null, export_name: null,

@ -1,6 +1,6 @@
export default { export default {
test(assert, stats) { test(assert, vars) {
assert.deepEqual(stats.vars, [ assert.deepEqual(vars, [
{ {
name: 'foo', name: 'foo',
export_name: null, export_name: null,

@ -0,0 +1,5 @@
export default {
test(assert, vars) {
assert.deepEqual(vars, []);
},
};

@ -0,0 +1,5 @@
export default {
test(assert, vars) {
assert.deepEqual(vars, []);
},
};
Loading…
Cancel
Save