agentic-qe 3.9.26 → 3.9.28
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.
- package/.claude/skills/skills-manifest.json +1 -1
- package/CHANGELOG.md +94 -0
- package/assets/skills/skills-manifest.json +1 -1
- package/dist/bridge/captured-experience-bridge.d.ts +40 -0
- package/dist/bridge/captured-experience-bridge.js +232 -0
- package/dist/cli/bundle.js +5 -5
- package/dist/cli/chunks/adapter-EZP2PBUO.js +2 -0
- package/dist/cli/chunks/{agent-booster-wasm-ZOADSKRX.js → agent-booster-wasm-V5PG6GFO.js} +2 -2
- package/dist/cli/chunks/{agent-handler-SPLFCIHA.js → agent-handler-7ZQNRIZC.js} +2 -2
- package/dist/cli/chunks/{agent-memory-branch-R6ZVL2FT.js → agent-memory-branch-KGEYSKXW.js} +2 -2
- package/dist/cli/chunks/aqe-learning-engine-RM4YQPRF.js +2 -0
- package/dist/cli/chunks/{audit-6TQQFGQN.js → audit-5A4AC2NA.js} +2 -2
- package/dist/cli/chunks/base-2KYCMSPN.js +2 -0
- package/dist/cli/chunks/{hnswlib-node-TULXUZI4.js → better-sqlite3-RZZIAME7.js} +2 -2
- package/dist/cli/chunks/{brain-handler-6BQCTD3M.js → brain-handler-KNERI5RC.js} +3 -3
- package/dist/cli/chunks/{branch-enumerator-JTESSKID.js → branch-enumerator-DGR3U73T.js} +2 -2
- package/dist/cli/chunks/{browser-YDZLFZNH.js → browser-Y5DC6QCK.js} +2 -2
- package/dist/cli/chunks/browser-workflow-FZ2BRH4H.js +2 -0
- package/dist/cli/chunks/{chunk-IKRLPS4M.js → chunk-2RKR6KT5.js} +2 -2
- package/dist/cli/chunks/{chunk-SDD3XQ7X.js → chunk-33VVPBAK.js} +1 -1
- package/dist/cli/chunks/{chunk-QFXOKERO.js → chunk-3ZPK7HCD.js} +1 -1
- package/dist/cli/chunks/{chunk-SYRUG2T7.js → chunk-4MYXPDXX.js} +1 -1
- package/dist/cli/chunks/chunk-4R6DN7IO.js +2 -0
- package/dist/cli/chunks/{chunk-TZ73IAF5.js → chunk-5KOR5ZMG.js} +2 -2
- package/dist/cli/chunks/{chunk-SYQZPNHQ.js → chunk-5RZ26J4J.js} +2 -2
- package/dist/cli/chunks/{chunk-6UFMNYQV.js → chunk-5UHMNAK2.js} +1 -1
- package/dist/cli/chunks/{chunk-RLAXE5HU.js → chunk-6BJ6O7JZ.js} +2 -2
- package/dist/cli/chunks/{chunk-PJPNRDEF.js → chunk-6WKX2O66.js} +2 -2
- package/dist/cli/chunks/{chunk-MW4WEMLE.js → chunk-7GLCWLZL.js} +2 -2
- package/dist/cli/chunks/{chunk-7T2KT74O.js → chunk-7MLACLCT.js} +2 -2
- package/dist/cli/chunks/{chunk-MSPY7HMF.js → chunk-7MVFQGFZ.js} +2 -2
- package/dist/cli/chunks/{chunk-Y3YJMKXS.js → chunk-7NDBKLDK.js} +2 -2
- package/dist/cli/chunks/{chunk-HKHRIPXP.js → chunk-A77JCFFC.js} +9 -9
- package/dist/cli/chunks/{chunk-QXQWQRZA.js → chunk-AFSVRY7S.js} +1 -1
- package/dist/cli/chunks/{chunk-G3KTLF57.js → chunk-AL7LMXTA.js} +2 -2
- package/dist/cli/chunks/{chunk-2OFL5HSB.js → chunk-B5KYS65U.js} +2 -2
- package/dist/cli/chunks/{chunk-FWPV44HL.js → chunk-BRCWESMJ.js} +2 -2
- package/dist/cli/chunks/{chunk-EPCKRFMU.js → chunk-C5RA5PDV.js} +2 -2
- package/dist/cli/chunks/{chunk-3QPQZJUY.js → chunk-CAZ2CIU4.js} +2 -2
- package/dist/cli/chunks/{chunk-FRUDEEZH.js → chunk-CCZGT2HD.js} +1 -1
- package/dist/cli/chunks/{chunk-RNVXTNEB.js → chunk-CGQN4R76.js} +2 -2
- package/dist/cli/chunks/{chunk-OFAXQGU5.js → chunk-CKDW7YFV.js} +2 -2
- package/dist/cli/chunks/{chunk-6AH4SN6I.js → chunk-D4YJ3SDF.js} +1 -1
- package/dist/cli/chunks/{chunk-JWKNHSXP.js → chunk-DHLT7OCI.js} +2 -2
- package/dist/cli/chunks/{chunk-EYFL6QLX.js → chunk-DMMFUB3Z.js} +2 -2
- package/dist/cli/chunks/{chunk-CMFRBO4N.js → chunk-DQ3FERVR.js} +3 -3
- package/dist/cli/chunks/{chunk-F24XTOID.js → chunk-DTS3ZD7P.js} +2 -2
- package/dist/cli/chunks/{chunk-UJPERPQU.js → chunk-FI2JQJYJ.js} +1 -1
- package/dist/cli/chunks/{chunk-LPDPGCDC.js → chunk-FQJXLJ6G.js} +2 -2
- package/dist/cli/chunks/{chunk-EFAN5HUX.js → chunk-FTQXXYHG.js} +2 -2
- package/dist/cli/chunks/{chunk-A4U4DNPR.js → chunk-FUKWABUF.js} +1 -1
- package/dist/cli/chunks/{chunk-GHQ6QT47.js → chunk-G4YZWVOV.js} +2 -2
- package/dist/cli/chunks/{chunk-EQ4IZRD5.js → chunk-G6LGV6KD.js} +2 -2
- package/dist/cli/chunks/{chunk-RXQX6JNQ.js → chunk-GECEU6U3.js} +2 -2
- package/dist/cli/chunks/{chunk-4F6RPT7N.js → chunk-HEMQ4DEF.js} +3 -3
- package/dist/cli/chunks/{chunk-VBJ4UQ3X.js → chunk-HL26OBVJ.js} +2 -2
- package/dist/cli/chunks/{chunk-YYOKX7VH.js → chunk-HQFREWNC.js} +2 -2
- package/dist/cli/chunks/{chunk-HSQLB4GR.js → chunk-I4TSLBEZ.js} +2 -2
- package/dist/cli/chunks/{chunk-4GUVB7FG.js → chunk-IJNRJY2R.js} +2 -2
- package/dist/cli/chunks/{chunk-ARLHD5MG.js → chunk-IVRBWQBU.js} +1 -1
- package/dist/cli/chunks/{chunk-4U57VG6R.js → chunk-J62GSTYJ.js} +2 -2
- package/dist/cli/chunks/{chunk-QQMGUORN.js → chunk-JOSEPQIU.js} +2 -2
- package/dist/cli/chunks/{chunk-6VRKHHYI.js → chunk-JZ5TPG5T.js} +1 -1
- package/dist/cli/chunks/{chunk-XAA7ZBNG.js → chunk-KCP5CS4C.js} +1 -1
- package/dist/cli/chunks/{chunk-AOURUJFN.js → chunk-KYPNHW4G.js} +1 -1
- package/dist/cli/chunks/{chunk-CYPOU765.js → chunk-LCSDE5DQ.js} +1 -1
- package/dist/cli/chunks/{chunk-IVNZLESN.js → chunk-LE3V4QHG.js} +2 -2
- package/dist/cli/chunks/{chunk-XDEF6UFY.js → chunk-LG3F5F7B.js} +2 -2
- package/dist/cli/chunks/{chunk-RD3CNJWR.js → chunk-LKWJUZVH.js} +2 -2
- package/dist/cli/chunks/{chunk-K64UL5PA.js → chunk-LM624ZDD.js} +2 -2
- package/dist/cli/chunks/{chunk-PPP7KZQL.js → chunk-LQDKLJBO.js} +2 -2
- package/dist/cli/chunks/{chunk-ETBVBV2M.js → chunk-M3FFEZFJ.js} +2 -2
- package/dist/cli/chunks/{chunk-YUMVG55I.js → chunk-MDXIESNH.js} +2 -2
- package/dist/cli/chunks/{chunk-CU5Q46NR.js → chunk-MFKVWTIY.js} +4 -4
- package/dist/cli/chunks/{chunk-ONYCSOAR.js → chunk-ML2XD4RS.js} +1 -1
- package/dist/cli/chunks/{chunk-AH3IPNOJ.js → chunk-MWVZTQOR.js} +2 -2
- package/dist/cli/chunks/{chunk-VC2FHUOY.js → chunk-NIWTQURH.js} +2 -2
- package/dist/cli/chunks/{chunk-GW5T4BSO.js → chunk-NNYRIYEZ.js} +4 -4
- package/dist/cli/chunks/{chunk-4EBC7ATS.js → chunk-NUN7N7MB.js} +9 -9
- package/dist/cli/chunks/{chunk-VPPXZORB.js → chunk-O22BAOMU.js} +1 -1
- package/dist/cli/chunks/{chunk-LP7ILPFQ.js → chunk-O5AZETA7.js} +2 -2
- package/dist/cli/chunks/{chunk-XHENTAXI.js → chunk-OE7U5SX2.js} +2 -2
- package/dist/cli/chunks/{chunk-U5BMUXV2.js → chunk-OQWTTKJU.js} +2 -2
- package/dist/cli/chunks/{chunk-5TTQNRAP.js → chunk-OVOXPXPC.js} +1 -1
- package/dist/cli/chunks/{chunk-AGBIQXB4.js → chunk-PHPT6QTF.js} +2 -2
- package/dist/cli/chunks/{chunk-F77VZ4IY.js → chunk-PMWIZ7TC.js} +2 -2
- package/dist/cli/chunks/{chunk-4RFODPDS.js → chunk-PNLEMDLY.js} +2 -2
- package/dist/cli/chunks/{chunk-TLBP7EVX.js → chunk-POOFM7MT.js} +1 -1
- package/dist/cli/chunks/{chunk-QU7TNCUB.js → chunk-Q2GEEKE4.js} +1 -1
- package/dist/cli/chunks/{chunk-C77FS4ER.js → chunk-QGQ6XWFK.js} +2 -2
- package/dist/cli/chunks/{chunk-MTRA6I7Y.js → chunk-QKODMLPS.js} +1 -1
- package/dist/cli/chunks/{chunk-N2ET2TL5.js → chunk-QMCRT3AX.js} +2 -2
- package/dist/cli/chunks/{chunk-FDC2ANCP.js → chunk-QY4NWJET.js} +3 -3
- package/dist/cli/chunks/{chunk-VHHFSVR3.js → chunk-RB5T2HNT.js} +2 -2
- package/dist/cli/chunks/{chunk-YCZEXLKL.js → chunk-RJGSHAHW.js} +2 -2
- package/dist/cli/chunks/{chunk-XYMUYLHY.js → chunk-ROXQZJ6J.js} +1 -1
- package/dist/cli/chunks/{chunk-N3GLRFMH.js → chunk-RPNBVYWZ.js} +1 -1
- package/dist/cli/chunks/{chunk-PS7YB3IV.js → chunk-RUOWR53U.js} +3 -3
- package/dist/cli/chunks/{chunk-KQQPUHQD.js → chunk-RX3S6244.js} +1 -1
- package/dist/cli/chunks/{chunk-BBALCRJM.js → chunk-S5YTV4G3.js} +1 -1
- package/dist/cli/chunks/{chunk-MXZY5IJA.js → chunk-S7RGN5OC.js} +1 -1
- package/dist/cli/chunks/{chunk-TU2A5BGA.js → chunk-SH7IVDWV.js} +2 -2
- package/dist/cli/chunks/{chunk-EX7UGFWX.js → chunk-SQHCTVEH.js} +2 -2
- package/dist/cli/chunks/{chunk-BOV44F3Z.js → chunk-SVPX24HJ.js} +2 -2
- package/dist/cli/chunks/{chunk-ZFLD5ATZ.js → chunk-T5YDBTD6.js} +2 -2
- package/dist/cli/chunks/{chunk-P6M6LNSI.js → chunk-TYR7ZETY.js} +2 -2
- package/dist/cli/chunks/{chunk-PSOF6DZA.js → chunk-UCQ2AFAR.js} +129 -124
- package/dist/cli/chunks/{chunk-AUD45G7X.js → chunk-UEADBMAA.js} +2 -2
- package/dist/cli/chunks/{chunk-22YZRYG4.js → chunk-UJRYZ6TO.js} +3 -3
- package/dist/cli/chunks/{chunk-B3KHJQ34.js → chunk-UYTAAWAO.js} +2 -2
- package/dist/cli/chunks/{chunk-3K2QCWFD.js → chunk-V6GKWUCS.js} +1 -1
- package/dist/cli/chunks/{chunk-G42KXBBG.js → chunk-V7VCP42A.js} +2 -2
- package/dist/cli/chunks/{chunk-C5ZA6UBI.js → chunk-VGQYRIQ2.js} +1 -1
- package/dist/cli/chunks/{chunk-TQBP3YGG.js → chunk-VJ7OJ7I3.js} +1 -1
- package/dist/cli/chunks/{chunk-5JGFDJA6.js → chunk-VK3VXDNA.js} +2 -2
- package/dist/cli/chunks/{chunk-MAPQ2UZ5.js → chunk-VPF2RECU.js} +2 -2
- package/dist/cli/chunks/{chunk-7L3F76MS.js → chunk-VQA6GDNN.js} +3 -3
- package/dist/cli/chunks/{chunk-TRIA62JA.js → chunk-VZEKUY3G.js} +2 -2
- package/dist/cli/chunks/{chunk-WCI2FMWZ.js → chunk-WQIT7I46.js} +1 -1
- package/dist/cli/chunks/{chunk-BFSKBIAM.js → chunk-WT2IUWYG.js} +1 -1
- package/dist/cli/chunks/{chunk-CBBVUZFD.js → chunk-XCLG5FGQ.js} +4 -4
- package/dist/cli/chunks/{chunk-PLB75ASZ.js → chunk-XCMM2NLF.js} +1 -1
- package/dist/cli/chunks/{chunk-2XOIJE7J.js → chunk-XLNWSI7Y.js} +2 -2
- package/dist/cli/chunks/{chunk-EEWGVVKH.js → chunk-Y7EPJRQT.js} +2 -2
- package/dist/cli/chunks/{chunk-4QUKBJAS.js → chunk-YF5JCM45.js} +2 -2
- package/dist/cli/chunks/{chunk-SGGYSL7J.js → chunk-YG6ZRK5N.js} +1 -1
- package/dist/cli/chunks/{chunk-ZUUNOGHI.js → chunk-YJPNL6K4.js} +2 -2
- package/dist/cli/chunks/{chunk-4I6XGKSB.js → chunk-YLZZZRB7.js} +2 -2
- package/dist/cli/chunks/{chunk-QUHNBIUZ.js → chunk-YUV4EMRT.js} +1 -1
- package/dist/cli/chunks/{chunk-4ZAOHYFA.js → chunk-ZDM6AWU6.js} +2 -2
- package/dist/cli/chunks/{chunk-DBSEDJ7P.js → chunk-ZH2WOQP3.js} +2 -2
- package/dist/cli/chunks/{chunk-WND3EYCS.js → chunk-ZJEPVWBV.js} +2 -2
- package/dist/cli/chunks/{chunk-ANEIDNH7.js → chunk-ZKNO5AR4.js} +2 -2
- package/dist/cli/chunks/{ci-EAX5WWT6.js → ci-XTEXFMLT.js} +2 -2
- package/dist/cli/chunks/{ci-output-JCWHRJ2A.js → ci-output-5NU5WEOG.js} +2 -2
- package/dist/cli/chunks/{circuit-breaker-RAEDVT33.js → circuit-breaker-UBO4B3ER.js} +2 -2
- package/dist/cli/chunks/{claude-flow-setup-NJAY4WXY.js → claude-flow-setup-X7SVV2YA.js} +2 -2
- package/dist/cli/chunks/client-SRNILWCG.js +2 -0
- package/dist/cli/chunks/{cline-installer-X3GCUEWC.js → cline-installer-EBLJPYJW.js} +2 -2
- package/dist/cli/chunks/{code-GXJ6JC6O.js → code-WO52OOGB.js} +2 -2
- package/dist/cli/chunks/{code-index-extractor-TTA7HZEW.js → code-index-extractor-MVR5EQ4S.js} +2 -2
- package/dist/cli/chunks/{codex-installer-TXMSGJHK.js → codex-installer-LR2NDWTK.js} +2 -2
- package/dist/cli/chunks/{completions-RSFIDY22.js → completions-J5OYMQCR.js} +2 -2
- package/dist/cli/chunks/{complexity-analyzer-C6244ZOI.js → complexity-analyzer-GUFXAK6I.js} +2 -2
- package/dist/cli/chunks/{continuedev-installer-5WQIRQW4.js → continuedev-installer-45ZDPPTK.js} +2 -2
- package/dist/cli/chunks/{copilot-installer-5Q64SC52.js → copilot-installer-FIKML2UD.js} +2 -2
- package/dist/cli/chunks/{cost-tracker-6SBRULNN.js → cost-tracker-SSI3GZ5C.js} +2 -2
- package/dist/cli/chunks/{coverage-X2AG3K6E.js → coverage-GQSRYPVJ.js} +3 -3
- package/dist/cli/chunks/cross-domain-router-QCOROKUM.js +2 -0
- package/dist/cli/chunks/{cursor-installer-VHZ5LEPG.js → cursor-installer-WRIQ2MXB.js} +2 -2
- package/dist/cli/chunks/{daemon-CDQXWIV4.js → daemon-TKQOU66X.js} +3 -3
- package/dist/cli/chunks/{dag-attention-scheduler-33UWNTSB.js → dag-attention-scheduler-DZ4Y7G3P.js} +2 -2
- package/dist/cli/chunks/{detect-UDWTKRQL.js → detect-DLXIZ3JQ.js} +2 -2
- package/dist/cli/chunks/{dist-node-CKTPNPBG.js → dist-node-3QZ37HLE.js} +2 -2
- package/dist/cli/chunks/{domain-handler-5J4AH4XR.js → domain-handler-F2XFKJOG.js} +2 -2
- package/dist/cli/chunks/{domain-transfer-P6VPN56R.js → domain-transfer-NZNJ6O5Y.js} +2 -2
- package/dist/cli/chunks/dream-P5YCSXOG.js +2 -0
- package/dist/cli/chunks/{embed-and-insert-pattern-2YFFI7IN.js → embed-and-insert-pattern-IXQSPD2Q.js} +2 -2
- package/dist/cli/chunks/{eval-K7VFIO2T.js → eval-5VQNSHMZ.js} +2 -2
- package/dist/cli/chunks/{experience-capture-middleware-P4RQW7JV.js → experience-capture-middleware-SQQVSGWT.js} +3 -3
- package/dist/cli/chunks/{fast-paths-T27YLQWQ.js → fast-paths-XZ4PMW4T.js} +2 -2
- package/dist/cli/chunks/{feature-flags-YFPFETDZ.js → feature-flags-I3E33SWO.js} +2 -2
- package/dist/cli/chunks/{feature-flags-HHQNCU6V.js → feature-flags-VYNQQIWP.js} +2 -2
- package/dist/cli/chunks/{file-discovery-ZKNENDOJ.js → file-discovery-VBJYSQEB.js} +2 -2
- package/dist/cli/chunks/{fleet-N5OTMFIN.js → fleet-R24REKY3.js} +4 -4
- package/dist/cli/chunks/{gnn-wrapper-D6L4FIWY.js → gnn-wrapper-ZSS765OF.js} +2 -2
- package/dist/cli/chunks/{heartbeat-handler-5RDU3KKK.js → heartbeat-handler-DXMMYI3L.js} +4 -4
- package/dist/cli/chunks/{heartbeat-scheduler-FALV24GQ.js → heartbeat-scheduler-CAXANO7U.js} +2 -2
- package/dist/cli/chunks/hnsw-adapter-CR22XKGP.js +2 -0
- package/dist/cli/chunks/hnsw-index-BTN322XC.js +2 -0
- package/dist/cli/chunks/{hnsw-legacy-bridge-ARD7KA3G.js → hnsw-legacy-bridge-EU46A4HQ.js} +2 -2
- package/dist/cli/chunks/{better-sqlite3-QIKWKEGD.js → hnswlib-node-K5N5YEYS.js} +2 -2
- package/dist/cli/chunks/{hooks-6HA23JHQ.js → hooks-2AFKHPAH.js} +30 -30
- package/dist/cli/chunks/{hybrid-router-XUYQW7FJ.js → hybrid-router-TLHKB3V6.js} +2 -2
- package/dist/cli/chunks/{hypergraph-engine-OGGXYQAO.js → hypergraph-engine-QKIUFDJP.js} +2 -2
- package/dist/cli/chunks/{hypergraph-handler-UFV3XYVX.js → hypergraph-handler-CT77BGUK.js} +3 -3
- package/dist/cli/chunks/impact-analyzer-ZYIZG4GS.js +2 -0
- package/dist/cli/chunks/{init-handler-VUSXGONQ.js → init-handler-L5Y4EZPZ.js} +8 -8
- package/dist/cli/chunks/init-wizard-2GJYCDEQ.js +2 -0
- package/dist/cli/chunks/kernel-GR44AXQ6.js +2 -0
- package/dist/cli/chunks/{kilocode-installer-C2JMSYAU.js → kilocode-installer-5XLS62BE.js} +2 -2
- package/dist/cli/chunks/{kiro-installer-6LJFFEEZ.js → kiro-installer-YNGEFQJ6.js} +2 -2
- package/dist/cli/chunks/knowledge-graph-23VGRP7G.js +2 -0
- package/dist/cli/chunks/{learning-4B624JV3.js → learning-H4PJXEZT.js} +3 -3
- package/dist/cli/chunks/{llm-router-QUOLZECD.js → llm-router-5V7S4RBP.js} +4 -4
- package/dist/cli/chunks/{load-MIQWBMGE.js → load-MERCK5J7.js} +2 -2
- package/dist/cli/chunks/load-test-5O3AB7JK.js +2 -0
- package/dist/cli/chunks/{mcp-MBJWNXDM.js → mcp-AY3EW3M4.js} +2 -2
- package/dist/cli/chunks/{memory-WX3XHQZP.js → memory-L7QEPZ3O.js} +5 -5
- package/dist/cli/chunks/memory-backend-JMFE5AFK.js +2 -0
- package/dist/cli/chunks/{memory-handlers-Q3XCN5SC.js → memory-handlers-3MMKDYQH.js} +2 -2
- package/dist/cli/chunks/{multi-model-executor-RLY7OQOG.js → multi-model-executor-MCYVGMYJ.js} +2 -2
- package/dist/cli/chunks/{opencode-installer-JATQNZWA.js → opencode-installer-NSJCDEG7.js} +2 -2
- package/dist/cli/chunks/{orchestrator-7BNG32I2.js → orchestrator-PSFROJTM.js} +5 -5
- package/dist/cli/chunks/{pipeline-ORKGL7DP.js → pipeline-TXZZCEOG.js} +2 -2
- package/dist/cli/chunks/{platform-4SLJDRVL.js → platform-PUFZFG66.js} +2 -2
- package/dist/cli/chunks/{plugin-V6FRBF4W.js → plugin-ALNATTS7.js} +2 -2
- package/dist/cli/chunks/{prime-radiant-advanced-wasm-NA7AXKCA.js → prime-radiant-advanced-wasm-PZZRWJEK.js} +2 -2
- package/dist/cli/chunks/protocol-executor-J6KJRPXK.js +2 -0
- package/dist/cli/chunks/{protocol-handler-RSJOZ4XL.js → protocol-handler-WR4JQLSR.js} +2 -2
- package/dist/cli/chunks/{prove-2ZMKUODH.js → prove-AI7HVVJW.js} +2 -2
- package/dist/cli/chunks/{provider-manager-PSPAFCK7.js → provider-manager-XWDJJTRQ.js} +2 -2
- package/dist/cli/chunks/qe-reasoning-bank-A2Z7QLTV.js +2 -0
- package/dist/cli/chunks/{quality-6PZOOQSK.js → quality-W5K6U7NU.js} +2 -2
- package/dist/cli/chunks/queen-coordinator-RSASVM4O.js +2 -0
- package/dist/cli/chunks/{real-embeddings-BGNTSKHD.js → real-embeddings-Y65TLGVT.js} +2 -2
- package/dist/cli/chunks/{roocode-installer-NOHRQJIP.js → roocode-installer-2INES4NP.js} +2 -2
- package/dist/cli/chunks/router-LIO2DAHL.js +2 -0
- package/dist/cli/chunks/routing-feedback-WQ4XI7TT.js +2 -0
- package/dist/cli/chunks/{routing-handler-ZAOGNENU.js → routing-handler-IR4K3W3W.js} +2 -2
- package/dist/cli/chunks/{ruvector-commands-5K3Q4N5H.js → ruvector-commands-JGIJKLE5.js} +2 -2
- package/dist/cli/chunks/{rvf-dual-writer-NWFQC4KN.js → rvf-dual-writer-3RPYL6GB.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-adapter-MS7QGBWK.js → rvf-migration-adapter-DZO5RSBU.js} +2 -2
- package/dist/cli/chunks/{rvf-migration-coordinator-YUBSSB6Z.js → rvf-migration-coordinator-5OIXOLND.js} +2 -2
- package/dist/cli/chunks/rvf-native-adapter-E7ODRU4B.js +2 -0
- package/dist/cli/chunks/safe-db-BW2OSAL7.js +2 -0
- package/dist/cli/chunks/schedule-JF75BBFQ.js +2 -0
- package/dist/cli/chunks/scheduler-EYCKXDGY.js +2 -0
- package/dist/cli/chunks/{security-BJWJWQRB.js → security-6I65LIPS.js} +3 -3
- package/dist/cli/chunks/shared-rvf-adapter-4Z3AKN2H.js +2 -0
- package/dist/cli/chunks/{shared-rvf-dual-writer-LEBD3EHA.js → shared-rvf-dual-writer-LEY65TEP.js} +2 -2
- package/dist/cli/chunks/sqlite-persistence-RUVPC4L5.js +2 -0
- package/dist/cli/chunks/{status-handler-XANOAVIB.js → status-handler-DOJ2JTXS.js} +2 -2
- package/dist/cli/chunks/{structural-health-TZA7PJ2T.js → structural-health-GSWBOWZR.js} +2 -2
- package/dist/cli/chunks/{sync-MKNYPUYP.js → sync-VJ7W4F4G.js} +2 -2
- package/dist/cli/chunks/{task-handler-KXSUKNQV.js → task-handler-AETQISNK.js} +2 -2
- package/dist/cli/chunks/{task-handlers-54MMRT3D.js → task-handlers-OQSZGWCK.js} +3 -3
- package/dist/cli/chunks/{test-AKS5AAT7.js → test-G57YV5WH.js} +4 -4
- package/dist/cli/chunks/{test-scheduling-OA7UPWQ5.js → test-scheduling-ONWDZENP.js} +3 -3
- package/dist/cli/chunks/{token-bootstrap-ZIUNRF3E.js → token-bootstrap-CTG7NE77.js} +2 -2
- package/dist/cli/chunks/{token-usage-IJENSXPQ.js → token-usage-YDHUAMJQ.js} +2 -2
- package/dist/cli/chunks/{transformers-CACTFP7H.js → transformers-W7SFGSLI.js} +2 -2
- package/dist/cli/chunks/{tree-sitter-wasm-parser-4H4UVHAQ.js → tree-sitter-wasm-parser-K7UHIIO2.js} +2 -2
- package/dist/cli/chunks/{types-AGACOWV3.js → types-EIZ5IMMV.js} +2 -2
- package/dist/cli/chunks/unified-memory-XE5LJO5T.js +2 -0
- package/dist/cli/chunks/unified-memory-hnsw-DB6HGWEU.js +2 -0
- package/dist/cli/chunks/unified-persistence-XGXZG42H.js +2 -0
- package/dist/cli/chunks/{upgrade-EKE25VPL.js → upgrade-TIQBZYJ7.js} +2 -2
- package/dist/cli/chunks/{validate-BZTYZQGP.js → validate-IIN2ODDK.js} +2 -2
- package/dist/cli/chunks/{validate-swarm-GZANKJ7M.js → validate-swarm-V6Y4I77Q.js} +2 -2
- package/dist/cli/chunks/{vibium-5X7QY25W.js → vibium-NMIWAEGL.js} +2 -2
- package/dist/cli/chunks/visual-security-NF4MBB32.js +2 -0
- package/dist/cli/chunks/{web-tree-sitter-KDFT6ZUY.js → web-tree-sitter-BGIECWPA.js} +2 -2
- package/dist/cli/chunks/{windsurf-installer-QFZJISMO.js → windsurf-installer-WTZG4PZD.js} +2 -2
- package/dist/cli/chunks/{witness-chain-ESSANJ4X.js → witness-chain-EQ2RE7CZ.js} +2 -2
- package/dist/cli/chunks/witness-chain-ZIE7GCJI.js +2 -0
- package/dist/cli/chunks/{workflow-EQFV2P66.js → workflow-3ZDRY6TE.js} +4 -4
- package/dist/cli/chunks/workflow-orchestrator-Z4KE75MK.js +2 -0
- package/dist/cli/chunks/{wrappers-RKJJDJLC.js → wrappers-FOP76K6J.js} +2 -2
- package/dist/cli/commands/fleet.js +2 -0
- package/dist/cli/commands/hooks-handlers/hooks-shared.js +39 -6
- package/dist/cli/handlers/init-handler.js +2 -0
- package/dist/cli/index.js +3 -0
- package/dist/kernel/interfaces.d.ts +14 -0
- package/dist/kernel/kernel.d.ts +1 -0
- package/dist/kernel/kernel.js +42 -0
- package/dist/learning/pattern-promotion.d.ts +6 -0
- package/dist/learning/pattern-promotion.js +5 -0
- package/dist/learning/qe-reasoning-bank-types.d.ts +12 -3
- package/dist/learning/qe-reasoning-bank.d.ts +10 -3
- package/dist/learning/qe-reasoning-bank.js +28 -7
- package/dist/mcp/bundle.js +323 -318
- package/dist/optimization/index.d.ts +0 -2
- package/dist/optimization/index.js +0 -2
- package/dist/workers/workers/learning-consolidation.js +9 -3
- package/package.json +1 -1
- package/dist/cli/chunks/adapter-LIPKRUFH.js +0 -2
- package/dist/cli/chunks/aqe-learning-engine-XJGJ6YS7.js +0 -2
- package/dist/cli/chunks/base-22RFSMJU.js +0 -2
- package/dist/cli/chunks/browser-workflow-ST7DX7KA.js +0 -2
- package/dist/cli/chunks/chunk-RSNZQ3MN.js +0 -2
- package/dist/cli/chunks/client-6463JNJR.js +0 -2
- package/dist/cli/chunks/cross-domain-router-OYUCD42M.js +0 -2
- package/dist/cli/chunks/dream-R76KD347.js +0 -2
- package/dist/cli/chunks/hnsw-adapter-CYWGI732.js +0 -2
- package/dist/cli/chunks/hnsw-index-UOYT3QKQ.js +0 -2
- package/dist/cli/chunks/impact-analyzer-PWV7CJUA.js +0 -2
- package/dist/cli/chunks/init-wizard-DKIFAPJJ.js +0 -2
- package/dist/cli/chunks/kernel-WQL2MUBH.js +0 -2
- package/dist/cli/chunks/knowledge-graph-U5OZDWGT.js +0 -2
- package/dist/cli/chunks/load-test-D2CQYRZQ.js +0 -2
- package/dist/cli/chunks/memory-backend-HFIGDCZE.js +0 -2
- package/dist/cli/chunks/protocol-executor-LTJIEFVG.js +0 -2
- package/dist/cli/chunks/qe-reasoning-bank-ZJ56AWO2.js +0 -2
- package/dist/cli/chunks/queen-coordinator-CZA7SS4O.js +0 -2
- package/dist/cli/chunks/router-N23IDBEQ.js +0 -2
- package/dist/cli/chunks/routing-feedback-IADXJ4RV.js +0 -2
- package/dist/cli/chunks/rvf-native-adapter-MOR7NUA5.js +0 -2
- package/dist/cli/chunks/safe-db-IRAUFZTC.js +0 -2
- package/dist/cli/chunks/schedule-PKUUCNCA.js +0 -2
- package/dist/cli/chunks/scheduler-NE4NP4W5.js +0 -2
- package/dist/cli/chunks/shared-rvf-adapter-OTON2BMV.js +0 -2
- package/dist/cli/chunks/sqlite-persistence-DXFBYN5L.js +0 -2
- package/dist/cli/chunks/unified-memory-4M3V7XL6.js +0 -2
- package/dist/cli/chunks/unified-memory-hnsw-6IKIDXEW.js +0 -2
- package/dist/cli/chunks/unified-persistence-XJ4D23TB.js +0 -2
- package/dist/cli/chunks/visual-security-2X63QHFJ.js +0 -2
- package/dist/cli/chunks/witness-chain-MWIG363M.js +0 -2
- package/dist/cli/chunks/workflow-orchestrator-B3ECPAFI.js +0 -2
- package/dist/optimization/qe-workers.d.ts +0 -193
- package/dist/optimization/qe-workers.js +0 -692
|
@@ -283,6 +283,20 @@ export interface KernelConfig {
|
|
|
283
283
|
enabledDomains: DomainName[];
|
|
284
284
|
/** Data directory for persistent storage (default: .agentic-qe relative to project root) */
|
|
285
285
|
dataDir?: string;
|
|
286
|
+
/**
|
|
287
|
+
* Whether to start the CapturedExperienceBridge during initialize().
|
|
288
|
+
* The bridge drains hook-fired captured_experiences rows into eventBus
|
|
289
|
+
* domain events. When `true` (default), kernel.initialize() force-loads
|
|
290
|
+
* all enabled domain plugins before starting the bridge so their
|
|
291
|
+
* subscribeToEvents() handlers are wired before the bridge publishes
|
|
292
|
+
* (issue #482 — without this, the bridge's immediate drain publishes
|
|
293
|
+
* to a kernel with zero subscribers and the events are silently lost).
|
|
294
|
+
*
|
|
295
|
+
* Long-lived processes (MCP server, daemon) want this true.
|
|
296
|
+
* Short-lived CLI commands that don't need event-driven domain reactions
|
|
297
|
+
* can set false to skip the plugin-load cost.
|
|
298
|
+
*/
|
|
299
|
+
enableExperienceBridge?: boolean;
|
|
286
300
|
}
|
|
287
301
|
/**
|
|
288
302
|
* Event middleware interface for anti-drift and other event processing (ADR-060)
|
package/dist/kernel/kernel.d.ts
CHANGED
|
@@ -20,6 +20,7 @@ export declare class QEKernelImpl implements QEKernel {
|
|
|
20
20
|
private _startTime;
|
|
21
21
|
private _initialized;
|
|
22
22
|
private _loopTracker;
|
|
23
|
+
private _experienceBridge?;
|
|
23
24
|
constructor(config?: Partial<KernelConfig>);
|
|
24
25
|
get eventBus(): EventBus;
|
|
25
26
|
get coordinator(): AgentCoordinator;
|
package/dist/kernel/kernel.js
CHANGED
|
@@ -18,6 +18,7 @@ import * as path from 'path';
|
|
|
18
18
|
import * as fs from 'fs';
|
|
19
19
|
import { PluginLifecycleManager } from '../plugins/lifecycle';
|
|
20
20
|
import { PluginCache } from '../plugins/cache';
|
|
21
|
+
import { CapturedExperienceBridge } from '../bridge/captured-experience-bridge.js';
|
|
21
22
|
// Import domain plugin factories
|
|
22
23
|
import { createTestGenerationPlugin } from '../domains/test-generation/plugin';
|
|
23
24
|
import { createTestExecutionPlugin } from '../domains/test-execution/plugin';
|
|
@@ -64,6 +65,10 @@ const DEFAULT_CONFIG = {
|
|
|
64
65
|
lazyLoading: true,
|
|
65
66
|
enabledDomains: [...ALL_DOMAINS],
|
|
66
67
|
dataDir: undefined, // Will use project root + .agentic-qe
|
|
68
|
+
// Default ON: long-lived processes (MCP server, daemon) need the bridge
|
|
69
|
+
// working out of the box. CLI commands that don't need event-driven
|
|
70
|
+
// domain reactions opt out by passing `enableExperienceBridge: false`.
|
|
71
|
+
enableExperienceBridge: true,
|
|
67
72
|
};
|
|
68
73
|
export class QEKernelImpl {
|
|
69
74
|
_eventBus;
|
|
@@ -75,6 +80,9 @@ export class QEKernelImpl {
|
|
|
75
80
|
_initialized = false;
|
|
76
81
|
// ADR-062: Loop detection tracker
|
|
77
82
|
_loopTracker;
|
|
83
|
+
// Issue #479: drains captured_experiences into the eventBus so hook-driven
|
|
84
|
+
// activity reaches the 13 domain plugins' subscribeToEvents() handlers.
|
|
85
|
+
_experienceBridge;
|
|
78
86
|
constructor(config = {}) {
|
|
79
87
|
this._config = { ...DEFAULT_CONFIG, ...config };
|
|
80
88
|
this._startTime = new Date();
|
|
@@ -225,9 +233,43 @@ export class QEKernelImpl {
|
|
|
225
233
|
catch {
|
|
226
234
|
// Migration coordinator is best-effort — don't block kernel startup
|
|
227
235
|
}
|
|
236
|
+
// Issue #479 + #482: start the captured-experience bridge so hook-driven
|
|
237
|
+
// activity (written to captured_experiences SQLite by short-lived hook
|
|
238
|
+
// subprocesses) reaches the domain plugins' eventBus handlers.
|
|
239
|
+
//
|
|
240
|
+
// Critical ordering: domain plugins MUST be loaded before the bridge
|
|
241
|
+
// starts. A plugin's subscribeToEvents() runs inside its initialize(),
|
|
242
|
+
// which is invoked by pluginLoader.load(). Until that happens, the
|
|
243
|
+
// plugin's handlers aren't wired as eventBus subscribers. The bridge's
|
|
244
|
+
// start() does an immediate drain, so if plugins are still lazy-pending
|
|
245
|
+
// at that point, the drained events publish to a kernel with zero
|
|
246
|
+
// subscribers and are silently lost (issue #482).
|
|
247
|
+
//
|
|
248
|
+
// Best-effort throughout: never block kernel startup on either step.
|
|
249
|
+
if (this._config.enableExperienceBridge !== false) {
|
|
250
|
+
try {
|
|
251
|
+
await this._plugins.loadAll();
|
|
252
|
+
}
|
|
253
|
+
catch (err) {
|
|
254
|
+
console.warn('[QEKernel] domain plugin pre-load (for bridge subscribers) failed:', err instanceof Error ? err.message : err);
|
|
255
|
+
}
|
|
256
|
+
try {
|
|
257
|
+
this._experienceBridge = new CapturedExperienceBridge(this._eventBus, this._memory);
|
|
258
|
+
await this._experienceBridge.start();
|
|
259
|
+
}
|
|
260
|
+
catch (err) {
|
|
261
|
+
console.warn('[QEKernel] CapturedExperienceBridge failed to start:', err instanceof Error ? err.message : err);
|
|
262
|
+
this._experienceBridge = undefined;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
228
265
|
this._initialized = true;
|
|
229
266
|
}
|
|
230
267
|
async dispose() {
|
|
268
|
+
// Stop the bridge first so it doesn't try to publish to a disposed bus.
|
|
269
|
+
if (this._experienceBridge) {
|
|
270
|
+
await this._experienceBridge.stop();
|
|
271
|
+
this._experienceBridge = undefined;
|
|
272
|
+
}
|
|
231
273
|
// Dispose in reverse order of initialization
|
|
232
274
|
await this._plugins.disposeAll();
|
|
233
275
|
await this._coordinator.dispose();
|
|
@@ -53,6 +53,12 @@ export interface SeedingDeps {
|
|
|
53
53
|
searchPatterns: (query: string | number[], options?: Record<string, unknown>) => Promise<Result<PatternSearchResult[]>>;
|
|
54
54
|
storePattern: (options: Record<string, unknown>) => Promise<Result<QEPattern>>;
|
|
55
55
|
patternStore: IPatternStore;
|
|
56
|
+
/**
|
|
57
|
+
* Optional cancellation signal. Checked before each store/search so that
|
|
58
|
+
* an aborted init (issue #478) stops appending to the pattern store
|
|
59
|
+
* instead of running to completion in the background.
|
|
60
|
+
*/
|
|
61
|
+
signal?: AbortSignal;
|
|
56
62
|
}
|
|
57
63
|
/**
|
|
58
64
|
* Seed cross-domain patterns by transferring generalizable patterns
|
|
@@ -152,10 +152,13 @@ export async function promotePattern(patternId, deps) {
|
|
|
152
152
|
* from populated domains to their related domains.
|
|
153
153
|
*/
|
|
154
154
|
export async function seedCrossDomainPatterns(deps) {
|
|
155
|
+
const { signal } = deps;
|
|
156
|
+
signal?.throwIfAborted();
|
|
155
157
|
const stats = await deps.patternStore.getStats();
|
|
156
158
|
let transferred = 0;
|
|
157
159
|
let skipped = 0;
|
|
158
160
|
for (const [sourceDomainStr, targetDomains] of Object.entries(RELATED_DOMAINS)) {
|
|
161
|
+
signal?.throwIfAborted();
|
|
159
162
|
const sourceDomain = sourceDomainStr;
|
|
160
163
|
const sourceCount = stats.byDomain[sourceDomain] || 0;
|
|
161
164
|
if (sourceCount === 0)
|
|
@@ -167,12 +170,14 @@ export async function seedCrossDomainPatterns(deps) {
|
|
|
167
170
|
if (!sourceResult.success)
|
|
168
171
|
continue;
|
|
169
172
|
for (const targetDomain of targetDomains) {
|
|
173
|
+
signal?.throwIfAborted();
|
|
170
174
|
const targetCount = stats.byDomain[targetDomain] || 0;
|
|
171
175
|
if (targetCount >= sourceCount) {
|
|
172
176
|
skipped++;
|
|
173
177
|
continue;
|
|
174
178
|
}
|
|
175
179
|
for (const { pattern: sourcePattern } of sourceResult.value) {
|
|
180
|
+
signal?.throwIfAborted();
|
|
176
181
|
const existingCheck = await deps.searchPatterns(sourcePattern.name, {
|
|
177
182
|
domain: targetDomain,
|
|
178
183
|
limit: 1,
|
|
@@ -112,8 +112,17 @@ export interface PromotionBlockedEvent {
|
|
|
112
112
|
* QEReasoningBank interface
|
|
113
113
|
*/
|
|
114
114
|
export interface IQEReasoningBank {
|
|
115
|
-
/**
|
|
116
|
-
|
|
115
|
+
/**
|
|
116
|
+
* Initialize the reasoning bank.
|
|
117
|
+
*
|
|
118
|
+
* Pass `signal` to bound long-running init steps (pattern bootstrap,
|
|
119
|
+
* cross-domain seeding). When the signal is aborted, every awaited step
|
|
120
|
+
* checks it via `throwIfAborted()` so the work stops promptly instead of
|
|
121
|
+
* leaking past a caller-side timeout.
|
|
122
|
+
*/
|
|
123
|
+
initialize(options?: {
|
|
124
|
+
signal?: AbortSignal;
|
|
125
|
+
}): Promise<void>;
|
|
117
126
|
/** Store a new pattern */
|
|
118
127
|
storePattern(options: CreateQEPatternOptions): Promise<Result<QEPattern>>;
|
|
119
128
|
/** Search for patterns */
|
|
@@ -136,7 +145,7 @@ export interface IQEReasoningBank {
|
|
|
136
145
|
/** Get embedding for text */
|
|
137
146
|
embed(text: string): Promise<number[]>;
|
|
138
147
|
/** Seed cross-domain patterns by transferring from populated domains to related ones */
|
|
139
|
-
seedCrossDomainPatterns(): Promise<{
|
|
148
|
+
seedCrossDomainPatterns(signal?: AbortSignal): Promise<{
|
|
140
149
|
transferred: number;
|
|
141
150
|
skipped: number;
|
|
142
151
|
}>;
|
|
@@ -65,9 +65,16 @@ export declare class QEReasoningBank implements IQEReasoningBank {
|
|
|
65
65
|
private stats;
|
|
66
66
|
constructor(memory: MemoryBackend, eventBus?: EventBus | undefined, config?: Partial<QEReasoningBankConfig>, coherenceService?: import("../integrations/coherence/coherence-service.js").ICoherenceService | undefined);
|
|
67
67
|
/**
|
|
68
|
-
* Initialize the reasoning bank
|
|
68
|
+
* Initialize the reasoning bank.
|
|
69
|
+
*
|
|
70
|
+
* `options.signal` bounds the init: every step calls
|
|
71
|
+
* `signal.throwIfAborted()` before starting work, so a caller-side
|
|
72
|
+
* timeout that aborts the signal causes initialize() to reject promptly
|
|
73
|
+
* instead of leaking writes past the timeout (issue #478).
|
|
69
74
|
*/
|
|
70
|
-
initialize(
|
|
75
|
+
initialize(options?: {
|
|
76
|
+
signal?: AbortSignal;
|
|
77
|
+
}): Promise<void>;
|
|
71
78
|
/**
|
|
72
79
|
* Load pre-trained patterns for common QE scenarios
|
|
73
80
|
*/
|
|
@@ -79,7 +86,7 @@ export declare class QEReasoningBank implements IQEReasoningBank {
|
|
|
79
86
|
* Uses the domain compatibility matrix to determine which domains
|
|
80
87
|
* are related and applies a relevance decay to transferred patterns.
|
|
81
88
|
*/
|
|
82
|
-
seedCrossDomainPatterns(): Promise<{
|
|
89
|
+
seedCrossDomainPatterns(signal?: AbortSignal): Promise<{
|
|
83
90
|
transferred: number;
|
|
84
91
|
skipped: number;
|
|
85
92
|
}>;
|
|
@@ -106,12 +106,20 @@ export class QEReasoningBank {
|
|
|
106
106
|
});
|
|
107
107
|
}
|
|
108
108
|
/**
|
|
109
|
-
* Initialize the reasoning bank
|
|
109
|
+
* Initialize the reasoning bank.
|
|
110
|
+
*
|
|
111
|
+
* `options.signal` bounds the init: every step calls
|
|
112
|
+
* `signal.throwIfAborted()` before starting work, so a caller-side
|
|
113
|
+
* timeout that aborts the signal causes initialize() to reject promptly
|
|
114
|
+
* instead of leaking writes past the timeout (issue #478).
|
|
110
115
|
*/
|
|
111
|
-
async initialize() {
|
|
116
|
+
async initialize(options) {
|
|
112
117
|
if (this.initialized)
|
|
113
118
|
return;
|
|
119
|
+
const signal = options?.signal;
|
|
120
|
+
signal?.throwIfAborted();
|
|
114
121
|
await this.patternStore.initialize();
|
|
122
|
+
signal?.throwIfAborted();
|
|
115
123
|
// Wire SQLitePatternStore into PatternStore for delete/promote persistence
|
|
116
124
|
try {
|
|
117
125
|
const store = this.getSqliteStore();
|
|
@@ -121,8 +129,10 @@ export class QEReasoningBank {
|
|
|
121
129
|
catch (e) {
|
|
122
130
|
logger.warn('Failed to wire SQLitePatternStore into PatternStore', { error: toErrorMessage(e) });
|
|
123
131
|
}
|
|
132
|
+
signal?.throwIfAborted();
|
|
124
133
|
// Load any pre-trained patterns
|
|
125
|
-
await this.loadPretrainedPatterns();
|
|
134
|
+
await this.loadPretrainedPatterns(signal);
|
|
135
|
+
signal?.throwIfAborted();
|
|
126
136
|
this.initialized = true;
|
|
127
137
|
// Run cross-domain transfer ONCE per DB lifetime (not every init)
|
|
128
138
|
// IMPORTANT: Set the flag BEFORE the transfer so that even if the transfer
|
|
@@ -134,7 +144,7 @@ export class QEReasoningBank {
|
|
|
134
144
|
if (!alreadySeeded) {
|
|
135
145
|
// Set flag FIRST to prevent re-runs if transfer times out or process exits
|
|
136
146
|
await this.memory.set(SEED_FLAG_KEY, true);
|
|
137
|
-
await this.seedCrossDomainPatterns();
|
|
147
|
+
await this.seedCrossDomainPatterns(signal);
|
|
138
148
|
}
|
|
139
149
|
else {
|
|
140
150
|
const stats = await this.patternStore.getStats();
|
|
@@ -142,6 +152,10 @@ export class QEReasoningBank {
|
|
|
142
152
|
}
|
|
143
153
|
}
|
|
144
154
|
catch (error) {
|
|
155
|
+
// Re-throw abort errors so the caller sees the cancellation;
|
|
156
|
+
// swallow other errors per the existing non-fatal contract.
|
|
157
|
+
if (signal?.aborted)
|
|
158
|
+
throw error;
|
|
145
159
|
logger.warn('Cross-domain seeding failed (non-fatal)', { error });
|
|
146
160
|
}
|
|
147
161
|
logger.info('Initialized');
|
|
@@ -149,8 +163,9 @@ export class QEReasoningBank {
|
|
|
149
163
|
/**
|
|
150
164
|
* Load pre-trained patterns for common QE scenarios
|
|
151
165
|
*/
|
|
152
|
-
async loadPretrainedPatterns() {
|
|
166
|
+
async loadPretrainedPatterns(signal) {
|
|
153
167
|
// Check if we already have patterns
|
|
168
|
+
signal?.throwIfAborted();
|
|
154
169
|
const stats = await this.patternStore.getStats();
|
|
155
170
|
if (stats.totalPatterns > 0) {
|
|
156
171
|
logger.info('Found existing patterns', { totalPatterns: stats.totalPatterns });
|
|
@@ -189,10 +204,15 @@ export class QEReasoningBank {
|
|
|
189
204
|
// 1. embeddings are computed via this.embed()
|
|
190
205
|
// 2. patternStore.store() calls adapter.ingest() for each pattern
|
|
191
206
|
for (const options of PRETRAINED_PATTERNS) {
|
|
207
|
+
// Bail before each store() so an aborted init does not keep appending
|
|
208
|
+
// to patterns.rvf (issue #478).
|
|
209
|
+
signal?.throwIfAborted();
|
|
192
210
|
try {
|
|
193
211
|
await this.storePattern(options);
|
|
194
212
|
}
|
|
195
213
|
catch (error) {
|
|
214
|
+
if (signal?.aborted)
|
|
215
|
+
throw error;
|
|
196
216
|
logger.warn('Failed to load pattern', { name: options.name, error });
|
|
197
217
|
}
|
|
198
218
|
}
|
|
@@ -205,14 +225,15 @@ export class QEReasoningBank {
|
|
|
205
225
|
* Uses the domain compatibility matrix to determine which domains
|
|
206
226
|
* are related and applies a relevance decay to transferred patterns.
|
|
207
227
|
*/
|
|
208
|
-
async seedCrossDomainPatterns() {
|
|
228
|
+
async seedCrossDomainPatterns(signal) {
|
|
209
229
|
if (!this.initialized) {
|
|
210
|
-
await this.initialize();
|
|
230
|
+
await this.initialize({ signal });
|
|
211
231
|
}
|
|
212
232
|
return seedCrossDomainPatternsFn({
|
|
213
233
|
searchPatterns: this.searchPatterns.bind(this),
|
|
214
234
|
storePattern: this.storePattern.bind(this),
|
|
215
235
|
patternStore: this.patternStore,
|
|
236
|
+
signal,
|
|
216
237
|
});
|
|
217
238
|
}
|
|
218
239
|
/**
|