mirror of https://github.com/sveltejs/svelte
Merge pull request #445 from sveltejs/gh-442-b
generate more idiomatic code when removing object propertiespull/448/head
commit
3881f5f84b
@ -1,9 +1,33 @@
|
||||
export default function removeObjectKey ( generator, node, key ) {
|
||||
if ( node.type !== 'ObjectExpression' ) return;
|
||||
const properties = node.properties;
|
||||
const index = properties.findIndex( property => property.key.type === 'Identifier' && property.key.name === key );
|
||||
if ( index === -1 ) return;
|
||||
const a = properties[ index ].start;
|
||||
const b = index < properties.length - 1 ? properties[ index + 1 ].start : node.end - 1;
|
||||
generator.code.remove( a, b );
|
||||
|
||||
let i = node.properties.length;
|
||||
while ( i-- ) {
|
||||
const property = node.properties[i];
|
||||
if ( property.key.type === 'Identifier' && property.key.name === key ) {
|
||||
let a;
|
||||
let b;
|
||||
|
||||
if ( node.properties.length === 1 ) {
|
||||
// remove everything, leave {}
|
||||
a = node.start + 1;
|
||||
b = node.end - 1;
|
||||
} else if ( i === 0 ) {
|
||||
// remove everything before second property, including comments
|
||||
a = node.start + 1;
|
||||
while ( /\s/.test( generator.code.original[a] ) ) a += 1;
|
||||
|
||||
b = node.properties[i].end;
|
||||
while ( /[\s,]/.test( generator.code.original[b] ) ) b += 1;
|
||||
} else {
|
||||
// remove the end of the previous property to the end of this one
|
||||
a = node.properties[ i - 1 ].end;
|
||||
b = property.end;
|
||||
}
|
||||
|
||||
generator.code.remove( a, b );
|
||||
node.properties.splice( i, 1 );
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,11 +1,11 @@
|
||||
<Component value="10px"/>
|
||||
|
||||
<script>
|
||||
import Component from './Component.html';
|
||||
import Component from './Component.html';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
Component
|
||||
}
|
||||
};
|
||||
export default {
|
||||
components: {
|
||||
Component
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
Loading…
Reference in new issue