@theia/debug 1.34.3 → 1.34.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (250) hide show
  1. package/LICENSE +641 -641
  2. package/README.md +62 -62
  3. package/bin/download-adapters.js +76 -76
  4. package/lib/browser/breakpoint/breakpoint-manager.d.ts +69 -69
  5. package/lib/browser/breakpoint/breakpoint-manager.js +311 -311
  6. package/lib/browser/breakpoint/breakpoint-marker.d.ts +40 -40
  7. package/lib/browser/breakpoint/breakpoint-marker.js +73 -73
  8. package/lib/browser/console/debug-console-contribution.d.ts +40 -40
  9. package/lib/browser/console/debug-console-contribution.js +227 -227
  10. package/lib/browser/console/debug-console-items.d.ts +93 -93
  11. package/lib/browser/console/debug-console-items.js +318 -318
  12. package/lib/browser/console/debug-console-session.d.ts +31 -31
  13. package/lib/browser/console/debug-console-session.js +199 -199
  14. package/lib/browser/debug-call-stack-item-type-key.d.ts +3 -3
  15. package/lib/browser/debug-call-stack-item-type-key.js +19 -19
  16. package/lib/browser/debug-configuration-manager.d.ts +101 -101
  17. package/lib/browser/debug-configuration-manager.js +521 -521
  18. package/lib/browser/debug-configuration-model.d.ts +29 -29
  19. package/lib/browser/debug-configuration-model.js +79 -79
  20. package/lib/browser/debug-contribution.d.ts +22 -22
  21. package/lib/browser/debug-contribution.js +19 -19
  22. package/lib/browser/debug-frontend-application-contribution.d.ts +214 -214
  23. package/lib/browser/debug-frontend-application-contribution.js +1351 -1351
  24. package/lib/browser/debug-frontend-module.d.ts +4 -4
  25. package/lib/browser/debug-frontend-module.js +108 -108
  26. package/lib/browser/debug-keybinding-contexts.d.ts +24 -24
  27. package/lib/browser/debug-keybinding-contexts.js +85 -85
  28. package/lib/browser/debug-package.spec.js +18 -18
  29. package/lib/browser/debug-preferences.d.ts +17 -17
  30. package/lib/browser/debug-preferences.js +89 -89
  31. package/lib/browser/debug-prefix-configuration.d.ts +50 -50
  32. package/lib/browser/debug-prefix-configuration.js +204 -204
  33. package/lib/browser/debug-resource.d.ts +14 -14
  34. package/lib/browser/debug-resource.js +65 -65
  35. package/lib/browser/debug-schema-updater.d.ts +15 -15
  36. package/lib/browser/debug-schema-updater.js +168 -168
  37. package/lib/browser/debug-session-connection.d.ts +110 -110
  38. package/lib/browser/debug-session-connection.js +258 -258
  39. package/lib/browser/debug-session-contribution.d.ts +73 -73
  40. package/lib/browser/debug-session-contribution.js +145 -145
  41. package/lib/browser/debug-session-manager.d.ts +137 -137
  42. package/lib/browser/debug-session-manager.js +593 -593
  43. package/lib/browser/debug-session-options.d.ts +48 -48
  44. package/lib/browser/debug-session-options.js +85 -85
  45. package/lib/browser/debug-session.d.ts +178 -178
  46. package/lib/browser/debug-session.js +859 -859
  47. package/lib/browser/debug-tab-bar-decorator.d.ts +16 -16
  48. package/lib/browser/debug-tab-bar-decorator.js +70 -70
  49. package/lib/browser/debug-watch-manager.d.ts +21 -21
  50. package/lib/browser/debug-watch-manager.js +93 -93
  51. package/lib/browser/disassembly-view/disassembly-view-accessibility-provider.d.ts +6 -6
  52. package/lib/browser/disassembly-view/disassembly-view-accessibility-provider.js +38 -38
  53. package/lib/browser/disassembly-view/disassembly-view-breakpoint-renderer.d.ts +19 -19
  54. package/lib/browser/disassembly-view/disassembly-view-breakpoint-renderer.js +110 -110
  55. package/lib/browser/disassembly-view/disassembly-view-contribution.d.ts +24 -24
  56. package/lib/browser/disassembly-view/disassembly-view-contribution.js +131 -131
  57. package/lib/browser/disassembly-view/disassembly-view-instruction-renderer.d.ts +38 -38
  58. package/lib/browser/disassembly-view/disassembly-view-instruction-renderer.js +222 -222
  59. package/lib/browser/disassembly-view/disassembly-view-table-delegate.d.ts +15 -15
  60. package/lib/browser/disassembly-view/disassembly-view-table-delegate.js +38 -38
  61. package/lib/browser/disassembly-view/disassembly-view-utilities.d.ts +37 -37
  62. package/lib/browser/disassembly-view/disassembly-view-utilities.js +17 -17
  63. package/lib/browser/disassembly-view/disassembly-view-widget.d.ts +60 -60
  64. package/lib/browser/disassembly-view/disassembly-view-widget.js +452 -452
  65. package/lib/browser/editor/debug-breakpoint-widget.d.ts +51 -51
  66. package/lib/browser/editor/debug-breakpoint-widget.js +245 -245
  67. package/lib/browser/editor/debug-editor-model.d.ts +91 -91
  68. package/lib/browser/editor/debug-editor-model.js +497 -497
  69. package/lib/browser/editor/debug-editor-service.d.ts +37 -37
  70. package/lib/browser/editor/debug-editor-service.js +214 -214
  71. package/lib/browser/editor/debug-editor.d.ts +3 -3
  72. package/lib/browser/editor/debug-editor.js +19 -19
  73. package/lib/browser/editor/debug-exception-widget.d.ts +28 -28
  74. package/lib/browser/editor/debug-exception-widget.js +111 -111
  75. package/lib/browser/editor/debug-expression-provider.d.ts +11 -11
  76. package/lib/browser/editor/debug-expression-provider.js +81 -81
  77. package/lib/browser/editor/debug-hover-source.d.ts +18 -18
  78. package/lib/browser/editor/debug-hover-source.js +117 -117
  79. package/lib/browser/editor/debug-hover-widget.d.ts +47 -47
  80. package/lib/browser/editor/debug-hover-widget.js +267 -267
  81. package/lib/browser/editor/debug-inline-value-decorator.d.ts +21 -21
  82. package/lib/browser/editor/debug-inline-value-decorator.js +337 -337
  83. package/lib/browser/model/debug-breakpoint.d.ts +47 -47
  84. package/lib/browser/model/debug-breakpoint.js +109 -109
  85. package/lib/browser/model/debug-function-breakpoint.d.ts +18 -18
  86. package/lib/browser/model/debug-function-breakpoint.js +92 -92
  87. package/lib/browser/model/debug-instruction-breakpoint.d.ts +14 -14
  88. package/lib/browser/model/debug-instruction-breakpoint.js +65 -65
  89. package/lib/browser/model/debug-source-breakpoint.d.ts +37 -37
  90. package/lib/browser/model/debug-source-breakpoint.js +211 -211
  91. package/lib/browser/model/debug-source.d.ts +24 -24
  92. package/lib/browser/model/debug-source.js +80 -80
  93. package/lib/browser/model/debug-stack-frame.d.ts +41 -41
  94. package/lib/browser/model/debug-stack-frame.js +146 -146
  95. package/lib/browser/model/debug-thread.d.ts +60 -60
  96. package/lib/browser/model/debug-thread.js +200 -200
  97. package/lib/browser/preferences/launch-preferences.d.ts +4 -4
  98. package/lib/browser/preferences/launch-preferences.js +38 -38
  99. package/lib/browser/view/debug-action.d.ts +16 -16
  100. package/lib/browser/view/debug-action.js +43 -43
  101. package/lib/browser/view/debug-breakpoints-source.d.ts +9 -9
  102. package/lib/browser/view/debug-breakpoints-source.js +70 -70
  103. package/lib/browser/view/debug-breakpoints-widget.d.ts +22 -22
  104. package/lib/browser/view/debug-breakpoints-widget.js +87 -87
  105. package/lib/browser/view/debug-configuration-select.d.ts +61 -61
  106. package/lib/browser/view/debug-configuration-select.js +204 -204
  107. package/lib/browser/view/debug-configuration-widget.d.ts +30 -30
  108. package/lib/browser/view/debug-configuration-widget.js +135 -135
  109. package/lib/browser/view/debug-exception-breakpoint.d.ts +13 -13
  110. package/lib/browser/view/debug-exception-breakpoint.js +34 -34
  111. package/lib/browser/view/debug-session-widget.d.ts +28 -28
  112. package/lib/browser/view/debug-session-widget.js +134 -134
  113. package/lib/browser/view/debug-stack-frames-source.d.ts +17 -17
  114. package/lib/browser/view/debug-stack-frames-source.js +89 -89
  115. package/lib/browser/view/debug-stack-frames-widget.d.ts +24 -24
  116. package/lib/browser/view/debug-stack-frames-widget.js +154 -154
  117. package/lib/browser/view/debug-threads-source.d.ts +8 -8
  118. package/lib/browser/view/debug-threads-source.js +63 -63
  119. package/lib/browser/view/debug-threads-widget.d.ts +26 -26
  120. package/lib/browser/view/debug-threads-widget.js +145 -145
  121. package/lib/browser/view/debug-toolbar-widget.d.ts +34 -34
  122. package/lib/browser/view/debug-toolbar-widget.js +156 -156
  123. package/lib/browser/view/debug-variables-source.d.ts +9 -9
  124. package/lib/browser/view/debug-variables-source.js +60 -60
  125. package/lib/browser/view/debug-variables-widget.d.ts +16 -16
  126. package/lib/browser/view/debug-variables-widget.js +78 -78
  127. package/lib/browser/view/debug-view-model.d.ts +51 -51
  128. package/lib/browser/view/debug-view-model.js +220 -220
  129. package/lib/browser/view/debug-watch-expression.d.ts +30 -30
  130. package/lib/browser/view/debug-watch-expression.js +73 -73
  131. package/lib/browser/view/debug-watch-source.d.ts +9 -9
  132. package/lib/browser/view/debug-watch-source.js +58 -58
  133. package/lib/browser/view/debug-watch-widget.d.ts +16 -16
  134. package/lib/browser/view/debug-watch-widget.js +78 -78
  135. package/lib/browser/view/debug-widget.d.ts +23 -23
  136. package/lib/browser/view/debug-widget.js +108 -108
  137. package/lib/common/debug-adapter-contribution-registry.d.ts +59 -59
  138. package/lib/common/debug-adapter-contribution-registry.js +212 -212
  139. package/lib/common/debug-adapter-session.d.ts +18 -18
  140. package/lib/common/debug-adapter-session.js +78 -78
  141. package/lib/common/debug-common.d.ts +1 -1
  142. package/lib/common/debug-common.js +29 -29
  143. package/lib/common/debug-compound.d.ts +14 -14
  144. package/lib/common/debug-compound.js +27 -27
  145. package/lib/common/debug-configuration.d.ts +58 -58
  146. package/lib/common/debug-configuration.js +31 -31
  147. package/lib/common/debug-model.d.ts +152 -152
  148. package/lib/common/debug-model.js +35 -35
  149. package/lib/common/debug-service.d.ts +123 -123
  150. package/lib/common/debug-service.js +66 -66
  151. package/lib/common/debug-uri-utils.d.ts +23 -23
  152. package/lib/common/debug-uri-utils.js +26 -26
  153. package/lib/common/inline-debug-adapter.d.ts +18 -18
  154. package/lib/common/inline-debug-adapter.js +44 -44
  155. package/lib/node/debug-adapter-factory.d.ts +19 -19
  156. package/lib/node/debug-adapter-factory.js +96 -96
  157. package/lib/node/debug-adapter-session-manager.d.ts +37 -37
  158. package/lib/node/debug-adapter-session-manager.js +111 -111
  159. package/lib/node/debug-backend-module.d.ts +3 -3
  160. package/lib/node/debug-backend-module.js +41 -41
  161. package/lib/node/debug-service-impl.d.ts +30 -30
  162. package/lib/node/debug-service-impl.js +124 -124
  163. package/lib/node/stream-debug-adapter.d.ts +36 -36
  164. package/lib/node/stream-debug-adapter.js +112 -112
  165. package/lib/node/vscode/vscode-debug-adapter-contribution.d.ts +47 -47
  166. package/lib/node/vscode/vscode-debug-adapter-contribution.js +221 -221
  167. package/package.json +15 -15
  168. package/src/browser/breakpoint/breakpoint-manager.ts +351 -351
  169. package/src/browser/breakpoint/breakpoint-marker.ts +102 -102
  170. package/src/browser/console/debug-console-contribution.tsx +239 -239
  171. package/src/browser/console/debug-console-items.tsx +383 -383
  172. package/src/browser/console/debug-console-session.ts +205 -205
  173. package/src/browser/debug-call-stack-item-type-key.ts +20 -20
  174. package/src/browser/debug-configuration-manager.ts +559 -559
  175. package/src/browser/debug-configuration-model.ts +100 -100
  176. package/src/browser/debug-contribution.ts +43 -43
  177. package/src/browser/debug-frontend-application-contribution.ts +1503 -1503
  178. package/src/browser/debug-frontend-module.ts +136 -136
  179. package/src/browser/debug-keybinding-contexts.ts +75 -75
  180. package/src/browser/debug-package.spec.ts +20 -20
  181. package/src/browser/debug-preferences.ts +98 -98
  182. package/src/browser/debug-prefix-configuration.ts +190 -190
  183. package/src/browser/debug-resource.ts +59 -59
  184. package/src/browser/debug-schema-updater.ts +149 -149
  185. package/src/browser/debug-session-connection.ts +357 -357
  186. package/src/browser/debug-session-contribution.ts +150 -150
  187. package/src/browser/debug-session-manager.ts +681 -681
  188. package/src/browser/debug-session-options.ts +114 -114
  189. package/src/browser/debug-session.tsx +936 -936
  190. package/src/browser/debug-tab-bar-decorator.ts +57 -57
  191. package/src/browser/debug-watch-manager.ts +93 -93
  192. package/src/browser/disassembly-view/disassembly-view-accessibility-provider.ts +43 -43
  193. package/src/browser/disassembly-view/disassembly-view-breakpoint-renderer.ts +119 -119
  194. package/src/browser/disassembly-view/disassembly-view-contribution.ts +109 -109
  195. package/src/browser/disassembly-view/disassembly-view-instruction-renderer.ts +245 -245
  196. package/src/browser/disassembly-view/disassembly-view-table-delegate.ts +39 -39
  197. package/src/browser/disassembly-view/disassembly-view-utilities.ts +55 -55
  198. package/src/browser/disassembly-view/disassembly-view-widget.ts +463 -463
  199. package/src/browser/editor/debug-breakpoint-widget.tsx +275 -275
  200. package/src/browser/editor/debug-editor-model.ts +508 -508
  201. package/src/browser/editor/debug-editor-service.ts +206 -206
  202. package/src/browser/editor/debug-editor.ts +20 -20
  203. package/src/browser/editor/debug-exception-widget.tsx +118 -118
  204. package/src/browser/editor/debug-expression-provider.ts +78 -78
  205. package/src/browser/editor/debug-hover-source.tsx +105 -105
  206. package/src/browser/editor/debug-hover-widget.ts +280 -280
  207. package/src/browser/editor/debug-inline-value-decorator.ts +377 -377
  208. package/src/browser/model/debug-breakpoint.tsx +151 -151
  209. package/src/browser/model/debug-function-breakpoint.tsx +101 -101
  210. package/src/browser/model/debug-instruction-breakpoint.tsx +68 -68
  211. package/src/browser/model/debug-source-breakpoint.tsx +237 -237
  212. package/src/browser/model/debug-source.ts +93 -93
  213. package/src/browser/model/debug-stack-frame.tsx +170 -170
  214. package/src/browser/model/debug-thread.tsx +240 -240
  215. package/src/browser/preferences/launch-preferences.ts +38 -38
  216. package/src/browser/style/index.css +445 -445
  217. package/src/browser/view/debug-action.tsx +57 -57
  218. package/src/browser/view/debug-breakpoints-source.tsx +53 -53
  219. package/src/browser/view/debug-breakpoints-widget.ts +71 -71
  220. package/src/browser/view/debug-configuration-select.tsx +256 -256
  221. package/src/browser/view/debug-configuration-widget.tsx +121 -121
  222. package/src/browser/view/debug-exception-breakpoint.tsx +43 -43
  223. package/src/browser/view/debug-session-widget.ts +124 -124
  224. package/src/browser/view/debug-stack-frames-source.tsx +75 -75
  225. package/src/browser/view/debug-stack-frames-widget.ts +135 -135
  226. package/src/browser/view/debug-threads-source.tsx +48 -48
  227. package/src/browser/view/debug-threads-widget.ts +125 -125
  228. package/src/browser/view/debug-toolbar-widget.tsx +145 -145
  229. package/src/browser/view/debug-variables-source.ts +43 -43
  230. package/src/browser/view/debug-variables-widget.ts +61 -61
  231. package/src/browser/view/debug-view-model.ts +230 -230
  232. package/src/browser/view/debug-watch-expression.tsx +88 -88
  233. package/src/browser/view/debug-watch-source.ts +41 -41
  234. package/src/browser/view/debug-watch-widget.ts +61 -61
  235. package/src/browser/view/debug-widget.ts +97 -97
  236. package/src/common/debug-adapter-contribution-registry.ts +206 -206
  237. package/src/common/debug-adapter-session.ts +102 -102
  238. package/src/common/debug-common.ts +19 -19
  239. package/src/common/debug-compound.ts +33 -33
  240. package/src/common/debug-configuration.ts +93 -93
  241. package/src/common/debug-model.ts +200 -200
  242. package/src/common/debug-service.ts +184 -184
  243. package/src/common/debug-uri-utils.ts +24 -24
  244. package/src/common/inline-debug-adapter.ts +47 -47
  245. package/src/node/debug-adapter-factory.ts +107 -107
  246. package/src/node/debug-adapter-session-manager.ts +106 -106
  247. package/src/node/debug-backend-module.ts +57 -57
  248. package/src/node/debug-service-impl.ts +119 -119
  249. package/src/node/stream-debug-adapter.ts +126 -126
  250. package/src/node/vscode/vscode-debug-adapter-contribution.ts +252 -252
package/README.md CHANGED
@@ -1,62 +1,62 @@
1
- <div align='center'>
2
-
3
- <br />
4
-
5
- <img src='https://raw.githubusercontent.com/eclipse-theia/theia/master/logo/theia.svg?sanitize=true' alt='theia-ext-logo' width='100px' />
6
-
7
- <h2>ECLIPSE THEIA - DEBUG EXTENSION</h2>
8
-
9
- <hr />
10
-
11
- </div>
12
-
13
- ## Architecture
14
-
15
- `DebugService` is used to initialize a new `DebugSession`. This service provides functionality to configure and to start a new debug session. The workflow is the following. If user wants to debug an application and there is no debug configuration associated with the application then the list of available debuggers is requested to create a suitable debug configuration. When configuration is chosen it is possible to alter the configuration by filling in missing values or by adding/changing/removing attributes.
16
-
17
- In most cases the default behavior of the `DebugSession` is enough. But it is possible to provide its own implementation. The `DebugSessionFactory` is used for this purpose via `DebugSessionContribution`. Documented model objects are located [here](https://github.com/eclipse-theia/theia/tree/master/packages/debug/src/browser/debug-model.ts)
18
-
19
- ### Debug Session life-cycle API
20
-
21
- `DebugSession` life-cycle is controlled and can be tracked as follows:
22
- * An `onDidPreCreateDebugSession` event indicates that a debug session is going to be created.
23
- * An `onDidCreateDebugSession` event indicates that a debug session has been created.
24
- * An `onDidDestroyDebugSession` event indicates that a debug session has terminated.
25
- * An `onDidChangeActiveDebugSession` event indicates that an active debug session has been changed
26
-
27
- ### Breakpoints API
28
-
29
- `ExtDebugProtocol.AggregatedBreakpoint` is used to handle breakpoints on the client side. It covers all three breakpoint types: `DebugProtocol.SourceBreakpoint`, `DebugProtocol.FunctionBreakpoint` and `ExtDebugProtocol.ExceptionBreakpoint`. It is possible to identify a breakpoint type with help of `DebugUtils`. Notification about added, removed, or changed breakpoints is received via `onDidChangeBreakpoints`.
30
-
31
- ### Server side
32
-
33
- At the back-end we start a debug adapter using `DebugAdapterFactory` and then a `DebugAdapterSession` is instantiated which works as a proxy between client and debug adapter. If a default implementation of the debug adapter session does not fit needs, it is possible to provide its own implementation using `DebugAdapterSessionFactory`. If so, it is recommended to extend the default implementation of the `DebugAdapterSession`. Documented model objects are located [here](https://github.com/eclipse-theia/theia/tree/master/packages/debug/src/node/debug-model.ts)
34
-
35
- `DebugSessionState` accumulates debug adapter events and is used to restore debug session on the client side when page is refreshed.
36
-
37
- ## How to contribute a new debugger
38
-
39
- `DebugAdapterContribution` is a contribution point for all debug adapters to provide and resolve debug configuration.
40
-
41
- ## Additional Information
42
-
43
- - [API documentation for `@theia/debug`](https://eclipse-theia.github.io/theia/docs/next/modules/debug.html)
44
- - [Theia - GitHub](https://github.com/eclipse-theia/theia)
45
- - [Theia - Website](https://theia-ide.org/)
46
- - [Debug Adapter Protocol](https://github.com/Microsoft/vscode-debugadapter-node/blob/master/protocol/src/debugProtocol.ts)
47
- - [VS Code debug API](https://code.visualstudio.com/docs/extensionAPI/api-debugging)
48
- - [Debug adapter example for VS Code](https://code.visualstudio.com/docs/extensions/example-debuggers)
49
-
50
- ## Debug adapter implementations for VS Code
51
- * [Node Debugger](https://github.com/microsoft/vscode-node-debug)
52
- * [Node Debugger 2](https://github.com/microsoft/vscode-node-debug2)
53
- * [Java Debugger](https://github.com/Microsoft/vscode-java-debug)
54
-
55
- ## License
56
-
57
- - [Eclipse Public License 2.0](http://www.eclipse.org/legal/epl-2.0/)
58
- - [一 (Secondary) GNU General Public License, version 2 with the GNU Classpath Exception](https://projects.eclipse.org/license/secondary-gpl-2.0-cp)
59
-
60
- ## Trademark
61
- "Theia" is a trademark of the Eclipse Foundation
62
- https://www.eclipse.org/theia
1
+ <div align='center'>
2
+
3
+ <br />
4
+
5
+ <img src='https://raw.githubusercontent.com/eclipse-theia/theia/master/logo/theia.svg?sanitize=true' alt='theia-ext-logo' width='100px' />
6
+
7
+ <h2>ECLIPSE THEIA - DEBUG EXTENSION</h2>
8
+
9
+ <hr />
10
+
11
+ </div>
12
+
13
+ ## Architecture
14
+
15
+ `DebugService` is used to initialize a new `DebugSession`. This service provides functionality to configure and to start a new debug session. The workflow is the following. If user wants to debug an application and there is no debug configuration associated with the application then the list of available debuggers is requested to create a suitable debug configuration. When configuration is chosen it is possible to alter the configuration by filling in missing values or by adding/changing/removing attributes.
16
+
17
+ In most cases the default behavior of the `DebugSession` is enough. But it is possible to provide its own implementation. The `DebugSessionFactory` is used for this purpose via `DebugSessionContribution`. Documented model objects are located [here](https://github.com/eclipse-theia/theia/tree/master/packages/debug/src/browser/debug-model.ts)
18
+
19
+ ### Debug Session life-cycle API
20
+
21
+ `DebugSession` life-cycle is controlled and can be tracked as follows:
22
+ * An `onDidPreCreateDebugSession` event indicates that a debug session is going to be created.
23
+ * An `onDidCreateDebugSession` event indicates that a debug session has been created.
24
+ * An `onDidDestroyDebugSession` event indicates that a debug session has terminated.
25
+ * An `onDidChangeActiveDebugSession` event indicates that an active debug session has been changed
26
+
27
+ ### Breakpoints API
28
+
29
+ `ExtDebugProtocol.AggregatedBreakpoint` is used to handle breakpoints on the client side. It covers all three breakpoint types: `DebugProtocol.SourceBreakpoint`, `DebugProtocol.FunctionBreakpoint` and `ExtDebugProtocol.ExceptionBreakpoint`. It is possible to identify a breakpoint type with help of `DebugUtils`. Notification about added, removed, or changed breakpoints is received via `onDidChangeBreakpoints`.
30
+
31
+ ### Server side
32
+
33
+ At the back-end we start a debug adapter using `DebugAdapterFactory` and then a `DebugAdapterSession` is instantiated which works as a proxy between client and debug adapter. If a default implementation of the debug adapter session does not fit needs, it is possible to provide its own implementation using `DebugAdapterSessionFactory`. If so, it is recommended to extend the default implementation of the `DebugAdapterSession`. Documented model objects are located [here](https://github.com/eclipse-theia/theia/tree/master/packages/debug/src/node/debug-model.ts)
34
+
35
+ `DebugSessionState` accumulates debug adapter events and is used to restore debug session on the client side when page is refreshed.
36
+
37
+ ## How to contribute a new debugger
38
+
39
+ `DebugAdapterContribution` is a contribution point for all debug adapters to provide and resolve debug configuration.
40
+
41
+ ## Additional Information
42
+
43
+ - [API documentation for `@theia/debug`](https://eclipse-theia.github.io/theia/docs/next/modules/debug.html)
44
+ - [Theia - GitHub](https://github.com/eclipse-theia/theia)
45
+ - [Theia - Website](https://theia-ide.org/)
46
+ - [Debug Adapter Protocol](https://github.com/Microsoft/vscode-debugadapter-node/blob/master/protocol/src/debugProtocol.ts)
47
+ - [VS Code debug API](https://code.visualstudio.com/docs/extensionAPI/api-debugging)
48
+ - [Debug adapter example for VS Code](https://code.visualstudio.com/docs/extensions/example-debuggers)
49
+
50
+ ## Debug adapter implementations for VS Code
51
+ * [Node Debugger](https://github.com/microsoft/vscode-node-debug)
52
+ * [Node Debugger 2](https://github.com/microsoft/vscode-node-debug2)
53
+ * [Java Debugger](https://github.com/Microsoft/vscode-java-debug)
54
+
55
+ ## License
56
+
57
+ - [Eclipse Public License 2.0](http://www.eclipse.org/legal/epl-2.0/)
58
+ - [一 (Secondary) GNU General Public License, version 2 with the GNU Classpath Exception](https://projects.eclipse.org/license/secondary-gpl-2.0-cp)
59
+
60
+ ## Trademark
61
+ "Theia" is a trademark of the Eclipse Foundation
62
+ https://www.eclipse.org/theia
@@ -1,76 +1,76 @@
1
- #!/usr/bin/env node
2
- // *****************************************************************************
3
- // Copyright (C) 2018 TypeFox and others.
4
- //
5
- // This program and the accompanying materials are made available under the
6
- // terms of the Eclipse Public License v. 2.0 which is available at
7
- // http://www.eclipse.org/legal/epl-2.0.
8
- //
9
- // This Source Code may also be made available under the following Secondary
10
- // Licenses when the conditions for such availability set forth in the Eclipse
11
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
- // with the GNU Classpath Exception which is available at
13
- // https://www.gnu.org/software/classpath/license.html.
14
- //
15
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
16
- // *****************************************************************************
17
-
18
- const fs = require('fs');
19
- const request = require('requestretry');
20
- const unzip = require('unzip-stream');
21
- const path = require('path');
22
- const process = require('process');
23
- const zlib = require('zlib');
24
- const mkdirp = require('mkdirp');
25
- const tar = require('tar');
26
-
27
- const pck = require(path.resolve(process.cwd(), 'package.json'));
28
- const adapterDir = pck.adapterDir || 'download';
29
-
30
- function isDownloaded(dirPath) {
31
- try {
32
- return !fs.readdirSync(dirPath).length;
33
- } catch (e) {
34
- return true;
35
- }
36
- }
37
-
38
- for (const name in pck.adapters) {
39
- const targetPath = path.join(process.cwd(), adapterDir, name);
40
- if (!isDownloaded(targetPath)) {
41
- console.log(name + ': already downloaded');
42
- continue;
43
- }
44
- const adapterUrl = pck.adapters[name];
45
- console.log(name + ': downloading from ' + adapterUrl);
46
- const download = request({
47
- ...pck.requestOptions,
48
- url: adapterUrl,
49
- maxAttempts: 5,
50
- retryDelay: 2000,
51
- retryStrategy: request.RetryStrategies.HTTPOrNetworkError
52
- }, (err, response) => {
53
- if (err) {
54
- console.error(name + ': failed to download', err)
55
- process.exitCode = 1;
56
- } else {
57
- console.log(name + ': downloaded successfully' + (response.attempts > 1 ? ` after ${response.attempts} attempts` : ''));
58
- }
59
- });
60
-
61
- if (adapterUrl.endsWith('gz')) {
62
- // Support tar gz
63
- mkdirp(targetPath);
64
- const gunzip = zlib.createGunzip({
65
- finishFlush: zlib.Z_SYNC_FLUSH,
66
- flush: zlib.Z_SYNC_FLUSH
67
- });
68
- const untar = tar.x({
69
- cwd: targetPath
70
- });
71
- download.pipe(gunzip).pipe(untar);
72
- } else {
73
- // Support zip or vsix
74
- download.pipe(unzip.Extract({ path: targetPath }));
75
- }
76
- }
1
+ #!/usr/bin/env node
2
+ // *****************************************************************************
3
+ // Copyright (C) 2018 TypeFox and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+
18
+ const fs = require('fs');
19
+ const request = require('requestretry');
20
+ const unzip = require('unzip-stream');
21
+ const path = require('path');
22
+ const process = require('process');
23
+ const zlib = require('zlib');
24
+ const mkdirp = require('mkdirp');
25
+ const tar = require('tar');
26
+
27
+ const pck = require(path.resolve(process.cwd(), 'package.json'));
28
+ const adapterDir = pck.adapterDir || 'download';
29
+
30
+ function isDownloaded(dirPath) {
31
+ try {
32
+ return !fs.readdirSync(dirPath).length;
33
+ } catch (e) {
34
+ return true;
35
+ }
36
+ }
37
+
38
+ for (const name in pck.adapters) {
39
+ const targetPath = path.join(process.cwd(), adapterDir, name);
40
+ if (!isDownloaded(targetPath)) {
41
+ console.log(name + ': already downloaded');
42
+ continue;
43
+ }
44
+ const adapterUrl = pck.adapters[name];
45
+ console.log(name + ': downloading from ' + adapterUrl);
46
+ const download = request({
47
+ ...pck.requestOptions,
48
+ url: adapterUrl,
49
+ maxAttempts: 5,
50
+ retryDelay: 2000,
51
+ retryStrategy: request.RetryStrategies.HTTPOrNetworkError
52
+ }, (err, response) => {
53
+ if (err) {
54
+ console.error(name + ': failed to download', err)
55
+ process.exitCode = 1;
56
+ } else {
57
+ console.log(name + ': downloaded successfully' + (response.attempts > 1 ? ` after ${response.attempts} attempts` : ''));
58
+ }
59
+ });
60
+
61
+ if (adapterUrl.endsWith('gz')) {
62
+ // Support tar gz
63
+ mkdirp(targetPath);
64
+ const gunzip = zlib.createGunzip({
65
+ finishFlush: zlib.Z_SYNC_FLUSH,
66
+ flush: zlib.Z_SYNC_FLUSH
67
+ });
68
+ const untar = tar.x({
69
+ cwd: targetPath
70
+ });
71
+ download.pipe(gunzip).pipe(untar);
72
+ } else {
73
+ // Support zip or vsix
74
+ download.pipe(unzip.Extract({ path: targetPath }));
75
+ }
76
+ }
@@ -1,70 +1,70 @@
1
- import { Emitter } from '@theia/core/lib/common';
2
- import { StorageService } from '@theia/core/lib/browser';
3
- import { Marker } from '@theia/markers/lib/common/marker';
4
- import { MarkerManager } from '@theia/markers/lib/browser/marker-manager';
5
- import URI from '@theia/core/lib/common/uri';
6
- import { SourceBreakpoint, ExceptionBreakpoint, FunctionBreakpoint, BaseBreakpoint, InstructionBreakpoint } from './breakpoint-marker';
7
- export interface BreakpointsChangeEvent<T extends BaseBreakpoint> {
8
- uri: URI;
9
- added: T[];
10
- removed: T[];
11
- changed: T[];
12
- }
13
- export declare type SourceBreakpointsChangeEvent = BreakpointsChangeEvent<SourceBreakpoint>;
14
- export declare type FunctionBreakpointsChangeEvent = BreakpointsChangeEvent<FunctionBreakpoint>;
15
- export declare type InstructionBreakpointsChangeEvent = BreakpointsChangeEvent<InstructionBreakpoint>;
16
- export declare class BreakpointManager extends MarkerManager<SourceBreakpoint> {
17
- static EXCEPTION_URI: URI;
18
- static FUNCTION_URI: URI;
19
- static INSTRUCTION_URI: URI;
20
- protected readonly owner = "breakpoint";
21
- protected readonly storage: StorageService;
22
- getKind(): string;
23
- protected readonly onDidChangeBreakpointsEmitter: Emitter<SourceBreakpointsChangeEvent>;
24
- readonly onDidChangeBreakpoints: import("@theia/core/lib/common").Event<SourceBreakpointsChangeEvent>;
25
- protected readonly onDidChangeFunctionBreakpointsEmitter: Emitter<FunctionBreakpointsChangeEvent>;
26
- readonly onDidChangeFunctionBreakpoints: import("@theia/core/lib/common").Event<FunctionBreakpointsChangeEvent>;
27
- protected readonly onDidChangeInstructionBreakpointsEmitter: Emitter<InstructionBreakpointsChangeEvent>;
28
- readonly onDidChangeInstructionBreakpoints: import("@theia/core/lib/common").Event<InstructionBreakpointsChangeEvent>;
29
- setMarkers(uri: URI, owner: string, newMarkers: SourceBreakpoint[]): Marker<SourceBreakpoint>[];
30
- getLineBreakpoints(uri: URI, line: number): SourceBreakpoint[];
31
- getInlineBreakpoint(uri: URI, line: number, column: number): SourceBreakpoint | undefined;
32
- getBreakpoints(uri?: URI): SourceBreakpoint[];
33
- setBreakpoints(uri: URI, breakpoints: SourceBreakpoint[]): void;
34
- addBreakpoint(breakpoint: SourceBreakpoint): boolean;
35
- enableAllBreakpoints(enabled: boolean): void;
36
- protected _breakpointsEnabled: boolean;
37
- get breakpointsEnabled(): boolean;
38
- set breakpointsEnabled(breakpointsEnabled: boolean);
39
- protected readonly exceptionBreakpoints: Map<string, ExceptionBreakpoint>;
40
- getExceptionBreakpoint(filter: string): ExceptionBreakpoint | undefined;
41
- getExceptionBreakpoints(): IterableIterator<ExceptionBreakpoint>;
42
- setExceptionBreakpoints(exceptionBreakpoints: ExceptionBreakpoint[]): void;
43
- toggleExceptionBreakpoint(filter: string): void;
44
- protected functionBreakpoints: FunctionBreakpoint[];
45
- getFunctionBreakpoints(): FunctionBreakpoint[];
46
- setFunctionBreakpoints(functionBreakpoints: FunctionBreakpoint[]): void;
47
- protected instructionBreakpoints: InstructionBreakpoint[];
48
- getInstructionBreakpoints(): ReadonlyArray<InstructionBreakpoint>;
49
- hasBreakpoints(): boolean;
50
- protected setInstructionBreakpoints(newBreakpoints: InstructionBreakpoint[]): void;
51
- addInstructionBreakpoint(address: string, offset: number, condition?: string, hitCondition?: string): void;
52
- updateInstructionBreakpoint(id: string, options: Partial<Pick<InstructionBreakpoint, 'condition' | 'hitCondition' | 'enabled'>>): void;
53
- removeInstructionBreakpoint(address?: string): void;
54
- clearInstructionBreakpoints(): void;
55
- removeBreakpoints(): void;
56
- load(): Promise<void>;
57
- save(): void;
58
- }
59
- export declare namespace BreakpointManager {
60
- interface Data {
61
- breakpointsEnabled: boolean;
62
- breakpoints: {
63
- [uri: string]: SourceBreakpoint[];
64
- };
65
- exceptionBreakpoints?: ExceptionBreakpoint[];
66
- functionBreakpoints?: FunctionBreakpoint[];
67
- instructionBreakpoints?: InstructionBreakpoint[];
68
- }
69
- }
1
+ import { Emitter } from '@theia/core/lib/common';
2
+ import { StorageService } from '@theia/core/lib/browser';
3
+ import { Marker } from '@theia/markers/lib/common/marker';
4
+ import { MarkerManager } from '@theia/markers/lib/browser/marker-manager';
5
+ import URI from '@theia/core/lib/common/uri';
6
+ import { SourceBreakpoint, ExceptionBreakpoint, FunctionBreakpoint, BaseBreakpoint, InstructionBreakpoint } from './breakpoint-marker';
7
+ export interface BreakpointsChangeEvent<T extends BaseBreakpoint> {
8
+ uri: URI;
9
+ added: T[];
10
+ removed: T[];
11
+ changed: T[];
12
+ }
13
+ export declare type SourceBreakpointsChangeEvent = BreakpointsChangeEvent<SourceBreakpoint>;
14
+ export declare type FunctionBreakpointsChangeEvent = BreakpointsChangeEvent<FunctionBreakpoint>;
15
+ export declare type InstructionBreakpointsChangeEvent = BreakpointsChangeEvent<InstructionBreakpoint>;
16
+ export declare class BreakpointManager extends MarkerManager<SourceBreakpoint> {
17
+ static EXCEPTION_URI: URI;
18
+ static FUNCTION_URI: URI;
19
+ static INSTRUCTION_URI: URI;
20
+ protected readonly owner = "breakpoint";
21
+ protected readonly storage: StorageService;
22
+ getKind(): string;
23
+ protected readonly onDidChangeBreakpointsEmitter: Emitter<SourceBreakpointsChangeEvent>;
24
+ readonly onDidChangeBreakpoints: import("@theia/core/lib/common").Event<SourceBreakpointsChangeEvent>;
25
+ protected readonly onDidChangeFunctionBreakpointsEmitter: Emitter<FunctionBreakpointsChangeEvent>;
26
+ readonly onDidChangeFunctionBreakpoints: import("@theia/core/lib/common").Event<FunctionBreakpointsChangeEvent>;
27
+ protected readonly onDidChangeInstructionBreakpointsEmitter: Emitter<InstructionBreakpointsChangeEvent>;
28
+ readonly onDidChangeInstructionBreakpoints: import("@theia/core/lib/common").Event<InstructionBreakpointsChangeEvent>;
29
+ setMarkers(uri: URI, owner: string, newMarkers: SourceBreakpoint[]): Marker<SourceBreakpoint>[];
30
+ getLineBreakpoints(uri: URI, line: number): SourceBreakpoint[];
31
+ getInlineBreakpoint(uri: URI, line: number, column: number): SourceBreakpoint | undefined;
32
+ getBreakpoints(uri?: URI): SourceBreakpoint[];
33
+ setBreakpoints(uri: URI, breakpoints: SourceBreakpoint[]): void;
34
+ addBreakpoint(breakpoint: SourceBreakpoint): boolean;
35
+ enableAllBreakpoints(enabled: boolean): void;
36
+ protected _breakpointsEnabled: boolean;
37
+ get breakpointsEnabled(): boolean;
38
+ set breakpointsEnabled(breakpointsEnabled: boolean);
39
+ protected readonly exceptionBreakpoints: Map<string, ExceptionBreakpoint>;
40
+ getExceptionBreakpoint(filter: string): ExceptionBreakpoint | undefined;
41
+ getExceptionBreakpoints(): IterableIterator<ExceptionBreakpoint>;
42
+ setExceptionBreakpoints(exceptionBreakpoints: ExceptionBreakpoint[]): void;
43
+ toggleExceptionBreakpoint(filter: string): void;
44
+ protected functionBreakpoints: FunctionBreakpoint[];
45
+ getFunctionBreakpoints(): FunctionBreakpoint[];
46
+ setFunctionBreakpoints(functionBreakpoints: FunctionBreakpoint[]): void;
47
+ protected instructionBreakpoints: InstructionBreakpoint[];
48
+ getInstructionBreakpoints(): ReadonlyArray<InstructionBreakpoint>;
49
+ hasBreakpoints(): boolean;
50
+ protected setInstructionBreakpoints(newBreakpoints: InstructionBreakpoint[]): void;
51
+ addInstructionBreakpoint(address: string, offset: number, condition?: string, hitCondition?: string): void;
52
+ updateInstructionBreakpoint(id: string, options: Partial<Pick<InstructionBreakpoint, 'condition' | 'hitCondition' | 'enabled'>>): void;
53
+ removeInstructionBreakpoint(address?: string): void;
54
+ clearInstructionBreakpoints(): void;
55
+ removeBreakpoints(): void;
56
+ load(): Promise<void>;
57
+ save(): void;
58
+ }
59
+ export declare namespace BreakpointManager {
60
+ interface Data {
61
+ breakpointsEnabled: boolean;
62
+ breakpoints: {
63
+ [uri: string]: SourceBreakpoint[];
64
+ };
65
+ exceptionBreakpoints?: ExceptionBreakpoint[];
66
+ functionBreakpoints?: FunctionBreakpoint[];
67
+ instructionBreakpoints?: InstructionBreakpoint[];
68
+ }
69
+ }
70
70
  //# sourceMappingURL=breakpoint-manager.d.ts.map