tt-rss/lib/dojo/_base/configSpidermonkey.js

81 lines
2.2 KiB
JavaScript
Raw Normal View History

2012-08-14 16:59:10 +02:00
// TODO: this file needs to be converted to the v1.7 loader
2013-03-18 07:26:24 +01:00
// module:
// configSpidermonkey
// summary:
// SpiderMonkey host environment
if(dojo.config["baseUrl"]){
dojo.baseUrl = dojo.config["baseUrl"];
}else{
dojo.baseUrl = "./";
}
dojo._name = 'spidermonkey';
2013-03-18 07:26:24 +01:00
dojo.isSpidermonkey = true;
2011-11-08 17:40:44 +01:00
dojo.exit = function(exitcode){
quit(exitcode);
2012-08-14 16:59:10 +02:00
};
if(typeof print == "function"){
console.debug = print;
}
if(typeof line2pc == 'undefined'){
throw new Error("attempt to use SpiderMonkey host environment when no 'line2pc' global");
}
dojo._spidermonkeyCurrentFile = function(depth){
2011-11-08 17:40:44 +01:00
//
// This is a hack that determines the current script file by parsing a
// generated stack trace (relying on the non-standard "stack" member variable
// of the SpiderMonkey Error object).
2011-11-08 17:40:44 +01:00
//
// If param depth is passed in, it'll return the script file which is that far down
// the stack, but that does require that you know how deep your stack is when you are
// calling.
2011-11-08 17:40:44 +01:00
//
2012-08-14 16:59:10 +02:00
var s = '';
try{
throw Error("whatever");
}catch(e){
s = e.stack;
}
2012-08-14 16:59:10 +02:00
// lines are like: bu_getCurrentScriptURI_spidermonkey("ScriptLoader.js")@burst/Runtime.js:101
var matches = s.match(/[^@]*\.js/gi);
if(!matches){
throw Error("could not parse stack string: '" + s + "'");
}
2012-08-14 16:59:10 +02:00
var fname = (typeof depth != 'undefined' && depth) ? matches[depth + 1] : matches[matches.length - 1];
if(!fname){
throw Error("could not find file name in stack string '" + s + "'");
}
2012-08-14 16:59:10 +02:00
//print("SpiderMonkeyRuntime got fname '" + fname + "' from stack string '" + s + "'");
return fname;
};
2011-11-08 17:40:44 +01:00
// print(dojo._spidermonkeyCurrentFile(0));
dojo._loadUri = function(uri){
// spidermonkey load() evaluates the contents into the global scope (which
// is what we want).
2011-11-08 17:40:44 +01:00
// TODO: sigh, load() does not return a useful value.
// Perhaps it is returning the value of the last thing evaluated?
2012-08-14 16:59:10 +02:00
// var ok =
load(uri);
// console.log("spidermonkey load(", uri, ") returned ", ok);
return 1;
2012-08-14 16:59:10 +02:00
};
//Register any module paths set up in djConfig. Need to do this
//in the hostenvs since hostenv_browser can read djConfig from a
//script tag's attribute.
if(dojo.config["modulePaths"]){
for(var param in dojo.config["modulePaths"]){
dojo.registerModulePath(param, dojo.config["modulePaths"][param]);
}
}