VS Code 扩展商店搜索 Meta JSON Schema
或 ClashMeta.meta-json-schema
,安装扩展后即可获取 Clash.Meta
的语法支持。
Visual Studio Code中使用
- 安装YAML语法支持插件
redhat.vscode-yaml
。 - 在
.vscode
目录下的settings.json
文件中(如不存在则手动创建),填入以下内容。其中,key为schema文件的地址,value为路径通配符,请根据需求自行修改。{ "yaml.schemas": { "https://fastly.jsdelivr.net/gh/dongchengjie/meta-json-schema@main/schemas/meta-json-schema.json": "**/*.yaml" } }
Monaco Editor中使用
-
安装
monaco-editor
(编辑器)和monaco-yaml
(YAML支持)。npm install monaco-editor npm install monaco-yaml
-
如果是vite项目,可通过安装插件简化初始化(其他构建工具如
webpack
请参考monaco-yaml文档)。- 安装
vite-plugin-monaco-editor
。
npm install vite-plugin-monaco-editor
- 配置
vite.config.ts
。
import { defineConfig } from "vite"; import monacoEditor from "vite-plugin-monaco-editor"; export default defineConfig({ plugins: [ monacoEditor({ languageWorkers: ["editorWorkerService"], customWorkers: [ { label: "yaml", entry: "monaco-yaml/yaml.worker" } ] }) ] });
- 代码中配置schema(请根据需求自行修改
fileMatch
)。
import * as monaco from "monaco-editor"; import { configureMonacoYaml } from "monaco-yaml"; configureMonacoYaml(monaco, { validate: true, enableSchemaRequest: true, schemas: [ { uri: "https://fastly.jsdelivr.net/gh/dongchengjie/airport@main/meta-json-schema.json", fileMatch: ["**/*.clash.yaml"] } ] });
- 安装
- 下载代码
git clone https://github.com/dongchengjie/meta-json-schema.git
- 使用Visual Studio Code打开项目(工作目录为.vscode所在目录)。
code /path/to/project/location
Note
项目打开后会弹出建议安装YAML插件的提示,请点击确认安装或手动安装,以获取良好的开发体验。
- 安装依赖
npm install
- 启动项目。执行下列命令后,会对
src
目录进行监视,如果发生变动则会对项目进行bundle,输出到schemas
目录下。
npm run dev
- 测试schema。由于
.vscode
目录下settings.json
中已事先配置了如下配置(test
目录下的文件使用schemas
目录下输出的schema文件)。因此可以对src
进行修改,并在test
目录下新增测试文件,及时观察变动并做出修正。
"yaml.schemas": {
"schemas/meta-json-schema.json": "test/clash-meta/**/*.yaml",
"schemas/clash-verge-merge-json-schema.json": "test/clash-verge/**/*.yaml"
},
- 发布release。执行下列命令后,会根据
package.json
文件中定义的releases
进行输出,并根据optimization
决定是否进行压缩。
npm run release
JSON Schema标准语法
项目使用的JSON Schema版本为draft-07
,语法请参考JSON Schema Reference。
Monaco Editor扩展语法
Monaco 编辑器是为 VS Code 提供支持的开源代码编辑器,使用下列属性提供更丰富的
Snippet
支持。
interface JSONSchema {
// 自定义Snippet建议(数组)
defaultSnippets?: {
label: string; // 标签文本(索引)
description?: string; // 标签描述(需要点击展开)
markdownDescription?: string; // 标签描述(需要点击展开,markdown格式,优先级高于description,)
body: any; // 实际取值内容
bodyText?: string; // 实际取值内容文本(暂无作用)
}[];
errorMessage?: string; // 错误信息
patternErrorMessage?: string; // 格式错误信息(优先级高于errorMessage)
deprecationMessage?: string; // 过时错误信息
enumDescriptions?: string[]; // 枚举描述信息(数组)
markdownEnumDescriptions?: string[]; // 枚举描述信息(markdown格式)
markdownDescription?: string; // 描述信息(markdown格式)
doNotSuggest?: boolean; // 不显示建议
suggestSortText?: string; // 属性值建议排序符(默认为属性名)
allowComments?: boolean; // 允许注释
allowTrailingCommas?: boolean; // 允许尾随逗号
}
YAML支持Folded Style
和Inline Style
的写法。
使用"type": "boolean"
来定义某个属性,那么'true'
和'false'
就会提示Incorrect type. Expected "boolean".
。因此引入compatible类型,以兼容多种编码风格。
Inline Style
proxies:
- { name: "proxy1", type: "ss", cipher: "auto", tls: "true" }
- { name: proxy2, type: ss, cipher: auto, tls: true }
Folded Style
proxies:
- name: "proxy1"
type: "ss"
cipher: "auto"
tls: "true"
- name: proxy1
type: ss
cipher: auto
tls: true
Note
由于这种情况多发生于proxies
配置部分,所以目前仅proxies
配置中使用了compatible.json
,其余地方可视情况使用。