Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/wp-conte.../plugins/wp-file-.../lib/codemirr.../mode/velocity
File: velocity.js
// CodeMirror, copyright (c) by Marijn Haverbeke and others
[0] Fix | Delete
// Distributed under an MIT license: http://codemirror.net/LICENSE
[1] Fix | Delete
[2] Fix | Delete
(function(mod) {
[3] Fix | Delete
if (typeof exports == "object" && typeof module == "object") // CommonJS
[4] Fix | Delete
mod(require("../../lib/codemirror"));
[5] Fix | Delete
else if (typeof define == "function" && define.amd) // AMD
[6] Fix | Delete
define(["../../lib/codemirror"], mod);
[7] Fix | Delete
else // Plain browser env
[8] Fix | Delete
mod(CodeMirror);
[9] Fix | Delete
})(function(CodeMirror) {
[10] Fix | Delete
"use strict";
[11] Fix | Delete
[12] Fix | Delete
CodeMirror.defineMode("velocity", function() {
[13] Fix | Delete
function parseWords(str) {
[14] Fix | Delete
var obj = {}, words = str.split(" ");
[15] Fix | Delete
for (var i = 0; i < words.length; ++i) obj[words[i]] = true;
[16] Fix | Delete
return obj;
[17] Fix | Delete
}
[18] Fix | Delete
[19] Fix | Delete
var keywords = parseWords("#end #else #break #stop #[[ #]] " +
[20] Fix | Delete
"#{end} #{else} #{break} #{stop}");
[21] Fix | Delete
var functions = parseWords("#if #elseif #foreach #set #include #parse #macro #define #evaluate " +
[22] Fix | Delete
"#{if} #{elseif} #{foreach} #{set} #{include} #{parse} #{macro} #{define} #{evaluate}");
[23] Fix | Delete
var specials = parseWords("$foreach.count $foreach.hasNext $foreach.first $foreach.last $foreach.topmost $foreach.parent.count $foreach.parent.hasNext $foreach.parent.first $foreach.parent.last $foreach.parent $velocityCount $!bodyContent $bodyContent");
[24] Fix | Delete
var isOperatorChar = /[+\-*&%=<>!?:\/|]/;
[25] Fix | Delete
[26] Fix | Delete
function chain(stream, state, f) {
[27] Fix | Delete
state.tokenize = f;
[28] Fix | Delete
return f(stream, state);
[29] Fix | Delete
}
[30] Fix | Delete
function tokenBase(stream, state) {
[31] Fix | Delete
var beforeParams = state.beforeParams;
[32] Fix | Delete
state.beforeParams = false;
[33] Fix | Delete
var ch = stream.next();
[34] Fix | Delete
// start of unparsed string?
[35] Fix | Delete
if ((ch == "'") && !state.inString && state.inParams) {
[36] Fix | Delete
state.lastTokenWasBuiltin = false;
[37] Fix | Delete
return chain(stream, state, tokenString(ch));
[38] Fix | Delete
}
[39] Fix | Delete
// start of parsed string?
[40] Fix | Delete
else if ((ch == '"')) {
[41] Fix | Delete
state.lastTokenWasBuiltin = false;
[42] Fix | Delete
if (state.inString) {
[43] Fix | Delete
state.inString = false;
[44] Fix | Delete
return "string";
[45] Fix | Delete
}
[46] Fix | Delete
else if (state.inParams)
[47] Fix | Delete
return chain(stream, state, tokenString(ch));
[48] Fix | Delete
}
[49] Fix | Delete
// is it one of the special signs []{}().,;? Seperator?
[50] Fix | Delete
else if (/[\[\]{}\(\),;\.]/.test(ch)) {
[51] Fix | Delete
if (ch == "(" && beforeParams)
[52] Fix | Delete
state.inParams = true;
[53] Fix | Delete
else if (ch == ")") {
[54] Fix | Delete
state.inParams = false;
[55] Fix | Delete
state.lastTokenWasBuiltin = true;
[56] Fix | Delete
}
[57] Fix | Delete
return null;
[58] Fix | Delete
}
[59] Fix | Delete
// start of a number value?
[60] Fix | Delete
else if (/\d/.test(ch)) {
[61] Fix | Delete
state.lastTokenWasBuiltin = false;
[62] Fix | Delete
stream.eatWhile(/[\w\.]/);
[63] Fix | Delete
return "number";
[64] Fix | Delete
}
[65] Fix | Delete
// multi line comment?
[66] Fix | Delete
else if (ch == "#" && stream.eat("*")) {
[67] Fix | Delete
state.lastTokenWasBuiltin = false;
[68] Fix | Delete
return chain(stream, state, tokenComment);
[69] Fix | Delete
}
[70] Fix | Delete
// unparsed content?
[71] Fix | Delete
else if (ch == "#" && stream.match(/ *\[ *\[/)) {
[72] Fix | Delete
state.lastTokenWasBuiltin = false;
[73] Fix | Delete
return chain(stream, state, tokenUnparsed);
[74] Fix | Delete
}
[75] Fix | Delete
// single line comment?
[76] Fix | Delete
else if (ch == "#" && stream.eat("#")) {
[77] Fix | Delete
state.lastTokenWasBuiltin = false;
[78] Fix | Delete
stream.skipToEnd();
[79] Fix | Delete
return "comment";
[80] Fix | Delete
}
[81] Fix | Delete
// variable?
[82] Fix | Delete
else if (ch == "$") {
[83] Fix | Delete
stream.eatWhile(/[\w\d\$_\.{}]/);
[84] Fix | Delete
// is it one of the specials?
[85] Fix | Delete
if (specials && specials.propertyIsEnumerable(stream.current())) {
[86] Fix | Delete
return "keyword";
[87] Fix | Delete
}
[88] Fix | Delete
else {
[89] Fix | Delete
state.lastTokenWasBuiltin = true;
[90] Fix | Delete
state.beforeParams = true;
[91] Fix | Delete
return "builtin";
[92] Fix | Delete
}
[93] Fix | Delete
}
[94] Fix | Delete
// is it a operator?
[95] Fix | Delete
else if (isOperatorChar.test(ch)) {
[96] Fix | Delete
state.lastTokenWasBuiltin = false;
[97] Fix | Delete
stream.eatWhile(isOperatorChar);
[98] Fix | Delete
return "operator";
[99] Fix | Delete
}
[100] Fix | Delete
else {
[101] Fix | Delete
// get the whole word
[102] Fix | Delete
stream.eatWhile(/[\w\$_{}@]/);
[103] Fix | Delete
var word = stream.current();
[104] Fix | Delete
// is it one of the listed keywords?
[105] Fix | Delete
if (keywords && keywords.propertyIsEnumerable(word))
[106] Fix | Delete
return "keyword";
[107] Fix | Delete
// is it one of the listed functions?
[108] Fix | Delete
if (functions && functions.propertyIsEnumerable(word) ||
[109] Fix | Delete
(stream.current().match(/^#@?[a-z0-9_]+ *$/i) && stream.peek()=="(") &&
[110] Fix | Delete
!(functions && functions.propertyIsEnumerable(word.toLowerCase()))) {
[111] Fix | Delete
state.beforeParams = true;
[112] Fix | Delete
state.lastTokenWasBuiltin = false;
[113] Fix | Delete
return "keyword";
[114] Fix | Delete
}
[115] Fix | Delete
if (state.inString) {
[116] Fix | Delete
state.lastTokenWasBuiltin = false;
[117] Fix | Delete
return "string";
[118] Fix | Delete
}
[119] Fix | Delete
if (stream.pos > word.length && stream.string.charAt(stream.pos-word.length-1)=="." && state.lastTokenWasBuiltin)
[120] Fix | Delete
return "builtin";
[121] Fix | Delete
// default: just a "word"
[122] Fix | Delete
state.lastTokenWasBuiltin = false;
[123] Fix | Delete
return null;
[124] Fix | Delete
}
[125] Fix | Delete
}
[126] Fix | Delete
[127] Fix | Delete
function tokenString(quote) {
[128] Fix | Delete
return function(stream, state) {
[129] Fix | Delete
var escaped = false, next, end = false;
[130] Fix | Delete
while ((next = stream.next()) != null) {
[131] Fix | Delete
if ((next == quote) && !escaped) {
[132] Fix | Delete
end = true;
[133] Fix | Delete
break;
[134] Fix | Delete
}
[135] Fix | Delete
if (quote=='"' && stream.peek() == '$' && !escaped) {
[136] Fix | Delete
state.inString = true;
[137] Fix | Delete
end = true;
[138] Fix | Delete
break;
[139] Fix | Delete
}
[140] Fix | Delete
escaped = !escaped && next == "\\";
[141] Fix | Delete
}
[142] Fix | Delete
if (end) state.tokenize = tokenBase;
[143] Fix | Delete
return "string";
[144] Fix | Delete
};
[145] Fix | Delete
}
[146] Fix | Delete
[147] Fix | Delete
function tokenComment(stream, state) {
[148] Fix | Delete
var maybeEnd = false, ch;
[149] Fix | Delete
while (ch = stream.next()) {
[150] Fix | Delete
if (ch == "#" && maybeEnd) {
[151] Fix | Delete
state.tokenize = tokenBase;
[152] Fix | Delete
break;
[153] Fix | Delete
}
[154] Fix | Delete
maybeEnd = (ch == "*");
[155] Fix | Delete
}
[156] Fix | Delete
return "comment";
[157] Fix | Delete
}
[158] Fix | Delete
[159] Fix | Delete
function tokenUnparsed(stream, state) {
[160] Fix | Delete
var maybeEnd = 0, ch;
[161] Fix | Delete
while (ch = stream.next()) {
[162] Fix | Delete
if (ch == "#" && maybeEnd == 2) {
[163] Fix | Delete
state.tokenize = tokenBase;
[164] Fix | Delete
break;
[165] Fix | Delete
}
[166] Fix | Delete
if (ch == "]")
[167] Fix | Delete
maybeEnd++;
[168] Fix | Delete
else if (ch != " ")
[169] Fix | Delete
maybeEnd = 0;
[170] Fix | Delete
}
[171] Fix | Delete
return "meta";
[172] Fix | Delete
}
[173] Fix | Delete
// Interface
[174] Fix | Delete
[175] Fix | Delete
return {
[176] Fix | Delete
startState: function() {
[177] Fix | Delete
return {
[178] Fix | Delete
tokenize: tokenBase,
[179] Fix | Delete
beforeParams: false,
[180] Fix | Delete
inParams: false,
[181] Fix | Delete
inString: false,
[182] Fix | Delete
lastTokenWasBuiltin: false
[183] Fix | Delete
};
[184] Fix | Delete
},
[185] Fix | Delete
[186] Fix | Delete
token: function(stream, state) {
[187] Fix | Delete
if (stream.eatSpace()) return null;
[188] Fix | Delete
return state.tokenize(stream, state);
[189] Fix | Delete
},
[190] Fix | Delete
blockCommentStart: "#*",
[191] Fix | Delete
blockCommentEnd: "*#",
[192] Fix | Delete
lineComment: "##",
[193] Fix | Delete
fold: "velocity"
[194] Fix | Delete
};
[195] Fix | Delete
});
[196] Fix | Delete
[197] Fix | Delete
CodeMirror.defineMIME("text/velocity", "velocity");
[198] Fix | Delete
[199] Fix | Delete
});
[200] Fix | Delete
[201] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function