|
|
@ -5,7 +5,7 @@ import Stats from '../Stats';
|
|
|
|
import { globals, reserved } from '../utils/names';
|
|
|
|
import { globals, reserved } from '../utils/names';
|
|
|
|
import { namespaces, valid_namespaces } from '../utils/namespaces';
|
|
|
|
import { namespaces, valid_namespaces } from '../utils/namespaces';
|
|
|
|
import create_module from './create_module';
|
|
|
|
import create_module from './create_module';
|
|
|
|
import { create_scopes, extract_names, Scope } from './utils/scope';
|
|
|
|
import { create_scopes, extract_names, Scope, extract_identifiers } from './utils/scope';
|
|
|
|
import Stylesheet from './css/Stylesheet';
|
|
|
|
import Stylesheet from './css/Stylesheet';
|
|
|
|
import { test } from '../config';
|
|
|
|
import { test } from '../config';
|
|
|
|
import Fragment from './nodes/Fragment';
|
|
|
|
import Fragment from './nodes/Fragment';
|
|
|
@ -19,6 +19,7 @@ import TemplateScope from './nodes/shared/TemplateScope';
|
|
|
|
import fuzzymatch from '../utils/fuzzymatch';
|
|
|
|
import fuzzymatch from '../utils/fuzzymatch';
|
|
|
|
import { remove_indentation, add_indentation } from '../utils/indentation';
|
|
|
|
import { remove_indentation, add_indentation } from '../utils/indentation';
|
|
|
|
import get_object from './utils/get_object';
|
|
|
|
import get_object from './utils/get_object';
|
|
|
|
|
|
|
|
import unwrap_parens from './utils/unwrap_parens';
|
|
|
|
|
|
|
|
|
|
|
|
type ComponentOptions = {
|
|
|
|
type ComponentOptions = {
|
|
|
|
namespace?: string;
|
|
|
|
namespace?: string;
|
|
|
@ -93,7 +94,7 @@ export default class Component {
|
|
|
|
node_for_declaration: Map<string, Node> = new Map();
|
|
|
|
node_for_declaration: Map<string, Node> = new Map();
|
|
|
|
partly_hoisted: string[] = [];
|
|
|
|
partly_hoisted: string[] = [];
|
|
|
|
fully_hoisted: string[] = [];
|
|
|
|
fully_hoisted: string[] = [];
|
|
|
|
reactive_declarations: Array<{ assignees: Set<string>, dependencies: Set<string>, node: Node, injected: boolean }> = [];
|
|
|
|
reactive_declarations: Array<{ assignees: Set<string>, dependencies: Set<string>, node: Node, declaration: Node }> = [];
|
|
|
|
reactive_declaration_nodes: Set<Node> = new Set();
|
|
|
|
reactive_declaration_nodes: Set<Node> = new Set();
|
|
|
|
has_reactive_assignments = false;
|
|
|
|
has_reactive_assignments = false;
|
|
|
|
injected_reactive_declaration_vars: Set<string> = new Set();
|
|
|
|
injected_reactive_declaration_vars: Set<string> = new Set();
|
|
|
@ -590,9 +591,11 @@ export default class Component {
|
|
|
|
script.content.body.forEach(node => {
|
|
|
|
script.content.body.forEach(node => {
|
|
|
|
if (node.type !== 'LabeledStatement') return;
|
|
|
|
if (node.type !== 'LabeledStatement') return;
|
|
|
|
if (node.body.type !== 'ExpressionStatement') return;
|
|
|
|
if (node.body.type !== 'ExpressionStatement') return;
|
|
|
|
if (node.body.expression.type !== 'AssignmentExpression') return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extract_names(node.body.expression.left).forEach(name => {
|
|
|
|
const expression = unwrap_parens(node.body.expression);
|
|
|
|
|
|
|
|
if (expression.type !== 'AssignmentExpression') return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extract_names(expression.left).forEach(name => {
|
|
|
|
if (!this.var_lookup.has(name) && name[0] !== '$') {
|
|
|
|
if (!this.var_lookup.has(name) && name[0] !== '$') {
|
|
|
|
this.injected_reactive_declaration_vars.add(name);
|
|
|
|
this.injected_reactive_declaration_vars.add(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1058,15 +1061,10 @@ export default class Component {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (node.type === 'AssignmentExpression') {
|
|
|
|
if (node.type === 'AssignmentExpression') {
|
|
|
|
if (node.left.type === 'MemberExpression' || node.left.type === 'Identifier') {
|
|
|
|
extract_identifiers(get_object(node.left)).forEach(node => {
|
|
|
|
const identifier = get_object(node.left)
|
|
|
|
assignee_nodes.add(node);
|
|
|
|
assignee_nodes.add(identifier);
|
|
|
|
assignees.add(node.name);
|
|
|
|
assignees.add(identifier.name);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
|
|
|
|
extract_names(node.left).forEach(name => {
|
|
|
|
|
|
|
|
assignees.add(name);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} else if (node.type === 'UpdateExpression') {
|
|
|
|
} else if (node.type === 'UpdateExpression') {
|
|
|
|
const identifier = get_object(node.argument);
|
|
|
|
const identifier = get_object(node.argument);
|
|
|
|
assignees.add(identifier.name);
|
|
|
|
assignees.add(identifier.name);
|
|
|
@ -1096,18 +1094,10 @@ export default class Component {
|
|
|
|
|
|
|
|
|
|
|
|
add_indentation(this.code, node.body, 2);
|
|
|
|
add_indentation(this.code, node.body, 2);
|
|
|
|
|
|
|
|
|
|
|
|
unsorted_reactive_declarations.push({
|
|
|
|
const expression = node.body.expression && unwrap_parens(node.body.expression);
|
|
|
|
assignees,
|
|
|
|
const declaration = expression && expression.left;
|
|
|
|
dependencies,
|
|
|
|
|
|
|
|
node,
|
|
|
|
unsorted_reactive_declarations.push({ assignees, dependencies, node, declaration });
|
|
|
|
injected: (
|
|
|
|
|
|
|
|
node.body.type === 'ExpressionStatement' &&
|
|
|
|
|
|
|
|
node.body.expression.type === 'AssignmentExpression' &&
|
|
|
|
|
|
|
|
extract_names(node.body.expression.left).every(name => {
|
|
|
|
|
|
|
|
return name[0] !== '$' && this.var_lookup.get(name).injected;
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|