option to exclude certain names from mangling

This commit is contained in:
Mihai Bazon
2012-10-02 14:02:33 +03:00
parent dde5b22b5e
commit 36be211e99
2 changed files with 14 additions and 4 deletions

View File

@@ -354,7 +354,8 @@ AST_LoopControl.DEFMETHOD("target", function(){
AST_Toplevel.DEFMETHOD("mangle_names", function(options){
options = defaults(options, {
sort: false
sort : false,
except : []
});
// We only need to mangle declaration nodes. Special logic wired
// into the code generator will display the mangled name if it's
@@ -376,8 +377,11 @@ AST_Toplevel.DEFMETHOD("mangle_names", function(options){
var a = node.variables;
for (var i in a) if (HOP(a, i)) {
var symbol = a[i];
if (!(is_setget && symbol instanceof AST_SymbolLambda))
to_mangle.push(symbol);
if (!(is_setget && symbol instanceof AST_SymbolLambda)) {
if (options.except.indexOf(symbol.name) < 0) {
to_mangle.push(symbol);
}
}
}
return;
}
@@ -385,7 +389,7 @@ AST_Toplevel.DEFMETHOD("mangle_names", function(options){
var name;
do name = base54(++lname); while (!is_identifier(name));
node.mangled_name = name;
return;
return true;
}
});
this.walk(tw);