@jingyi0605/codingns 0.8.1 → 0.8.5

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 (249) hide show
  1. package/bin/codingns.mjs +180 -0
  2. package/dist/public/assets/{AdaptiveButlerPage-b7s6F_sd.js → AdaptiveButlerPage-CJw8Ae62.js} +3 -3
  3. package/dist/public/assets/App-BOHBGFOd.js +30 -0
  4. package/dist/public/assets/{BootstrapPage-jFfl7KNK.js → BootstrapPage-BxHQT4nA.js} +1 -1
  5. package/dist/public/assets/{ConversationPage-sj_rn4q0.js → ConversationPage-DWFsF6BB.js} +6 -6
  6. package/dist/public/assets/{DesktopDetachPreviewPage-C5c88SOX.js → DesktopDetachPreviewPage-DOgEjYEf.js} +1 -1
  7. package/dist/public/assets/DesktopModal-D_A8sgQU.js +1 -0
  8. package/dist/public/assets/DesktopWindowPage-DK7L7osV.js +2 -0
  9. package/dist/public/assets/FileContextPanel-BdCoubcJ.js +1 -0
  10. package/dist/public/assets/GitSidebar-BeZ0hj7A.js +6 -0
  11. package/dist/public/assets/MobileCreateSessionSheet-DfLMVu8q.js +1 -0
  12. package/dist/public/assets/MobileSheet-5kZ-w-gU.js +1 -0
  13. package/dist/public/assets/{MobileTopHeaderFrame-_I0t7cC_.js → MobileTopHeaderFrame-lcp2GscV.js} +1 -1
  14. package/dist/public/assets/MobileWorkspaceSwitcherHeader-C6JMiOq_.js +1 -0
  15. package/dist/public/assets/PluginAccessOverview-DGcKAMQl.js +1 -0
  16. package/dist/public/assets/PluginContainerPage-BlY-xJDh.js +1 -0
  17. package/dist/public/assets/PluginDetailPage-CAJ7LFpD.js +1 -0
  18. package/dist/public/assets/PluginsListPage-BxZG1NyT.js +1 -0
  19. package/dist/public/assets/{RelayConnectEntryPage-CMtDWyGS.js → RelayConnectEntryPage-CfNO_TIl.js} +1 -1
  20. package/dist/public/assets/ServerSettingsModal-by36Z_5k.js +1 -0
  21. package/dist/public/assets/SessionIndexPage-DkBp9Mqz.js +1 -0
  22. package/dist/public/assets/SettingsPage-C-ASmJAG.js +2 -0
  23. package/dist/public/assets/TerminalManagerPanel-NVZRxxmH.js +1 -0
  24. package/dist/public/assets/{TerminalPage-CBIKHI33.js → TerminalPage-C4LNoPBp.js} +3 -3
  25. package/dist/public/assets/TerminalRuntimeFallbackModal-Bzum5nZ0.js +1 -0
  26. package/dist/public/assets/ToolFilesPage-47zbdgTW.js +1 -0
  27. package/dist/public/assets/ToolGitPage-Fuk_b_jg.js +1 -0
  28. package/dist/public/assets/ToolProcessesPage-sWSMWD-9.js +1 -0
  29. package/dist/public/assets/ToolsHomePage-R1mZlbZi.js +1 -0
  30. package/dist/public/assets/WorkbenchLandingPage-CqmiFH2u.js +1 -0
  31. package/dist/public/assets/WorkbenchLayout-OFi6CWgH.js +244 -0
  32. package/dist/public/assets/WorkbenchModal-C7qoQElW.js +1 -0
  33. package/dist/public/assets/WorkbenchShellRoute-BAQe_E0O.js +1 -0
  34. package/dist/public/assets/WorkspaceDebugDetailPage-DhKa6e9y.js +1 -0
  35. package/dist/public/assets/WorkspaceDetailPage-BPsrFffw.js +1 -0
  36. package/dist/public/assets/WorkspaceHomePage-KAtqZOAb.js +1 -0
  37. package/dist/public/assets/{client-runtime-manager-CdJP7nUp.js → client-runtime-manager-wmCJZKYd.js} +1 -1
  38. package/dist/public/assets/file-tree-icon-Mg1DiBRX.js +590 -0
  39. package/dist/public/assets/{index-VVxfF0s5.css → index-C4t-vvqk.css} +1 -1
  40. package/dist/public/assets/index-CL97fwWB.js +42 -0
  41. package/dist/public/assets/{login-direct-candidate-resolver-C-mo698r.js → login-direct-candidate-resolver-BOAgTuUf.js} +1 -1
  42. package/dist/public/assets/plugin-permission-copy-Cq99cnzV.js +1 -0
  43. package/dist/public/assets/plugins-api-BQTV5DOp.js +1 -0
  44. package/dist/public/assets/{preferences-service-CnaTvZq2.js → preferences-service-DJxbEEeg.js} +1 -1
  45. package/dist/public/assets/realtime-client-CLafKzzJ.js +1 -0
  46. package/dist/public/assets/{relay-entry-D7OgZZN-.js → relay-entry-D-LfvdiX.js} +1 -1
  47. package/dist/public/assets/{terminal-runtime-meta-BCtAYB0E.js → terminal-runtime-meta-BJmy8dyK.js} +1 -1
  48. package/dist/public/assets/useRegisteredDebugTemplates-DQAWVdCo.js +1 -0
  49. package/dist/public/assets/workbench-navigation-MEzCSmsK.js +1 -0
  50. package/dist/public/index.html +2 -2
  51. package/dist/server/config/env.d.ts +1 -0
  52. package/dist/server/config/env.js +4 -0
  53. package/dist/server/config/env.js.map +1 -1
  54. package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js +1 -1
  55. package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js.map +1 -1
  56. package/dist/server/modules/channels/wechat-claw-client.d.ts +51 -0
  57. package/dist/server/modules/channels/wechat-claw-client.js +245 -0
  58. package/dist/server/modules/channels/wechat-claw-client.js.map +1 -0
  59. package/dist/server/modules/file/file-access-guard.d.ts +2 -0
  60. package/dist/server/modules/file/file-access-guard.js +24 -2
  61. package/dist/server/modules/file/file-access-guard.js.map +1 -1
  62. package/dist/server/modules/file/file-controller.d.ts +153 -1
  63. package/dist/server/modules/file/file-controller.js +215 -1
  64. package/dist/server/modules/file/file-controller.js.map +1 -1
  65. package/dist/server/modules/file/file-preview-link-service.d.ts +2 -0
  66. package/dist/server/modules/file/file-preview-link-service.js +5 -1
  67. package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
  68. package/dist/server/modules/file/runtime/codingns-workspace-bridge.js +911 -0
  69. package/dist/server/modules/file/workspace-file-bridge-service.d.ts +126 -0
  70. package/dist/server/modules/file/workspace-file-bridge-service.js +471 -0
  71. package/dist/server/modules/file/workspace-file-bridge-service.js.map +1 -0
  72. package/dist/server/modules/file/workspace-file-bridge-watch-service.d.ts +42 -0
  73. package/dist/server/modules/file/workspace-file-bridge-watch-service.js +304 -0
  74. package/dist/server/modules/file/workspace-file-bridge-watch-service.js.map +1 -0
  75. package/dist/server/modules/model-switch/cc-switch-adapter.js +1 -1
  76. package/dist/server/modules/model-switch/cc-switch-adapter.js.map +1 -1
  77. package/dist/server/modules/plugins/plugin-controller.d.ts +131 -0
  78. package/dist/server/modules/plugins/plugin-controller.js +277 -0
  79. package/dist/server/modules/plugins/plugin-controller.js.map +1 -0
  80. package/dist/server/modules/plugins/plugin-file-gateway-service.d.ts +38 -0
  81. package/dist/server/modules/plugins/plugin-file-gateway-service.js +178 -0
  82. package/dist/server/modules/plugins/plugin-file-gateway-service.js.map +1 -0
  83. package/dist/server/modules/plugins/plugin-manifest.d.ts +8 -0
  84. package/dist/server/modules/plugins/plugin-manifest.js +420 -0
  85. package/dist/server/modules/plugins/plugin-manifest.js.map +1 -0
  86. package/dist/server/modules/plugins/plugin-permission-service.d.ts +49 -0
  87. package/dist/server/modules/plugins/plugin-permission-service.js +267 -0
  88. package/dist/server/modules/plugins/plugin-permission-service.js.map +1 -0
  89. package/dist/server/modules/plugins/plugin-process-runner.d.ts +21 -0
  90. package/dist/server/modules/plugins/plugin-process-runner.js +127 -0
  91. package/dist/server/modules/plugins/plugin-process-runner.js.map +1 -0
  92. package/dist/server/modules/plugins/plugin-registry-service.d.ts +41 -0
  93. package/dist/server/modules/plugins/plugin-registry-service.js +238 -0
  94. package/dist/server/modules/plugins/plugin-registry-service.js.map +1 -0
  95. package/dist/server/modules/plugins/plugin-runtime-service.d.ts +55 -0
  96. package/dist/server/modules/plugins/plugin-runtime-service.js +252 -0
  97. package/dist/server/modules/plugins/plugin-runtime-service.js.map +1 -0
  98. package/dist/server/modules/plugins/plugin-runtime-session-service.d.ts +21 -0
  99. package/dist/server/modules/plugins/plugin-runtime-session-service.js +83 -0
  100. package/dist/server/modules/plugins/plugin-runtime-session-service.js.map +1 -0
  101. package/dist/server/modules/plugins/plugin-scheduler-service.d.ts +31 -0
  102. package/dist/server/modules/plugins/plugin-scheduler-service.js +232 -0
  103. package/dist/server/modules/plugins/plugin-scheduler-service.js.map +1 -0
  104. package/dist/server/modules/plugins/plugin-static-service.d.ts +11 -0
  105. package/dist/server/modules/plugins/plugin-static-service.js +145 -0
  106. package/dist/server/modules/plugins/plugin-static-service.js.map +1 -0
  107. package/dist/server/modules/presentation/presentation-controller.d.ts +3 -0
  108. package/dist/server/modules/presentation/presentation-controller.js +11 -0
  109. package/dist/server/modules/presentation/presentation-controller.js.map +1 -1
  110. package/dist/server/modules/presentation/presentation-export-task-service.d.ts +6 -0
  111. package/dist/server/modules/presentation/presentation-export-task-service.js +52 -8
  112. package/dist/server/modules/presentation/presentation-export-task-service.js.map +1 -1
  113. package/dist/server/modules/presentation/presentation-pptx-export-service.js +200 -14
  114. package/dist/server/modules/presentation/presentation-pptx-export-service.js.map +1 -1
  115. package/dist/server/modules/presentation/presentation-renderer.d.ts +50 -0
  116. package/dist/server/modules/presentation/presentation-renderer.js +450 -37
  117. package/dist/server/modules/presentation/presentation-renderer.js.map +1 -1
  118. package/dist/server/modules/tasks/task-types.d.ts +2 -0
  119. package/dist/server/modules/tasks/task-types.js +2 -0
  120. package/dist/server/modules/tasks/task-types.js.map +1 -1
  121. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js +1 -1
  122. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js.map +1 -1
  123. package/dist/server/routes/files.js +40 -0
  124. package/dist/server/routes/files.js.map +1 -1
  125. package/dist/server/routes/plugins-public.d.ts +3 -0
  126. package/dist/server/routes/plugins-public.js +5 -0
  127. package/dist/server/routes/plugins-public.js.map +1 -0
  128. package/dist/server/routes/plugins.d.ts +3 -0
  129. package/dist/server/routes/plugins.js +19 -0
  130. package/dist/server/routes/plugins.js.map +1 -0
  131. package/dist/server/routes/presentation.js +1 -0
  132. package/dist/server/routes/presentation.js.map +1 -1
  133. package/dist/server/server/create-server.d.ts +20 -0
  134. package/dist/server/server/create-server.js +47 -1
  135. package/dist/server/server/create-server.js.map +1 -1
  136. package/dist/server/shared/http/error-handler.js +10 -6
  137. package/dist/server/shared/http/error-handler.js.map +1 -1
  138. package/dist/server/shared/runtime/better-sqlite3.d.ts +5 -0
  139. package/dist/server/shared/runtime/better-sqlite3.js +6 -0
  140. package/dist/server/shared/runtime/better-sqlite3.js.map +1 -0
  141. package/dist/server/storage/repositories/plugin-audit-event-repository.d.ts +8 -0
  142. package/dist/server/storage/repositories/plugin-audit-event-repository.js +49 -0
  143. package/dist/server/storage/repositories/plugin-audit-event-repository.js.map +1 -0
  144. package/dist/server/storage/repositories/plugin-definition-repository.d.ts +10 -0
  145. package/dist/server/storage/repositories/plugin-definition-repository.js +84 -0
  146. package/dist/server/storage/repositories/plugin-definition-repository.js.map +1 -0
  147. package/dist/server/storage/repositories/plugin-enablement-repository.d.ts +9 -0
  148. package/dist/server/storage/repositories/plugin-enablement-repository.js +74 -0
  149. package/dist/server/storage/repositories/plugin-enablement-repository.js.map +1 -0
  150. package/dist/server/storage/repositories/plugin-permission-grant-repository.d.ts +12 -0
  151. package/dist/server/storage/repositories/plugin-permission-grant-repository.js +142 -0
  152. package/dist/server/storage/repositories/plugin-permission-grant-repository.js.map +1 -0
  153. package/dist/server/storage/repositories/plugin-run-repository.d.ts +10 -0
  154. package/dist/server/storage/repositories/plugin-run-repository.js +111 -0
  155. package/dist/server/storage/repositories/plugin-run-repository.js.map +1 -0
  156. package/dist/server/storage/repositories/plugin-runtime-session-repository.d.ts +10 -0
  157. package/dist/server/storage/repositories/plugin-runtime-session-repository.js +86 -0
  158. package/dist/server/storage/repositories/plugin-runtime-session-repository.js.map +1 -0
  159. package/dist/server/storage/sqlite/client.d.ts +2 -2
  160. package/dist/server/storage/sqlite/client.js +250 -1
  161. package/dist/server/storage/sqlite/client.js.map +1 -1
  162. package/dist/server/storage/sqlite/schema.sql +140 -0
  163. package/dist/server/types/domain.d.ts +122 -0
  164. package/package.json +10 -3
  165. package/scripts/postinstall.mjs +248 -11
  166. package/vendor/better-sqlite3-win32-x64-node22/LICENSE +21 -0
  167. package/vendor/better-sqlite3-win32-x64-node22/README.md +12 -0
  168. package/vendor/better-sqlite3-win32-x64-node22/README.upstream.md +99 -0
  169. package/vendor/better-sqlite3-win32-x64-node22/binding.gyp +38 -0
  170. package/vendor/better-sqlite3-win32-x64-node22/build/Release/better_sqlite3.node +0 -0
  171. package/vendor/better-sqlite3-win32-x64-node22/deps/common.gypi +68 -0
  172. package/vendor/better-sqlite3-win32-x64-node22/deps/copy.js +31 -0
  173. package/vendor/better-sqlite3-win32-x64-node22/deps/defines.gypi +41 -0
  174. package/vendor/better-sqlite3-win32-x64-node22/deps/download.sh +122 -0
  175. package/vendor/better-sqlite3-win32-x64-node22/deps/patches/1208.patch +15 -0
  176. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3.c +265994 -0
  177. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3.h +13968 -0
  178. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3ext.h +730 -0
  179. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3.gyp +80 -0
  180. package/vendor/better-sqlite3-win32-x64-node22/deps/test_extension.c +21 -0
  181. package/vendor/better-sqlite3-win32-x64-node22/lib/database.js +90 -0
  182. package/vendor/better-sqlite3-win32-x64-node22/lib/index.js +3 -0
  183. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/aggregate.js +43 -0
  184. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/backup.js +67 -0
  185. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/function.js +31 -0
  186. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/inspect.js +7 -0
  187. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/pragma.js +12 -0
  188. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/serialize.js +16 -0
  189. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/table.js +189 -0
  190. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/transaction.js +78 -0
  191. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/wrappers.js +54 -0
  192. package/vendor/better-sqlite3-win32-x64-node22/lib/sqlite-error.js +20 -0
  193. package/vendor/better-sqlite3-win32-x64-node22/lib/util.js +12 -0
  194. package/vendor/better-sqlite3-win32-x64-node22/package.json +38 -0
  195. package/vendor/better-sqlite3-win32-x64-node22/scripts/verify-runtime.cjs +42 -0
  196. package/vendor/better-sqlite3-win32-x64-node22/src/addon.cpp +47 -0
  197. package/vendor/better-sqlite3-win32-x64-node22/src/better_sqlite3.cpp +74 -0
  198. package/vendor/better-sqlite3-win32-x64-node22/src/objects/backup.cpp +120 -0
  199. package/vendor/better-sqlite3-win32-x64-node22/src/objects/backup.hpp +36 -0
  200. package/vendor/better-sqlite3-win32-x64-node22/src/objects/database.cpp +417 -0
  201. package/vendor/better-sqlite3-win32-x64-node22/src/objects/database.hpp +103 -0
  202. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement-iterator.cpp +113 -0
  203. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement-iterator.hpp +50 -0
  204. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement.cpp +383 -0
  205. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement.hpp +58 -0
  206. package/vendor/better-sqlite3-win32-x64-node22/src/util/bind-map.cpp +73 -0
  207. package/vendor/better-sqlite3-win32-x64-node22/src/util/binder.cpp +193 -0
  208. package/vendor/better-sqlite3-win32-x64-node22/src/util/constants.cpp +172 -0
  209. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-aggregate.cpp +121 -0
  210. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-function.cpp +59 -0
  211. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-table.cpp +409 -0
  212. package/vendor/better-sqlite3-win32-x64-node22/src/util/data-converter.cpp +17 -0
  213. package/vendor/better-sqlite3-win32-x64-node22/src/util/data.cpp +194 -0
  214. package/vendor/better-sqlite3-win32-x64-node22/src/util/helpers.cpp +109 -0
  215. package/vendor/better-sqlite3-win32-x64-node22/src/util/macros.cpp +83 -0
  216. package/vendor/better-sqlite3-win32-x64-node22/src/util/query-macros.cpp +71 -0
  217. package/vendor/better-sqlite3-win32-x64-node22/src/util/row-builder.cpp +49 -0
  218. package/vendor/node-pty-fork/README.md +1 -0
  219. package/vendor/node-pty-fork/scripts/runtime-install-context.cjs +24 -0
  220. package/vendor/node-pty-fork/scripts/verify-runtime.cjs +8 -0
  221. package/vendor/node-pty-fork/scripts/verify-runtime.test.cjs +30 -0
  222. package/vendor-src/better-sqlite3-win32-x64-node22/README.md +12 -0
  223. package/dist/public/assets/App-B0q8uDA-.js +0 -30
  224. package/dist/public/assets/DesktopWindowPage-BdKUZrKG.js +0 -2
  225. package/dist/public/assets/FileContextPanel-lM5mBcfn.js +0 -1
  226. package/dist/public/assets/GitSidebar-CmXAhyjo.js +0 -6
  227. package/dist/public/assets/MobileCreateSessionSheet-CceV0-AH.js +0 -1
  228. package/dist/public/assets/MobileWorkspaceSwitcherHeader-DhaM9fgx.js +0 -1
  229. package/dist/public/assets/ServerSettingsModal-Rkgn3jft.js +0 -1
  230. package/dist/public/assets/SessionIndexPage-BOumP3ij.js +0 -1
  231. package/dist/public/assets/SettingsPage-vx_c-00-.js +0 -2
  232. package/dist/public/assets/TerminalManagerPanel-D9JHCS6d.js +0 -1
  233. package/dist/public/assets/TerminalRuntimeFallbackModal-W5NjqFEz.js +0 -1
  234. package/dist/public/assets/ToolFilesPage-DWtpaN_7.js +0 -1
  235. package/dist/public/assets/ToolGitPage-MpGXsw4_.js +0 -1
  236. package/dist/public/assets/ToolProcessesPage-B1jHQKhZ.js +0 -1
  237. package/dist/public/assets/ToolsHomePage-CJrn8ZFl.js +0 -1
  238. package/dist/public/assets/WorkbenchLandingPage-CJQ1V5U-.js +0 -1
  239. package/dist/public/assets/WorkbenchLayout-D48i71PU.js +0 -244
  240. package/dist/public/assets/WorkbenchModal-BYNuMIoV.js +0 -1
  241. package/dist/public/assets/WorkbenchShellRoute-CGKjy4J-.js +0 -1
  242. package/dist/public/assets/WorkspaceDebugDetailPage-DCAYgays.js +0 -1
  243. package/dist/public/assets/WorkspaceDetailPage-D5v-nUIi.js +0 -1
  244. package/dist/public/assets/WorkspaceHomePage-I5G1p5SR.js +0 -1
  245. package/dist/public/assets/file-tree-icon-BFwaPxKs.js +0 -590
  246. package/dist/public/assets/index-CjewzOUG.js +0 -42
  247. package/dist/public/assets/model-switch-api-Br0ivfe5.js +0 -1
  248. package/dist/public/assets/realtime-client-BlQRqVmm.js +0 -1
  249. package/dist/public/assets/useRegisteredDebugTemplates-CXmxu69X.js +0 -1
@@ -0,0 +1,109 @@
1
+ inline v8::Local<v8::String> StringFromUtf8(v8::Isolate* isolate, const char* data, int length) {
2
+ return v8::String::NewFromUtf8(isolate, data, v8::NewStringType::kNormal, length).ToLocalChecked();
3
+ }
4
+
5
+ inline v8::Local<v8::String> InternalizedFromUtf8(v8::Isolate* isolate, const char* data, int length) {
6
+ return v8::String::NewFromUtf8(isolate, data, v8::NewStringType::kInternalized, length).ToLocalChecked();
7
+ }
8
+
9
+ inline v8::Local<v8::Value> InternalizedFromUtf8OrNull(v8::Isolate* isolate, const char* data, int length) {
10
+ if (data == NULL) return v8::Null(isolate);
11
+ return InternalizedFromUtf8(isolate, data, length);
12
+ }
13
+
14
+ inline v8::Local<v8::String> InternalizedFromLatin1(v8::Isolate* isolate, const char* str) {
15
+ return v8::String::NewFromOneByte(isolate, reinterpret_cast<const uint8_t*>(str), v8::NewStringType::kInternalized).ToLocalChecked();
16
+ }
17
+
18
+ inline void SetFrozen(v8::Isolate* isolate, v8::Local<v8::Context> ctx, v8::Local<v8::Object> obj, v8::Global<v8::String>& key, v8::Local<v8::Value> value) {
19
+ obj->DefineOwnProperty(ctx, key.Get(isolate), value, static_cast<v8::PropertyAttribute>(v8::DontDelete | v8::ReadOnly)).FromJust();
20
+ }
21
+
22
+ void ThrowError(const char* message) { EasyIsolate; isolate->ThrowException(v8::Exception::Error(StringFromUtf8(isolate, message, -1))); }
23
+ void ThrowTypeError(const char* message) { EasyIsolate; isolate->ThrowException(v8::Exception::TypeError(StringFromUtf8(isolate, message, -1))); }
24
+ void ThrowRangeError(const char* message) { EasyIsolate; isolate->ThrowException(v8::Exception::RangeError(StringFromUtf8(isolate, message, -1))); }
25
+
26
+ // Determines whether to skip the given character at the start of an SQL string.
27
+ inline bool IS_SKIPPED(char c) {
28
+ return c == ' ' || c == ';' || (c >= '\t' && c <= '\r');
29
+ }
30
+
31
+ // Allocates an empty array, without calling constructors/initializers.
32
+ template<class T> inline T* ALLOC_ARRAY(size_t count) {
33
+ return static_cast<T*>(::operator new[](count * sizeof(T)));
34
+ }
35
+
36
+ // Deallocates an array, without calling destructors.
37
+ template<class T> inline void FREE_ARRAY(T* array_pointer) {
38
+ ::operator delete[](array_pointer);
39
+ }
40
+
41
+ v8::Local<v8::FunctionTemplate> NewConstructorTemplate(
42
+ v8::Isolate* isolate,
43
+ v8::Local<v8::External> data,
44
+ v8::FunctionCallback func,
45
+ const char* name
46
+ ) {
47
+ v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(isolate, func, data);
48
+ t->InstanceTemplate()->SetInternalFieldCount(1);
49
+ t->SetClassName(InternalizedFromLatin1(isolate, name));
50
+ return t;
51
+ }
52
+
53
+ void SetPrototypeMethod(
54
+ v8::Isolate* isolate,
55
+ v8::Local<v8::External> data,
56
+ v8::Local<v8::FunctionTemplate> recv,
57
+ const char* name,
58
+ v8::FunctionCallback func
59
+ ) {
60
+ v8::HandleScope scope(isolate);
61
+ recv->PrototypeTemplate()->Set(
62
+ InternalizedFromLatin1(isolate, name),
63
+ v8::FunctionTemplate::New(isolate, func, data, v8::Signature::New(isolate, recv))
64
+ );
65
+ }
66
+
67
+ void SetPrototypeSymbolMethod(
68
+ v8::Isolate* isolate,
69
+ v8::Local<v8::External> data,
70
+ v8::Local<v8::FunctionTemplate> recv,
71
+ v8::Local<v8::Symbol> symbol,
72
+ v8::FunctionCallback func
73
+ ) {
74
+ v8::HandleScope scope(isolate);
75
+ recv->PrototypeTemplate()->Set(
76
+ symbol,
77
+ v8::FunctionTemplate::New(isolate, func, data, v8::Signature::New(isolate, recv))
78
+ );
79
+ }
80
+
81
+ void SetPrototypeGetter(
82
+ v8::Isolate* isolate,
83
+ v8::Local<v8::External> data,
84
+ v8::Local<v8::FunctionTemplate> recv,
85
+ const char* name,
86
+ v8::AccessorNameGetterCallback func
87
+ ) {
88
+ v8::HandleScope scope(isolate);
89
+ recv->InstanceTemplate()->SetNativeDataProperty(
90
+ InternalizedFromLatin1(isolate, name),
91
+ func,
92
+ 0,
93
+ data
94
+ );
95
+ }
96
+
97
+ #if defined(V8_ENABLE_SANDBOX)
98
+ // When V8 Sandbox is enabled (in newer Electron versions), we need to use Buffer::Copy
99
+ // instead of Buffer::New to ensure the ArrayBuffer backing store is allocated inside the sandbox
100
+ static inline v8::MaybeLocal<v8::Object> BufferSandboxNew(v8::Isolate* isolate, char* data, size_t length, void (*finalizeCallback)(char*, void*), void* finalizeHint) {
101
+ v8::MaybeLocal<v8::Object> buffer = node::Buffer::Copy(isolate, data, length);
102
+ finalizeCallback(data, finalizeHint);
103
+ return buffer;
104
+ }
105
+ #define SAFE_NEW_BUFFER(env, data, length, finalizeCallback, finalizeHint) BufferSandboxNew(env, data, length, finalizeCallback, finalizeHint)
106
+ #else
107
+ // When V8 Sandbox is not enabled, we can use the more efficient Buffer::New
108
+ #define SAFE_NEW_BUFFER(env, data, length, finalizeCallback, finalizeHint) node::Buffer::New(env, data, length, finalizeCallback, finalizeHint)
109
+ #endif
@@ -0,0 +1,83 @@
1
+ #define NODE_ARGUMENTS const v8::FunctionCallbackInfo<v8::Value>&
2
+ #define NODE_ARGUMENTS_POINTER const v8::FunctionCallbackInfo<v8::Value>*
3
+ #define NODE_METHOD(name) void name(NODE_ARGUMENTS info)
4
+ #define NODE_GETTER(name) void name(v8::Local<v8::Name> _, const v8::PropertyCallbackInfo<v8::Value>& info)
5
+ #define INIT(name) v8::Local<v8::Function> name(v8::Isolate* isolate, v8::Local<v8::External> data)
6
+
7
+ #if defined(V8_MAJOR_VERSION) && V8_MAJOR_VERSION >= 13
8
+ // v8::Object::GetPrototype has been deprecated. See http://crbug.com/333672197
9
+ #define GET_PROTOTYPE(obj) ((obj)->GetPrototypeV2())
10
+ #else
11
+ #define GET_PROTOTYPE(obj) ((obj)->GetPrototype())
12
+ #endif
13
+
14
+ // PropertyCallbackInfo::This() and Holder() were removed; use HolderV2().
15
+ // Tracking bug for V8 API removals: http://crbug.com/333672197
16
+ // V8 head has since restored Holder() and deprecated HolderV2():
17
+ // https://chromium.googlesource.com/v8/v8/+/main/include/v8-function-callback.h
18
+ // V8_INLINE Local<Object> Holder() const;
19
+ // V8_DEPRECATE_SOON("Use Holder().")
20
+ // V8_INLINE Local<Object> HolderV2() const;
21
+ #if defined(V8_MAJOR_VERSION) && V8_MAJOR_VERSION >= 13
22
+ #define PROPERTY_HOLDER(info) (info).HolderV2()
23
+ #else
24
+ #define PROPERTY_HOLDER(info) (info).This()
25
+ #endif
26
+
27
+ #define EasyIsolate v8::Isolate* isolate = v8::Isolate::GetCurrent()
28
+ #define OnlyIsolate info.GetIsolate()
29
+ #define OnlyContext isolate->GetCurrentContext()
30
+ #define OnlyAddon static_cast<Addon*>(info.Data().As<v8::External>()->Value())
31
+ #define UseIsolate v8::Isolate* isolate = OnlyIsolate
32
+ #define UseContext v8::Local<v8::Context> ctx = OnlyContext
33
+ #define UseAddon Addon* addon = OnlyAddon
34
+ #define Unwrap node::ObjectWrap::Unwrap
35
+
36
+ #define REQUIRE_ARGUMENT_ANY(at, var) \
37
+ if (info.Length() <= (at())) \
38
+ return ThrowTypeError("Expected a "#at" argument"); \
39
+ var = info[at()]
40
+
41
+ #define _REQUIRE_ARGUMENT(at, var, Type, message, ...) \
42
+ if (info.Length() <= (at()) || !info[at()]->Is##Type()) \
43
+ return ThrowTypeError("Expected "#at" argument to be "#message); \
44
+ var = (info[at()].As<v8::Type>())__VA_ARGS__
45
+
46
+ #define REQUIRE_ARGUMENT_INT32(at, var) \
47
+ _REQUIRE_ARGUMENT(at, var, Int32, a 32-bit signed integer, ->Value())
48
+ #define REQUIRE_ARGUMENT_BOOLEAN(at, var) \
49
+ _REQUIRE_ARGUMENT(at, var, Boolean, a boolean, ->Value())
50
+ #define REQUIRE_ARGUMENT_STRING(at, var) \
51
+ _REQUIRE_ARGUMENT(at, var, String, a string)
52
+ #define REQUIRE_ARGUMENT_OBJECT(at, var) \
53
+ _REQUIRE_ARGUMENT(at, var, Object, an object)
54
+ #define REQUIRE_ARGUMENT_FUNCTION(at, var) \
55
+ _REQUIRE_ARGUMENT(at, var, Function, a function)
56
+
57
+ #define REQUIRE_DATABASE_OPEN(db) \
58
+ if (!db->open) \
59
+ return ThrowTypeError("The database connection is not open")
60
+ #define REQUIRE_DATABASE_NOT_BUSY(db) \
61
+ if (db->busy) \
62
+ return ThrowTypeError("This database connection is busy executing a query")
63
+ #define REQUIRE_DATABASE_NO_ITERATORS(db) \
64
+ if (db->iterators) \
65
+ return ThrowTypeError("This database connection is busy executing a query")
66
+ #define REQUIRE_DATABASE_NO_ITERATORS_UNLESS_UNSAFE(db) \
67
+ if (!db->unsafe_mode) { \
68
+ REQUIRE_DATABASE_NO_ITERATORS(db); \
69
+ } ((void)0)
70
+ #define REQUIRE_STATEMENT_NOT_LOCKED(stmt) \
71
+ if (stmt->locked) \
72
+ return ThrowTypeError("This statement is busy executing a query")
73
+
74
+ #define first() 0
75
+ #define second() 1
76
+ #define third() 2
77
+ #define fourth() 3
78
+ #define fifth() 4
79
+ #define sixth() 5
80
+ #define seventh() 6
81
+ #define eighth() 7
82
+ #define ninth() 8
83
+ #define tenth() 9
@@ -0,0 +1,71 @@
1
+ #define STATEMENT_BIND(handle) \
2
+ Binder binder(handle); \
3
+ if (!binder.Bind(info, info.Length(), stmt)) { \
4
+ sqlite3_clear_bindings(handle); \
5
+ return; \
6
+ } ((void)0)
7
+
8
+ #define STATEMENT_THROW_LOGIC() \
9
+ db->ThrowDatabaseError(); \
10
+ if (!bound) { sqlite3_clear_bindings(handle); } \
11
+ return
12
+
13
+ #define STATEMENT_RETURN_LOGIC(return_value) \
14
+ info.GetReturnValue().Set(return_value); \
15
+ if (!bound) { sqlite3_clear_bindings(handle); } \
16
+ return
17
+
18
+ #define STATEMENT_START_LOGIC(RETURNS_DATA_CHECK, MUTATE_CHECK) \
19
+ Statement* stmt = Unwrap<Statement>(info.This()); \
20
+ RETURNS_DATA_CHECK(); \
21
+ sqlite3_stmt* handle = stmt->handle; \
22
+ Database* db = stmt->db; \
23
+ REQUIRE_DATABASE_OPEN(db->GetState()); \
24
+ REQUIRE_DATABASE_NOT_BUSY(db->GetState()); \
25
+ MUTATE_CHECK(); \
26
+ const bool bound = stmt->bound; \
27
+ if (!bound) { \
28
+ STATEMENT_BIND(handle); \
29
+ } else if (info.Length() > 0) { \
30
+ return ThrowTypeError("This statement already has bound parameters"); \
31
+ } ((void)0)
32
+
33
+
34
+ #define STATEMENT_THROW() db->GetState()->busy = false; STATEMENT_THROW_LOGIC()
35
+ #define STATEMENT_RETURN(x) db->GetState()->busy = false; STATEMENT_RETURN_LOGIC(x)
36
+ #define STATEMENT_START(x, y) \
37
+ STATEMENT_START_LOGIC(x, y); \
38
+ db->GetState()->busy = true; \
39
+ UseIsolate; \
40
+ if (db->Log(isolate, handle)) { \
41
+ STATEMENT_THROW(); \
42
+ } ((void)0)
43
+
44
+
45
+ #define DOES_NOT_MUTATE() REQUIRE_STATEMENT_NOT_LOCKED(stmt)
46
+ #define DOES_MUTATE() \
47
+ REQUIRE_STATEMENT_NOT_LOCKED(stmt); \
48
+ REQUIRE_DATABASE_NO_ITERATORS_UNLESS_UNSAFE(db->GetState())
49
+ #define DOES_ADD_ITERATOR() \
50
+ DOES_NOT_MUTATE(); \
51
+ if (db->GetState()->iterators == USHRT_MAX) \
52
+ return ThrowRangeError("Too many active database iterators")
53
+ #define REQUIRE_STATEMENT_RETURNS_DATA() \
54
+ if (!stmt->returns_data) \
55
+ return ThrowTypeError("This statement does not return data. Use run() instead")
56
+ #define ALLOW_ANY_STATEMENT() \
57
+ ((void)0)
58
+
59
+
60
+ #define _FUNCTION_START(type) \
61
+ type* self = static_cast<type*>(sqlite3_user_data(invocation)); \
62
+ v8::Isolate* isolate = self->isolate; \
63
+ v8::HandleScope scope(isolate)
64
+
65
+ #define FUNCTION_START() \
66
+ _FUNCTION_START(CustomFunction)
67
+
68
+ #define AGGREGATE_START() \
69
+ _FUNCTION_START(CustomAggregate); \
70
+ Accumulator* acc = self->GetAccumulator(invocation); \
71
+ if (acc->value.IsEmpty()) return
@@ -0,0 +1,49 @@
1
+ class RowBuilder {
2
+ public:
3
+
4
+ explicit RowBuilder(
5
+ v8::Isolate* isolate,
6
+ sqlite3_stmt* handle,
7
+ bool safe_ints
8
+ ) :
9
+ isolate(isolate),
10
+ handle(handle),
11
+ column_count(-1),
12
+ safe_ints(safe_ints),
13
+ keys(isolate) {}
14
+
15
+ v8::Local<v8::Value> GetRowJS() {
16
+ if (column_count < 0) {
17
+ column_count = sqlite3_column_count(handle);
18
+ keys.reserve(column_count);
19
+ for (int i = 0; i < column_count; ++i) {
20
+ keys.emplace_back(
21
+ InternalizedFromUtf8(isolate, sqlite3_column_name(handle, i), -1)
22
+ .As<v8::Name>()
23
+ );
24
+ }
25
+ }
26
+
27
+ v8::LocalVector<v8::Value> values(isolate);
28
+ values.reserve(column_count);
29
+ for (int i = 0; i < column_count; ++i) {
30
+ values.emplace_back(
31
+ Data::GetValueJS(isolate, handle, i, safe_ints)
32
+ );
33
+ }
34
+
35
+ return v8::Object::New(isolate,
36
+ GET_PROTOTYPE(v8::Object::New(isolate)),
37
+ keys.data(),
38
+ values.data(),
39
+ column_count
40
+ );
41
+ }
42
+
43
+ private:
44
+ v8::Isolate* isolate;
45
+ sqlite3_stmt* handle;
46
+ int column_count;
47
+ const bool safe_ints;
48
+ v8::LocalVector<v8::Name> keys;
49
+ };
@@ -66,6 +66,7 @@ npm run smoke:install
66
66
 
67
67
  - `verify:tarball` 会把最新的 `.tgz` 解包到临时目录,直接检查发布包内容
68
68
  - `smoke:install` 会在临时目录里安装 tarball,并阻断任何 `node-gyp rebuild`
69
+ - workspace 源码目录执行 `pnpm install` / `npm install` 时,`install` 脚本会主动跳过;因为源码目录默认不是正式发布包,真正的 Windows 运行时验收要显式执行 `npm run verify:runtime`
69
70
 
70
71
  ## 发布阻断条件
71
72
 
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ const path = require("node:path");
4
+
5
+ function normalizeSegments(targetPath) {
6
+ return path
7
+ .resolve(targetPath)
8
+ .split(/[\\/]+/u)
9
+ .filter(Boolean)
10
+ .map((segment) => segment.toLowerCase());
11
+ }
12
+
13
+ function isInstalledUnderNodeModules(targetPath) {
14
+ return normalizeSegments(targetPath).includes("node_modules");
15
+ }
16
+
17
+ function isWorkspaceSourceInstall(targetPath) {
18
+ return !isInstalledUnderNodeModules(targetPath);
19
+ }
20
+
21
+ module.exports = {
22
+ isInstalledUnderNodeModules,
23
+ isWorkspaceSourceInstall
24
+ };
@@ -2,6 +2,7 @@
2
2
 
3
3
  const fs = require("node:fs");
4
4
  const path = require("node:path");
5
+ const { isWorkspaceSourceInstall } = require("./runtime-install-context.cjs");
5
6
 
6
7
  const packageRoot = path.resolve(__dirname, "..");
7
8
  const releaseDir = path.join(packageRoot, "build", "Release");
@@ -30,6 +31,13 @@ if (process.arch !== "x64") {
30
31
  process.exit(1);
31
32
  }
32
33
 
34
+ if (isWorkspaceSourceInstall(packageRoot)) {
35
+ console.log(
36
+ "[codingns-node-pty] 检测到源码工作区安装,跳过 install 阶段运行时校验;正式验收请显式执行 npm run verify:runtime。"
37
+ );
38
+ process.exit(0);
39
+ }
40
+
33
41
  const nodeMajor = Number((process.versions.node || "").split(".")[0]);
34
42
  if (nodeMajor !== 22) {
35
43
  console.error(`[codingns-node-pty] 当前仅支持 Node 22,检测到 ${process.versions.node || "unknown"}。`);
@@ -4,9 +4,39 @@ const assert = require("node:assert/strict");
4
4
  const { spawnSync } = require("node:child_process");
5
5
  const path = require("node:path");
6
6
  const test = require("node:test");
7
+ const {
8
+ isInstalledUnderNodeModules,
9
+ isWorkspaceSourceInstall
10
+ } = require("./runtime-install-context.cjs");
7
11
 
8
12
  const scriptPath = path.join(__dirname, "verify-runtime.cjs");
9
13
 
14
+ test("源码工作区路径不会被误判成 node_modules 安装", () => {
15
+ assert.equal(
16
+ isInstalledUnderNodeModules("/repo/packages/node-pty-fork"),
17
+ false
18
+ );
19
+ assert.equal(
20
+ isWorkspaceSourceInstall("/repo/packages/node-pty-fork"),
21
+ true
22
+ );
23
+ });
24
+
25
+ test("node_modules 路径会命中正式安装上下文", () => {
26
+ assert.equal(
27
+ isInstalledUnderNodeModules(
28
+ "C:\\repo\\node_modules\\@codingns\\node-pty"
29
+ ),
30
+ true
31
+ );
32
+ assert.equal(
33
+ isWorkspaceSourceInstall(
34
+ "C:\\repo\\node_modules\\@codingns\\node-pty"
35
+ ),
36
+ false
37
+ );
38
+ });
39
+
10
40
  test("非 Windows 环境会跳过 node-pty 运行时校验", () => {
11
41
  const result = spawnSync(process.execPath, [scriptPath], {
12
42
  encoding: "utf8"
@@ -0,0 +1,12 @@
1
+ # `better-sqlite3`(CodingNS Windows 受控包)
2
+
3
+ 这是 CodingNS 自维护的 `better-sqlite3` Windows 运行时包。
4
+
5
+ 目标很窄:
6
+
7
+ - 只支持 `win32 + x64 + Node 22`
8
+ - 包名保持 `better-sqlite3`,这样 npm 安装时不会再把“依赖名”和“真实包名”装成两套
9
+ - 只给 `@jingyi0605/codingns` 的正式安装使用
10
+ - 不接受安装阶段再回退到本机 `node-gyp rebuild`
11
+
12
+ 它不是通用发布包,也不是给工作区开发时直接依赖的源码包。