{"id":263,"date":"2025-04-24T21:20:59","date_gmt":"2025-04-24T12:20:59","guid":{"rendered":"https:\/\/www.vinesystems.net\/?p=263"},"modified":"2025-04-24T21:21:00","modified_gmt":"2025-04-24T12:21:00","slug":"vscode%e3%82%b7%e3%83%b3%e3%82%bf%e3%83%83%e3%82%af%e3%82%b9%e3%83%8f%e3%82%a4%e3%83%a9%e3%82%a4%e3%83%88%e6%8b%a1%e5%bc%b5%e3%82%92%e6%9c%80%e9%80%9f%e3%81%a7%e4%bd%9c%e3%82%8b","status":"publish","type":"post","link":"https:\/\/www.vinesystems.net\/?p=263","title":{"rendered":"VSCode\u30b7\u30f3\u30bf\u30c3\u30af\u30b9\u30cf\u30a4\u30e9\u30a4\u30c8\u62e1\u5f35\u3092\u6700\u901f\u3067\u4f5c\u308b"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">1. \u306f\u3058\u3081\u306b \u2015 \u81ea\u4f5c\u30b7\u30f3\u30bf\u30c3\u30af\u30b9\u30cf\u30a4\u30e9\u30a4\u30c8\u306e\u610f\u7fa9<\/h2>\n\n\n\n<p>\u307f\u306a\u3055\u307e\u306f\u3001\u72ec\u81ea\u30c9\u30e1\u30a4\u30f3\u8a00\u8a9e\uff08DSL\uff09\u3092 VSCode \u3067\u7de8\u96c6\u3059\u308b\u3068\u304d\u3001\u30ad\u30fc\u30ef\u30fc\u30c9\u3082\u30b3\u30e1\u30f3\u30c8\u3082\u4e00\u69d8\u306b\u7070\u8272\u3067\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u5834\u9762\u306b\u906d\u9047\u3057\u305f\u3053\u3068\u306f\u3042\u308a\u307e\u305b\u3093\u304b\u3002\u79c1\u304c\u696d\u52d9\u3067\u6271\u3046 <strong>TPG<\/strong>\uff08Test Program Generator\uff09\u3068\u3044\u3046\u7523\u696d\u6a5f\u5668\u5411\u3051\u30b9\u30af\u30ea\u30d7\u30c8\u8a00\u8a9e\u3082\u3001\u305d\u306e\u307e\u307e\u3067\u306f\u8aad\u307f\u3065\u3089\u304f\u3001\u3061\u3087\u3063\u3068\u3057\u305f\u5165\u529b\u30df\u30b9\u3092\u898b\u843d\u3068\u3057\u3084\u3059\u3044\u72b6\u6cc1\u3067\u3057\u305f\u3002<\/p>\n\n\n\n<p>\u672c\u8a18\u4e8b\u3067\u306f\u300c<strong>\u307e\u305a\u306f\u6700\u4f4e\u9650\u306e\u8272\u5206\u3051\u3092\u5b9f\u73fe\u3059\u308b<\/strong>\u300d\u3068\u3044\u3046\u73fe\u5b9f\u7684\u306a\u76ee\u6a19\u3092\u63b2\u3052\u3001VSCode \u62e1\u5f35\u3068\u3057\u3066\u30b7\u30f3\u30bf\u30c3\u30af\u30b9\u30cf\u30a4\u30e9\u30a4\u30c8\u3092\u5b9f\u88c5\u3059\u308b\u624b\u9806\u3092\u9806\u3092\u8ffd\u3063\u3066\u3054\u6848\u5185\u3044\u305f\u3057\u307e\u3059\u3002\u5c02\u9580\u7528\u8a9e\u306f\u3067\u304d\u308b\u9650\u308a\u304b\u307f\u7815\u304d\u3001\u624b\u9806\u3054\u3068\u306b\u80cc\u666f\u3092\u8aac\u660e\u3057\u307e\u3059\u306e\u3067\u3001\u62e1\u5f35\u958b\u767a\u304c\u521d\u3081\u3066\u306e\u65b9\u3067\u3082\u5b89\u5fc3\u3057\u3066\u8aad\u307f\u9032\u3081\u3066\u3044\u305f\u3060\u3051\u307e\u3059\u3002<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"1536\" height=\"1024\" src=\"https:\/\/www.vinesystems.net\/wp-content\/uploads\/2025\/04\/image-20.png\" alt=\"\" class=\"wp-image-267\" srcset=\"https:\/\/www.vinesystems.net\/wp-content\/uploads\/2025\/04\/image-20.png 1536w, https:\/\/www.vinesystems.net\/wp-content\/uploads\/2025\/04\/image-20-300x200.png 300w\" sizes=\"auto, (max-width: 1536px) 100vw, 1536px\" \/><\/figure>\n<\/blockquote>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">2. \u958b\u767a\u74b0\u5883\u306e\u6e96\u5099 \u2015 \u5fc5\u8981\u30c4\u30fc\u30eb\u3092\u305d\u308d\u3048\u308b<\/h2>\n\n\n\n<p>\u62e1\u5f35\u958b\u767a\u306b\u5fc5\u8981\u3068\u306a\u308b\u4e3b\u306a\u30c4\u30fc\u30eb\u306f\u4ee5\u4e0b\u306e\u4e09\u3064\u3067\u3059\u3002<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li><strong>Node.js<\/strong>\uff08LTS \u7248\u63a8\u5968\uff09<\/li>\n\n\n\n<li><strong>Yeoman &amp; VSCode \u62e1\u5f35\u30b8\u30a7\u30cd\u30ec\u30fc\u30bf<\/strong>\uff08<code>generator-code<\/code>\uff09<\/li>\n\n\n\n<li><strong>Visual Studio Code \u672c\u4f53<\/strong><\/li>\n<\/ol>\n\n\n\n<p>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u304c\u304a\u6e08\u307f\u3067\u306a\u3044\u5834\u5408\u306f\u3001\u4e0b\u8a18\u30b3\u30de\u30f3\u30c9\u3092\u53c2\u8003\u306b\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code># Node.js \u306f\u516c\u5f0f\u30b5\u30a4\u30c8\u304b\u3089\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u6e08\u307f\u3068\u4eee\u5b9a\nnpm install -g yo generator-code   # Yeoman \u3068\u62e1\u5f35\u30b8\u30a7\u30cd\u30ec\u30fc\u30bf\u3092\u5168\u5c40\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\ncode --version                     # VSCode \u304c\u6b63\u3057\u304f\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u3066\u3044\u308b\u304b\u78ba\u8a8d<\/code><\/pre>\n\n\n\n<p>\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3078\u306e\u30ea\u30f3\u30af\u3092\u4f75\u8a18\u3044\u305f\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Node.js: <a>https:\/\/nodejs.org\/<\/a><\/li>\n\n\n\n<li>generator-code: <a>https:\/\/github.com\/microsoft\/vscode-generator-code<\/a><\/li>\n\n\n\n<li>VSCode Extension API: <a>https:\/\/code.visualstudio.com\/api<\/a><\/li>\n<\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">3. \u96db\u5f62\u3092\u4f5c\u6210\u3059\u308b \u2015 <code><strong>yo code<\/strong><\/code> \u30a6\u30a3\u30b6\u30fc\u30c9\u3092\u4e00\u6b69\u305a\u3064\u9032\u3081\u308b<\/h2>\n\n\n\n<p>\u307e\u305a\u306f\u30bf\u30fc\u30df\u30ca\u30eb\u3067\u6b21\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u3001\u62e1\u5f35\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3092\u751f\u6210\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>yo code<\/code><\/pre>\n\n\n\n<p>\u30a6\u30a3\u30b6\u30fc\u30c9\u3067\u306f\u8907\u6570\u306e\u5165\u529b\u304c\u6c42\u3081\u3089\u308c\u307e\u3059\u3002\u4ee3\u8868\u7684\u306a\u9805\u76ee\u3068\u5165\u529b\u4f8b\u3001\u305d\u3057\u3066\u8003\u616e\u4e8b\u9805\u3092\u4ee5\u4e0b\u306e\u8868\u306b\u307e\u3068\u3081\u307e\u3057\u305f\u3002\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u3054\u81ea\u8eab\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u5408\u308f\u305b\u3066\u5909\u66f4\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><tbody><tr><th>\u8cea\u554f\u9805\u76ee<\/th><th>\u5165\u529b\u4f8b<\/th><th>\u30dd\u30a4\u30f3\u30c8\u30fb\u88dc\u8db3\u8aac\u660e<\/th><\/tr><tr><td>Extension type<\/td><td><strong>New Language<\/strong><\/td><td>\u30cf\u30a4\u30e9\u30a4\u30c8\u7528\u62e1\u5f35\u3092\u4f5c\u6210\u3059\u308b\u5834\u5408\u306f\u3053\u308c\u3092\u9078\u629e\u3057\u307e\u3059\u3002<\/td><\/tr><tr><td>Extension name<\/td><td>TPG Syntax Highlight<\/td><td>VSCode \u306e\u62e1\u5f35\u4e00\u89a7\u306b\u8868\u793a\u3055\u308c\u308b\u540d\u79f0\u3067\u3059\u3002<\/td><\/tr><tr><td>Identifier<\/td><td>tpg-syntax-highlight<\/td><td>npm \u516c\u958b\u3092\u60f3\u5b9a\u3057\u3001\u77ed\u304f\u308f\u304b\u308a\u3084\u3059\u3044\u82f1\u5c0f\u6587\u5b57\uff0b\u30cf\u30a4\u30d5\u30f3\u63a8\u5968\u3002<\/td><\/tr><tr><td>Description<\/td><td>\uff08\u7a7a\u6b04\u3067\u3082\u53ef\uff09<\/td><td>\u5f8c\u307b\u3069 <code>package.json<\/code> \u3067\u52a0\u7b46\u3067\u304d\u307e\u3059\u3002<\/td><\/tr><tr><td>Language id<\/td><td><strong>tpg<\/strong><\/td><td>VSCode \u304c\u5185\u90e8\u3067\u6271\u3046\u8a00\u8a9e ID\u3002\u62e1\u5f35\u5b50\u3068\u306f\u5225\u6982\u5ff5\u3067\u3059\u3002<\/td><\/tr><tr><td>Language name<\/td><td>Test Programming Generator<\/td><td>\u30b9\u30c6\u30fc\u30bf\u30b9\u30d0\u30fc\u306a\u3069\u306b\u8868\u793a\u3055\u308c\u308b\u30d5\u30ec\u30f3\u30c9\u30ea\u30fc\u306a\u540d\u79f0\u3002<\/td><\/tr><tr><td>File extensions<\/td><td><strong>.tpg<\/strong><\/td><td>\u8907\u6570\u3042\u308b\u5834\u5408\u306f\u30ab\u30f3\u30de\u533a\u5207\u308a\u3067\u5217\u6319\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/td><\/tr><tr><td>Scope name<\/td><td>source.tpg<\/td><td>\u5f8c\u8ff0\u3059\u308b <code>scopeName<\/code> \u3068\u4e00\u81f4\u3055\u305b\u307e\u3059\u3002<\/td><\/tr><tr><td>Initialize git repo<\/td><td>Yes<\/td><td>Git \u7ba1\u7406\u304c\u4e0d\u8981\u306a\u5834\u5408\u306f No \u3067\u3082\u69cb\u3044\u307e\u305b\u3093\u3002<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<p>\u30a6\u30a3\u30b6\u30fc\u30c9\u5b8c\u4e86\u5f8c\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u304c\u751f\u6210\u3055\u308c\u307e\u3059\uff08\u629c\u7c8b\uff09\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>tpg-syntax-highlight\/\n|   package.json\n|   README.md\n|   language-configuration.json\n|\n+---syntaxes\n|       tpg.tmLanguage.json\n|\n+---.vscode\n        launch.json<\/code><\/pre>\n\n\n\n<p>\u3053\u3053\u307e\u3067\u3067\u300c\u9aa8\u683c\u300d\u306f\u5b8c\u6210\u3057\u307e\u3057\u305f\u3002\u6b21\u7ae0\u304b\u3089\u306f\u30cf\u30a4\u30e9\u30a4\u30c8\u306e\u672c\u4f53\u3067\u3042\u308b <strong>TextMate Grammar<\/strong> \u3092\u4f5c\u6210\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">4. TextMate Grammar \u3092\u7406\u89e3\u3059\u308b \u2015 <code><strong>tpg.tmLanguage.json<\/strong><\/code> \u306e\u66f8\u304d\u65b9<\/h2>\n\n\n\n<p>VSCode \u306f TextMate \u5f62\u5f0f\u306e\u6587\u6cd5\u5b9a\u7fa9\u3092\u7528\u3044\u3066\u30c8\u30fc\u30af\u30f3\uff08\u30ad\u30fc\u30ef\u30fc\u30c9\u3084\u6587\u5b57\u5217\u306a\u3069\uff09\u3078\u8272\u3092\u9069\u7528\u3057\u307e\u3059\u3002\u30dd\u30a4\u30f3\u30c8\u306f\u6b21\u306e\u4e09\u8981\u7d20\u3067\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><tbody><tr><td>JSON \u30ad\u30fc<\/td><td>\u5f79\u5272<\/td><td>\u8a18\u8ff0\u4f8b<\/td><\/tr><tr><td><code>scopeName<\/code><\/td><td>\u300c\u3053\u306e\u6587\u6cd5\u306e\u5168\u4f53\u540d\u300d\u3092\u5ba3\u8a00<\/td><td><code>source.tpg<\/code><\/td><\/tr><tr><td><code>patterns<\/code><\/td><td>\u4e0a\u304b\u3089\u9806\u306b\u8a55\u4fa1\u3055\u308c\u308b\u30eb\u30fc\u30eb\u306e\u5165\u53e3<\/td><td><code>{ \"include\": \"#comment\" }<\/code> \u306a\u3069<\/td><\/tr><tr><td><code>repository<\/code><\/td><td>\u30e9\u30d9\u30eb\u3054\u3068\u306e\u8a73\u7d30\u306a\u6b63\u898f\u8868\u73fe\u3092\u683c\u7d0d<\/td><td><code>comment<\/code>, <code>string<\/code> \u306a\u3069<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">4.1 \u30e9\u30d9\u30eb\u8a2d\u8a08 \u2015 \u201c\u4f55\u306b\u8272\u3092\u4ed8\u3051\u308b\u304b\u201d \u3092\u6c7a\u3081\u308b<\/h3>\n\n\n\n<p>\u307e\u305a\u306f\u5bfe\u8c61\u8a00\u8a9e\uff08TPG\uff09\u306b\u304a\u3044\u3066\u5f37\u8abf\u3057\u305f\u3044\u30c8\u30fc\u30af\u30f3\u3092\u6d17\u3044\u51fa\u3057\u307e\u3057\u3087\u3046\u3002\u6700\u4f4e\u9650\u3001\u4ee5\u4e0b 7 \u7a2e\u985e\u304c\u3042\u308b\u3068\u5b9f\u52d9\u3067\u56f0\u308a\u307e\u305b\u3093\u3002<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><tbody><tr><td>\u30e9\u30d9\u30eb<\/td><td>\u4e3b\u306a\u5bfe\u8c61<\/td><td>\u63a8\u5968\u30b9\u30b3\u30fc\u30d7\u4f8b<\/td><\/tr><tr><td><code>comment<\/code><\/td><td><code>\/* \u2026 *\/<\/code> \u30d6\u30ed\u30c3\u30af\u30b3\u30e1\u30f3\u30c8\u3001\u884c\u982d <code>;<\/code> \u30b3\u30e1\u30f3\u30c8<\/td><td><code>comment.block<\/code>, <code>comment.line<\/code><\/td><\/tr><tr><td><code>string<\/code><\/td><td>\u30b7\u30f3\u30b0\u30eb\u30af\u30a9\u30fc\u30c8\u6587\u5b57\u5217\u3001\u8a08\u6e2c\u5668 <code>%NN<\/code> \u30a8\u30b9\u30b1\u30fc\u30d7\u4ed8\u304d\u6587\u5b57\u5217<\/td><td><code>string.quoted.single<\/code><\/td><\/tr><tr><td><code>number<\/code><\/td><td>10 \/ 2 \/ 8 \/ 16 \u9032\u6570\u30ea\u30c6\u30e9\u30eb\u3001\u5b9f\u6570\u30ea\u30c6\u30e9\u30eb<\/td><td><code>constant.numeric<\/code><\/td><\/tr><tr><td><code>keyword<\/code><\/td><td>\u5236\u5fa1\u69cb\u6587 (<code>IF<\/code> \u306a\u3069)\u3001\u30c7\u30fc\u30bf\u578b (<code>FLOAT<\/code> \u306a\u3069)<\/td><td><code>keyword.control<\/code>, <code>storage.type<\/code><\/td><\/tr><tr><td><code>operator<\/code><\/td><td><code>!!<\/code>, <code>.AND.<\/code>, <code>&gt;=<\/code> \u306a\u3069\u591a\u7a2e\u591a\u69d8\u306a\u6f14\u7b97\u5b50<\/td><td><code>keyword.operator<\/code><\/td><\/tr><tr><td><code>label<\/code><\/td><td>\u884c\u982d\u306e\u30b8\u30e3\u30f3\u30d7\u5148 <code>START_LOOP:<\/code><\/td><td><code>entity.name.label<\/code><\/td><\/tr><tr><td><code>identifier<\/code><\/td><td>\u4e88\u7d04\u8a9e\u3092\u9664\u304f\u3059\u3079\u3066\u306e\u8b58\u5225\u5b50<\/td><td><code>variable.other<\/code><\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">4.2 \u4f8b\u793a \u2015 \u30b3\u30e1\u30f3\u30c8\u4ed8\u304d\u6700\u5c0f\u69cb\u6210 JSON<\/h3>\n\n\n\n<p>\u4ee5\u4e0b\u306f <strong>\u52d5\u4f5c\u78ba\u8a8d\u7528\u306e\u6700\u5c0f\u5b9f\u88c5<\/strong> \u3067\u3059\u3002\u5b9f\u52d9\u3067\u306f\u6b63\u898f\u8868\u73fe\u3092\u3055\u3089\u306b\u7d30\u5206\u5316\u3059\u308b\u3068\u4fdd\u5b88\u3057\u3084\u3059\u304f\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>{\n  \"$schema\": \"https:\/\/raw.githubusercontent.com\/martinring\/tmlanguage\/v1.0.0\/tmlanguage.json\",\n  \"name\": \"Teradyne TPG\",\n  \"scopeName\": \"source.tpg\",\n  \"patterns\": &#91;\n    { \"include\": \"#comment\" },\n    { \"include\": \"#string\" },\n    { \"include\": \"#number\" },\n    { \"include\": \"#keyword\" },\n    { \"include\": \"#operator\" },\n    { \"include\": \"#label\" },\n    { \"include\": \"#identifier\" }\n  ],\n  \"repository\": {\n    \"comment\": {\n      \"patterns\": &#91;\n        { \"name\": \"comment.line.semicolon.tpg\", \"match\": \";.*$\" },\n        {\n          \"name\": \"comment.block.tpg\",\n          \"begin\": \"\/\\\\*\",              \/\/ `\/*` \u306b\u30de\u30c3\u30c1\n          \"end\": \"\\\\*\/\",                \/\/ `*\/` \u3067\u9589\u3058\u308b\n          \"patterns\": &#91; { \"include\": \"#comment\" } ] \/\/ \u30cd\u30b9\u30c8\u5bfe\u5fdc\n        }\n      ]\n    },\n    \"string\": {\n      \"name\": \"string.quoted.single.tpg\",\n      \"begin\": \"'\",\n      \"end\": \"'\",\n      \"patterns\": &#91;\n        {\n          \"match\": \"%%|%&#91;0-9A-Fa-f]{2}\",\n          \"name\": \"constant.character.escape.tpg\"\n        }\n      ]\n    },\n    \"number\": {\n      \"patterns\": &#91;\n        { \"match\": \"\\\\b&#91;0-9]+(\\\\.&#91;0-9]+)?(&#91;eE]&#91;+-]?&#91;0-9]+)?\\\\b\", \"name\": \"constant.numeric.decimal.tpg\" },\n        { \"match\": \"\\\\bB'&#91;01]+'\", \"name\": \"constant.numeric.binary.tpg\" },\n        { \"match\": \"\\\\bO'&#91;0-7]+'\", \"name\": \"constant.numeric.octal.tpg\" },\n        { \"match\": \"\\\\bX'&#91;0-9A-Fa-f]+'\", \"name\": \"constant.numeric.hex.tpg\" }\n      ]\n    },\n    \"keyword\": {\n      \"patterns\": &#91;\n        { \"match\": \"\\\\b(?:IF|THEN|ELSE|END)\\\\b\", \"name\": \"keyword.control.tpg\" },\n        { \"match\": \"\\\\b(?:FLOAT|CSTRING|BSTRING|FILE)\\\\b\", \"name\": \"storage.type.tpg\" }\n      ]\n    },\n    \"operator\": {\n      \"patterns\": &#91;\n        { \"match\": \"!!\", \"name\": \"keyword.operator.concat.tpg\" },\n        { \"match\": \"\\\\.(?:AND|OR|NOT)\\\\.\", \"name\": \"keyword.operator.logical.tpg\" },\n        { \"match\": \"(?:&lt;=|&gt;=|&lt;&gt;|!=|=|&lt;|&gt;|\\\\+|\\\\-|\\\\*|\/)\", \"name\": \"keyword.operator.tpg\" }\n      ]\n    },\n    \"label\": {\n      \"match\": \"^\\\\s*&#91;A-Za-z_]&#91;A-Za-z0-9_]*:\\\\s*(?=\\\\S)\",\n      \"name\": \"entity.name.label.tpg\"\n    },\n    \"identifier\": {\n      \"match\": \"\\\\b&#91;A-Za-z_]&#91;A-Za-z0-9_]{0,23}\\\\b\",\n      \"name\": \"variable.other.tpg\"\n    }\n  }\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">4.3 \u6b63\u898f\u8868\u73fe\u8a2d\u8a08\u3067\u62bc\u3055\u3048\u3066\u304a\u304f\u3079\u304d\u30dd\u30a4\u30f3\u30c8<\/h3>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li><strong>\u4f59\u767d\u306e\u53d6\u308a\u6271\u3044\u3092\u660e\u78ba\u306b\u3059\u308b<\/strong> \u2014 \u884c\u982d\u304c\u63c3\u308f\u306a\u3044\u30b3\u30e1\u30f3\u30c8\u306a\u3069\u306f <code>^\\\\s*<\/code> \u3092\u7528\u3044\u3066\u5438\u53ce\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u7d42\u7aef\u30c8\u30fc\u30af\u30f3\u306e\u8aa4\u4e00\u81f4\u3092\u907f\u3051\u308b<\/strong> \u2014 \u6587\u5b57\u5217\u30ea\u30c6\u30e9\u30eb\u306e\u9589\u3058\u30af\u30a9\u30fc\u30c8\u306f\u3001\u30a8\u30b9\u30b1\u30fc\u30d7 (<code>\\\\'<\/code>) \u3092\u8a31\u5bb9\u3057\u305f\u4e0a\u3067\u6b63\u3057\u304f\u691c\u51fa\u3057\u307e\u3057\u3087\u3046\u3002<\/li>\n\n\n\n<li><strong>\u5358\u8a9e\u5883\u754c\u3060\u3051\u306b\u983c\u3089\u306a\u3044<\/strong> \u2014 <code>.AND.<\/code> \u306e\u3088\u3046\u306b\u30d4\u30ea\u30aa\u30c9\u306b\u631f\u307e\u308c\u305f\u6f14\u7b97\u5b50\u306f <code>\\\\.<\/code> \u3092\u542b\u3081\u305f\u30ab\u30b9\u30bf\u30e0\u5883\u754c\u3067\u62fe\u3046\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p><strong>\u88dc\u8db3:<\/strong> \u8272\u304c\u53cd\u6620\u3055\u308c\u306a\u3044\u3068\u304d\u306f VSCode \u30b3\u30de\u30f3\u30c9 <strong>Developer: Inspect Editor Tokens and Scopes<\/strong> \u3067\u5b9f\u969b\u306b\u4ed8\u4e0e\u3055\u308c\u305f\u30b9\u30b3\u30fc\u30d7\u540d\u3092\u78ba\u8a8d\u3059\u308b\u3068\u539f\u56e0\u7a76\u660e\u304c\u5bb9\u6613\u3067\u3059\u3002<\/p>\n<\/blockquote>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">5. \u30c6\u30b9\u30c8\u3068\u30c7\u30d0\u30c3\u30b0 \u2015 Extension Development Host \u3092\u6d3b\u7528\u3059\u308b<\/h2>\n\n\n\n<p>\u62e1\u5f35\u30d5\u30a9\u30eb\u30c0\u3092 VSCode \u3067\u958b\u304d\u3001<code>F5<\/code> \u30ad\u30fc\u3092\u62bc\u3059\u3068 <strong>Extension Development Host<\/strong>\uff08\u958b\u767a\u7528\u306e\u5225\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\uff09\u304c\u8d77\u52d5\u3057\u307e\u3059\u3002\u305d\u3053\u3067 <code>.tpg<\/code> \u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\u3057\u3001\u8272\u5206\u3051\u304c\u671f\u5f85\u3069\u304a\u308a\u304b\u78ba\u8a8d\u3057\u307e\u3057\u3087\u3046\u3002<code>tmLanguage.json<\/code> \u3092\u4fdd\u5b58\u3059\u308b\u3068\u5373\u5ea7\u306b\u53cd\u6620\u3055\u308c\u308b\u305f\u3081\u3001\u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9\u611f\u899a\u3067\u8abf\u6574\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30c6\u30b9\u30c8\u7528\u30b3\u30fc\u30c9\u4f8b:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>; Sample TPG\nIF SIGNAL_A &gt; 5 THEN\n    SET VOLTAGE \"CH1\" 3.3\nELSE\n    LOG \"Voltage too low\"\nEND<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">\u3088\u304f\u3042\u308b\u3064\u307e\u305a\u304d\u3068\u5bfe\u51e6\u6cd5\uff083 \u4f8b\uff09<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code><strong>scopeName<\/strong><\/code><strong> \u306e\u4e0d\u4e00\u81f4<\/strong> \u2014 <code>package.json<\/code> \u3068 <code>tmLanguage.json<\/code> \u306e <code>scopeName<\/code> \u304c\u63c3\u3063\u3066\u3044\u308b\u304b\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n\n\n\n<li><strong>\u6b63\u898f\u8868\u73fe\u30a8\u30e9\u30fc<\/strong> \u2014 \u7121\u52b9\u306a\u6b63\u898f\u8868\u73fe\u304c\u3042\u308b\u3068\u8a72\u5f53\u30d1\u30bf\u30fc\u30f3\u304c\u7121\u8996\u3055\u308c\u307e\u3059\u3002\u7279\u306b\u30d0\u30c3\u30af\u30b9\u30e9\u30c3\u30b7\u30e5\u306e JSON \u30a8\u30b9\u30b1\u30fc\u30d7\u6f0f\u308c\u306b\u3054\u6ce8\u610f\u3092\u3002<\/li>\n\n\n\n<li><strong>\u62e1\u5f35\u5b50\u306e\u767b\u9332\u6f0f\u308c<\/strong> \u2014 <code>.tpg<\/code> \u304c <code>contributes.languages.extensions<\/code> \u306b\u542b\u307e\u308c\u3066\u3044\u306a\u3044\u5834\u5408\u3001VSCode \u304c\u8a00\u8a9e\u3092\u8a8d\u8b58\u3067\u304d\u307e\u305b\u3093\u3002<\/li>\n<\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">6. \u4ed5\u4e0a\u3052 \u2015 <code><strong>package.json<\/strong><\/code> \u3068 <code><strong>README.md<\/strong><\/code> \u3092\u6574\u3048\u308b<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">6.1 <code>package.json<\/code> \u306e\u5fc5\u9808\u30d5\u30a3\u30fc\u30eb\u30c9<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code>\"contributes\": {\n  \"languages\": &#91;\n    { \"id\": \"tpg\", \"aliases\": &#91;\"TPG\"], \"extensions\": &#91;\".tpg\"] }\n  ],\n  \"grammars\": &#91;\n    {\n      \"language\": \"tpg\",\n      \"scopeName\": \"source.tpg\",\n      \"path\": \".\/syntaxes\/tpg.tmLanguage.json\"\n    }\n  ]\n}<\/code><\/pre>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code><strong>languages<\/strong><\/code> \u2014 \u8a00\u8a9e ID\u30fb\u8868\u793a\u540d\u30fb\u5bfe\u5fdc\u62e1\u5f35\u5b50\u3092\u5ba3\u8a00\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><code><strong>grammars<\/strong><\/code> \u2014 \u6587\u6cd5\u30d5\u30a1\u30a4\u30eb\u3078\u306e\u30d1\u30b9\u3068 <code>scopeName<\/code> \u3092\u7d10\u4ed8\u3051\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<p>\u305d\u306e\u4ed6\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\uff08\u30d0\u30fc\u30b8\u30e7\u30f3\u3084\u51fa\u7248\u793e\u540d\u306a\u3069\uff09\u306f\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u306e\u307e\u307e\u3067\u3082\u52d5\u4f5c\u3057\u307e\u3059\u304c\u3001Marketplace \u306b\u516c\u958b\u3059\u308b\u969b\u306f\u9069\u5207\u306b\u8a18\u8ff0\u3059\u308b\u3053\u3068\u3092\u304a\u52e7\u3081\u3044\u305f\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">6.2 <code>README.md<\/code> \u306b\u6700\u4f4e\u9650\u542b\u3081\u305f\u3044 3 \u9805\u76ee<\/h3>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li><strong>\u5c0e\u5165\u624b\u9806<\/strong> \u2014 VSIX \u30d5\u30a1\u30a4\u30eb\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30b3\u30de\u30f3\u30c9\u3084 Marketplace URL\u3002<\/li>\n\n\n\n<li><strong>\u8a00\u8a9e\u4ed5\u69d8\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3078\u306e\u5c0e\u7dda<\/strong> \u2014 \u516c\u5f0f\u8cc7\u6599\u3084\u793e\u5185 Wiki \u3078\u306e\u30ea\u30f3\u30af\u3002<\/li>\n\n\n\n<li><strong>\u30e9\u30a4\u30bb\u30f3\u30b9<\/strong> \u2014 MIT \u30e9\u30a4\u30bb\u30f3\u30b9\u306a\u3089\u4e00\u884c\u3067\u660e\u8a18\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">7. \u307e\u3068\u3081 \u2015 \u307e\u305a\u306f\u201c\u4e00\u8272\u5206\u985e\u201d\u304b\u3089\u59cb\u3081\u3088\u3046<\/h2>\n\n\n\n<p>\u81ea\u4f5c\u30b7\u30f3\u30bf\u30c3\u30af\u30b9\u30cf\u30a4\u30e9\u30a4\u30c8\u306e\u6838\u5fc3\u306f\u300c<strong>\u6b63\u898f\u8868\u73fe\u3092\u66f8\u3044\u3066\u5373\u78ba\u8a8d\u3059\u308b<\/strong>\u300d\u306e\u7e70\u308a\u8fd4\u3057\u3067\u3059\u3002\u4eca\u56de\u3054\u7d39\u4ecb\u3057\u305f\u6700\u5c0f\u5b9f\u88c5\u3067\u3082\u3001\u7121\u5f69\u8272\u3060\u3063\u305f DSL \u304c\u4e00\u6c17\u306b\u8aad\u307f\u3084\u3059\u304f\u306a\u308b\u3053\u3068\u3092\u4f53\u611f\u3044\u305f\u3060\u3051\u308b\u3067\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p>\u5c06\u6765\u7684\u306b\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u6a5f\u80fd\u62e1\u5f35\u3082\u8996\u91ce\u306b\u5165\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30b7\u30f3\u30dc\u30eb\u4e00\u89a7\u3084\u30b8\u30e3\u30f3\u30d7\u6a5f\u80fd\u3092\u63d0\u4f9b\u3059\u308b <strong>Document Symbol Provider<\/strong><\/li>\n\n\n\n<li>\u30b9\u30cb\u30da\u30c3\u30c8\u3084\u30b3\u30fc\u30c9\u88dc\u5b8c\u3092\u8ffd\u52a0\u3059\u308b <strong>Completion Provider<\/strong><\/li>\n\n\n\n<li>Marketplace \u3078\u306e\u516c\u958b\u3068\u81ea\u52d5\u66f4\u65b0\u5bfe\u5fdc<\/li>\n<\/ul>\n\n\n\n<p>\u307e\u305a\u306f\u3054\u81ea\u8eab\u304c\u65e5\u5e38\u7684\u306b\u89e6\u308c\u3066\u3044\u308b DSL \u3092\u5bfe\u8c61\u306b\u300110 \u884c\u306e\u6b63\u898f\u8868\u73fe\u304b\u3089\u59cb\u3081\u3066\u307f\u3066\u306f\u3044\u304b\u304c\u3067\u3057\u3087\u3046\u304b\u3002\u304d\u3063\u3068\u958b\u767a\u52b9\u7387\u304c\u4e00\u6bb5\u4e0a\u304c\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u53c2\u8003\u8cc7\u6599<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Visual Studio Code Extension API\uff08\u516c\u5f0f\uff09<\/li>\n\n\n\n<li>TextMate Grammar Documentation<\/li>\n\n\n\n<li>generator-code GitHub \u30ea\u30dd\u30b8\u30c8\u30ea<\/li>\n\n\n\n<li>Regular Expressions 101\uff08\u30aa\u30f3\u30e9\u30a4\u30f3\u6b63\u898f\u8868\u73fe\u30c6\u30b9\u30bf\u30fc\uff09<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>1. \u306f\u3058\u3081\u306b \u2015 \u81ea\u4f5c\u30b7\u30f3\u30bf\u30c3\u30af\u30b9\u30cf\u30a4\u30e9\u30a4\u30c8\u306e\u610f\u7fa9 \u307f\u306a\u3055\u307e\u306f\u3001\u72ec\u81ea\u30c9\u30e1\u30a4\u30f3\u8a00\u8a9e\uff08DSL\uff09\u3092 VSCode \u3067\u7de8\u96c6\u3059\u308b\u3068\u304d\u3001\u30ad\u30fc\u30ef\u30fc\u30c9\u3082\u30b3\u30e1\u30f3\u30c8\u3082\u4e00\u69d8\u306b\u7070\u8272\u3067\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u5834\u9762\u306b\u906d\u9047\u3057\u305f\u3053\u3068\u306f\u3042\u308a\u307e\u305b\u3093\u304b\u3002\u79c1\u304c\u696d\u52d9\u3067\u6271 &hellip; <a href=\"https:\/\/www.vinesystems.net\/?post_type=wpadc&#038;p=177\">Continued<\/a><\/p>\n","protected":false},"author":1,"featured_media":266,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[50],"tags":[92,91,90,88,100,87,84,85,89,101,97,86,99,95,94,93,96,98],"class_list":{"0":"post-263","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","6":"hentry","7":"category-50","8":"tag-dsl","9":"tag-generator-code","10":"tag-node-js","11":"tag-textmate-grammar","12":"tag-tpg","13":"tag-visual-studio-code","14":"tag-vscode","16":"tag-yo-code","17":"tag-101","18":"tag-97","19":"tag-86","20":"tag-99","21":"tag-95","22":"tag-94","23":"tag-93","24":"tag-96","25":"tag-98"},"jetpack_featured_media_url":"https:\/\/www.vinesystems.net\/wp-content\/uploads\/2025\/04\/ChatGPT-Image-2025\u5e744\u670824\u65e5-20_43_54-1.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/posts\/263","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=263"}],"version-history":[{"count":1,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/posts\/263\/revisions"}],"predecessor-version":[{"id":268,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/posts\/263\/revisions\/268"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=\/wp\/v2\/media\/266"}],"wp:attachment":[{"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=263"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=263"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.vinesystems.net\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=263"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}