Bump version to 19.1.0 (final)
[llvm-project.git] / lldb / tools / lldb-dap / package.json
blobfd5de30ed28dd79a32fef9ebbeaeb311852a0a6a
2   "name": "lldb-dap",
3   "displayName": "LLDB DAP",
4   "version": "0.2.2",
5   "publisher": "llvm-vs-code-extensions",
6   "homepage": "https://lldb.llvm.org",
7   "description": "LLDB debugging from VSCode",
8   "license": "Apache 2.0 License with LLVM exceptions",
9   "repository": {
10     "type": "git",
11     "url": "https://github.com/llvm/vscode-lldb.git"
12   },
13   "bugs": {
14     "url": "https://github.com/llvm/llvm-project/issues"
15   },
16   "keywords": [
17     "C",
18     "C++",
19     "LLVM",
20     "LLDB"
21   ],
22   "engines": {
23     "vscode": "^1.75.0"
24   },
25   "categories": [
26     "Debuggers"
27   ],
28   "devDependencies": {
29     "@types/node": "^18.11.18",
30     "@types/vscode": "~1.74.0",
31     "@vscode/vsce": "^2.19.0",
32     "prettier-plugin-curly": "^0.1.3",
33     "prettier": "^3.1.1",
34     "typescript": "^4.6.4"
35   },
36   "activationEvents": [
37     "onDebug"
38   ],
39   "main": "./out/extension",
40   "scripts": {
41     "vscode:prepublish": "tsc -p ./",
42     "watch": "tsc -watch -p ./",
43     "format": "npx prettier './src-ts/' --write",
44     "package": "vsce package --out ./out/lldb-dap.vsix",
45     "publish": "vsce publish",
46     "vscode-uninstall": "code --uninstall-extension llvm.lldb-dap",
47     "vscode-install": "code --install-extension ./out/lldb-dap.vsix"
48   },
49   "contributes": {
50     "languages": [
51       {
52         "id": "lldb.disassembly",
53         "aliases": [
54           "Disassembly"
55         ],
56         "extensions": [
57           ".disasm"
58         ]
59       }
60     ],
61     "grammars": [
62       {
63         "language": "lldb.disassembly",
64         "scopeName": "source.disassembly",
65         "path": "./syntaxes/disassembly.json"
66       }
67     ],
68     "configuration": {
69       "type": "object",
70       "title": "lldb-dap",
71       "properties": {
72         "lldb-dap.executable-path": {
73           "scope": "resource",
74           "type": "string",
75           "description": "The path to the lldb-dap binary."
76         }
77       }
78     },
79     "breakpoints": [
80       {
81         "language": "ada"
82       },
83       {
84         "language": "arm"
85       },
86       {
87         "language": "asm"
88       },
89       {
90         "language": "c"
91       },
92       {
93         "language": "cpp"
94       },
95       {
96         "language": "crystal"
97       },
98       {
99         "language": "d"
100       },
101       {
102         "language": "fortan"
103       },
104       {
105         "language": "fortran-modern"
106       },
107       {
108         "language": "nim"
109       },
110       {
111         "language": "objective-c"
112       },
113       {
114         "language": "objectpascal"
115       },
116       {
117         "language": "pascal"
118       },
119       {
120         "language": "rust"
121       },
122       {
123         "language": "swift"
124       }
125     ],
126     "debuggers": [
127       {
128         "type": "lldb-dap",
129         "label": "Native LLDB Debugger",
130         "program": "./bin/lldb-dap",
131         "windows": {
132           "program": "./bin/lldb-dap.exe"
133         },
134         "configurationAttributes": {
135           "launch": {
136             "required": [
137               "program"
138             ],
139             "properties": {
140               "program": {
141                 "type": "string",
142                 "description": "Path to the program to debug."
143               },
144               "args": {
145                 "type": [
146                   "array",
147                   "string"
148                 ],
149                 "description": "Program arguments.",
150                 "default": []
151               },
152               "cwd": {
153                 "type": "string",
154                 "description": "Program working directory.",
155                 "default": "${workspaceRoot}"
156               },
157               "env": {
158                 "type": "array",
159                 "description": "Additional environment variables to set when launching the program. This is an array of strings that contains the variable name followed by an optional '=' character and the environment variable's value.",
160                 "default": []
161               },
162               "stopOnEntry": {
163                 "type": "boolean",
164                 "description": "Automatically stop after launch.",
165                 "default": false
166               },
167               "disableASLR": {
168                 "type": "boolean",
169                 "description": "Enable or disable Address space layout randomization if the debugger supports it.",
170                 "default": true
171               },
172               "disableSTDIO": {
173                 "type": "boolean",
174                 "description": "Don't retrieve STDIN, STDOUT and STDERR as the program is running.",
175                 "default": false
176               },
177               "shellExpandArguments": {
178                 "type": "boolean",
179                 "description": "Expand program arguments as a shell would without actually launching the program in a shell.",
180                 "default": false
181               },
182               "detachOnError": {
183                 "type": "boolean",
184                 "description": "Detach from the program.",
185                 "default": false
186               },
187               "sourcePath": {
188                 "type": "string",
189                 "description": "Specify a source path to remap \"./\" to allow full paths to be used when setting breakpoints in binaries that have relative source paths."
190               },
191               "sourceMap": {
192                 "type": "array",
193                 "description": "Specify an array of path remappings; each element must itself be a two element array containing a source and destination path name. Overrides sourcePath.",
194                 "default": []
195               },
196               "debuggerRoot": {
197                 "type": "string",
198                 "description": "Specify a working directory to set the debug adapter to so relative object files can be located."
199               },
200               "targetTriple": {
201                 "type": "string",
202                 "description": "Triplet of the target architecture to override value derived from the program file."
203               },
204               "platformName": {
205                 "type": "string",
206                 "description": "Name of the execution platform to override value derived from the program file."
207               },
208               "initCommands": {
209                 "type": "array",
210                 "description": "Initialization commands executed upon debugger startup.",
211                 "default": []
212               },
213               "preRunCommands": {
214                 "type": "array",
215                 "description": "Commands executed just before the program is launched.",
216                 "default": []
217               },
218               "postRunCommands": {
219                 "type": "array",
220                 "description": "Commands executed just as soon as the program is successfully launched when it's in a stopped state prior to any automatic continuation.",
221                 "default": []
222               },
223               "launchCommands": {
224                 "type": "array",
225                 "description": "Custom commands that are executed instead of launching a process. A target will be created with the launch arguments prior to executing these commands. The commands may optionally create a new target and must perform a launch. A valid process must exist after these commands complete or the \"launch\" will fail. Launch the process with \"process launch -s\" to make the process to at the entry point since lldb-dap will auto resume if necessary.",
226                 "default": []
227               },
228               "stopCommands": {
229                 "type": "array",
230                 "description": "Commands executed each time the program stops.",
231                 "default": []
232               },
233               "exitCommands": {
234                 "type": "array",
235                 "description": "Commands executed at the end of debugging session.",
236                 "default": []
237               },
238               "runInTerminal": {
239                 "type": "boolean",
240                 "description": "Launch the program inside an integrated terminal in the IDE. Useful for debugging interactive command line programs",
241                 "default": false
242               },
243               "timeout": {
244                 "type": "string",
245                 "description": "The time in seconds to wait for a program to stop at entry point when launching with \"launchCommands\". Defaults to 30 seconds."
246               },
247               "enableAutoVariableSummaries": {
248                 "type": "boolean",
249                 "description": "Enable auto generated summaries for variables when no summaries exist for a given type. This feature can cause performance delays in large projects when viewing variables.",
250                 "default": false
251               },
252               "enableSyntheticChildDebugging": {
253                 "type": "boolean",
254                 "description": "If a variable is displayed using a synthetic children, also display the actual contents of the variable at the end under a [raw] entry. This is useful when creating sythetic child plug-ins as it lets you see the actual contents of the variable.",
255                 "default": false
256               },
257               "commandEscapePrefix": {
258                 "type": "string",
259                 "description": "The escape prefix to use for executing regular LLDB commands in the Debug Console, instead of printing variables. Defaults to a back-tick (`). If it's an empty string, then all expression in the Debug Console are treated as regular LLDB commands.",
260                 "default": "`"
261               },
262               "customFrameFormat": {
263                 "type": "string",
264                 "description": "If non-empty, stack frames will have descriptions generated based on the provided format. See https://lldb.llvm.org/use/formatting.html for an explanation on format strings for frames. If the format string contains errors, an error message will be displayed on the Debug Console and the default frame names will be used. This might come with a performance cost because debug information might need to be processed to generate the description.",
265                 "default": ""
266               },
267               "customThreadFormat": {
268                 "type": "string",
269                 "description": "If non-empty, threads will have descriptions generated based on the provided format. See https://lldb.llvm.org/use/formatting.html for an explanation on format strings for threads. If the format string contains errors, an error message will be displayed on the Debug Console and the default thread names will be used. This might come with a performance cost because debug information might need to be processed to generate the description.",
270                 "default": ""
271               }
272             }
273           },
274           "attach": {
275             "properties": {
276               "program": {
277                 "type": "string",
278                 "description": "Path to the program to attach to."
279               },
280               "pid": {
281                 "type": [
282                   "number",
283                   "string"
284                 ],
285                 "description": "System process ID to attach to."
286               },
287               "waitFor": {
288                 "type": "boolean",
289                 "description": "If set to true, then wait for the process to launch by looking for a process with a basename that matches `program`. No process ID needs to be specified when using this flag.",
290                 "default": true
291               },
292               "sourcePath": {
293                 "type": "string",
294                 "description": "Specify a source path to remap \"./\" to allow full paths to be used when setting breakpoints in binaries that have relative source paths."
295               },
296               "sourceMap": {
297                 "type": "array",
298                 "description": "Specify an array of path remappings; each element must itself be a two element array containing a source and destination path name. Overrides sourcePath.",
299                 "default": []
300               },
301               "debuggerRoot": {
302                 "type": "string",
303                 "description": "Specify a working directory to set the debug adapter to so relative object files can be located."
304               },
305               "targetTriple": {
306                 "type": "string",
307                 "description": "Triplet of the target architecture to override value derived from the program file."
308               },
309               "platformName": {
310                 "type": "string",
311                 "description": "Name of the execution platform to override value derived from the program file."
312               },
313               "attachCommands": {
314                 "type": "array",
315                 "description": "Custom commands that are executed instead of attaching to a process ID or to a process by name. These commands may optionally create a new target and must perform an attach. A valid process must exist after these commands complete or the \"attach\" will fail.",
316                 "default": []
317               },
318               "initCommands": {
319                 "type": "array",
320                 "description": "Initialization commands executed upon debugger startup.",
321                 "default": []
322               },
323               "preRunCommands": {
324                 "type": "array",
325                 "description": "Commands executed just before the program is attached to.",
326                 "default": []
327               },
328               "postRunCommands": {
329                 "type": "array",
330                 "description": "Commands executed just as soon as the program is successfully attached when it's in a stopped state prior to any automatic continuation.",
331                 "default": []
332               },
333               "stopCommands": {
334                 "type": "array",
335                 "description": "Commands executed each time the program stops.",
336                 "default": []
337               },
338               "exitCommands": {
339                 "type": "array",
340                 "description": "Commands executed at the end of debugging session.",
341                 "default": []
342               },
343               "coreFile": {
344                 "type": "string",
345                 "description": "Path to the core file to debug."
346               },
347               "timeout": {
348                 "type": "string",
349                 "description": "The time in seconds to wait for a program to stop when attaching using \"attachCommands\". Defaults to 30 seconds."
350               },
351               "gdb-remote-port": {
352                 "type": [
353                   "number",
354                   "string"
355                 ],
356                 "description": "TCP/IP port to attach to. Specifying both pid and port is an error."
357               },
358               "gdb-remote-hostname": {
359                 "type": "string",
360                 "description": "The hostname to connect to a remote system. The default hostname being used localhost."
361               },
362               "enableAutoVariableSummaries": {
363                 "type": "boolean",
364                 "description": "Enable auto generated summaries for variables when no summaries exist for a given type. This feature can cause performance delays in large projects when viewing variables.",
365                 "default": false
366               },
367               "enableSyntheticChildDebugging": {
368                 "type": "boolean",
369                 "description": "If a variable is displayed using a synthetic children, also display the actual contents of the variable at the end under a [raw] entry. This is useful when creating sythetic child plug-ins as it lets you see the actual contents of the variable.",
370                 "default": false
371               },
372               "commandEscapePrefix": {
373                 "type": "string",
374                 "description": "The escape prefix character to use for executing regular LLDB commands in the Debug Console, instead of printing variables. Defaults to a back-tick (`). If empty, then all expression in the Debug Console are treated as regular LLDB commands.",
375                 "default": "`"
376               },
377               "customFrameFormat": {
378                 "type": "string",
379                 "description": "If non-empty, stack frames will have descriptions generated based on the provided format. See https://lldb.llvm.org/use/formatting.html for an explanation on format strings for frames. If the format string contains errors, an error message will be displayed on the Debug Console and the default frame names will be used. This might come with a performance cost because debug information might need to be processed to generate the description.",
380                 "default": ""
381               },
382               "customThreadFormat": {
383                 "type": "string",
384                 "description": "If non-empty, threads will have descriptions generated based on the provided format. See https://lldb.llvm.org/use/formatting.html for an explanation on format strings for threads. If the format string contains errors, an error message will be displayed on the Debug Console and the default thread names will be used. This might come with a performance cost because debug information might need to be processed to generate the description.",
385                 "default": ""
386               }
387             }
388           }
389         },
390         "initialConfigurations": [
391           {
392             "type": "lldb-dap",
393             "request": "launch",
394             "name": "Debug",
395             "program": "${workspaceRoot}/<your program>",
396             "args": [],
397             "env": [],
398             "cwd": "${workspaceRoot}"
399           }
400         ],
401         "configurationSnippets": [
402           {
403             "label": "LLDB: Launch",
404             "description": "",
405             "body": {
406               "type": "lldb-dap",
407               "request": "launch",
408               "name": "${2:Launch}",
409               "program": "^\"\\${workspaceRoot}/${1:<your program>}\"",
410               "args": [],
411               "env": [],
412               "cwd": "^\"\\${workspaceRoot}\""
413             }
414           }
415         ]
416       }
417     ]
418   }