Вход Регистрация
Файл: wysiwyg/live/scripts/common/codemirror/mode/javascript/javascript.js
Строк: 575
<?php
CodeMirror
.defineMode("javascript", function(configparserConfig) {
  var 
indentUnit config.indentUnit;
  var 
jsonMode parserConfig.json;

  
// Tokenizer

  
var keywords = function(){
    function 
kw(type) {return {typetypestyle"keyword"};}
    var 
kw("keyword a"), kw("keyword b"), kw("keyword c");
    var 
operator kw("operator"), atom = {type"atom"style"atom"};
    return {
      
"if"A"while"A"with"A"else"B"do"B"try"B"finally"B,
      
"return"C"break"C"continue"C"new"C"delete"C"throw"C,
      
"var"kw("var"), "const"kw("var"), "let"kw("var"),
      
"function"kw("function"), "catch"kw("catch"),
      
"for"kw("for"), "switch"kw("switch"), "case"kw("case"), "default"kw("default"),
      
"in"operator"typeof"operator"instanceof"operator,
      
"true"atom"false"atom"null"atom"undefined"atom"NaN"atom"Infinity"atom
    
};
  }();

  var 
isOperatorChar = /[+-*&%=<>!?|]/;

  function 
chain(streamstatef) {
    
state.tokenize f;
    return 
f(streamstate);
  }

  function 
nextUntilUnescaped(streamend) {
    var 
escaped falsenext;
    while ((
next stream.next()) != null) {
      if (
next == end && !escaped)
        return 
false;
      
escaped = !escaped && next == "\";
    }
    return escaped;
  }

  // Used as scratch variables to communicate multiple values without
  // consing up tons of objects.
  var type, content;
  function ret(tp, style, cont) {
    type = tp; content = cont;
    return style;
  }

  function jsTokenBase(stream, state) {
    var ch = stream.next();
    if (ch == '"' || ch == "'")
      return chain(stream, state, jsTokenString(ch));
    else if (/[[]{}(),;:.]/.test(ch))
      return ret(ch);
    else if (ch == "
0" && stream.eat(/x/i)) {
      stream.eatWhile(/[da-f]/i);
      return ret("
number", "number");
    }      
    else if (/d/.test(ch)) {
      stream.match(/^d*(?:.d*)?(?:[eE][+-]?d+)?/);
      return ret("
number", "number");
    }
    else if (ch == "
/") {
      if (stream.eat("
*")) {
        return chain(stream, state, jsTokenComment);
      }
      else if (stream.eat("
/")) {
        stream.skipToEnd();
        return ret("
comment", "comment");
      }
      else if (state.reAllowed) {
        nextUntilUnescaped(stream, "
/");
        stream.eatWhile(/[gimy]/); // 'y' is "
sticky" option in Mozilla
        return ret("
regexp", "string");
      }
      else {
        stream.eatWhile(isOperatorChar);
        return ret("
operator", null, stream.current());
      }
    }
    else if (ch == "
#") {
        
stream.skipToEnd();
        return 
ret("error""error");
    }
    else if (
isOperatorChar.test(ch)) {
      
stream.eatWhile(isOperatorChar);
      return 
ret("operator"nullstream.current());
    }
    else {
      
stream.eatWhile(/[w$_]/);
      var 
word stream.current(), known keywords.propertyIsEnumerable(word) && keywords[word];
      return (
known && state.kwAllowed) ? ret(known.typeknown.styleword) :
                     
ret("variable""variable"word);
    }
  }

  function 
jsTokenString(quote) {
    return function(
streamstate) {
      if (!
nextUntilUnescaped(streamquote))
        
state.tokenize jsTokenBase;
      return 
ret("string""string");
    };
  }

  function 
jsTokenComment(streamstate) {
    var 
maybeEnd falsech;
    while (
ch stream.next()) {
      if (
ch == "/" && maybeEnd) {
        
state.tokenize jsTokenBase;
        break;
      }
      
maybeEnd = (ch == "*");
    }
    return 
ret("comment""comment");
  }

  
// Parser

  
var atomicTypes = {"atom"true"number"true"variable"true"string"true"regexp"true};

  function 
JSLexical(indentedcolumntypealignprevinfo) {
    
this.indented indented;
    
this.column column;
    
this.type type;
    
this.prev prev;
    
this.info info;
    if (
align != nullthis.align align;
  }

  function 
inScope(statevarname) {
    for (var 
state.localVarsvv.next)
      if (
v.name == varname) return true;
  }

  function 
parseJS(statestyletypecontentstream) {
    var 
cc state.cc;
    
// Communicate our context to the combinators.
    // (Less wasteful than consing up a hundred closures on every call.)
    
cx.state statecx.stream streamcx.marked nullcx.cc cc;
  
    if (!
state.lexical.hasOwnProperty("align"))
      
state.lexical.align true;

    while(
true) {
      var 
combinator cc.length cc.pop() : jsonMode expression statement;
      if (
combinator(typecontent)) {
        while(
cc.length && cc[cc.length 1].lex)
          
cc.pop()();
        if (
cx.marked) return cx.marked;
        if (
type == "variable" && inScope(statecontent)) return "variable-2";
        return 
style;
      }
    }
  }

  
// Combinator utils

  
var cx = {statenullcolumnnullmarkednullccnull};
  function 
pass() {
    for (var 
arguments.length 1>= 0i--) cx.cc.push(arguments[i]);
  }
  function 
cont() {
    
pass.apply(nullarguments);
    return 
true;
  }
  function 
register(varname) {
    var 
state cx.state;
    if (
state.context) {
      
cx.marked "def";
      for (var 
state.localVarsvv.next)
        if (
v.name == varname) return;
      
state.localVars = {namevarnamenextstate.localVars};
    }
  }

  
// Combinators

  
var defaultVars = {name"this"next: {name"arguments"}};
  function 
pushcontext() {
    if (!
cx.state.contextcx.state.localVars defaultVars;
    
cx.state.context = {prevcx.state.contextvarscx.state.localVars};
  }
  function 
popcontext() {
    
cx.state.localVars cx.state.context.vars;
    
cx.state.context cx.state.context.prev;
  }
  function 
pushlex(typeinfo) {
    var 
result = function() {
      var 
state cx.state;
      
state.lexical = new JSLexical(state.indentedcx.stream.column(), typenullstate.lexicalinfo)
    };
    
result.lex true;
    return 
result;
  }
  function 
poplex() {
    var 
state cx.state;
    if (
state.lexical.prev) {
      if (
state.lexical.type == ")")
        
state.indented state.lexical.indented;
      
state.lexical state.lexical.prev;
    }
  }
  
poplex.lex true;

  function 
expect(wanted) {
    return function 
expecting(type) {
      if (
type == wanted) return cont();
      else if (
wanted == ";") return pass();
      else return 
cont(arguments.callee);
    };
  }

  function 
statement(type) {
    if (
type == "var") return cont(pushlex("vardef"), vardef1expect(";"), poplex);
    if (
type == "keyword a") return cont(pushlex("form"), expressionstatementpoplex);
    if (
type == "keyword b") return cont(pushlex("form"), statementpoplex);
    if (
type == "{") return cont(pushlex("}"), blockpoplex);
    if (
type == ";") return cont();
    if (
type == "function") return cont(functiondef);
    if (
type == "for") return cont(pushlex("form"), expect("("), pushlex(")"), forspec1expect(")"),
                                      
poplexstatementpoplex);
    if (
type == "variable") return cont(pushlex("stat"), maybelabel);
    if (
type == "switch") return cont(pushlex("form"), expressionpushlex("}""switch"), expect("{"),
                                         
blockpoplexpoplex);
    if (
type == "case") return cont(expressionexpect(":"));
    if (
type == "default") return cont(expect(":"));
    if (
type == "catch") return cont(pushlex("form"), pushcontextexpect("("), funargexpect(")"),
                                        
statementpoplexpopcontext);
    return 
pass(pushlex("stat"), expressionexpect(";"), poplex);
  }
  function 
expression(type) {
    if (
atomicTypes.hasOwnProperty(type)) return cont(maybeoperator);
    if (
type == "function") return cont(functiondef);
    if (
type == "keyword c") return cont(maybeexpression);
    if (
type == "(") return cont(pushlex(")"), expressionexpect(")"), poplexmaybeoperator);
    if (
type == "operator") return cont(expression);
    if (
type == "[") return cont(pushlex("]"), commasep(expression"]"), poplexmaybeoperator);
    if (
type == "{") return cont(pushlex("}"), commasep(objprop"}"), poplexmaybeoperator);
    return 
cont();
  }
  function 
maybeexpression(type) {
    if (
type.match(/[;})],]/)) return pass();
    return 
pass(expression);
  }
    
  function 
maybeoperator(typevalue) {
    if (
type == "operator" && /++|--/.test(value)) return cont(maybeoperator);
    if (
type == "operator") return cont(expression);
    if (
type == ";") return;
    if (
type == "(") return cont(pushlex(")"), commasep(expression")"), poplexmaybeoperator);
    if (
type == ".") return cont(propertymaybeoperator);
    if (
type == "[") return cont(pushlex("]"), expressionexpect("]"), poplexmaybeoperator);
  }
  function 
maybelabel(type) {
    if (
type == ":") return cont(poplexstatement);
    return 
pass(maybeoperatorexpect(";"), poplex);
  }
  function 
property(type) {
    if (
type == "variable") {cx.marked "property"; return cont();}
  }
  function 
objprop(type) {
    if (
type == "variable"cx.marked "property";
    if (
atomicTypes.hasOwnProperty(type)) return cont(expect(":"), expression);
  }
  function 
commasep(whatend) {
    function 
proceed(type) {
      if (
type == ",") return cont(whatproceed);
      if (
type == end) return cont();
      return 
cont(expect(end));
    }
    return function 
commaSeparated(type) {
      if (
type == end) return cont();
      else return 
pass(whatproceed);
    };
  }
  function 
block(type) {
    if (
type == "}") return cont();
    return 
pass(statementblock);
  }
  function 
vardef1(typevalue) {
    if (
type == "variable"){register(value); return cont(vardef2);}
    return 
cont();
  }
  function 
vardef2(typevalue) {
    if (
value == "=") return cont(expressionvardef2);
    if (
type == ",") return cont(vardef1);
  }
  function 
forspec1(type) {
    if (
type == "var") return cont(vardef1forspec2);
    if (
type == ";") return pass(forspec2);
    if (
type == "variable") return cont(formaybein);
    return 
pass(forspec2);
  }
  function 
formaybein(typevalue) {
    if (
value == "in") return cont(expression);
    return 
cont(maybeoperatorforspec2);
  }
  function 
forspec2(typevalue) {
    if (
type == ";") return cont(forspec3);
    if (
value == "in") return cont(expression);
    return 
cont(expressionexpect(";"), forspec3);
  }
  function 
forspec3(type) {
    if (
type != ")"cont(expression);
  }
  function 
functiondef(typevalue) {
    if (
type == "variable") {register(value); return cont(functiondef);}
    if (
type == "(") return cont(pushlex(")"), pushcontextcommasep(funarg")"), poplexstatementpopcontext);
  }
  function 
funarg(typevalue) {
    if (
type == "variable") {register(value); return cont();}
  }

  
// Interface

  
return {
    
startState: function(basecolumn) {
      return {
        
tokenizejsTokenBase,
        
reAllowedtrue,
        
kwAllowedtrue,
        
cc: [],
        
lexical: new JSLexical((basecolumn || 0) - indentUnit0"block"false),
        
localVarsnull,
        
contextnull,
        
indented0
      
};
    },

    
token: function(streamstate) {
      if (
stream.sol()) {
        if (!
state.lexical.hasOwnProperty("align"))
          
state.lexical.align false;
        
state.indented stream.indentation();
      }
      if (
stream.eatSpace()) return null;
      var 
style state.tokenize(streamstate);
      if (
type == "comment") return style;
      
state.reAllowed type == "operator" || type == "keyword c" || type.match(/^[[{}(,;:]$/);
      
state.kwAllowed type != '.';
      return 
parseJS(statestyletypecontentstream);
    },

    
indent: function(statetextAfter) {
      if (
state.tokenize != jsTokenBase) return 0;
      var 
firstChar textAfter && textAfter.charAt(0), lexical state.lexical,
          
type lexical.typeclosing firstChar == type;
      if (
type == "vardef") return lexical.indented 4;
      else if (
type == "form" && firstChar == "{") return lexical.indented;
      else if (
type == "stat" || type == "form") return lexical.indented indentUnit;
      else if (
lexical.info == "switch" && !closing)
        return 
lexical.indented + (/^(?:case|default)b/.test(textAfter) ? indentUnit indentUnit);
      else if (
lexical.align) return lexical.column + (closing 1);
      else return 
lexical.indented + (closing indentUnit);
    },

    
electricChars":{}"
  
};
});

CodeMirror.defineMIME("text/javascript""javascript");
CodeMirror.defineMIME("application/json", {name"javascript"jsontrue});
?>
Онлайн: 1
Реклама