編譯和打包
- 首先按照 https://github.com/Microsoft/vscode/wiki/How-to-Contribute#prerequisites 的方法準(zhǔn)備好前提條件荞怒。
- 運(yùn)行 yarn
- 如果想運(yùn)行肯适,按照文檔中說(shuō)明的蚂蕴,運(yùn)行 .\scripts\code.bat 就可以夕春。經(jīng)測(cè)試走净,不需要先進(jìn)行 yarn watch.
- 打包方法: yarn run gulp vscode-win32-x64-archive,打包后生成的包在 .build\win32-x64\archive\VSCode-win32-x64.zip , 這種方法目前看似乎是從某個(gè)文件夾直接壓縮坝撑。在這個(gè)之前蜂厅,需要先做 yarn的動(dòng)作。
- 另一種方法: yarn run gulp vscode-win32-x64-min, 打包后劫乱,會(huì)在 vscode 當(dāng)前目錄的上一級(jí)生成目錄VSCode-win32-x64织中,帶 min 和不帶 min 的編譯方法相比,min對(duì)于其中的js文件做過(guò)體積簡(jiǎn)化衷戈。我們編譯應(yīng)該用帶min的方式來(lái)編譯狭吼。
- archive的方法是否可以打包帶min的生成結(jié)果,還有待研究殖妇。
其他
- 運(yùn)行命令 yarn run 可以列出所有可以執(zhí)行的task刁笙。而這些task都是在 package.json里面定義的。Yarn就是一個(gè)包管理的工具
- 運(yùn)行命令 yarn run gulp --tasks 可以列出所有可用的gulp任務(wù),這些任務(wù)都是在gulpfile.js中定義的
- 在調(diào)試模式下采盒,運(yùn)行 Gulp Build旧乞,可以命中 gulpfile.js中的斷點(diǎn)“醢保可以用來(lái)研究gulp任務(wù)是如何定義的尺栖。
- 從package.json中可以看到y(tǒng)arn watch其實(shí)就是gulp watch --max_old_space_size=4095,所以它應(yīng)該等同于yarn run gulp watch
- yarn run gulp 的各種選項(xiàng)都能編出不同的目標(biāo)烦租,比如 vscode-win32-x64 和 vscode-linux-x64-min延赌。具體這些目標(biāo)之間有什么差別,與 archive 的方式有什么關(guān)聯(lián)叉橱,后續(xù)還需要深入研究挫以。
- 查看 scripts下的code.bat命令,它其實(shí)就是執(zhí)行一個(gè) Electron的exe窃祝,然后參數(shù)指向 VSCode邏輯所在的文件夾掐松。所以,不管上面build的什么目標(biāo)粪小,只要編譯出來(lái)的folder有main.js大磺,應(yīng)該都可以用 Electron.exe <folder> 來(lái)運(yùn)行起來(lái)。
- 曾經(jīng)碰到錯(cuò)誤:yarn install failed :vscode-ripgrep: Command failed.
發(fā)現(xiàn)是以下的文件損壞:ripgrep-0.10.0-pcre-win32-x64.zip 的文件損壞, 把這個(gè)路徑下的zip刪掉以后再運(yùn)行yarn就正常了探膊。C:\Users\zzp\AppData\Local\Temp\vscode-ripgrep-cache-1.2.4
轉(zhuǎn)載請(qǐng)注明出處杠愧。
更多視頻教程請(qǐng)?jiān)?a target="_blank">網(wǎng)易云課堂,優(yōu)酷或騰訊視頻搜索黑山老雕逞壁。