##// END OF EJS Templates
caches: use individual namespaces per user to prevent beaker caching problems....
caches: use individual namespaces per user to prevent beaker caching problems. - especially for mysql in case large number of data in caches there could be critical errors storing cache, and thus preventing users from authentication. This is caused by the fact that we used single namespace for ALL users. It means it grew as number of users grew reaching mysql single column limit. This changes the behaviour and now we use namespace per-user it means that each user-id will have it's own cache namespace fragmenting maximum column data to a single user cache. Which we should never reach.

File last commit:

r1:854a839a default
r2572:5b07455a default
Show More
spreadsheet.js
109 lines | 3.0 KiB | application/javascript | JavascriptLexer
// CodeMirror, copyright (c) by Marijn Haverbeke and others
// Distributed under an MIT license: http://codemirror.net/LICENSE
(function(mod) {
if (typeof exports == "object" && typeof module == "object") // CommonJS
mod(require("../../lib/codemirror"));
else if (typeof define == "function" && define.amd) // AMD
define(["../../lib/codemirror"], mod);
else // Plain browser env
mod(CodeMirror);
})(function(CodeMirror) {
"use strict";
CodeMirror.defineMode("spreadsheet", function () {
return {
startState: function () {
return {
stringType: null,
stack: []
};
},
token: function (stream, state) {
if (!stream) return;
//check for state changes
if (state.stack.length === 0) {
//strings
if ((stream.peek() == '"') || (stream.peek() == "'")) {
state.stringType = stream.peek();
stream.next(); // Skip quote
state.stack.unshift("string");
}
}
//return state
//stack has
switch (state.stack[0]) {
case "string":
while (state.stack[0] === "string" && !stream.eol()) {
if (stream.peek() === state.stringType) {
stream.next(); // Skip quote
state.stack.shift(); // Clear flag
} else if (stream.peek() === "\\") {
stream.next();
stream.next();
} else {
stream.match(/^.[^\\\"\']*/);
}
}
return "string";
case "characterClass":
while (state.stack[0] === "characterClass" && !stream.eol()) {
if (!(stream.match(/^[^\]\\]+/) || stream.match(/^\\./)))
state.stack.shift();
}
return "operator";
}
var peek = stream.peek();
//no stack
switch (peek) {
case "[":
stream.next();
state.stack.unshift("characterClass");
return "bracket";
case ":":
stream.next();
return "operator";
case "\\":
if (stream.match(/\\[a-z]+/)) return "string-2";
else return null;
case ".":
case ",":
case ";":
case "*":
case "-":
case "+":
case "^":
case "<":
case "/":
case "=":
stream.next();
return "atom";
case "$":
stream.next();
return "builtin";
}
if (stream.match(/\d+/)) {
if (stream.match(/^\w+/)) return "error";
return "number";
} else if (stream.match(/^[a-zA-Z_]\w*/)) {
if (stream.match(/(?=[\(.])/, false)) return "keyword";
return "variable-2";
} else if (["[", "]", "(", ")", "{", "}"].indexOf(peek) != -1) {
stream.next();
return "bracket";
} else if (!stream.eatSpace()) {
stream.next();
}
return null;
}
};
});
CodeMirror.defineMIME("text/x-spreadsheet", "spreadsheet");
});