VSCcode插件极简开发指南

前言

俗话说得好,懒惰使人进步
最近用hexo搭建了一个静态博客,不过发现每次写完总要打三个命令

hexo clean
hexo g
hexo d

像我这么懒的人显然是无法接受每次都要这样干的,所以我就干脆写了一个shell script,但毕竟每次还要在terminal里面输,还是太麻烦了Orz,所以就觉得干脆写一个VSCode的小插件来解决这个问题(虽然我既不会Javascript也不会Typescript,QAQ)

还是在开头放一个Github的链接好了。

准备

像Node.js和npm什么的肯定是要的了(虽然我不知道他们是干啥用的QWQ),先安装这两个东西:

npm install -g yo
npm install -g generator-code

然后就输入启动yo code之后就会有一大堆可以选择的东西(这里我偷懒就直接copy and paste 官网的东西了)

yo code

# ? What type of extension do you want to create? New Extension (TypeScript)
# ? What's the name of your extension? HelloWorld
### Press <Enter> to choose default for all options below ###

# ? What's the identifier of your extension? helloworld
# ? What's the description of your extension? LEAVE BLANK
# ? Enable stricter TypeScript checking in 'tsconfig.json'? Yes
# ? Setup linting using 'tslint'? Yes
# ? Initialize a git repository? Yes
# ? Which package manager to use? npm

code ./helloworld

用VSCode打开刚建立的文件夹之后就可以继续了。
目录结构大概长这样:

.
├── CHANGELOG.md
├── README.md
├── extension.js
├── jsconfig.json
├── node_modules
├── package-lock.json
├── package.json
├── test
└── vsc-extension-quickstart.md

我们要关注的大概就只有extension.jspackage.json这两个文件(如果只是写一个小插件偷一下懒的话)

开始

打开extension.js之后应该是张这样的(别被吓到,大部分是注释)

// The module 'vscode' contains the VS Code extensibility API
// Import the module and reference it with the alias vscode in your code below
const vscode = require('vscode');

// this method is called when your extension is activated
// your extension is activated the very first time the command is executed

/**
 * @param {vscode.ExtensionContext} context
 */
function activate(context) {
    // Use the console to output diagnostic information (console.log) and errors (console.error)
    // This line of code will only be executed once when your extension is activated
    console.log('Congratulations, your extension "helloworld-minimal-sample" is now active!');

    // The command has been defined in the package.json file
    // Now provide the implementation of the command with  registerCommand
    // The commandId parameter must match the command field in package.json
    let disposable = vscode.commands.registerCommand('extension.helloWorld', () => {
        // The code you place here will be executed every time your command is executed

        // Display a message box to the user
        vscode.window.showInformationMessage('Hello World!');
    });

    context.subscriptions.push(disposable);
}

// this method is called when your extension is deactivated
function deactivate() {}

module.exports = {
    activate,
    deactivate
}

然后另外一个就是package.json,这里直接我copy helloWorld的sample

{
    "name": "helloworld-sample",  //插件名称
    "displayName": "helloworld-sample",  //发布后展示的名称
    "description": "HelloWorld example for VS Code",  //介绍
    "version": "0.0.1",  //版本
    "publisher": "vscode-samples",  //发布者的名字,这个一开始是没有的,但一定要加上去!
    "repository": "url", //repo的连接这个也要写上
    "engines": {
        "vscode": "^1.25.0"
    },
    "categories": [  //类别
        "Other"
    ],
    "activationEvents": [
        "onCommand:extension.helloWorld" //命令,这个要和extension.js里面的对应才有用
    ],
    "main": "./out/extension.js",
    "contributes": { //这里面的东西会出现在插件页面“贡献”那一栏上
        "commands": [
            {
                "command": "extension.helloWorld",
                "title": "Hello World"
            }
        ]
    },
    ...
}

可以看到json里面的extension.helloWorld和js里面... vscode.commands.registerCommand('extension.helloWorld' ...是相对应的,也就是说如果要添加什么事件,在json里面加完之后,如果主程序的函数必须要与其相对应。

那我们就现在开始添加自己需要的东西了。因为我把插件命名为了hexo-one,所以也顺便将其改为这个。

...
"publisher": "Meowcolm024",
"license": "MIT",
"repository": {
    "type": "git",
    "url": "https://meowcolm024.visualstudio.com/DefaultCollection/VSCode%20Extension/_git/hexo-one"
    },
...
"activationEvents": [
        "onCommand:hexo-one.pushHexo",
        "onCommand:hexo-one.newPost"
    ],
...
"contributes": {
        "commands": [
            {
                "command": "hexo-one.pushHexo",
                "title": "Push Hexo"
            },
            {
                "command": "hexo-one.newPost",
                "title": "New Hexo Post"
            }
        ],
        "keybindings": [  //快捷键
            {
                "command": "hexo-one.pushHexo",
                "key": "ctrl+p ctrl+h"
            },
            {
                "command": "hexo-one.newPost",
                "key": "ctrl+n ctrl+p"
            }
        ]
    },

也就是要把publisher加上(这个后面再说),还有repo的地址,我们同时可以事件加上快捷键。这样package.json部分就算完成了

然后我们回到extension.js里面。(虽然不会JavaScript,但照葫芦画瓢还是可以的)。我们要做的只不过是让插件帮我们执行几个命令,所以可以先写一个执行系统命令的函数(这个还是可以Google到的)

function runCmd(cmd) {
    const {workspace} = require('vscode');
    const options = {
        cwd: workspace.rootPath, // 要把路径设定到工作区才行
        env: process.env
    }
    const { exec } = require('child_process');
        exec(cmd, options, (err, stdout, stderr) => {
            if(err) {
                console.log(err);
                return;
            }
            console.log(`stdout: ${stdout}`);
            console.log(`stderr: ${stderr}`);
            vscode.window.showInformationMessage(stdout); // 这一行是给vscode的输出
        })
}

然后我们回到上面function active(context) 那里,找到他们已经给我们准备好的一个函数,稍作修改即可:

let disposable = vscode.commands.registerCommand('hexo-one.pushHexo', function () {
        runCmd('hexo clean \n hexo g \n hexo d');
        vscode.window.showInformationMessage('Deploying Hexo, please wait...');
    });  
context.subscriptions.push(disposable);

想要偷懒的的话,也可以直接copy and paste这一段然后稍作修改作为我们另外一个Event的函数:

let disposable2 = vscode.commands.registerCommand('hexo-one.newPost', function() {
        const options = {
            ignoreFocusOut: true,
            password: false,
            prompt: "Please type the title of your post"
            };
      // 这里稍微用到了VSCode的API,基本上就是弹出输入框然后检测内容是否为空,然后再执行相应的命令
        vscode.window.showInputBox(options).then((value) => {
            if (value === undefined || value.trim() === '') {
            vscode.window.showInformationMessage('Please type the title of your post');
            }else{
                const title = value.trim();
                const cmd = "hexo new \"" + title + "\""
                runCmd(cmd);
            }});
    });
  context.subscriptions.push(disposable2);

(这里很明显是偷懒了,直接加一个“2”完事)

到了这里基本上就已经完事了,然后我们需要打包发布(当然还要先创建一个publisher)。
不过我们还是要先安装:

npm install -g vsce

然后输入

vsce create-publisher xxxxxx #一个名字,然后按照后面的instructions就是了
# Publisher human-friendly name: xxx xxx
# Email: xxx@xxx.com
# Personal Access Token: *.... (这里是一个比较tricky的部分)

关于那个Personal Access Token,需要在Visual Studio Team Services里面注册/登陆之后找到Security那里新建一个Token,选择All accessible organizations,而Scopes里面则要勾选Marketplace中所有的项目,详细的话参见这个链接
然后我们可以干这些事了:

vsce package  #如果你想生成本地插件的文件的话(当然不生成也行)
vsce publish  #将插件发布到VSCode的Marketpla上面

到这里最简单的应该就搞定了,如果想具体参考一下我这个extension的话,那我就把Github的链接放在这里

orz 简书的json和bash居然没有syntax highlighting
先写这么多吧到时候有时间再补详细点

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容