kopia lustrzana https://github.com/c9/core
simplify setting handling in ace
rodzic
3ac7d84a6d
commit
2314af3795
|
@ -3,7 +3,7 @@ define(function(require, exports, module) {
|
|||
main.consumes = [
|
||||
"Editor", "editors", "commands", "menus", "Menu", "MenuItem", "Divider",
|
||||
"settings", "c9", "preferences", "ui", "tabManager", "layout", "util",
|
||||
"threewaymerge", "error_handler"
|
||||
"threewaymerge", "error_handler", "apf"
|
||||
];
|
||||
main.provides = ["ace"];
|
||||
return main;
|
||||
|
@ -15,6 +15,7 @@ define(function(require, exports, module) {
|
|||
var menus = imports.menus;
|
||||
var settings = imports.settings;
|
||||
var layout = imports.layout;
|
||||
var apf = imports.apf;
|
||||
var c9 = imports.c9;
|
||||
var ui = imports.ui;
|
||||
var util = imports.util;
|
||||
|
@ -233,49 +234,49 @@ define(function(require, exports, module) {
|
|||
var STRING = "get";
|
||||
var NUMBER = "getNumber";
|
||||
|
||||
// Name, Default Value, Type, Old Name, Store in Project Settings
|
||||
var font = "Monaco, Menlo, Ubuntu Mono, Consolas, source-code-pro, monospace";
|
||||
// Name, Default Value, Type
|
||||
var aceSettings = [
|
||||
// detected from document value
|
||||
["newLineMode", "unix", STRING, "newlinemode", 1],
|
||||
["newLineMode", "unix", STRING],
|
||||
// Per document
|
||||
["tabSize", 4, NUMBER, "tabsize", 1],
|
||||
["useSoftTabs", true, BOOL, "softtabs", 1],
|
||||
["guessTabSize", true, BOOL, "guesstabsize", 1],
|
||||
["useWrapMode", false, BOOL, "wrapmode"],
|
||||
["wrapToView", true, BOOL, "wrapmodeViewport"],
|
||||
["tabSize", 4, NUMBER],
|
||||
["useSoftTabs", true, BOOL],
|
||||
["guessTabSize", true, BOOL],
|
||||
["useWrapMode", false, BOOL],
|
||||
["wrapToView", true, BOOL],
|
||||
|
||||
// Ace
|
||||
["fontSize", 12, NUMBER, "fontsize"],
|
||||
["fontFamily", font, STRING, "fontfamily"],
|
||||
["fontSize", 12, NUMBER],
|
||||
["fontFamily", font, STRING],
|
||||
["antialiasedfonts", false, BOOL],
|
||||
["overwrite", false, BOOL, "overwrite"],
|
||||
["selectionStyle", "line", STRING, "selectstyle"],
|
||||
["cursorStyle", "ace", STRING, "cursorstyle"],
|
||||
["highlightActiveLine", true, BOOL, "activeline"],
|
||||
["highlightGutterLine", true, BOOL, "gutterline"],
|
||||
["showInvisibles", false, BOOL, "showinvisibles"],
|
||||
["showPrintMargin", true, BOOL, "showprintmargin"],
|
||||
["displayIndentGuides", true, BOOL, "showindentguides"],
|
||||
["printMarginColumn", 80, NUMBER, "printmargincolumn"],
|
||||
["behavioursEnabled", true, BOOL, "behaviors"],
|
||||
["wrapBehavioursEnabled", false, BOOL, "wrapbehaviors"],
|
||||
["scrollSpeed", 2, NUMBER, "scrollspeed"],
|
||||
["showGutter", true, BOOL, "gutter"],
|
||||
["overwrite", false, BOOL],
|
||||
["selectionStyle", "line", STRING],
|
||||
["cursorStyle", "ace", STRING],
|
||||
["highlightActiveLine", true, BOOL],
|
||||
["highlightGutterLine", true, BOOL],
|
||||
["showInvisibles", false, BOOL],
|
||||
["showPrintMargin", true, BOOL],
|
||||
["displayIndentGuides", true, BOOL],
|
||||
["printMarginColumn", 80, NUMBER],
|
||||
["behavioursEnabled", true, BOOL],
|
||||
["wrapBehavioursEnabled", false, BOOL],
|
||||
["scrollSpeed", 2, NUMBER],
|
||||
["showGutter", true, BOOL],
|
||||
["showLineNumbers", true, STRING],
|
||||
["showFoldWidgets", true, BOOL, "folding"],
|
||||
["fadeFoldWidgets", true, BOOL, "fadefoldwidgets"],
|
||||
["highlightSelectedWord", true, BOOL, "highlightselectedword"],
|
||||
["animatedScroll", true, BOOL, "animatedscroll"],
|
||||
["showFoldWidgets", true, BOOL],
|
||||
["fadeFoldWidgets", true, BOOL],
|
||||
["highlightSelectedWord", true, BOOL],
|
||||
["animatedScroll", true, BOOL],
|
||||
["scrollPastEnd", 0.5, NUMBER],
|
||||
["mergeUndoDeltas", "off", STRING],
|
||||
["theme", defaultThemes[skin], STRING, "theme"]
|
||||
["theme", defaultThemes[skin], STRING]
|
||||
];
|
||||
var docSettings = aceSettings.slice(1, 6);
|
||||
var editorSettings = aceSettings.slice(6);
|
||||
var projectSettings = aceSettings.slice(0, 4);
|
||||
var userSettings = aceSettings.slice(4);
|
||||
var docLut = {}; docSettings.forEach(function(x) { docLut[x[0]] = x; });
|
||||
var lastSettings = {};
|
||||
|
||||
/***** Undo Manager *****/
|
||||
|
||||
|
@ -482,7 +483,6 @@ define(function(require, exports, module) {
|
|||
setCommands();
|
||||
|
||||
// Settings
|
||||
var lastSettings = {};
|
||||
function updateSettings(e, list, prefix) {
|
||||
var options = {};
|
||||
(list || aceSettings).forEach(function(setting) {
|
||||
|
@ -490,15 +490,6 @@ define(function(require, exports, module) {
|
|||
= settings[setting[2]](prefix + "/ace/@" + setting[0]);
|
||||
});
|
||||
|
||||
// When loading from settings only set editor settings
|
||||
docSettings.forEach(function(setting) {
|
||||
var val = options[setting[0]];
|
||||
if (val !== undefined) {
|
||||
setting[1] = val;
|
||||
delete options[setting[0]];
|
||||
}
|
||||
});
|
||||
|
||||
handleEmit("settingsUpdate", {
|
||||
options: options
|
||||
});
|
||||
|
@ -509,10 +500,10 @@ define(function(require, exports, module) {
|
|||
util.extend(lastSettings, options);
|
||||
}
|
||||
|
||||
settings.setDefaults("user/ace", userSettings);
|
||||
settings.setDefaults("project/ace", projectSettings);
|
||||
|
||||
settings.on("read", function(e) {
|
||||
settings.setDefaults("user/ace", userSettings);
|
||||
settings.setDefaults("project/ace", projectSettings);
|
||||
|
||||
// TODO remove when there is a better way of loading custom themes
|
||||
var customTheme = settings.get("user/ace/@customTheme");
|
||||
if (customTheme)
|
||||
|
@ -2500,7 +2491,7 @@ define(function(require, exports, module) {
|
|||
if (!e.state || !e.state.options)
|
||||
docSettings.forEach(function(setting) {
|
||||
var name = setting[0];
|
||||
setOption(name, setting[1], c9Session);
|
||||
setOption(name, lastSettings[name], c9Session);
|
||||
});
|
||||
|
||||
if (e.state && e.state.customSyntax)
|
||||
|
|
Ładowanie…
Reference in New Issue