Mark vars with /** @const */ pragma as consts so they can be eliminated.
Fixes older browser support for consts and allows more flexibility in dead code removal.
This commit is contained in:
12
lib/scope.js
12
lib/scope.js
@@ -154,7 +154,7 @@ AST_Toplevel.DEFMETHOD("figure_out_scope", function(options){
|
||||
else if (node instanceof AST_SymbolVar
|
||||
|| node instanceof AST_SymbolConst) {
|
||||
var def = defun.def_variable(node);
|
||||
def.constant = node instanceof AST_SymbolConst;
|
||||
def.constant = node instanceof AST_SymbolConst || node.has_const_pragma();
|
||||
def.init = tw.parent().value;
|
||||
}
|
||||
else if (node instanceof AST_SymbolCatch) {
|
||||
@@ -357,6 +357,16 @@ AST_Symbol.DEFMETHOD("global", function(){
|
||||
return this.definition().global;
|
||||
});
|
||||
|
||||
AST_Symbol.DEFMETHOD("has_const_pragma", function() {
|
||||
var token = this.scope.body[0] && this.scope.body[0].start;
|
||||
var comments = token && token.comments_before;
|
||||
if (comments && comments.length > 0) {
|
||||
var last = comments[comments.length - 1];
|
||||
return /@const/.test(last.value);
|
||||
}
|
||||
return false;
|
||||
})
|
||||
|
||||
AST_Toplevel.DEFMETHOD("_default_mangler_options", function(options){
|
||||
return defaults(options, {
|
||||
except : [],
|
||||
|
||||
Reference in New Issue
Block a user