|
|
|
@ -750,7 +750,7 @@ export default class Component {
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
rewrite_props() {
|
|
|
|
|
rewrite_props(get_insert: (name: string) => string) {
|
|
|
|
|
const component = this;
|
|
|
|
|
const { code, instance_scope, instance_scope_map: map, componentOptions } = this;
|
|
|
|
|
let scope = instance_scope;
|
|
|
|
@ -771,25 +771,46 @@ export default class Component {
|
|
|
|
|
|
|
|
|
|
if (node.type === 'VariableDeclaration') {
|
|
|
|
|
if (node.kind === 'var' || scope === instance_scope) {
|
|
|
|
|
let has_exports = false;
|
|
|
|
|
let has_only_exports = true;
|
|
|
|
|
node.declarations.forEach((declarator, i) => {
|
|
|
|
|
const next = node.declarations[i + 1];
|
|
|
|
|
|
|
|
|
|
if (declarator.id.type !== 'Identifier') {
|
|
|
|
|
const inserts = [];
|
|
|
|
|
|
|
|
|
|
node.declarations.forEach(declarator => {
|
|
|
|
|
extractNames(declarator.id).forEach(name => {
|
|
|
|
|
const variable = component.var_lookup.get(name);
|
|
|
|
|
|
|
|
|
|
if (name === componentOptions.props_object) {
|
|
|
|
|
if (variable.export_name) {
|
|
|
|
|
if (variable.export_name || name === componentOptions.props_object) {
|
|
|
|
|
component.error(declarator, {
|
|
|
|
|
code: 'exported-options-props',
|
|
|
|
|
message: `Cannot export props binding`
|
|
|
|
|
code: 'destructured-prop',
|
|
|
|
|
message: `Cannot declare props in destructured declaration`
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (declarator.id.type !== 'Identifier') {
|
|
|
|
|
if (variable.subscribable) {
|
|
|
|
|
inserts.push(get_insert(name));
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (inserts.length > 0) {
|
|
|
|
|
if (next) {
|
|
|
|
|
code.overwrite(declarator.end, next.start, `; ${inserts.join('; ')}; ${node.kind} `);
|
|
|
|
|
} else {
|
|
|
|
|
code.appendLeft(declarator.end, `; ${inserts.join('; ')}`);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const { name } = declarator.id;
|
|
|
|
|
const variable = component.var_lookup.get(name);
|
|
|
|
|
|
|
|
|
|
if (name === componentOptions.props_object) {
|
|
|
|
|
if (variable.export_name) {
|
|
|
|
|
component.error(declarator, {
|
|
|
|
|
code: 'destructured-prop',
|
|
|
|
|
message: `props binding in destructured declaration is not yet supported`
|
|
|
|
|
code: 'exported-options-props',
|
|
|
|
|
message: `Cannot export props binding`
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -809,36 +830,39 @@ export default class Component {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (variable.export_name) {
|
|
|
|
|
has_exports = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!variable.export_name || variable.subscribable) {
|
|
|
|
|
has_only_exports = false;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
if (variable.subscribable) {
|
|
|
|
|
coalesced_declarations.push({
|
|
|
|
|
kind: node.kind,
|
|
|
|
|
declarators: [declarator],
|
|
|
|
|
insert: get_insert(name)
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (has_only_exports) {
|
|
|
|
|
if (current_group && current_group[current_group.length - 1].kind !== node.kind) {
|
|
|
|
|
} else {
|
|
|
|
|
if (current_group && current_group.kind !== node.kind) {
|
|
|
|
|
current_group = null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// rewrite as a group, later
|
|
|
|
|
if (!current_group) {
|
|
|
|
|
current_group = [];
|
|
|
|
|
current_group = { kind: node.kind, declarators: [], insert: null };
|
|
|
|
|
coalesced_declarations.push(current_group);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
current_group.push(node);
|
|
|
|
|
} else {
|
|
|
|
|
if (has_exports) {
|
|
|
|
|
// rewrite in place
|
|
|
|
|
throw new Error('TODO rewrite prop declaration in place');
|
|
|
|
|
current_group.declarators.push(declarator);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
current_group = null;
|
|
|
|
|
|
|
|
|
|
if (variable.subscribable) {
|
|
|
|
|
let insert = get_insert(name);
|
|
|
|
|
|
|
|
|
|
if (next) {
|
|
|
|
|
code.overwrite(declarator.end, next.start, `; ${insert}; ${node.kind} `);
|
|
|
|
|
} else {
|
|
|
|
|
code.appendLeft(declarator.end, `; ${insert}`);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
if (node.type !== 'ExportNamedDeclaration') {
|
|
|
|
|
if (!parent) current_group = null;
|
|
|
|
@ -858,14 +882,8 @@ export default class Component {
|
|
|
|
|
|
|
|
|
|
let combining = false;
|
|
|
|
|
|
|
|
|
|
group.forEach(node => {
|
|
|
|
|
node.declarations.forEach(declarator => {
|
|
|
|
|
const { id, init } = declarator;
|
|
|
|
|
|
|
|
|
|
if (id.type === 'Identifier') {
|
|
|
|
|
const value = init
|
|
|
|
|
? this.code.slice(id.start, init.end)
|
|
|
|
|
: this.code.slice(id.start, id.end);
|
|
|
|
|
group.declarators.forEach(declarator => {
|
|
|
|
|
const { id } = declarator;
|
|
|
|
|
|
|
|
|
|
if (combining) {
|
|
|
|
|
code.overwrite(c, id.start, ', ');
|
|
|
|
@ -873,16 +891,16 @@ export default class Component {
|
|
|
|
|
code.appendLeft(id.start, '{ ');
|
|
|
|
|
combining = true;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
throw new Error('TODO destructured declarations');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c = declarator.end;
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (combining) {
|
|
|
|
|
const suffix = code.original[c] === ';' ? ` } = $$props` : ` } = $$props;`;
|
|
|
|
|
const insert = group.insert
|
|
|
|
|
? `; ${group.insert}`
|
|
|
|
|
: '';
|
|
|
|
|
|
|
|
|
|
const suffix = code.original[c] === ';' ? ` } = $$props${insert}` : ` } = $$props${insert};`;
|
|
|
|
|
code.appendLeft(c, suffix);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|