ScriptingCore{
//偽代碼
ScriptingCore.getInstance(){
}
ScriptingCore{
將JSRuntime,JSContext,_callFromScript初始化
}
initRegister{
增加注冊器回調(diào)涤姊,內(nèi)部添加到registrationList vector中
初始化SimpleRunLoop香椎,該類實現(xiàn)了Ref(用于引用計數(shù))肢础,增加了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賦值
設(shè)置GC參數(shù)
設(shè)置受信任的主體
設(shè)置安全的回調(diào)
設(shè)置本地棧指標(biāo)為50W
使用8K大小的棧塊生成新的上下文賦給_cx
使用函數(shù)參數(shù)作為錯誤報告器設(shè)置到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乾戏,然后調(diào)用保存在里面的回調(diào)(即逐個調(diào)用前面注冊的回調(diào)轴合,基本上是將CPP層的方法映射到JS層)
}
}
使用函數(shù)runScript運行腳本script/jsb_boot.js{
compileScript{
如果路徑為空直接返回
getScript如果非空传透,說明編譯過了就直接返回{
通過string的rfind函數(shù)移除擴展名胳挎,然后添加上.jsc
在unordered_map中去找是否有相應(yīng)的值
如果有直返回
如果沒有調(diào)用fullPathForFilename去找
{
filename為空直接返回
如果首元素為/直接返回(不是絕對路徑)
使用filename去unordered_map中去找是否緩存過帜讲,有則直接返回
使用getNewFilename返回的字符串初始化newFilename getNewFilename{ 從_filenameLookupDict無序map中找,如果找到就返回癞己,找不到就返回second}
遍歷通過FileUtils設(shè)置的搜索路徑_searchPathArray
嵌套遍歷_searchResolutionsOrderArray膀斋,改vector是通過FileUtils的setSearchResolutionsOrder設(shè)置的,如果沒有設(shè)置里面默認添加""痹雅,
拼接路徑//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判斷手字節(jié)是否為"/"
else
searchFullPathForFilename內(nèi)部去指定的搜索路徑搜索文件
}
如果文件存在就具體的讀取文件內(nèi)的字符getDataFromFile -》 getData -》如果讀出來的Data不為null就讓Spidermonkey去解析它
如果解析成功就保存到filename_script中摔蓝,否則就看代碼
}
使用JSContext和解析的文件封裝JS::RootedScript對象
調(diào)用JS_ExecuteScript執(zhí)行腳本返回bool值表示是否執(zhí)行成功
}
}