123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- /* ***** BEGIN LICENSE BLOCK *****
- * Distributed under the BSD license:
- *
- * Copyright (c) 2010, Ajax.org B.V.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * * Neither the name of Ajax.org B.V. nor the
- * names of its contributors may be used to endorse or promote products
- * derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL AJAX.ORG B.V. BE LIABLE FOR ANY
- * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- * ***** END LICENSE BLOCK ***** */
- define(function(ace_require, exports, module) {
- "no use strict";
- var lang = ace_require("./lib/lang");
- var oop = ace_require("./lib/oop");
- var net = ace_require("./lib/net");
- var AppConfig = ace_require("./lib/app_config").AppConfig;
- module.exports = exports = new AppConfig();
- var global = (function() {
- return this || typeof window != "undefined" && window;
- })();
- var options = {
- packaged: false,
- workerPath: null,
- modePath: null,
- themePath: null,
- basePath: "",
- suffix: ".js",
- $moduleUrls: {},
- loadWorkerFromBlob: true,
- sharedPopups: false
- };
- exports.get = function(key) {
- if (!options.hasOwnProperty(key))
- throw new Error("Unknown config key: " + key);
- return options[key];
- };
- exports.set = function(key, value) {
- if (options.hasOwnProperty(key))
- options[key] = value;
- else if (this.setDefaultValue("", key, value) == false)
- throw new Error("Unknown config key: " + key);
- };
- exports.all = function() {
- return lang.copyObject(options);
- };
- exports.$ace_modes = {};
- // module loading
- exports.moduleUrl = function(name, component) {
- if (options.$moduleUrls[name])
- return options.$moduleUrls[name];
- var parts = name.split("/");
- component = component || parts[parts.length - 2] || "";
-
- // todo make this configurable or get rid of '-'
- var sep = component == "snippets" ? "/" : "-";
- var base = parts[parts.length - 1];
- if (component == "worker" && sep == "-") {
- var re = new RegExp("^" + component + "[\\-_]|[\\-_]" + component + "$", "g");
- base = base.replace(re, "");
- }
- if ((!base || base == component) && parts.length > 1)
- base = parts[parts.length - 2];
- var path = options[component + "Path"];
- if (path == null) {
- path = options.basePath;
- } else if (sep == "/") {
- component = sep = "";
- }
- if (path && path.slice(-1) != "/")
- path += "/";
- return path + component + sep + base + this.get("suffix");
- };
- exports.setModuleUrl = function(name, subst) {
- return options.$moduleUrls[name] = subst;
- };
- exports.$loading = {};
- exports.loadModule = function(moduleName, onLoad) {
- var module, moduleType;
- if (Array.isArray(moduleName)) {
- moduleType = moduleName[0];
- moduleName = moduleName[1];
- }
- try {
- module = ace_require(moduleName);
- } catch (e) {}
- // ace_require(moduleName) can return empty object if called after ace_require([moduleName], callback)
- if (module && !exports.$loading[moduleName])
- return onLoad && onLoad(module);
- if (!exports.$loading[moduleName])
- exports.$loading[moduleName] = [];
- exports.$loading[moduleName].push(onLoad);
- if (exports.$loading[moduleName].length > 1)
- return;
- var afterLoad = function() {
- ace_require([moduleName], function(module) {
- exports._emit("load.module", {name: moduleName, module: module});
- var listeners = exports.$loading[moduleName];
- exports.$loading[moduleName] = null;
- listeners.forEach(function(onLoad) {
- onLoad && onLoad(module);
- });
- });
- };
- if (!exports.get("packaged"))
- return afterLoad();
-
- net.loadScript(exports.moduleUrl(moduleName, moduleType), afterLoad);
- reportErrorIfPathIsNotConfigured();
- };
- var reportErrorIfPathIsNotConfigured = function() {
- if (
- !options.basePath && !options.workerPath
- && !options.modePath && !options.themePath
- && !Object.keys(options.$moduleUrls).length
- ) {
- console.error(
- "Unable to infer path to ace from script src,",
- "use ace.config.set('basePath', 'path') to enable dynamic loading of modes and themes",
- "or with webpack use ace/webpack-resolver"
- );
- reportErrorIfPathIsNotConfigured = function() {};
- }
- };
- // initialization
- function init(packaged) {
- if (!global || !global.document)
- return;
-
- options.packaged = packaged || ace_require.packaged || module.packaged || (global.define && define.packaged);
- var scriptOptions = {};
- var scriptUrl = "";
- // Use currentScript.ownerDocument in case this file was loaded from imported document. (HTML Imports)
- var currentScript = (document.currentScript || document._currentScript ); // native or polyfill
- var currentDocument = currentScript && currentScript.ownerDocument || document;
-
- var scripts = currentDocument.getElementsByTagName("script");
- for (var i=0; i<scripts.length; i++) {
- var script = scripts[i];
- var src = script.src || script.getAttribute("src");
- if (!src)
- continue;
- var attributes = script.attributes;
- for (var j=0, l=attributes.length; j < l; j++) {
- var attr = attributes[j];
- if (attr.name.indexOf("data-ace-") === 0) {
- scriptOptions[deHyphenate(attr.name.replace(/^data-ace-/, ""))] = attr.value;
- }
- }
- var m = src.match(/^(.*)\/ace(\-\w+)?\.js(\?|$)/);
- if (m)
- scriptUrl = m[1];
- }
- if (scriptUrl) {
- scriptOptions.base = scriptOptions.base || scriptUrl;
- scriptOptions.packaged = true;
- }
- scriptOptions.basePath = scriptOptions.base;
- scriptOptions.workerPath = scriptOptions.workerPath || scriptOptions.base;
- scriptOptions.modePath = scriptOptions.modePath || scriptOptions.base;
- scriptOptions.themePath = scriptOptions.themePath || scriptOptions.base;
- delete scriptOptions.base;
- for (var key in scriptOptions)
- if (typeof scriptOptions[key] !== "undefined")
- exports.set(key, scriptOptions[key]);
- }
- exports.init = init;
- function deHyphenate(str) {
- return str.replace(/-(.)/g, function(m, m1) { return m1.toUpperCase(); });
- }
- exports.version = "1.4.10";
- });
|