# Custom Vscode Extension Analyzer Debug
最近都告一段落了,晚上臨時起意寫了個plugin 結合我的靜態分析器
> apt-get install npm
> apt-get install npde.js
>https://code.visualstudio.com/api/get-started/your-first-extension
data:image/s3,"s3://crabby-images/55a64/55a645388891c89191a6441c720f2d3feb39b913" alt=""
> 選取 vscode extension development
data:image/s3,"s3://crabby-images/dea91/dea91071a6dfa0564d5e29d6940e6427d59064b5" alt=""
extension 使用的是 typescript 從vue.js 3改版後就很久沒寫 javascript 來寫一下
> ctrl + shift + p 輸入 hello word 即可在右下角看到剛才註冊的 extension
data:image/s3,"s3://crabby-images/1b0fe/1b0fe680ecb7edcb45ca4e8b5f0180f700fcd615" alt=""
> 論文到尾聲,或許需要部屬到 docker ,這邊只是實驗性質的去寫一個vscode 實現我 static analyzer breakpoints extension
參考了這兩個 網站,一個是真正 debuger run 起來的
https://stackoverflow.com/questions/56012353/how-to-get-vs-code-debug-data-like-breakpoints-steps-line-code
第二個網址才是可以攔截breakpoint增加或刪除
https://stackoverflow.com/questions/57250136/can-i-capture-breakpoint-event-on-vscode
看一下返回的資料結構是個array 我們直接把他 console.log 出來
data:image/s3,"s3://crabby-images/f70a2/f70a21beced00a4224793e2e8c89836df339a0fc" alt=""
data:image/s3,"s3://crabby-images/9471d/9471d97a663eabee3cf3f9f2d12c7c9bfb4f8009" alt=""
到著邊幾乎我們就已經把我們的前置作業做完了
data:image/s3,"s3://crabby-images/cdf49/cdf497eee1f58ed548b1260e8e06f6c9bd1693af" alt=""
嘗試找到一個可以寫入檔案的位置
```bash=
const storagePath = context.storagePath;
const globalStoragePath = context.globalStoragePath;
```
嘗試寫檔案
```javascript=
fs.writeFile(globalStoragePath+'/test.txt', '您好嗎?', function (err: any) {
if (err)
console.log(err);
else
console.log('Write operation complete.');
});
```
撈取斷點infomation
data:image/s3,"s3://crabby-images/e1283/e12831889a3741bc07030d3e90ca645ce6d4f152" alt=""
可以看到已經可以得到debug 斷點的位置
```
/root/test/test.cpp
/root/.vscode-server/bin/c13f1abb110fc756f9b3a6f16670df9cd9d4cf63/out/bootstrap-fork.js:5
28
/root/.vscode-server/bin/c13f1abb110fc756f9b3a6f16670df9cd9d4cf63/out/bootstrap-fork.js:5
```
這邊 斷點的行數跟我的plugin 實際斷點的位置有點不太一樣
data:image/s3,"s3://crabby-images/aebc7/aebc7a5e23a169dd6d46bb1975786db189468308" alt=""
```javascript=
var fs = require('fs');
for (let sess of session.added) {
const obj =Object.values(sess);
const path =Object.values(obj[1]);
const line =Object.values(obj[1]);
let getpath = path[0];
let getline = path[1];
// var property = 'path';
// console.log(line);
console.log(getpath['path']);
console.log(getline['_start']['_line']);
// console.log(obj);
// Object.keys(test).forEach(key => {
// console.log(key);
// });
// console.log(sess.location.url);
fs.appendFile(globalStoragePath+'/breakpoint',getpath['path']+" "+ (Number(getline['_start']['_line'])+1) +"\n" , function (err: any) {
if (err)
console.log(err);
else
console.log('Write operation complete.');
});
}
```
extension 開始前初始化
```javascript=
var fs = require('fs');
fs.unlink(globalStoragePath+'/breakpoint', err => {
if(err) console.log('init error');
})
```
來開始處理gcc plugin 這部分
```cpp=
breakpoint getbp;
std::ifstream ifs("input.txt", std::ios::in);
if (!ifs.is_open())
{
cout << "Failed to open file.\n";
}
else
{
std::string name;
int score;
while (ifs >> name >> score)
{
getbp.name = name.c_str();
getbp.line = score + 1;
fprintf(stderr, "%s %d\n", getbp.name, getbp.line);
// cout << name << " " << score << "\n";
vbreakpoint.push_back(getbp);
// scores.push_back(score);
}
ifs.close();
}
ifs.close();
```
嘗試讓extension 可以顯示可以複製訊息
>vscode.window.showInformationMessage("you setting in globalStoragePath:"+globalStoragePath)
data:image/s3,"s3://crabby-images/bbaa0/bbaa0652eb9cfbbe812d77160eee529267de37e0" alt=""
斷點初始化
```javascript=
var fs = require('fs');
const globalStoragePath = context.globalStoragePath;
fs.unlink(globalStoragePath+'/breakpoint.txt', (err: any) => {
if(err) console.log('init error');
})
for (let sess of session.added) {
const obj =Object.values(sess);
const path =Object.values(obj[1]);
const line =Object.values(obj[1]);
let getpath = path[0];
let getline = path[1];
// var property = 'path';
// console.log(line);
console.log(getpath['path']);
console.log(getline['_start']['_line']);
// console.log(obj);
// Object.keys(test).forEach(key => {
// console.log(key);
// });
// console.log(sess.location.url);
fs.appendFile(globalStoragePath+'/breakpoint.txt',getpath['path']+" "+ (Number(getline['_start']['_line'])+1) +"\n" , function (err: any) {
if (err)
console.log(err);
else
console.log('Write operation complete.');
});
}
console.log("globalStoragePath" + globalStoragePath);
console.log("Breakpoint changed" + session.added);
```
data:image/s3,"s3://crabby-images/d3d6f/d3d6f543aeb5d97b791d6ded5a0e544229054d78" alt=""
組合一下
data:image/s3,"s3://crabby-images/2cc76/2cc763bb92f37e347f9e91b74f8a574963dc45c2" alt=""
data:image/s3,"s3://crabby-images/61fa8/61fa889e6695f3c9472fcd5a9e643348ee1386fb" alt=""
參考 gimple
https://code.woboq.org/gcc/gcc/input.h.html
data:image/s3,"s3://crabby-images/ad853/ad853dc6d4971656502b69f025841dd96f624d71" alt=""
到這邊我的靜態分析器就支援 vscode extension
data:image/s3,"s3://crabby-images/628f9/628f9f45053fb2e7710e81fe7f4856bc1dd5325f" alt=""
```c=
int find = 0;
for (int i = 0; i < vbreakpoint.size(); i++)
{
size_t found = vbreakpoint[i].name.find(LOCATION_FILE(loc));
if (found)
if (vbreakpoint[i].line == LOCATION_LINE(loc))
{
fprintf(stderr, "set breakpoint %s %d\n", vbreakpoint[i].name.c_str(), vbreakpoint[i].line);
find = 1;
}
}
if (find == 0)
return;
```
# 流程
ctrl + shift + p 輸入 helloword 打開我的插件
data:image/s3,"s3://crabby-images/5bb7f/5bb7fbfb3bc62097a98be96d4f43a973acd24cf2" alt=""
修改讀取 breakpoint 路徑
data:image/s3,"s3://crabby-images/187de/187de06db3f81eef99fe3726f3c4b33b6c28334e" alt=""
到這裡我們就可以自由的使用vscode ide 配合gcc plugin 去debug
data:image/s3,"s3://crabby-images/a7504/a75044b03b32e9f0e3f421c754dc50794cc83f14" alt=""
plugin 可能要等真正寫完論文才能公布了
data:image/s3,"s3://crabby-images/686f6/686f623dc977a3b20d4f8af7e4480a48084ab96c" alt=""