ScriptingCore{
//偽代碼
ScriptingCore.getInstance(){
}
ScriptingCore{
將JSRuntime,JSContext,_callFromScript初始化
}
initRegister{
增加注冊器回調,內部添加到registrationList vector中
初始化SimpleRunLoop,該類實現了Ref(用于引用計數),增加了update方法
}
start{
createGlobalContext{
JSContext JSRuntime is not null, destory it and set null
JS_Init() //if Spidermonkey has not set up,then set up it
使用8M大小的JS_NewRuntime對象為JSRuntime賦值
設置GC參數
設置受信任的主體
設置安全的回調
設置本地棧指標為50W
使用8K大小的棧塊生成新的上下文賦給_cx
使用函數參數作為錯誤報告器設置到SpiderMonkey上
_global.construct(_cx);//Maybe模板類
_global.ref() = NewGlobalObject(_cx);
JSAutoCompartment ac(_cx, _global.ref());
// Removed in Firefox v34
js::SetDefaultObjectForContext(_cx, _global.ref());
迭代registrationList vector,然后調用保存在里面的回調(即逐個調用前面注冊的回調,基本上是將CPP層的方法映射到JS層)
}
}
使用函數runScript運行腳本script/jsb_boot.js{
compileScript{
如果路徑為空直接返回
getScript如果非空,說明編譯過了就直接返回{
通過string的rfind函數移除擴展名,然后添加上.jsc
在unordered_map中去找是否有相應的值
如果有直返回
如果沒有調用fullPathForFilename去找
{
filename為空直接返回
如果首元素為/直接返回(不是絕對路徑)
使用filename去unordered_map中去找是否緩存過,有則直接返回
使用getNewFilename返回的字符串初始化newFilename getNewFilename{ 從_filenameLookupDict無序map中找,如果找到就返回,找不到就返回second}
遍歷通過FileUtils設置的搜索路徑_searchPathArray
嵌套遍歷_searchResolutionsOrderArray,改vector是通過FileUtils的setSearchResolutionsOrder設置的,如果沒有設置里面默認添加"",
拼接路徑//fullpath = searchPath + file_path + resourceDirectory
判斷路徑是否存在,如果存在就添加到_fullPathCache map中
再次編譯filename_script去找文件,找到就返回找到的文件名
最后沒有找到返回null
}
}
if (global == NULL) {
global = _global.ref().get();
}
if (cx == NULL) {
cx = _cx;
}
移除文件的擴展名,添加上.jsc
判斷jsc文件名是否存在 isFileExist{
if isAbsolutePath判斷手字節是否為"/"
else
searchFullPathForFilename內部去指定的搜索路徑搜索文件
}
如果文件存在就具體的讀取文件內的字符getDataFromFile -》 getData -》如果讀出來的Data不為null就讓Spidermonkey去解析它
如果解析成功就保存到filename_script中,否則就看代碼
}
使用JSContext和解析的文件封裝JS::RootedScript對象
調用JS_ExecuteScript執行腳本返回bool值表示是否執行成功
}
}