@mrclrchtr/supi-lsp 1.7.0 → 1.9.0

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 (251) hide show
  1. package/README.md +33 -10
  2. package/node_modules/@mrclrchtr/supi-code-runtime/README.md +13 -0
  3. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/README.md +97 -0
  4. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/package.json +53 -0
  5. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/api.ts +30 -0
  6. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/config/config-settings.ts +76 -0
  7. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/config/config.ts +186 -0
  8. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/config.ts +11 -0
  9. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/context/context-messages.ts +119 -0
  10. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/context/context-provider-registry.ts +36 -0
  11. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/context/context-tag.ts +31 -0
  12. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/context.ts +16 -0
  13. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/debug-registry.ts +255 -0
  14. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/index.ts +30 -0
  15. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/path-utils.ts +40 -0
  16. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/path.ts +2 -0
  17. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/project-roots.ts +170 -0
  18. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/project.ts +15 -0
  19. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/registry-utils.ts +86 -0
  20. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/session-utils.ts +29 -0
  21. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/session.ts +4 -0
  22. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/settings/settings-command.ts +15 -0
  23. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/settings/settings-registry.ts +41 -0
  24. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/settings/settings-ui.ts +226 -0
  25. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/settings-ui.ts +2 -0
  26. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/settings.ts +9 -0
  27. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/substrate-types.ts +11 -0
  28. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/terminal.ts +60 -0
  29. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/tool-framework.ts +116 -0
  30. package/node_modules/@mrclrchtr/supi-code-runtime/node_modules/@mrclrchtr/supi-core/src/types.ts +2 -0
  31. package/node_modules/@mrclrchtr/supi-code-runtime/package.json +40 -0
  32. package/node_modules/@mrclrchtr/supi-code-runtime/src/api.ts +35 -0
  33. package/node_modules/@mrclrchtr/supi-code-runtime/src/capability/types.ts +68 -0
  34. package/node_modules/@mrclrchtr/supi-code-runtime/src/index.ts +31 -0
  35. package/node_modules/@mrclrchtr/supi-code-runtime/src/types.ts +110 -0
  36. package/node_modules/@mrclrchtr/supi-code-runtime/src/workspace/context.ts +41 -0
  37. package/node_modules/@mrclrchtr/supi-code-runtime/src/workspace/runtime.ts +170 -0
  38. package/node_modules/@mrclrchtr/supi-core/README.md +3 -13
  39. package/node_modules/@mrclrchtr/supi-core/package.json +13 -8
  40. package/node_modules/@mrclrchtr/supi-core/src/api.ts +26 -92
  41. package/node_modules/@mrclrchtr/supi-core/src/config.ts +11 -0
  42. package/node_modules/@mrclrchtr/supi-core/src/context.ts +16 -0
  43. package/node_modules/@mrclrchtr/supi-core/src/index.ts +26 -92
  44. package/node_modules/@mrclrchtr/supi-core/src/path.ts +2 -0
  45. package/node_modules/@mrclrchtr/supi-core/src/project.ts +15 -0
  46. package/node_modules/@mrclrchtr/supi-core/src/session.ts +4 -0
  47. package/node_modules/@mrclrchtr/supi-core/src/settings-ui.ts +2 -0
  48. package/node_modules/@mrclrchtr/supi-core/src/settings.ts +9 -0
  49. package/node_modules/@mrclrchtr/supi-core/src/substrate-types.ts +11 -0
  50. package/node_modules/@mrclrchtr/supi-core/src/types.ts +2 -0
  51. package/node_modules/vscode-jsonrpc/License.txt +11 -0
  52. package/node_modules/vscode-jsonrpc/README.md +69 -0
  53. package/node_modules/vscode-jsonrpc/browser.d.ts +6 -0
  54. package/node_modules/vscode-jsonrpc/browser.js +7 -0
  55. package/node_modules/vscode-jsonrpc/lib/browser/main.d.ts +17 -0
  56. package/node_modules/vscode-jsonrpc/lib/browser/main.js +76 -0
  57. package/node_modules/vscode-jsonrpc/lib/browser/ril.d.ts +12 -0
  58. package/node_modules/vscode-jsonrpc/lib/browser/ril.js +156 -0
  59. package/node_modules/vscode-jsonrpc/lib/common/api.d.ts +14 -0
  60. package/node_modules/vscode-jsonrpc/lib/common/api.js +81 -0
  61. package/node_modules/vscode-jsonrpc/lib/common/cancellation.d.ts +32 -0
  62. package/node_modules/vscode-jsonrpc/lib/common/cancellation.js +96 -0
  63. package/node_modules/vscode-jsonrpc/lib/common/connection.d.ts +358 -0
  64. package/node_modules/vscode-jsonrpc/lib/common/connection.js +1214 -0
  65. package/node_modules/vscode-jsonrpc/lib/common/disposable.d.ts +9 -0
  66. package/node_modules/vscode-jsonrpc/lib/common/disposable.js +16 -0
  67. package/node_modules/vscode-jsonrpc/lib/common/encoding.d.ts +52 -0
  68. package/node_modules/vscode-jsonrpc/lib/common/encoding.js +70 -0
  69. package/node_modules/vscode-jsonrpc/lib/common/events.d.ts +39 -0
  70. package/node_modules/vscode-jsonrpc/lib/common/events.js +128 -0
  71. package/node_modules/vscode-jsonrpc/lib/common/is.d.ts +7 -0
  72. package/node_modules/vscode-jsonrpc/lib/common/is.js +35 -0
  73. package/node_modules/vscode-jsonrpc/lib/common/linkedMap.d.ts +53 -0
  74. package/node_modules/vscode-jsonrpc/lib/common/linkedMap.js +398 -0
  75. package/node_modules/vscode-jsonrpc/lib/common/messageBuffer.d.ts +18 -0
  76. package/node_modules/vscode-jsonrpc/lib/common/messageBuffer.js +152 -0
  77. package/node_modules/vscode-jsonrpc/lib/common/messageReader.d.ts +77 -0
  78. package/node_modules/vscode-jsonrpc/lib/common/messageReader.js +197 -0
  79. package/node_modules/vscode-jsonrpc/lib/common/messageWriter.d.ts +60 -0
  80. package/node_modules/vscode-jsonrpc/lib/common/messageWriter.js +115 -0
  81. package/node_modules/vscode-jsonrpc/lib/common/messages.d.ts +369 -0
  82. package/node_modules/vscode-jsonrpc/lib/common/messages.js +306 -0
  83. package/node_modules/vscode-jsonrpc/lib/common/ral.d.ts +74 -0
  84. package/node_modules/vscode-jsonrpc/lib/common/ral.js +23 -0
  85. package/node_modules/vscode-jsonrpc/lib/common/semaphore.d.ts +10 -0
  86. package/node_modules/vscode-jsonrpc/lib/common/semaphore.js +68 -0
  87. package/node_modules/vscode-jsonrpc/lib/common/sharedArrayCancellation.d.ts +15 -0
  88. package/node_modules/vscode-jsonrpc/lib/common/sharedArrayCancellation.js +76 -0
  89. package/node_modules/vscode-jsonrpc/lib/node/main.d.ts +63 -0
  90. package/node_modules/vscode-jsonrpc/lib/node/main.js +257 -0
  91. package/node_modules/vscode-jsonrpc/lib/node/ril.d.ts +13 -0
  92. package/node_modules/vscode-jsonrpc/lib/node/ril.js +161 -0
  93. package/node_modules/vscode-jsonrpc/node.cmd +5 -0
  94. package/node_modules/vscode-jsonrpc/node.d.ts +6 -0
  95. package/node_modules/vscode-jsonrpc/node.js +7 -0
  96. package/node_modules/vscode-jsonrpc/package.json +45 -0
  97. package/node_modules/vscode-jsonrpc/thirdpartynotices.txt +16 -0
  98. package/node_modules/vscode-jsonrpc/typings/thenable.d.ts +5 -0
  99. package/node_modules/vscode-languageserver-protocol/License.txt +11 -0
  100. package/node_modules/vscode-languageserver-protocol/README.md +16 -0
  101. package/node_modules/vscode-languageserver-protocol/browser.d.ts +6 -0
  102. package/node_modules/vscode-languageserver-protocol/browser.js +7 -0
  103. package/node_modules/vscode-languageserver-protocol/lib/browser/main.d.ts +4 -0
  104. package/node_modules/vscode-languageserver-protocol/lib/browser/main.js +28 -0
  105. package/node_modules/vscode-languageserver-protocol/lib/common/api.d.ts +58 -0
  106. package/node_modules/vscode-languageserver-protocol/lib/common/api.js +77 -0
  107. package/node_modules/vscode-languageserver-protocol/lib/common/connection.d.ts +187 -0
  108. package/node_modules/vscode-languageserver-protocol/lib/common/connection.js +15 -0
  109. package/node_modules/vscode-languageserver-protocol/lib/common/messages.d.ts +51 -0
  110. package/node_modules/vscode-languageserver-protocol/lib/common/messages.js +44 -0
  111. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.$.d.ts +1 -0
  112. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.$.js +43 -0
  113. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.callHierarchy.d.ts +86 -0
  114. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.callHierarchy.js +42 -0
  115. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.colorProvider.d.ts +66 -0
  116. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.colorProvider.js +32 -0
  117. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.configuration.d.ts +35 -0
  118. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.configuration.js +24 -0
  119. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.d.ts +3252 -0
  120. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.declaration.d.ts +37 -0
  121. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.declaration.js +22 -0
  122. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.diagnostic.d.ts +341 -0
  123. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.diagnostic.js +74 -0
  124. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.fileOperations.d.ts +306 -0
  125. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.fileOperations.js +101 -0
  126. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.foldingRange.d.ts +109 -0
  127. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.foldingRange.js +30 -0
  128. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.implementation.d.ts +38 -0
  129. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.implementation.js +21 -0
  130. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.inlayHint.d.ts +110 -0
  131. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.inlayHint.js +43 -0
  132. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.inlineCompletion.d.ts +57 -0
  133. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.inlineCompletion.js +22 -0
  134. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.inlineValue.d.ts +86 -0
  135. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.inlineValue.js +30 -0
  136. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.js +943 -0
  137. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.linkedEditingRange.d.ts +52 -0
  138. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.linkedEditingRange.js +19 -0
  139. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.moniker.d.ts +106 -0
  140. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.moniker.js +68 -0
  141. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.notebook.d.ts +400 -0
  142. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.notebook.js +214 -0
  143. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.progress.d.ts +107 -0
  144. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.progress.js +37 -0
  145. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.selectionRange.d.ts +41 -0
  146. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.selectionRange.js +20 -0
  147. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.semanticTokens.d.ts +223 -0
  148. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.semanticTokens.js +57 -0
  149. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.showDocument.d.ts +72 -0
  150. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.showDocument.js +22 -0
  151. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.typeDefinition.d.ts +38 -0
  152. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.typeDefinition.js +21 -0
  153. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.typeHierarchy.d.ts +83 -0
  154. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.typeHierarchy.js +42 -0
  155. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.workspaceFolder.d.ts +74 -0
  156. package/node_modules/vscode-languageserver-protocol/lib/common/protocol.workspaceFolder.js +27 -0
  157. package/node_modules/vscode-languageserver-protocol/lib/common/utils/is.d.ts +9 -0
  158. package/node_modules/vscode-languageserver-protocol/lib/common/utils/is.js +46 -0
  159. package/node_modules/vscode-languageserver-protocol/lib/node/main.d.ts +6 -0
  160. package/node_modules/vscode-languageserver-protocol/lib/node/main.js +28 -0
  161. package/node_modules/vscode-languageserver-protocol/metaModel.schema.json +783 -0
  162. package/node_modules/vscode-languageserver-protocol/node.cmd +5 -0
  163. package/node_modules/vscode-languageserver-protocol/node.d.ts +6 -0
  164. package/node_modules/vscode-languageserver-protocol/node.js +7 -0
  165. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/License.txt +11 -0
  166. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/README.md +69 -0
  167. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/browser.d.ts +6 -0
  168. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/browser.js +7 -0
  169. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/browser/main.d.ts +17 -0
  170. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/browser/main.js +76 -0
  171. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/browser/ril.d.ts +12 -0
  172. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/browser/ril.js +156 -0
  173. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/api.d.ts +14 -0
  174. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/api.js +81 -0
  175. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/cancellation.d.ts +32 -0
  176. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/cancellation.js +96 -0
  177. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/connection.d.ts +358 -0
  178. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/connection.js +1212 -0
  179. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/disposable.d.ts +9 -0
  180. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/disposable.js +16 -0
  181. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/encoding.d.ts +52 -0
  182. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/encoding.js +70 -0
  183. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/events.d.ts +39 -0
  184. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/events.js +128 -0
  185. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/is.d.ts +7 -0
  186. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/is.js +35 -0
  187. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/linkedMap.d.ts +53 -0
  188. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/linkedMap.js +398 -0
  189. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messageBuffer.d.ts +18 -0
  190. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messageBuffer.js +152 -0
  191. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messageReader.d.ts +77 -0
  192. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messageReader.js +197 -0
  193. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messageWriter.d.ts +60 -0
  194. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messageWriter.js +115 -0
  195. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messages.d.ts +369 -0
  196. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/messages.js +306 -0
  197. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/ral.d.ts +74 -0
  198. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/ral.js +23 -0
  199. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/semaphore.d.ts +10 -0
  200. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/semaphore.js +68 -0
  201. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/sharedArrayCancellation.d.ts +15 -0
  202. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/common/sharedArrayCancellation.js +76 -0
  203. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/node/main.d.ts +63 -0
  204. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/node/main.js +257 -0
  205. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/node/ril.d.ts +13 -0
  206. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/lib/node/ril.js +161 -0
  207. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/node.cmd +5 -0
  208. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/node.d.ts +6 -0
  209. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/node.js +7 -0
  210. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/package.json +45 -0
  211. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/thirdpartynotices.txt +16 -0
  212. package/node_modules/vscode-languageserver-protocol/node_modules/vscode-jsonrpc/typings/thenable.d.ts +5 -0
  213. package/node_modules/vscode-languageserver-protocol/package.json +45 -0
  214. package/node_modules/vscode-languageserver-protocol/thirdpartynotices.txt +31 -0
  215. package/node_modules/vscode-languageserver-types/License.txt +11 -0
  216. package/node_modules/vscode-languageserver-types/README.md +17 -0
  217. package/node_modules/vscode-languageserver-types/lib/esm/main.d.ts +3139 -0
  218. package/node_modules/vscode-languageserver-types/lib/esm/main.js +2222 -0
  219. package/node_modules/vscode-languageserver-types/lib/esm/package.json +3 -0
  220. package/node_modules/vscode-languageserver-types/lib/umd/main.d.ts +3139 -0
  221. package/node_modules/vscode-languageserver-types/lib/umd/main.js +2272 -0
  222. package/node_modules/vscode-languageserver-types/package.json +38 -0
  223. package/node_modules/vscode-languageserver-types/thirdpartynotices.txt +16 -0
  224. package/package.json +9 -6
  225. package/src/config/config.ts +1 -1
  226. package/src/handlers/diagnostic-injection.ts +182 -0
  227. package/src/handlers/session-lifecycle.ts +149 -0
  228. package/src/handlers/status-command.ts +38 -0
  229. package/src/handlers/workspace-recovery.ts +92 -0
  230. package/src/lsp.ts +18 -414
  231. package/src/manager/capability-index.ts +24 -0
  232. package/src/manager/client-pool.ts +33 -0
  233. package/src/manager/diagnostic-store.ts +51 -0
  234. package/src/manager/manager-helpers.ts +1 -1
  235. package/src/manager/manager-workspace-symbol.ts +1 -1
  236. package/src/manager/manager.ts +1 -1
  237. package/src/manager/recovery-coordinator.ts +37 -0
  238. package/src/manager/workspace-router.ts +44 -0
  239. package/src/provider/lsp-semantic-provider.ts +156 -0
  240. package/src/session/runtime-registration.ts +39 -0
  241. package/src/session/scanner.ts +1 -1
  242. package/src/session/service-registry.ts +1 -1
  243. package/src/session/settings-registration.ts +1 -1
  244. package/src/tool/guidance.ts +5 -14
  245. package/src/tool/names.ts +12 -4
  246. package/src/tool/register-tools.ts +2 -4
  247. package/src/tool/service-actions.ts +141 -0
  248. package/src/tool/tool-specs.ts +93 -93
  249. package/src/utils.ts +1 -1
  250. package/src/workspace-change.ts +40 -0
  251. package/node_modules/@mrclrchtr/supi-core/src/extension.ts +0 -1
package/README.md CHANGED
@@ -1,3 +1,5 @@
1
+ ![SuPi](assets/logo.png)
2
+
1
3
  # @mrclrchtr/supi-lsp
2
4
 
3
5
  Adds Language Server Protocol support to the [pi coding agent](https://github.com/earendil-works/pi).
@@ -14,26 +16,31 @@ For local development:
14
16
  pi install ./packages/supi-lsp
15
17
  ```
16
18
 
17
- After editing the source, run `/reload`.
18
-
19
19
  ## What you get
20
20
 
21
- After install, pi gets:
21
+ After install, pi gets **10 focused expert tools** for semantic language-server analysis:
22
22
 
23
- - `lsp_lookup` — semantic hover, definition, references, and implementation at a known position
23
+ - `lsp_hover` — semantic type or symbol information at a given position
24
+ - `lsp_definition` — go to definition at a known position
25
+ - `lsp_references` — find all references to a symbol
26
+ - `lsp_implementation` — find implementations of an interface or method
24
27
  - `lsp_document_symbols` — semantic declarations for one supported file
25
28
  - `lsp_workspace_symbols` — semantic symbol-name lookup across the project
26
29
  - `lsp_diagnostics` — current diagnostics for one file or a workspace summary
27
- - `lsp_refactor` — semantic rename planning and code actions at a known position
30
+ - `lsp_rename` — semantic rename planning at a known position
31
+ - `lsp_code_actions` — semantic fixes or refactors at a known position
28
32
  - `lsp_recover` — refresh stale diagnostics after workspace changes
29
33
  - `/lsp-status` — inspect detected servers, roots, open files, and diagnostics
30
- - automatic LSP-aware diagnostic surfacing around edits and agent turns
34
+
35
+ ![LSP status overlay](https://raw.githubusercontent.com/mrclrchtr/supi/main/screenshots/supi-lsp-status.png)
36
+
37
+ ![LSP hover in action](https://raw.githubusercontent.com/mrclrchtr/supi/main/screenshots/supi-lsp-hover.png)
31
38
 
32
39
  Coordinates use **1-based** line and character positions.
33
40
 
34
41
  ## Automatic behavior
35
42
 
36
- This package does more than register a tool:
43
+ This package does more than register these tools:
37
44
 
38
45
  - starts detected language servers for the current project
39
46
  - rebuilds project-specific prompt guidance based on active servers
@@ -58,10 +65,24 @@ Config lives in the standard SuPi config files:
58
65
  - global: `~/.pi/agent/supi/config.json`
59
66
  - project: `.pi/supi/config.json`
60
67
 
68
+ ## Architecture
69
+
70
+ `@mrclrchtr/supi-lsp` is the **semantic substrate** in SuPi's code-understanding stack.
71
+ It depends on `@mrclrchtr/supi-core` and `@mrclrchtr/supi-code-runtime` for shared
72
+ contracts, and provides a session-scoped LSP service that publishes semantic and
73
+ diagnostic capabilities into the shared workspace runtime.
74
+
75
+ ```text
76
+ supi-code-runtime ← shared contracts + workspace runtime
77
+
78
+ supi-lsp ← LSP client + session-scoped service + runtime capabilities
79
+ ```
80
+
61
81
  ## Package surfaces
62
82
 
63
83
  - `@mrclrchtr/supi-lsp/api` — reusable session-scoped LSP service and related types
64
84
  - `@mrclrchtr/supi-lsp/extension` — pi extension entrypoint
85
+ - `@mrclrchtr/supi-lsp/provider/lsp-semantic-provider` — shared SemanticProvider adapter
65
86
 
66
87
  Example:
67
88
 
@@ -74,16 +95,18 @@ if (state.kind === "ready") {
74
95
  }
75
96
  ```
76
97
 
77
- `SessionLspService` methods use raw **0-based LSP positions**. The expert tools (`lsp_lookup`, `lsp_refactor`, etc.) keep the public 1-based coordinate UX.
98
+ `SessionLspService` methods use raw **0-based LSP positions**. The expert tools (`lsp_hover`, `lsp_definition`, etc.) keep the public 1-based coordinate UX.
78
99
 
79
100
  ## Source
80
101
 
81
102
  - `src/lsp.ts` — extension wiring, session lifecycle, and `/lsp-status`
82
103
  - `src/config/` — server config, defaults, capabilities, and exported LSP protocol types
83
104
  - `src/session/` — session state, scanning, settings registration, tree persistence, and shared service registry
84
- - `src/tool/register-tools.ts` — expert tool registration for the split LSP toolset
105
+ - `src/tool/tool-specs.ts` — single source of truth for the public LSP tool surface
106
+ - `src/tool/guidance.ts` — prompt surfaces derived from tool specs
107
+ - `src/tool/register-tools.ts` — focused tool registration driven by tool specs
85
108
  - `src/tool/service-actions.ts` — service-backed tool execution and formatting
86
- - `src/tool/guidance.ts` / `src/tool/names.ts` — prompt surfaces and stable tool names
109
+ - `src/tool/names.ts` — stable tool name constants
87
110
  - `src/tool/overrides.ts` — read/write/edit overrides for inline diagnostics
88
111
  - `src/ui/` — custom diagnostic message rendering and the status overlay
89
112
  - `src/client/`, `src/manager/`, `src/diagnostics/` — runtime engine subsystems
@@ -0,0 +1,13 @@
1
+ # @mrclrchtr/supi-code-runtime
2
+
3
+ Shared workspace context, capability contracts, and canonical types for the SuPi code-understanding stack.
4
+
5
+ This is a **library-only package** — it has no pi extension surface, no user-facing tools, and no UI. It provides the shared abstractions that `supi-lsp`, `supi-tree-sitter`, and `supi-code-intelligence` use to communicate capability availability.
6
+
7
+ ## Package surfaces
8
+
9
+ - `@mrclrchtr/supi-code-runtime/api` — shared canonical types, capability interfaces, workspace runtime registry, and typed request context
10
+
11
+ ## License
12
+
13
+ MIT
@@ -0,0 +1,97 @@
1
+ ![SuPi](assets/logo.png)
2
+
3
+ # @mrclrchtr/supi-core
4
+
5
+ Shared infrastructure for SuPi extensions.
6
+
7
+ This is a **pure library** — it does not register any pi commands or tools. The `/supi-settings` command is now available through `@mrclrchtr/supi-settings`.
8
+
9
+ ## Install
10
+
11
+ ```bash
12
+ pnpm add @mrclrchtr/supi-core
13
+ ```
14
+
15
+ ## Package surfaces
16
+
17
+ - `@mrclrchtr/supi-core/api` — reusable helpers for other packages and extensions
18
+
19
+ ## What you get from the API
20
+
21
+ ### Config helpers
22
+
23
+ - `loadSupiConfig()` — merged config with resolution order `defaults <- global <- project`
24
+ - `loadSupiConfigForScope()` — load one scope at a time for settings UIs
25
+ - `writeSupiConfig()` — persist values
26
+ - `removeSupiConfigKey()` — remove a key or override
27
+
28
+ Config file locations:
29
+
30
+ - global: `~/.pi/agent/supi/config.json`
31
+ - project: `.pi/supi/config.json`
32
+
33
+ ### Settings helpers
34
+
35
+ - `registerSettings()` — register an arbitrary settings section
36
+ - `registerConfigSettings()` — register a config-backed settings section with scoped persistence helpers
37
+ - `registerSettingsCommand()` — register `/supi-settings`
38
+ - `openSettingsOverlay()` — open the shared settings UI directly
39
+ - `createInputSubmenu()` — helper for simple text-entry submenus
40
+
41
+ The built-in settings UI supports:
42
+
43
+ - project/global scope toggle
44
+ - grouped extension sections
45
+ - searchable setting lists
46
+
47
+ ### Context helpers
48
+
49
+ - `wrapExtensionContext()` — wrap injected text in SuPi's `<extension-context>` tag
50
+ - `findLastUserMessageIndex()`
51
+ - `getContextToken()`
52
+ - `getPromptContent()`
53
+ - `pruneAndReorderContextMessages()`
54
+ - `restorePromptContent()`
55
+
56
+ ### Shared registries
57
+
58
+ - context-provider registry for `/supi-context`
59
+ - debug-event registry for producers that want shared debug capture
60
+ - settings registry used by `/supi-settings`
61
+
62
+ ### Project and session helpers
63
+
64
+ - project-root detection and directory walking helpers such as `findProjectRoot()` and `walkProject()`
65
+ - active-branch session helper: `getActiveBranchEntries()`
66
+ - terminal helpers such as `formatTitle()`, `signalWaiting()`, and `signalDone()`
67
+
68
+ ## Example
69
+
70
+ ```ts
71
+ import { loadSupiConfig, registerConfigSettings, wrapExtensionContext } from "@mrclrchtr/supi-core/api";
72
+
73
+ const config = loadSupiConfig("my-extension", process.cwd(), {
74
+ enabled: true,
75
+ });
76
+
77
+ registerConfigSettings({
78
+ id: "my-extension",
79
+ label: "My Extension",
80
+ section: "my-extension",
81
+ defaults: { enabled: true },
82
+ buildItems: () => [],
83
+ persistChange: () => {},
84
+ });
85
+
86
+ const message = wrapExtensionContext("my-extension", "hello", {
87
+ file: "CLAUDE.md",
88
+ turn: 1,
89
+ });
90
+ ```
91
+
92
+ ## Source
93
+
94
+ - `src/api.ts` — exported library surface
95
+ - `src/config.ts` — shared config loading and writing
96
+ - `src/config-settings.ts` — config-backed settings registration helper
97
+ - `src/settings-ui.ts` — shared settings overlay
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "@mrclrchtr/supi-core",
3
+ "version": "1.9.0",
4
+ "description": "SuPi core — shared infrastructure for SuPi extensions (XML context tags, config system)",
5
+ "license": "MIT",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "git+https://github.com/mrclrchtr/supi.git"
9
+ },
10
+ "publishConfig": {
11
+ "access": "public"
12
+ },
13
+ "keywords": [
14
+ "pi",
15
+ "pi-coding-agent"
16
+ ],
17
+ "files": [
18
+ "src/**/*.ts",
19
+ "!__tests__"
20
+ ],
21
+ "peerDependencies": {
22
+ "@earendil-works/pi-coding-agent": "*",
23
+ "@earendil-works/pi-tui": "*",
24
+ "typebox": "*"
25
+ },
26
+ "peerDependenciesMeta": {
27
+ "@earendil-works/pi-coding-agent": {
28
+ "optional": true
29
+ },
30
+ "@earendil-works/pi-tui": {
31
+ "optional": true
32
+ },
33
+ "typebox": {
34
+ "optional": true
35
+ }
36
+ },
37
+ "main": "src/api.ts",
38
+ "exports": {
39
+ "./api": "./src/api.ts",
40
+ "./config": "./src/config.ts",
41
+ "./context": "./src/context.ts",
42
+ "./debug": "./src/debug-registry.ts",
43
+ "./package.json": "./package.json",
44
+ "./path": "./src/path.ts",
45
+ "./project": "./src/project.ts",
46
+ "./session": "./src/session.ts",
47
+ "./settings": "./src/settings.ts",
48
+ "./settings-ui": "./src/settings-ui.ts",
49
+ "./terminal": "./src/terminal.ts",
50
+ "./tool-framework": "./src/tool-framework.ts",
51
+ "./types": "./src/types.ts"
52
+ }
53
+ }
@@ -0,0 +1,30 @@
1
+ // supi-core — shared infrastructure for SuPi extensions.
2
+ // Provides XML context tag wrapping, unified config system, context-message utilities,
3
+ // settings registry for supi-wide TUI settings, and a shared tool-spec/registration framework.
4
+ //
5
+ // Convenience barrel — re-exports all domain entry points.
6
+ // For lighter imports, use one of the domain subpaths directly
7
+ // (e.g. @mrclrchtr/supi-core/config, @mrclrchtr/supi-core/context).
8
+
9
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
10
+ export * from "./config.ts";
11
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
12
+ export * from "./context.ts";
13
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
14
+ export * from "./debug-registry.ts";
15
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
16
+ export * from "./path.ts";
17
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
18
+ export * from "./project.ts";
19
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
20
+ export * from "./session.ts";
21
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
22
+ export * from "./settings.ts";
23
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
24
+ export * from "./settings-ui.ts";
25
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
26
+ export * from "./terminal.ts";
27
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
28
+ export * from "./tool-framework.ts";
29
+ // biome-ignore lint/performance/noReExportAll: intentional convenience barrel
30
+ export * from "./types.ts";
@@ -0,0 +1,76 @@
1
+ // Config-aware settings helper for SuPi config-backed settings sections.
2
+ // Wraps registerSettings() and centralizes selected-scope loading + scoped persistence.
3
+
4
+ import type { SettingItem } from "@earendil-works/pi-tui";
5
+ import type { SettingsScope } from "../settings/settings-registry.ts";
6
+ import { registerSettings } from "../settings/settings-registry.ts";
7
+ import { loadSupiConfigForScope, removeSupiConfigKey, writeSupiConfig } from "./config.ts";
8
+
9
+ export interface ConfigSettingsHelpers {
10
+ /** Write a key to the selected scope's config section. */
11
+ set(key: string, value: unknown): void;
12
+ /** Remove a key from the selected scope's config section. */
13
+ unset(key: string): void;
14
+ }
15
+
16
+ export interface ConfigSettingsOptions<T> {
17
+ /** Extension identifier — e.g. "lsp", "claude-md" */
18
+ id: string;
19
+ /** Human-readable label shown in the UI */
20
+ label: string;
21
+ /** SuPi config section name — e.g. "lsp", "claude-md" */
22
+ section: string;
23
+ /** Default config values */
24
+ defaults: T;
25
+ /** Build SettingItem[] from scoped config. Called by loadValues. */
26
+ buildItems: (settings: T, scope: SettingsScope, cwd: string) => SettingItem[];
27
+ /** Handle a settings change with scoped persistence helpers. */
28
+ persistChange: (
29
+ scope: SettingsScope,
30
+ cwd: string,
31
+ settingId: string,
32
+ value: string,
33
+ helpers: ConfigSettingsHelpers,
34
+ ) => void;
35
+ /** Optional home directory for config resolution (testing). */
36
+ homeDir?: string;
37
+ }
38
+
39
+ /**
40
+ * Register a config-backed settings section.
41
+ *
42
+ * Loads display values from the selected scope only (`defaults <- selected scope`)
43
+ * instead of merged effective runtime config. Provides scoped `set` / `unset`
44
+ * persistence helpers so extensions don't need to wire `writeSupiConfig` /
45
+ * `removeSupiConfigKey` by hand.
46
+ */
47
+ export function registerConfigSettings<T>(options: ConfigSettingsOptions<T>): void {
48
+ registerSettings({
49
+ id: options.id,
50
+ label: options.label,
51
+ loadValues: (scope, cwd) => {
52
+ const settings = loadSupiConfigForScope(options.section, cwd, options.defaults, {
53
+ scope,
54
+ homeDir: options.homeDir,
55
+ });
56
+ return options.buildItems(settings, scope, cwd);
57
+ },
58
+ persistChange: (scope, cwd, settingId, value) => {
59
+ const helpers: ConfigSettingsHelpers = {
60
+ set: (key, val) => {
61
+ writeSupiConfig(
62
+ { section: options.section, scope, cwd },
63
+ { [key]: val },
64
+ { homeDir: options.homeDir },
65
+ );
66
+ },
67
+ unset: (key) => {
68
+ removeSupiConfigKey({ section: options.section, scope, cwd }, key, {
69
+ homeDir: options.homeDir,
70
+ });
71
+ },
72
+ };
73
+ options.persistChange(scope, cwd, settingId, value, helpers);
74
+ },
75
+ });
76
+ }
@@ -0,0 +1,186 @@
1
+ // Shared config system for SuPi extensions.
2
+ //
3
+ // Global config: ~/.pi/agent/supi/config.json
4
+ // Project config: .pi/supi/config.json (relative to cwd)
5
+ // Resolution: hardcoded defaults ← global ← project
6
+
7
+ import * as fs from "node:fs";
8
+ import * as os from "node:os";
9
+ import * as path from "node:path";
10
+
11
+ const GLOBAL_CONFIG_DIR = ".pi/agent/supi";
12
+ const PROJECT_CONFIG_DIR = ".pi/supi";
13
+ const CONFIG_FILE = "config.json";
14
+
15
+ function getGlobalConfigPath(homeDir?: string): string {
16
+ return path.join(homeDir ?? os.homedir(), GLOBAL_CONFIG_DIR, CONFIG_FILE);
17
+ }
18
+
19
+ function getProjectConfigPath(cwd: string): string {
20
+ return path.join(cwd, PROJECT_CONFIG_DIR, CONFIG_FILE);
21
+ }
22
+
23
+ export function readJsonFile(filePath: string): Record<string, unknown> | null {
24
+ let content: string;
25
+ try {
26
+ content = fs.readFileSync(filePath, "utf-8");
27
+ } catch {
28
+ // ENOENT or permission error — silent, file may not exist
29
+ return null;
30
+ }
31
+
32
+ let parsed: unknown;
33
+ try {
34
+ parsed = JSON.parse(content);
35
+ } catch {
36
+ // biome-ignore lint/suspicious/noConsole: deliberate config parse warning
37
+ console.warn(`[supi-core] Failed to parse config file, ignoring: ${filePath}`);
38
+ return null;
39
+ }
40
+
41
+ if (typeof parsed === "object" && parsed !== null && !Array.isArray(parsed)) {
42
+ return parsed as Record<string, unknown>;
43
+ }
44
+
45
+ // biome-ignore lint/suspicious/noConsole: deliberate config parse warning
46
+ console.warn(`[supi-core] Config file root is not an object, ignoring: ${filePath}`);
47
+ return null;
48
+ }
49
+
50
+ function shallowMerge<T>(base: T, ...overrides: Array<Record<string, unknown> | null>): T {
51
+ let result = { ...base };
52
+ for (const override of overrides) {
53
+ if (!override) continue;
54
+ result = { ...result, ...override };
55
+ }
56
+ return result;
57
+ }
58
+
59
+ export interface SupiConfigOptions {
60
+ homeDir?: string;
61
+ }
62
+
63
+ /**
64
+ * Load and merge config for a given extension section.
65
+ *
66
+ * Resolution order: defaults ← global ← project
67
+ */
68
+ export function loadSupiConfig<T>(
69
+ section: string,
70
+ cwd: string,
71
+ defaults: T,
72
+ options?: SupiConfigOptions,
73
+ ): T {
74
+ const globalConfig = readJsonFile(getGlobalConfigPath(options?.homeDir));
75
+ const projectConfig = readJsonFile(getProjectConfigPath(cwd));
76
+
77
+ const globalSection = extractSection(globalConfig, section);
78
+ const projectSection = extractSection(projectConfig, section);
79
+
80
+ return shallowMerge(defaults, globalSection, projectSection);
81
+ }
82
+
83
+ /**
84
+ * Load config for a single scope only.
85
+ *
86
+ * Resolution order: defaults ← selected scope
87
+ *
88
+ * This is useful for settings UIs that need to show the raw values stored in
89
+ * one scope, rather than the effective merged config.
90
+ */
91
+ export function loadSupiConfigForScope<T>(
92
+ section: string,
93
+ cwd: string,
94
+ defaults: T,
95
+ options: { scope: "global" | "project" } & SupiConfigOptions,
96
+ ): T {
97
+ const config =
98
+ options.scope === "global"
99
+ ? readJsonFile(getGlobalConfigPath(options.homeDir))
100
+ : readJsonFile(getProjectConfigPath(cwd));
101
+
102
+ const scopedSection = extractSection(config, section);
103
+ return shallowMerge(defaults, scopedSection);
104
+ }
105
+
106
+ export interface SupiConfigLocation {
107
+ section: string;
108
+ scope: "global" | "project";
109
+ cwd: string;
110
+ }
111
+
112
+ /**
113
+ * Write config values for a given extension section.
114
+ */
115
+ export function writeSupiConfig(
116
+ loc: SupiConfigLocation,
117
+ value: Record<string, unknown>,
118
+ options?: SupiConfigOptions,
119
+ ): void {
120
+ const configPath =
121
+ loc.scope === "global" ? getGlobalConfigPath(options?.homeDir) : getProjectConfigPath(loc.cwd);
122
+
123
+ const dir = path.dirname(configPath);
124
+ fs.mkdirSync(dir, { recursive: true });
125
+
126
+ const existing = readJsonFile(configPath) ?? {};
127
+ existing[loc.section] = {
128
+ ...((existing[loc.section] as Record<string, unknown>) ?? {}),
129
+ ...value,
130
+ };
131
+
132
+ fs.writeFileSync(configPath, `${JSON.stringify(existing, null, 2)}\n`, "utf-8");
133
+ }
134
+
135
+ /**
136
+ * Remove a key from a config section.
137
+ * Used by `interval default` to remove the project override.
138
+ */
139
+ export function removeSupiConfigKey(
140
+ loc: SupiConfigLocation,
141
+ key: string,
142
+ options?: SupiConfigOptions,
143
+ ): void {
144
+ const configPath =
145
+ loc.scope === "global" ? getGlobalConfigPath(options?.homeDir) : getProjectConfigPath(loc.cwd);
146
+
147
+ const existing = readJsonFile(configPath);
148
+ if (!existing) return;
149
+
150
+ const sectionData = existing[loc.section] as Record<string, unknown> | undefined;
151
+ if (!sectionData) return;
152
+
153
+ delete sectionData[key];
154
+
155
+ if (Object.keys(sectionData).length === 0) {
156
+ delete existing[loc.section];
157
+ }
158
+
159
+ const dir = path.dirname(configPath);
160
+ fs.mkdirSync(dir, { recursive: true });
161
+
162
+ const content = Object.keys(existing).length > 0 ? `${JSON.stringify(existing, null, 2)}\n` : "";
163
+
164
+ if (content) {
165
+ // Directory guaranteed to exist since we just read from it
166
+ fs.writeFileSync(configPath, content, "utf-8");
167
+ } else {
168
+ try {
169
+ fs.unlinkSync(configPath);
170
+ } catch {
171
+ // File may not exist
172
+ }
173
+ }
174
+ }
175
+
176
+ function extractSection(
177
+ config: Record<string, unknown> | null,
178
+ section: string,
179
+ ): Record<string, unknown> | null {
180
+ if (!config) return null;
181
+ const data = config[section];
182
+ if (typeof data === "object" && data !== null && !Array.isArray(data)) {
183
+ return data as Record<string, unknown>;
184
+ }
185
+ return null;
186
+ }
@@ -0,0 +1,11 @@
1
+ // supi-core config domain — config loading and config-settings helpers.
2
+ export type { SupiConfigLocation, SupiConfigOptions } from "./config/config.ts";
3
+ export {
4
+ loadSupiConfig,
5
+ loadSupiConfigForScope,
6
+ readJsonFile,
7
+ removeSupiConfigKey,
8
+ writeSupiConfig,
9
+ } from "./config/config.ts";
10
+ export type { ConfigSettingsHelpers, ConfigSettingsOptions } from "./config/config-settings.ts";
11
+ export { registerConfigSettings } from "./config/config-settings.ts";
@@ -0,0 +1,119 @@
1
+ // Shared context-message utilities for SuPi extensions.
2
+ //
3
+ // Provides a generic prune-and-reorder pattern for extensions that inject
4
+ // managed context messages (via `before_agent_start` with a `customType` and
5
+ // `contextToken`) and maintain them via the `context` event.
6
+
7
+ /**
8
+ * Minimal message shape needed for context-message operations.
9
+ * Extensions cast their event.messages entries to this type.
10
+ */
11
+ export type ContextMessageLike = {
12
+ role?: string;
13
+ customType?: string;
14
+ content?: unknown;
15
+ details?: unknown;
16
+ };
17
+
18
+ /**
19
+ * Extract the `contextToken` string from a message's `details` object.
20
+ * Returns `null` when the token is absent or not a string.
21
+ */
22
+ export function getContextToken(details: unknown): string | null {
23
+ if (!details || typeof details !== "object") return null;
24
+ const token = (details as { contextToken?: unknown }).contextToken;
25
+ return typeof token === "string" ? token : null;
26
+ }
27
+
28
+ /**
29
+ * Find the index of the last message with `role: "user"`.
30
+ * Returns `-1` when no user message exists.
31
+ */
32
+ export function findLastUserMessageIndex<T extends ContextMessageLike>(messages: T[]): number {
33
+ for (let index = messages.length - 1; index >= 0; index--) {
34
+ if (messages[index]?.role === "user") return index;
35
+ }
36
+ return -1;
37
+ }
38
+
39
+ /**
40
+ * Filter stale context messages and reorder the active one before the last user message.
41
+ *
42
+ * - Removes all messages matching `customType` whose token differs from `activeToken`.
43
+ * - When `activeToken` is `null`, removes **all** messages of that `customType`.
44
+ * - If the active context message is after the last user message, moves it before.
45
+ *
46
+ * Returns the modified array, or the original reference when no changes were needed.
47
+ */
48
+ export function pruneAndReorderContextMessages<T extends ContextMessageLike>(
49
+ messages: T[],
50
+ customType: string,
51
+ activeToken: string | null,
52
+ ): T[] {
53
+ // Remove stale messages of the target customType
54
+ const filtered = messages.filter((message) => {
55
+ if (message.customType !== customType) return true;
56
+ if (!activeToken) return false;
57
+ return getContextToken(message.details) === activeToken;
58
+ });
59
+
60
+ if (!activeToken) return filtered;
61
+
62
+ // Find the active context message
63
+ const contextIndex = filtered.findIndex(
64
+ (message) =>
65
+ message.customType === customType && getContextToken(message.details) === activeToken,
66
+ );
67
+ if (contextIndex === -1) return filtered;
68
+
69
+ // Find the last user message
70
+ const userIndex = findLastUserMessageIndex(filtered);
71
+ if (userIndex === -1 || contextIndex < userIndex) return filtered;
72
+
73
+ // Move context message before last user message
74
+ const next = [...filtered];
75
+ const [contextMessage] = next.splice(contextIndex, 1);
76
+ if (!contextMessage) return filtered;
77
+ next.splice(userIndex, 0, contextMessage);
78
+ return next;
79
+ }
80
+
81
+ /**
82
+ * Restore the raw prompt content on a context message that was swapped for display text.
83
+ *
84
+ * Extensions using `registerMessageRenderer` store their LLM-facing content in
85
+ * `details.promptContent` and put a human-readable summary in `content`. This function
86
+ * reverses the swap so the model sees the original prompt content.
87
+ *
88
+ * Returns the original array reference when no change is needed.
89
+ */
90
+ export function restorePromptContent<T extends ContextMessageLike>(
91
+ messages: T[],
92
+ customType: string,
93
+ activeToken: string | null,
94
+ ): T[] {
95
+ if (!activeToken) return messages;
96
+
97
+ const index = messages.findIndex(
98
+ (message) =>
99
+ message.customType === customType && getContextToken(message.details) === activeToken,
100
+ );
101
+ if (index === -1) return messages;
102
+
103
+ const promptContent = getPromptContent(messages[index]?.details);
104
+ if (!promptContent || messages[index]?.content === promptContent) return messages;
105
+
106
+ const next = [...messages];
107
+ next[index] = { ...next[index], content: promptContent };
108
+ return next;
109
+ }
110
+
111
+ /**
112
+ * Extract the `promptContent` string from a message's `details` object.
113
+ * Returns `null` when absent or not a string.
114
+ */
115
+ export function getPromptContent(details: unknown): string | null {
116
+ if (!details || typeof details !== "object") return null;
117
+ const promptContent = (details as { promptContent?: unknown }).promptContent;
118
+ return typeof promptContent === "string" ? promptContent : null;
119
+ }