react-native start 運行流程

在CMD下鍵入

C:\Node_JS\MyAwesomeProject>react-native start

運行流程:

C:\Users\Grart\AppData\Roaming\npm\react-native.cmd

C:\Users\Grart\AppData\Roaming\npm\node_modules\react-native-cli\index.js

cli.run();

C:\Node_JS\MyAwesomeProject\node_modules\react-native\cli.js

module.exports = require('./local-cli/cli.js');

C:\Node_JS\MyAwesomeProject\node_modules\react-native\local-cli\cli.js

module.exports = {

run: run,

init: init,

};

image

C:\Node_JS\MyAwesomeProject\node_modules\react-native\private-cli\src\server\server.js

C:\Node_JS\MyAwesomeProject\node_modules\react-native\private-cli\src\server\runServer.js

function getAppMiddleware(args, config) {

………………………...

return ReactPackager.middleware({

nonPersistent: args.nonPersistent,

projectRoots: args.projectRoots,

blacklistRE: config.getBlacklistRE(),

cacheVersion: '3',

transformModulePath: transformerPath,

assetRoots: args.assetRoots,

assetExts: ['png', 'jpeg', 'jpg'],

resetCache: args.resetCache || args['reset-cache'],

polyfillModuleNames: [

  require.resolve(

    '../../../Libraries/JavaScriptAppEngine/polyfills/document.js'

  ),

],

verbose: args.verbose,

});

}

C:\Node_JS\MyAwesomeProject\node_modules\react-native\packager\react-packager\index.js

function createServer(options) {

// the debug module is configured globally, we need to enable debugging

// before requiring any packages that use debug for logging

if (options.verbose) {

enableDebug();

}

startSocketInterface();

var Server = require('./src/Server');

return new Server(omit(options, ['verbose']));

}

C:\Node_JS\MyAwesomeProject\node_modules\react-native\packager\react-packager\src\Server\index.js

function processRequest(req, res, next) {

…………

const building = this._bundles[optionsJson] || this.buildBundle(options);

this._bundles[optionsJson] = building;

building.then(……

)

…………

}

C:\Node_JS\MyAwesomeProject\node_modules\react-native\packager\react-packager\src\Bundler\index.js

function bundle(main, runModule, sourceMapUrl, isDev, platform) {

const bundle = new Bundle(sourceMapUrl);

const findEventId = Activity.startEvent('find dependencies');

let transformEventId;

return this.getDependencies(main, isDev, platform)

.then(………………

.………………..

}

function getDependencies(main, isDev, platform) {

return this._resolver.getDependencies(main, { dev: isDev, platform });

}

C:\Node_JS\MyAwesomeProject\node_modules\react-native\packager\react-packager\src\DependencyResolver\index.js

HasteDependencyResolver.prototype.getDependencies = function(main, options) {

var opts = getDependenciesValidateOpts(options);

return this._depGraph.getDependencies(main, opts.platform)

.then(

resolutionResponse => {

  this._getPolyfillDependencies(opts.dev).reverse().forEach(

    polyfill => resolutionResponse.prependDependency(polyfill)

  );

  return resolutionResponse.finalize();

}

);

};

C:\Node_JS\MyAwesomeProject\node_modules\react-native\packager\react-packager\src\DependencyResolver\DependencyGraph\index

getDependencies(entryPath, platform) {

console.log('call DependencyGraph entryPath='+entryPath);

return this.load()

.then(

  () => {

    platform = this._getRequestPlatform(entryPath, platform);

    const absPath = this._getAbsolutePath(entryPath);

    const req = new ResolutionRequest({

      platform,

      entryPath: absPath,

      deprecatedAssetMap: this._deprecatedAssetMap,

      hasteMap: this._hasteMap,

      helpers: this._helpers,

      moduleCache: this._moduleCache,

fastfs: this._fastfs,

    });

    const response = new ResolutionResponse();

    console.log('call ResolutionRequest');

    return Promise.all([

      req.getOrderedDependencies(response),

      req.getAsyncDependencies(response),

    ]).then(() => response);

  }

);

}

C:\Node_JS\MyAwesomeProject\node_modules\react-native\packager\react-packager\src\DependencyResolver\DependencyGraph\ResolutionRequest.js

getOrderedDependencies(response) {….

resolveDependency(fromModule, toModuleName) {….

_resolveNodeDependency(fromModule, toModuleName) {….

_loadAsFile(potentialModulePath, fromModule, toModule) {….

this._fastfs.fileExists(potentialModulePath)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子忌锯,更是在濱河造成了極大的恐慌箍鼓,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機稚茅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來平斩,“玉大人亚享,你說我怎么就攤上這事』婷妫” “怎么了欺税?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵侈沪,是天一觀的道長。 經(jīng)常有香客問我晚凿,道長亭罪,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任歼秽,我火速辦了婚禮应役,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘燥筷。我一直安慰自己箩祥,他們只是感情好,可當我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布肆氓。 她就那樣靜靜地躺著袍祖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪做院。 梳的紋絲不亂的頭發(fā)上盲泛,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天,我揣著相機與錄音键耕,去河邊找鬼。 笑死柑营,一個胖子當著我的面吹牛屈雄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播官套,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼酒奶,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了奶赔?” 一聲冷哼從身側(cè)響起惋嚎,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎站刑,沒想到半個月后另伍,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡绞旅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年摆尝,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片因悲。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡堕汞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晃琳,到底是詐尸還是另有隱情讯检,我是刑警寧澤琐鲁,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站人灼,受9級特大地震影響围段,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜挡毅,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一蒜撮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧跪呈,春花似錦段磨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至误阻,卻和暖如春债蜜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背究反。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工寻定, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人精耐。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓狼速,卻偏偏與公主長得像,于是被迫代替她去往敵國和親卦停。 傳聞我的和親對象是個殘疾皇子向胡,可洞房花燭夜當晚...
    茶點故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容