onbuzz 4.0.2 → 4.2.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.
- package/package.json +1 -1
- package/scripts/audit-report.js +164 -0
- package/src/core/__tests__/agentPoolToolConfig.test.js +191 -0
- package/src/core/__tests__/agentPoolWakeOnMessage.test.js +315 -0
- package/src/core/__tests__/agentScheduler.emptyResponseDiagnostics.test.js +191 -0
- package/src/core/__tests__/agentScheduler.modeTransitions.test.js +233 -0
- package/src/core/__tests__/agentScheduler.taskLifecycleInstruction.test.js +78 -0
- package/src/core/__tests__/agentScheduler.test.js +31 -13
- package/src/core/__tests__/messageProcessor.test.js +42 -0
- package/src/core/agentPool.js +127 -25
- package/src/core/agentScheduler.js +330 -151
- package/src/core/messageProcessor.js +19 -1
- package/src/interfaces/__tests__/galleryRoutes.test.js +311 -0
- package/src/interfaces/webServer.js +183 -2
- package/src/services/__tests__/agentActivityService.test.js +83 -0
- package/src/services/__tests__/aiService.reasoningTokens.test.js +66 -0
- package/src/services/__tests__/aiService.stream.test.js +301 -0
- package/src/services/__tests__/conversationQuery.reasoning.test.js +102 -0
- package/src/services/__tests__/conversationQuery.test.js +723 -0
- package/src/services/__tests__/toolCallBridgeContract.test.js +129 -0
- package/src/services/agentActivityService.js +25 -4
- package/src/services/aiService.js +180 -91
- package/src/services/conversationQuery.js +803 -0
- package/src/tools/__tests__/agentCommunicationTool.test.js +114 -0
- package/src/tools/__tests__/baseTool.getEffectiveConfig.test.js +77 -0
- package/src/tools/__tests__/baseTool.test.js +471 -420
- package/src/tools/__tests__/filesystemTool.test.js +98 -0
- package/src/tools/__tests__/memoryTool.reminisce.test.js +363 -0
- package/src/tools/__tests__/memoryTool.test.js +2 -2
- package/src/tools/__tests__/openaiFunctionSchemas.memoryReminisce.test.js +84 -0
- package/src/tools/__tests__/taskManagerTool.lifecycleGuidance.test.js +71 -0
- package/src/tools/__tests__/terminalTool.test.js +64 -0
- package/src/tools/__tests__/webTool.perAgentConfig.test.js +94 -0
- package/src/tools/agentCommunicationTool.js +33 -22
- package/src/tools/baseTool.js +980 -899
- package/src/tools/fileSystemTool.js +76 -2
- package/src/tools/memoryTool.js +270 -4
- package/src/tools/openaiFunctionSchemas.js +62 -7
- package/src/tools/taskManagerTool.js +21 -4
- package/src/tools/terminalTool.js +62 -2
- package/src/tools/webTool.js +65 -1
- package/src/utilities/__tests__/auditReport.test.js +328 -0
- package/src/utilities/__tests__/modeTransitionReasons.test.js +105 -0
- package/src/utilities/auditReport.js +331 -0
- package/src/utilities/modeTransitionReasons.js +101 -0
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-C_9olPfq.js +1 -0
- package/web-ui/build/static/abap--DeFI1OC.js +1 -0
- package/web-ui/build/static/abnf-5HzSmxRy.js +1 -0
- package/web-ui/build/static/abnf-IG-O3NHT.js +1 -0
- package/web-ui/build/static/accesslog-qO_3I5IJ.js +1 -0
- package/web-ui/build/static/actionscript-DbFc2Uxo.js +1 -0
- package/web-ui/build/static/actionscript-jU7xUh7w.js +1 -0
- package/web-ui/build/static/ada-DBOzyNDe.js +1 -0
- package/web-ui/build/static/ada-F0QwXh2e.js +1 -0
- package/web-ui/build/static/agda-Drhr_GYC.js +1 -0
- package/web-ui/build/static/al-bEatcrqU.js +1 -0
- package/web-ui/build/static/angelscript-Bp0mqasc.js +1 -0
- package/web-ui/build/static/antlr4-BCvixOqW.js +1 -0
- package/web-ui/build/static/apache-zSeWcGFf.js +1 -0
- package/web-ui/build/static/apacheconf-CEDX0qIZ.js +1 -0
- package/web-ui/build/static/apex-BHlvjPxZ.js +1 -0
- package/web-ui/build/static/apl-S86eLVnh.js +1 -0
- package/web-ui/build/static/applescript-D15JiHTt.js +1 -0
- package/web-ui/build/static/applescript-D6g2nIGs.js +1 -0
- package/web-ui/build/static/aql-C4SWmhk2.js +1 -0
- package/web-ui/build/static/arcade-DrwRCCCh.js +1 -0
- package/web-ui/build/static/arduino-Blsw4-hb.js +1 -0
- package/web-ui/build/static/arduino-s6CYn6L3.js +1 -0
- package/web-ui/build/static/arff-DnrfdsTx.js +1 -0
- package/web-ui/build/static/armasm-C2WK9q2y.js +1 -0
- package/web-ui/build/static/asciidoc-BiY2pDol.js +1 -0
- package/web-ui/build/static/asciidoc-DG128-Q1.js +1 -0
- package/web-ui/build/static/asm6502-BEAW0Cck.js +1 -0
- package/web-ui/build/static/asmatmel-C4v7boSu.js +1 -0
- package/web-ui/build/static/aspectj-Bfek529B.js +1 -0
- package/web-ui/build/static/aspnet-8K2PeLn2.js +1 -0
- package/web-ui/build/static/autohotkey-BHw78HYu.js +1 -0
- package/web-ui/build/static/autohotkey-C5DDQtDL.js +1 -0
- package/web-ui/build/static/autoit-CgsSmQkF.js +1 -0
- package/web-ui/build/static/autoit-DZ7IS_9i.js +1 -0
- package/web-ui/build/static/avisynth-B20WuEUg.js +1 -0
- package/web-ui/build/static/avrasm-C7TrcWBg.js +1 -0
- package/web-ui/build/static/avro-idl-CfDy8XWE.js +1 -0
- package/web-ui/build/static/awk-cjY-7p5o.js +1 -0
- package/web-ui/build/static/axapta-Bu9INQG2.js +1 -0
- package/web-ui/build/static/bash-B998wxy_.js +1 -0
- package/web-ui/build/static/bash-LE6roX2s.js +1 -0
- package/web-ui/build/static/basic-Cd6-vDdH.js +1 -0
- package/web-ui/build/static/basic-mfY-ovnp.js +1 -0
- package/web-ui/build/static/batch-DxVy2cwv.js +1 -0
- package/web-ui/build/static/bbcode-Ct3Yu8De.js +1 -0
- package/web-ui/build/static/bicep-CexPoMEW.js +1 -0
- package/web-ui/build/static/birb-CH1RMpPI.js +1 -0
- package/web-ui/build/static/bison-XQFuPB_Q.js +1 -0
- package/web-ui/build/static/bnf-CIDGmY3l.js +1 -0
- package/web-ui/build/static/bnf-DjN_FU2s.js +1 -0
- package/web-ui/build/static/brainfuck-Cu_hvayi.js +1 -0
- package/web-ui/build/static/brainfuck-eRbe4_qo.js +1 -0
- package/web-ui/build/static/brightscript-Cdq0ttTN.js +1 -0
- package/web-ui/build/static/bro-D3aio8LS.js +1 -0
- package/web-ui/build/static/bsl-DFEwVZ2J.js +1 -0
- package/web-ui/build/static/c-D6RK1vhn.js +1 -0
- package/web-ui/build/static/c-DUcBA02q.js +1 -0
- package/web-ui/build/static/c-like-BApJDFwD.js +1 -0
- package/web-ui/build/static/cal-Ckv8Qnpw.js +1 -0
- package/web-ui/build/static/capnproto-DCoblEyS.js +1 -0
- package/web-ui/build/static/ceylon-DM-zZDWY.js +1 -0
- package/web-ui/build/static/cfscript-CMoOAgUK.js +1 -0
- package/web-ui/build/static/chaiscript-B3Vl3wGb.js +1 -0
- package/web-ui/build/static/cil-ChEi_uFO.js +1 -0
- package/web-ui/build/static/clean-BtA08oDV.js +1 -0
- package/web-ui/build/static/clojure-CWMlf7lJ.js +1 -0
- package/web-ui/build/static/clojure-Vur8C4jr.js +1 -0
- package/web-ui/build/static/clojure-repl-BsfGHdYy.js +1 -0
- package/web-ui/build/static/cmake-Csgl_IVr.js +1 -0
- package/web-ui/build/static/cmake-DFMKvwxy.js +1 -0
- package/web-ui/build/static/cobol-XhlGrCrW.js +1 -0
- package/web-ui/build/static/coffeescript-DYldGW35.js +1 -0
- package/web-ui/build/static/coffeescript-DvbNKwrC.js +1 -0
- package/web-ui/build/static/concurnas-DjALqCYn.js +1 -0
- package/web-ui/build/static/coq-D9QGJI6g.js +1 -0
- package/web-ui/build/static/coq-fAZpoc7i.js +1 -0
- package/web-ui/build/static/cos-GgM7WWVZ.js +1 -0
- package/web-ui/build/static/cpp-Cgt5qqfd.js +1 -0
- package/web-ui/build/static/cpp-DxVcOuBe.js +1 -0
- package/web-ui/build/static/crmsh-BlZWnzbY.js +1 -0
- package/web-ui/build/static/crystal--H7HLAQf.js +1 -0
- package/web-ui/build/static/crystal-DWm0bbUT.js +1 -0
- package/web-ui/build/static/csharp-8dr-wktE.js +1 -0
- package/web-ui/build/static/csharp-DFuHLPFe.js +1 -0
- package/web-ui/build/static/cshtml-C-L4_dy2.js +1 -0
- package/web-ui/build/static/csp-CJ6qbecO.js +1 -0
- package/web-ui/build/static/csp-DswTy-5u.js +1 -0
- package/web-ui/build/static/css-DdRPdKXQ.js +1 -0
- package/web-ui/build/static/css-extras-DMwOZFrB.js +1 -0
- package/web-ui/build/static/csv-BiWlhIMC.js +1 -0
- package/web-ui/build/static/cypher-ByNaJKO8.js +1 -0
- package/web-ui/build/static/d-BR89VlK-.js +1 -0
- package/web-ui/build/static/d-KlWvBc4w.js +1 -0
- package/web-ui/build/static/dart-BIsk7m6o.js +1 -0
- package/web-ui/build/static/dart-BnyP1Rjp.js +1 -0
- package/web-ui/build/static/dataweave-CH_Q2gWX.js +1 -0
- package/web-ui/build/static/dax-wulX9uc-.js +1 -0
- package/web-ui/build/static/delphi-CFowdk_A.js +1 -0
- package/web-ui/build/static/dhall-BfCOemEp.js +1 -0
- package/web-ui/build/static/diff-DQD2zPaG.js +1 -0
- package/web-ui/build/static/diff-DZoEdrYM.js +1 -0
- package/web-ui/build/static/django-B0j973Kw.js +1 -0
- package/web-ui/build/static/django-CYScL320.js +1 -0
- package/web-ui/build/static/dns-DoECkAgz.js +1 -0
- package/web-ui/build/static/dns-zone-file-CuoIcXgj.js +1 -0
- package/web-ui/build/static/docker-C2nfXTBG.js +1 -0
- package/web-ui/build/static/dockerfile-DBalxIH7.js +1 -0
- package/web-ui/build/static/dos-GNL9IdmL.js +1 -0
- package/web-ui/build/static/dot-rKuRS-PS.js +1 -0
- package/web-ui/build/static/dsconfig-CKmenTFr.js +1 -0
- package/web-ui/build/static/dts-AxT2qjQU.js +1 -0
- package/web-ui/build/static/dust-DpqHWPC4.js +1 -0
- package/web-ui/build/static/ebnf-CONEMpLp.js +1 -0
- package/web-ui/build/static/ebnf-DRWcOs8R.js +1 -0
- package/web-ui/build/static/editorconfig-lmLHmECZ.js +1 -0
- package/web-ui/build/static/eiffel-B39e31fw.js +1 -0
- package/web-ui/build/static/ejs-DtJwpVdo.js +1 -0
- package/web-ui/build/static/elixir-BH4JTqa9.js +1 -0
- package/web-ui/build/static/elixir-aH1DLjYD.js +1 -0
- package/web-ui/build/static/elm-BcCGkSrW.js +1 -0
- package/web-ui/build/static/elm-CCrB1JbX.js +1 -0
- package/web-ui/build/static/erb-CcumI1K3.js +1 -0
- package/web-ui/build/static/erb-_HK77hx-.js +1 -0
- package/web-ui/build/static/erlang-B1qxMZZp.js +1 -0
- package/web-ui/build/static/erlang-CCM_ejO_.js +1 -0
- package/web-ui/build/static/erlang-repl-D1zC2Zf6.js +1 -0
- package/web-ui/build/static/etlua-HJMRx9x7.js +1 -0
- package/web-ui/build/static/excel-DqXCKUKa.js +1 -0
- package/web-ui/build/static/excel-formula-oNw1T5Gi.js +1 -0
- package/web-ui/build/static/factor-BrTp5FZH.js +1 -0
- package/web-ui/build/static/false-CAVqV3ok.js +1 -0
- package/web-ui/build/static/firestore-security-rules-CxTofGT0.js +1 -0
- package/web-ui/build/static/fix-BMooo7-3.js +1 -0
- package/web-ui/build/static/flix-DR5Pi_4n.js +1 -0
- package/web-ui/build/static/flow-BoCWpUCW.js +1 -0
- package/web-ui/build/static/fortran-B9JI5ahV.js +1 -0
- package/web-ui/build/static/fortran-LXg81aOn.js +1 -0
- package/web-ui/build/static/fsharp-BqcGG-SM.js +1 -0
- package/web-ui/build/static/fsharp-Dj5YVL_h.js +1 -0
- package/web-ui/build/static/ftl-kuY7uFR8.js +1 -0
- package/web-ui/build/static/gams-CzihHKqE.js +1 -0
- package/web-ui/build/static/gap-BbS0A-Wl.js +1 -0
- package/web-ui/build/static/gauss-BauwG_O4.js +1 -0
- package/web-ui/build/static/gcode-VY1OKBcC.js +1 -0
- package/web-ui/build/static/gcode-lapsLgV5.js +1 -0
- package/web-ui/build/static/gdscript-1UIYB8m0.js +1 -0
- package/web-ui/build/static/gedcom-Bhrxt1LM.js +1 -0
- package/web-ui/build/static/gherkin-BsUD3vJB.js +1 -0
- package/web-ui/build/static/gherkin-hj_asmFX.js +1 -0
- package/web-ui/build/static/git-DXIrRKzR.js +1 -0
- package/web-ui/build/static/glsl-Bww3i9-P.js +1 -0
- package/web-ui/build/static/glsl-tW4hvcaQ.js +1 -0
- package/web-ui/build/static/gml-BIqshajA.js +1 -0
- package/web-ui/build/static/gml-CQqc9F-B.js +1 -0
- package/web-ui/build/static/gn-CBgpy8B9.js +1 -0
- package/web-ui/build/static/go-CEUAUIgn.js +1 -0
- package/web-ui/build/static/go-DPEd33Yn.js +1 -0
- package/web-ui/build/static/go-module-BVPbZOg5.js +1 -0
- package/web-ui/build/static/golo-CqB3OATq.js +1 -0
- package/web-ui/build/static/gradle-Djj_6FTv.js +1 -0
- package/web-ui/build/static/graphql-ymSYYmmE.js +1 -0
- package/web-ui/build/static/groovy-BLoXi1Ew.js +1 -0
- package/web-ui/build/static/groovy-D8ua3DVO.js +1 -0
- package/web-ui/build/static/haml-DKlxHs26.js +1 -0
- package/web-ui/build/static/haml-S_iUNysn.js +1 -0
- package/web-ui/build/static/handlebars-B7tcAMGB.js +1 -0
- package/web-ui/build/static/handlebars-CV-zB05N.js +1 -0
- package/web-ui/build/static/haskell-CMxCwdZX.js +1 -0
- package/web-ui/build/static/haskell-Dis6rGJ5.js +1 -0
- package/web-ui/build/static/haxe-C76IK5YN.js +1 -0
- package/web-ui/build/static/haxe-hbmD2uei.js +1 -0
- package/web-ui/build/static/hcl-BPI_t80W.js +1 -0
- package/web-ui/build/static/hlsl-BmeH3MXM.js +1 -0
- package/web-ui/build/static/hoon-BYLX7KiR.js +1 -0
- package/web-ui/build/static/hpkp-CFV1lvIV.js +1 -0
- package/web-ui/build/static/hsp-_VXPtQPw.js +1 -0
- package/web-ui/build/static/hsts-DzmFog1b.js +1 -0
- package/web-ui/build/static/htmlbars-uX8JubPS.js +1 -0
- package/web-ui/build/static/http-BTDAHgkv.js +1 -0
- package/web-ui/build/static/http-Ba1gTHCW.js +1 -0
- package/web-ui/build/static/hy-G7MK4TLb.js +1 -0
- package/web-ui/build/static/ichigojam-BKKN56jZ.js +1 -0
- package/web-ui/build/static/icon-nrqdEYwB.js +1 -0
- package/web-ui/build/static/icu-message-format-Bjone7XH.js +1 -0
- package/web-ui/build/static/idris-CKkY_0op.js +1 -0
- package/web-ui/build/static/iecst-EV3ZvBDC.js +1 -0
- package/web-ui/build/static/ignore-LJIbInke.js +1 -0
- package/web-ui/build/static/index-C1x426Pt.js +734 -0
- package/web-ui/build/static/index-CTzeYMwr.js +13 -0
- package/web-ui/build/static/index-CUBjz1OL.css +1 -0
- package/web-ui/build/static/index-DnVIkRiR.js +1 -0
- package/web-ui/build/static/inform7-BiW6HbUl.js +1 -0
- package/web-ui/build/static/inform7-DT-x6SRD.js +1 -0
- package/web-ui/build/static/ini-BbnHjAtW.js +1 -0
- package/web-ui/build/static/ini-DuNY7Iqz.js +1 -0
- package/web-ui/build/static/io-BquAtlCB.js +1 -0
- package/web-ui/build/static/irpf90-CZELNeJl.js +1 -0
- package/web-ui/build/static/isbl-DhOgOzai.js +1 -0
- package/web-ui/build/static/j-r8D3BrBj.js +1 -0
- package/web-ui/build/static/java-MjQ5EBN5.js +1 -0
- package/web-ui/build/static/java-c3Jyc0B6.js +1 -0
- package/web-ui/build/static/javadoc-CfNFziRD.js +1 -0
- package/web-ui/build/static/javadoclike-BUcJZQAh.js +1 -0
- package/web-ui/build/static/javascript-CL_4g6j3.js +1 -0
- package/web-ui/build/static/javastacktrace-4P_J-58S.js +1 -0
- package/web-ui/build/static/jboss-cli-DUfK88hO.js +1 -0
- package/web-ui/build/static/jexl-DsSijmcs.js +1 -0
- package/web-ui/build/static/jolie-DjtNIZB4.js +1 -0
- package/web-ui/build/static/jq-BXdSm79y.js +1 -0
- package/web-ui/build/static/js-extras-B-C7ngCD.js +1 -0
- package/web-ui/build/static/js-templates-CmPAiwFC.js +1 -0
- package/web-ui/build/static/jsdoc-CkiXOOMV.js +1 -0
- package/web-ui/build/static/json-Bmvhezfj.js +1 -0
- package/web-ui/build/static/json-HPR8wBiw.js +1 -0
- package/web-ui/build/static/json5-Chcg9nnQ.js +1 -0
- package/web-ui/build/static/jsonp-C3KWcfzJ.js +1 -0
- package/web-ui/build/static/jsstacktrace-D1jRFy-S.js +1 -0
- package/web-ui/build/static/jsx-COtCqQ_9.js +1 -0
- package/web-ui/build/static/julia-BVvfw2TB.js +1 -0
- package/web-ui/build/static/julia-Ddalvdoa.js +1 -0
- package/web-ui/build/static/julia-repl-Bc-uwnIZ.js +1 -0
- package/web-ui/build/static/keepalived-CJ9ZYuQx.js +1 -0
- package/web-ui/build/static/keyman-BHea-dB6.js +1 -0
- package/web-ui/build/static/kotlin-DWOyCb_2.js +1 -0
- package/web-ui/build/static/kotlin-fvMiFIS3.js +1 -0
- package/web-ui/build/static/kumir-DaNls7gN.js +1 -0
- package/web-ui/build/static/kusto-DKweJuKl.js +1 -0
- package/web-ui/build/static/lasso-BB9dUrv_.js +1 -0
- package/web-ui/build/static/latex-C7U5RUQQ.js +1 -0
- package/web-ui/build/static/latex-CXM3EEy0.js +1 -0
- package/web-ui/build/static/latte-B4pEA635.js +1 -0
- package/web-ui/build/static/ldif-D3wYig10.js +1 -0
- package/web-ui/build/static/leaf-uFkjT9sR.js +1 -0
- package/web-ui/build/static/less-CbUH4jBX.js +1 -0
- package/web-ui/build/static/less-DEGyfeZn.js +1 -0
- package/web-ui/build/static/lilypond-UuoBjShK.js +1 -0
- package/web-ui/build/static/liquid-DB3a9n7S.js +1 -0
- package/web-ui/build/static/lisp-BDbj7Kd2.js +1 -0
- package/web-ui/build/static/lisp-D3T0YOb1.js +1 -0
- package/web-ui/build/static/livecodeserver-CkZMVLmr.js +1 -0
- package/web-ui/build/static/livescript-CJbtbTfA.js +1 -0
- package/web-ui/build/static/livescript-CdWg1xgf.js +1 -0
- package/web-ui/build/static/llvm-8hpjZ6qF.js +1 -0
- package/web-ui/build/static/llvm-DPpuma6i.js +1 -0
- package/web-ui/build/static/log-DwsLgecp.js +1 -0
- package/web-ui/build/static/lolcode-D3tkyiVB.js +1 -0
- package/web-ui/build/static/lsl-BBM4ZYza.js +1 -0
- package/web-ui/build/static/lua-DT0su8pZ.js +1 -0
- package/web-ui/build/static/lua-DqZXmUwn.js +1 -0
- package/web-ui/build/static/magma-DGW0-GCr.js +1 -0
- package/web-ui/build/static/makefile-C_K7AaVw.js +1 -0
- package/web-ui/build/static/makefile-CarddjPJ.js +1 -0
- package/web-ui/build/static/markdown-3dq-8I9T.js +1 -0
- package/web-ui/build/static/markdown-c4VYoNo2.js +1 -0
- package/web-ui/build/static/markup-templating-BBX0gWS5.js +1 -0
- package/web-ui/build/static/mathematica-n-aqoCbO.js +1 -0
- package/web-ui/build/static/matlab-B_kYC-A2.js +1 -0
- package/web-ui/build/static/matlab-CQP2D_0j.js +1 -0
- package/web-ui/build/static/maxima-piaAhCcP.js +1 -0
- package/web-ui/build/static/maxscript-CkxNZR1a.js +1 -0
- package/web-ui/build/static/mel-BXbrV0aU.js +1 -0
- package/web-ui/build/static/mel-CBSpVZcl.js +1 -0
- package/web-ui/build/static/mercury-CffeC87B.js +1 -0
- package/web-ui/build/static/mermaid-DAZcfksM.js +1 -0
- package/web-ui/build/static/mipsasm-DvOPoNgz.js +1 -0
- package/web-ui/build/static/mizar-C2ki99qc.js +1 -0
- package/web-ui/build/static/mizar-C5AXRrsD.js +1 -0
- package/web-ui/build/static/mojolicious-DklqV-uP.js +1 -0
- package/web-ui/build/static/mongodb-BbuSPlN0.js +1 -0
- package/web-ui/build/static/monkey-CJBb2-mV.js +1 -0
- package/web-ui/build/static/monkey-DgERCZQd.js +1 -0
- package/web-ui/build/static/moonscript-BovBU9jW.js +1 -0
- package/web-ui/build/static/moonscript-lPqbcjjy.js +1 -0
- package/web-ui/build/static/n1ql-CjVXW0Z0.js +1 -0
- package/web-ui/build/static/n1ql-DkfG2dTH.js +1 -0
- package/web-ui/build/static/n4js-6L9QW_kw.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-CqohGHfB.js +1 -0
- package/web-ui/build/static/naniscript-CIvQ6y1b.js +1 -0
- package/web-ui/build/static/nasm-CQbJbZZf.js +1 -0
- package/web-ui/build/static/neon-Cz41RJxQ.js +1 -0
- package/web-ui/build/static/nevod-WPRJ2Q9j.js +1 -0
- package/web-ui/build/static/nginx-BL2wPbD-.js +1 -0
- package/web-ui/build/static/nginx-DsqC_gQT.js +1 -0
- package/web-ui/build/static/nim-7qnwzYm_.js +1 -0
- package/web-ui/build/static/nim-D6iDo5H6.js +1 -0
- package/web-ui/build/static/nix-BQSsaH-G.js +1 -0
- package/web-ui/build/static/nix-DgwCtjpD.js +1 -0
- package/web-ui/build/static/node-repl-Cb4w8DbD.js +1 -0
- package/web-ui/build/static/nsis-CiXZWrqR.js +1 -0
- package/web-ui/build/static/nsis-CuwGI5px.js +1 -0
- package/web-ui/build/static/objectivec-DZXCqQ1J.js +1 -0
- package/web-ui/build/static/objectivec-GNGh-wiY.js +1 -0
- package/web-ui/build/static/ocaml-BPg_ANkr.js +1 -0
- package/web-ui/build/static/ocaml-DRUpaN8p.js +1 -0
- package/web-ui/build/static/opencl-CazTs_sf.js +1 -0
- package/web-ui/build/static/openqasm-DHuuXGjm.js +1 -0
- package/web-ui/build/static/openscad-YbvBFeLc.js +1 -0
- package/web-ui/build/static/oxygene-DDzgbCaQ.js +1 -0
- package/web-ui/build/static/oz-BRDBLIjx.js +1 -0
- package/web-ui/build/static/parigp-BbApdos7.js +1 -0
- package/web-ui/build/static/parser-CbVH4ySK.js +1 -0
- package/web-ui/build/static/parser3-BIkvuuuE.js +1 -0
- package/web-ui/build/static/pascal-oS7U_3sO.js +1 -0
- package/web-ui/build/static/pascaligo-57DdFj76.js +1 -0
- package/web-ui/build/static/pcaxis-V-Euf0DV.js +1 -0
- package/web-ui/build/static/peoplecode-DjyRW5V8.js +1 -0
- package/web-ui/build/static/perl-BEQWvjeP.js +1 -0
- package/web-ui/build/static/perl-CiDHRorC.js +1 -0
- package/web-ui/build/static/pf-S5x_U1LC.js +1 -0
- package/web-ui/build/static/pgsql-DwHZC-iy.js +1 -0
- package/web-ui/build/static/php-7enmlb-I.js +1 -0
- package/web-ui/build/static/php-extras-BhRDMlXE.js +1 -0
- package/web-ui/build/static/php-kIwfq-Jj.js +1 -0
- package/web-ui/build/static/php-template-M2RrZc1R.js +1 -0
- package/web-ui/build/static/phpdoc-HUeiWlkw.js +1 -0
- package/web-ui/build/static/plaintext-CPt25ow_.js +1 -0
- package/web-ui/build/static/plsql-BvoRAbdz.js +1 -0
- package/web-ui/build/static/pony-BVuhxk7D.js +1 -0
- package/web-ui/build/static/powerquery-rnRfiL3F.js +1 -0
- package/web-ui/build/static/powershell-BQR2-qjF.js +1 -0
- package/web-ui/build/static/powershell-S_XnLato.js +1 -0
- package/web-ui/build/static/processing-B-8pt1gx.js +1 -0
- package/web-ui/build/static/processing-ozS1KPr7.js +1 -0
- package/web-ui/build/static/profile-DOjTmxRs.js +1 -0
- package/web-ui/build/static/prolog-BaaxuI5L.js +1 -0
- package/web-ui/build/static/prolog-D90dFqfr.js +1 -0
- package/web-ui/build/static/promql-BuyoLqtl.js +1 -0
- package/web-ui/build/static/properties-C0pMastm.js +1 -0
- package/web-ui/build/static/properties-k7bXYQao.js +1 -0
- package/web-ui/build/static/protobuf-ChaO1q7B.js +1 -0
- package/web-ui/build/static/protobuf-DAGxv01T.js +1 -0
- package/web-ui/build/static/psl-BpYOLBqn.js +1 -0
- package/web-ui/build/static/pug-BUlJA4UD.js +1 -0
- package/web-ui/build/static/puppet-8l--PVpO.js +1 -0
- package/web-ui/build/static/puppet-BJDN84xr.js +1 -0
- package/web-ui/build/static/pure-DhqjQg1a.js +1 -0
- package/web-ui/build/static/purebasic-BHnSz9Yh.js +1 -0
- package/web-ui/build/static/purebasic-CeiLO2aV.js +1 -0
- package/web-ui/build/static/purescript-BaXXPnKS.js +1 -0
- package/web-ui/build/static/python-BXdJ4yqN.js +1 -0
- package/web-ui/build/static/python-Cef5Vfx2.js +1 -0
- package/web-ui/build/static/python-repl-CRpJP363.js +1 -0
- package/web-ui/build/static/q-C6Ov0g11.js +1 -0
- package/web-ui/build/static/q-D3tQMiHa.js +1 -0
- package/web-ui/build/static/qml-BYofTHXZ.js +1 -0
- package/web-ui/build/static/qml-DTxi8T37.js +1 -0
- package/web-ui/build/static/qore-Ny7MVtbP.js +1 -0
- package/web-ui/build/static/qsharp-Cy_rqHs2.js +1 -0
- package/web-ui/build/static/r-BtNaz7Jx.js +1 -0
- package/web-ui/build/static/r-DkF7wq0g.js +1 -0
- package/web-ui/build/static/racket-C5r8oFZa.js +1 -0
- package/web-ui/build/static/reason-BURRGL8T.js +1 -0
- package/web-ui/build/static/reasonml-ZPKVqo38.js +1 -0
- package/web-ui/build/static/regex-DgaaAttu.js +1 -0
- package/web-ui/build/static/rego-CtwYq-qp.js +1 -0
- package/web-ui/build/static/renpy-OueysuHf.js +1 -0
- package/web-ui/build/static/rest-Co13hzuk.js +1 -0
- package/web-ui/build/static/rib-CvGWooaO.js +1 -0
- package/web-ui/build/static/rip-5glwZfvx.js +1 -0
- package/web-ui/build/static/roboconf-B9R_ZXBj.js +1 -0
- package/web-ui/build/static/roboconf-Gf0nTNKt.js +1 -0
- package/web-ui/build/static/robotframework-C2axWAv1.js +1 -0
- package/web-ui/build/static/routeros-CE_Iedbm.js +1 -0
- package/web-ui/build/static/rsl-2QjczbcI.js +1 -0
- package/web-ui/build/static/ruby-5q7nApRB.js +1 -0
- package/web-ui/build/static/ruby-BUTeEeQo.js +1 -0
- package/web-ui/build/static/ruleslanguage-vxFl2T6e.js +1 -0
- package/web-ui/build/static/rust-BMuquF4q.js +1 -0
- package/web-ui/build/static/rust-CcZQo8qE.js +1 -0
- package/web-ui/build/static/sas-B3kZio_a.js +1 -0
- package/web-ui/build/static/sas-Bbv6Pcs_.js +1 -0
- package/web-ui/build/static/sass-C0q0q-U-.js +1 -0
- package/web-ui/build/static/scala-B5vW0oUX.js +1 -0
- package/web-ui/build/static/scala-CyVnVDED.js +1 -0
- package/web-ui/build/static/scheme-C9JOo4R_.js +1 -0
- package/web-ui/build/static/scheme-W2233tzx.js +1 -0
- package/web-ui/build/static/scilab-D2Bvw6Ov.js +1 -0
- package/web-ui/build/static/scss-CTlab4AI.js +1 -0
- package/web-ui/build/static/scss-DZ5g2Z9m.js +1 -0
- package/web-ui/build/static/shell-bYpiB--U.js +1 -0
- package/web-ui/build/static/shell-session-C4jzoNup.js +1 -0
- package/web-ui/build/static/smali-9ucoTzDl.js +1 -0
- package/web-ui/build/static/smali-BnluPxDD.js +1 -0
- package/web-ui/build/static/smalltalk-CAMGWItN.js +1 -0
- package/web-ui/build/static/smalltalk-DNxg0Og_.js +1 -0
- package/web-ui/build/static/smarty-YxNaCRZt.js +1 -0
- package/web-ui/build/static/sml-CZbvurr2.js +1 -0
- package/web-ui/build/static/sml-DGs_TRXx.js +1 -0
- package/web-ui/build/static/solidity-CEsviKxI.js +1 -0
- package/web-ui/build/static/solution-file-D0Yvaoet.js +1 -0
- package/web-ui/build/static/soy-BmVAPY7I.js +1 -0
- package/web-ui/build/static/sparql-D8d4i2J8.js +1 -0
- package/web-ui/build/static/splunk-spl-CcgWj5Im.js +1 -0
- package/web-ui/build/static/sqf-Cd4tBlXZ.js +1 -0
- package/web-ui/build/static/sqf-DC8e-wlP.js +1 -0
- package/web-ui/build/static/sql-D5KtfAwl.js +1 -0
- package/web-ui/build/static/sql-DX4iGc5J.js +1 -0
- package/web-ui/build/static/sql_more-9ztUFh5U.js +1 -0
- package/web-ui/build/static/squirrel-CiVV01fQ.js +1 -0
- package/web-ui/build/static/stan-DCrPYtdq.js +1 -0
- package/web-ui/build/static/stan-LL9ScTUT.js +1 -0
- package/web-ui/build/static/stata-n-r5-RvF.js +1 -0
- package/web-ui/build/static/step21-B2hxGG1E.js +1 -0
- package/web-ui/build/static/stylus-D-1wq2uN.js +1 -0
- package/web-ui/build/static/stylus-Dr-w1AjW.js +1 -0
- package/web-ui/build/static/subunit-DRCyiRHI.js +1 -0
- package/web-ui/build/static/swift-B2ZIuBjB.js +1 -0
- package/web-ui/build/static/swift-CnRpp8ao.js +1 -0
- package/web-ui/build/static/systemd-LPN-yj3b.js +1 -0
- package/web-ui/build/static/t4-cs-CXJSMlet.js +1 -0
- package/web-ui/build/static/t4-templating-Ciw3keAZ.js +1 -0
- package/web-ui/build/static/t4-vb-CXe99AWF.js +1 -0
- package/web-ui/build/static/taggerscript-Bm830ZwV.js +1 -0
- package/web-ui/build/static/tap-B0WwYGVt.js +1 -0
- package/web-ui/build/static/tap-Dw_cgj6K.js +1 -0
- package/web-ui/build/static/tcl-Di4JhH4s.js +1 -0
- package/web-ui/build/static/tcl-cIeBNf2V.js +1 -0
- package/web-ui/build/static/textile-DgMdCAz5.js +1 -0
- package/web-ui/build/static/thrift-zY2WxYMk.js +1 -0
- package/web-ui/build/static/toml-BtXdKizf.js +1 -0
- package/web-ui/build/static/tp-DxY0K8UF.js +1 -0
- package/web-ui/build/static/tremor-890wqxvH.js +1 -0
- package/web-ui/build/static/tsx-92ElsKxL.js +1 -0
- package/web-ui/build/static/tt2-DqcvjDKh.js +1 -0
- package/web-ui/build/static/turtle-BZikMsiD.js +1 -0
- package/web-ui/build/static/twig-BlxkEMdw.js +1 -0
- package/web-ui/build/static/twig-CfsoMGnv.js +1 -0
- package/web-ui/build/static/typescript-3xS8yDgH.js +1 -0
- package/web-ui/build/static/typescript-Dx0zHssr.js +1 -0
- package/web-ui/build/static/typoscript-BdFwMGCV.js +1 -0
- package/web-ui/build/static/unrealscript-DJzoqp3G.js +1 -0
- package/web-ui/build/static/uorazor-CQO8Ynpw.js +1 -0
- package/web-ui/build/static/uri-BUBBJdel.js +1 -0
- package/web-ui/build/static/v-XU798JEc.js +1 -0
- package/web-ui/build/static/vala-DsH-Nomr.js +1 -0
- package/web-ui/build/static/vala-gCVw4o0d.js +1 -0
- package/web-ui/build/static/vbnet-BHw8cZ4s.js +1 -0
- package/web-ui/build/static/vbnet-DPa2ddOk.js +1 -0
- package/web-ui/build/static/vbscript-html-CNADYJ1-.js +1 -0
- package/web-ui/build/static/vbscript-ztRmIppj.js +1 -0
- package/web-ui/build/static/velocity-DVfeN53w.js +1 -0
- package/web-ui/build/static/verilog-C9VDLRl9.js +1 -0
- package/web-ui/build/static/verilog-Dsmt_WJW.js +1 -0
- package/web-ui/build/static/vhdl-DbylNGny.js +1 -0
- package/web-ui/build/static/vhdl-wNJe3yKK.js +1 -0
- package/web-ui/build/static/vim-6PLlVaq_.js +1 -0
- package/web-ui/build/static/vim-BJpkTTe-.js +1 -0
- package/web-ui/build/static/visual-basic-GY3wXjJ3.js +1 -0
- package/web-ui/build/static/warpscript-DUb9z3yI.js +1 -0
- package/web-ui/build/static/wasm-Dey0RlHH.js +1 -0
- package/web-ui/build/static/web-idl-qAF1RqaI.js +1 -0
- package/web-ui/build/static/wiki-Dh3Vjtce.js +1 -0
- package/web-ui/build/static/wolfram-BrQcRMlt.js +1 -0
- package/web-ui/build/static/wren-Cu3Mzln6.js +1 -0
- package/web-ui/build/static/x86asm-DD5mhaEi.js +1 -0
- package/web-ui/build/static/xeora-DKRZ6hlr.js +1 -0
- package/web-ui/build/static/xl-BL8R8sAx.js +1 -0
- package/web-ui/build/static/xml-doc-BSpNJbEM.js +1 -0
- package/web-ui/build/static/xml-i5BJyEQ7.js +1 -0
- package/web-ui/build/static/xojo-r2ieNAyP.js +1 -0
- package/web-ui/build/static/xquery-BtAK8Dvl.js +1 -0
- package/web-ui/build/static/xquery-CM4Q_TX7.js +1 -0
- package/web-ui/build/static/yaml-Mm8ArZA3.js +1 -0
- package/web-ui/build/static/yaml-r-QeuY00.js +1 -0
- package/web-ui/build/static/yang-qcKR-Y23.js +1 -0
- package/web-ui/build/static/zephir-8ApHtH7c.js +1 -0
- package/web-ui/build/static/zig-BanqOd9_.js +1 -0
- package/web-ui/build/static/1c-alYWzgyM.js +0 -1
- package/web-ui/build/static/abap-MNX4MGQu.js +0 -1
- package/web-ui/build/static/abnf-PB6umZUe.js +0 -1
- package/web-ui/build/static/abnf-lLelqyRq.js +0 -1
- package/web-ui/build/static/accesslog-ECfnNf6M.js +0 -1
- package/web-ui/build/static/actionscript-48Mv-P2G.js +0 -1
- package/web-ui/build/static/actionscript-CmFMkWAF.js +0 -1
- package/web-ui/build/static/ada-D0nj2830.js +0 -1
- package/web-ui/build/static/ada-DC68kRrL.js +0 -1
- package/web-ui/build/static/agda-CjnuTEYG.js +0 -1
- package/web-ui/build/static/al-DICLGfy9.js +0 -1
- package/web-ui/build/static/angelscript-D7H0wknj.js +0 -1
- package/web-ui/build/static/antlr4-C_KsZIwI.js +0 -1
- package/web-ui/build/static/apache-Cfj2o0TW.js +0 -1
- package/web-ui/build/static/apacheconf-D5jQXqP_.js +0 -1
- package/web-ui/build/static/apex-G2rOb7vm.js +0 -1
- package/web-ui/build/static/apl-CE_aKOLQ.js +0 -1
- package/web-ui/build/static/applescript-BffXi9IZ.js +0 -1
- package/web-ui/build/static/applescript-CshVa-pZ.js +0 -1
- package/web-ui/build/static/aql-F9xr2xIN.js +0 -1
- package/web-ui/build/static/arcade-29Re4fPy.js +0 -1
- package/web-ui/build/static/arduino-BGsZiYrf.js +0 -1
- package/web-ui/build/static/arduino-HiqNS--s.js +0 -1
- package/web-ui/build/static/arff-jPcJv_eJ.js +0 -1
- package/web-ui/build/static/armasm-DDockn0p.js +0 -1
- package/web-ui/build/static/asciidoc-BW3nh79M.js +0 -1
- package/web-ui/build/static/asciidoc-Dxit6U7t.js +0 -1
- package/web-ui/build/static/asm6502-eTpxnsNy.js +0 -1
- package/web-ui/build/static/asmatmel-BHeErmNQ.js +0 -1
- package/web-ui/build/static/aspectj-CX6x53Aw.js +0 -1
- package/web-ui/build/static/aspnet-BFDGvlyU.js +0 -1
- package/web-ui/build/static/autohotkey-CRNZnW-g.js +0 -1
- package/web-ui/build/static/autohotkey-DhdXEUbC.js +0 -1
- package/web-ui/build/static/autoit-BrCU_LoC.js +0 -1
- package/web-ui/build/static/autoit-CNY5ZLoO.js +0 -1
- package/web-ui/build/static/avisynth-CvpX-vR-.js +0 -1
- package/web-ui/build/static/avrasm-Ch0VgbnW.js +0 -1
- package/web-ui/build/static/avro-idl-DVNgaXeA.js +0 -1
- package/web-ui/build/static/awk-DBbMErBm.js +0 -1
- package/web-ui/build/static/axapta-BZMCBJyd.js +0 -1
- package/web-ui/build/static/bash-B7W9_l_H.js +0 -1
- package/web-ui/build/static/bash-nUxPXV93.js +0 -1
- package/web-ui/build/static/basic-CncKWTdb.js +0 -1
- package/web-ui/build/static/basic-t050Yfrj.js +0 -1
- package/web-ui/build/static/batch-DzppEDD6.js +0 -1
- package/web-ui/build/static/bbcode-Cxa6xUCC.js +0 -1
- package/web-ui/build/static/bicep-CNfRbyLD.js +0 -1
- package/web-ui/build/static/birb-BQn3C4qH.js +0 -1
- package/web-ui/build/static/bison-CG1ITN82.js +0 -1
- package/web-ui/build/static/bnf-BH6EqVfg.js +0 -1
- package/web-ui/build/static/bnf-DOOI4ziA.js +0 -1
- package/web-ui/build/static/brainfuck-CuvanNT4.js +0 -1
- package/web-ui/build/static/brainfuck-DEN53aXA.js +0 -1
- package/web-ui/build/static/brightscript-C_qPLhPu.js +0 -1
- package/web-ui/build/static/bro-DE4fdxVn.js +0 -1
- package/web-ui/build/static/bsl-DhilRMN1.js +0 -1
- package/web-ui/build/static/c-DJMkv9RR.js +0 -1
- package/web-ui/build/static/c-HH0eyrSO.js +0 -1
- package/web-ui/build/static/c-like-CievvBLp.js +0 -1
- package/web-ui/build/static/cal-BBz3_HT0.js +0 -1
- package/web-ui/build/static/capnproto-BOgD9Wf3.js +0 -1
- package/web-ui/build/static/ceylon-MWYZBIMt.js +0 -1
- package/web-ui/build/static/cfscript-BiVuxt5i.js +0 -1
- package/web-ui/build/static/chaiscript-CPx7l6f-.js +0 -1
- package/web-ui/build/static/cil-3DGkdNym.js +0 -1
- package/web-ui/build/static/clean-Bxi-hwbJ.js +0 -1
- package/web-ui/build/static/clojure-BBMLjTS9.js +0 -1
- package/web-ui/build/static/clojure-RPrwnP3x.js +0 -1
- package/web-ui/build/static/clojure-repl-BE9VGIhP.js +0 -1
- package/web-ui/build/static/cmake-BMeSZbTq.js +0 -1
- package/web-ui/build/static/cmake-CLVNptnB.js +0 -1
- package/web-ui/build/static/cobol-f-w6Mj2H.js +0 -1
- package/web-ui/build/static/coffeescript-CESbl4tN.js +0 -1
- package/web-ui/build/static/coffeescript-DmOzsrDS.js +0 -1
- package/web-ui/build/static/concurnas-DxQ9U571.js +0 -1
- package/web-ui/build/static/coq-4Wu7fuDB.js +0 -1
- package/web-ui/build/static/coq-BERQ-1c4.js +0 -1
- package/web-ui/build/static/cos-SsvxAn6O.js +0 -1
- package/web-ui/build/static/cpp-BkY4KhJS.js +0 -1
- package/web-ui/build/static/cpp-CGkeKbAD.js +0 -1
- package/web-ui/build/static/crmsh-BL32bNK1.js +0 -1
- package/web-ui/build/static/crystal-C4e562-w.js +0 -1
- package/web-ui/build/static/crystal-Hu8WDm2E.js +0 -1
- package/web-ui/build/static/csharp-DvnJhHBw.js +0 -1
- package/web-ui/build/static/csharp-DxFH-E_J.js +0 -1
- package/web-ui/build/static/cshtml-BkimeLw1.js +0 -1
- package/web-ui/build/static/csp-CDNmbLWI.js +0 -1
- package/web-ui/build/static/csp-DXmobqdr.js +0 -1
- package/web-ui/build/static/css-VRUoX-cu.js +0 -1
- package/web-ui/build/static/css-extras-Dcz-5Gz_.js +0 -1
- package/web-ui/build/static/csv-Cy-vj0dX.js +0 -1
- package/web-ui/build/static/cypher-CyiGMZEd.js +0 -1
- package/web-ui/build/static/d-50yhKzqs.js +0 -1
- package/web-ui/build/static/d-CtQcHe9N.js +0 -1
- package/web-ui/build/static/dart-Dj05IVm2.js +0 -1
- package/web-ui/build/static/dart-kumEUEig.js +0 -1
- package/web-ui/build/static/dataweave-CyaTPvHl.js +0 -1
- package/web-ui/build/static/dax-BYZEUwTe.js +0 -1
- package/web-ui/build/static/delphi-Hrkf0_Zm.js +0 -1
- package/web-ui/build/static/dhall-ZfXZcVvQ.js +0 -1
- package/web-ui/build/static/diff-B681Qorw.js +0 -1
- package/web-ui/build/static/diff-C85U1vU3.js +0 -1
- package/web-ui/build/static/django-BbqkMAd3.js +0 -1
- package/web-ui/build/static/django-ebEm7IW1.js +0 -1
- package/web-ui/build/static/dns-CIKOn0cx.js +0 -1
- package/web-ui/build/static/dns-zone-file-Cgfj303q.js +0 -1
- package/web-ui/build/static/docker-DezZesK-.js +0 -1
- package/web-ui/build/static/dockerfile-HOIJDSPT.js +0 -1
- package/web-ui/build/static/dos-Bv0IPgh2.js +0 -1
- package/web-ui/build/static/dot-BiJIuPYL.js +0 -1
- package/web-ui/build/static/dsconfig-DCPRv9km.js +0 -1
- package/web-ui/build/static/dts-CXMbX7gl.js +0 -1
- package/web-ui/build/static/dust-Mjmn5ftw.js +0 -1
- package/web-ui/build/static/ebnf-469W3R_o.js +0 -1
- package/web-ui/build/static/ebnf-Bs6Ftm9u.js +0 -1
- package/web-ui/build/static/editorconfig-C4dD8cK_.js +0 -1
- package/web-ui/build/static/eiffel-D78uHdvn.js +0 -1
- package/web-ui/build/static/ejs-CUydrtqr.js +0 -1
- package/web-ui/build/static/elixir-BIxlPrSO.js +0 -1
- package/web-ui/build/static/elixir-CLS7rDXm.js +0 -1
- package/web-ui/build/static/elm-CdXXWPN7.js +0 -1
- package/web-ui/build/static/elm-DT7wSSPo.js +0 -1
- package/web-ui/build/static/erb-8Xeo3WFF.js +0 -1
- package/web-ui/build/static/erb-DROzrB_O.js +0 -1
- package/web-ui/build/static/erlang-DbMlkDTN.js +0 -1
- package/web-ui/build/static/erlang-DoF730hs.js +0 -1
- package/web-ui/build/static/erlang-repl-B7enXvga.js +0 -1
- package/web-ui/build/static/etlua-CehWhSD3.js +0 -1
- package/web-ui/build/static/excel-DHmOIegb.js +0 -1
- package/web-ui/build/static/excel-formula-DdeWF1_w.js +0 -1
- package/web-ui/build/static/factor-DBMZ3xT3.js +0 -1
- package/web-ui/build/static/false-AxZ_vqH0.js +0 -1
- package/web-ui/build/static/firestore-security-rules-BChGByFG.js +0 -1
- package/web-ui/build/static/fix-Cc-mOcI9.js +0 -1
- package/web-ui/build/static/flix-CBpO-hKP.js +0 -1
- package/web-ui/build/static/flow-FI5Ahl__.js +0 -1
- package/web-ui/build/static/fortran-C-jW3mxU.js +0 -1
- package/web-ui/build/static/fortran-zFBKdQax.js +0 -1
- package/web-ui/build/static/fsharp-Qu8P7ZfJ.js +0 -1
- package/web-ui/build/static/fsharp-gJT07_u6.js +0 -1
- package/web-ui/build/static/ftl-DcmD2jIl.js +0 -1
- package/web-ui/build/static/gams-BAhsVwik.js +0 -1
- package/web-ui/build/static/gap-DtjJMac5.js +0 -1
- package/web-ui/build/static/gauss-DLNJrvWH.js +0 -1
- package/web-ui/build/static/gcode-CbChIRHG.js +0 -1
- package/web-ui/build/static/gcode-lgPukEuS.js +0 -1
- package/web-ui/build/static/gdscript-ChdqKkXx.js +0 -1
- package/web-ui/build/static/gedcom-B3RAxWnR.js +0 -1
- package/web-ui/build/static/gherkin-BwKe4UMd.js +0 -1
- package/web-ui/build/static/gherkin-D1Q4xoY6.js +0 -1
- package/web-ui/build/static/git-CwA8K3Cg.js +0 -1
- package/web-ui/build/static/glsl-B_AtY5k6.js +0 -1
- package/web-ui/build/static/glsl-BgXyZa9x.js +0 -1
- package/web-ui/build/static/gml-O2ebFipB.js +0 -1
- package/web-ui/build/static/gml-xLusiP_j.js +0 -1
- package/web-ui/build/static/gn-T-uGKQLr.js +0 -1
- package/web-ui/build/static/go-B9spniuU.js +0 -1
- package/web-ui/build/static/go-DTwlbvuB.js +0 -1
- package/web-ui/build/static/go-module-DWCbGNjZ.js +0 -1
- package/web-ui/build/static/golo-Dp3ZC9Ry.js +0 -1
- package/web-ui/build/static/gradle-DxnYLs2J.js +0 -1
- package/web-ui/build/static/graphql-8stFQb3o.js +0 -1
- package/web-ui/build/static/groovy-Dbpy85Rs.js +0 -1
- package/web-ui/build/static/groovy-zimUQS73.js +0 -1
- package/web-ui/build/static/haml-B5gJAH_w.js +0 -1
- package/web-ui/build/static/haml-CXW3L0QY.js +0 -1
- package/web-ui/build/static/handlebars-BW92WxdN.js +0 -1
- package/web-ui/build/static/handlebars-DNysemQE.js +0 -1
- package/web-ui/build/static/haskell-BCP5M1h6.js +0 -1
- package/web-ui/build/static/haskell-BvSwVdJS.js +0 -1
- package/web-ui/build/static/haxe-BBVHLa1y.js +0 -1
- package/web-ui/build/static/haxe-DHK7XQB_.js +0 -1
- package/web-ui/build/static/hcl-CW0_ZJVS.js +0 -1
- package/web-ui/build/static/hlsl-DAH7B5KM.js +0 -1
- package/web-ui/build/static/hoon-CXY0i4p4.js +0 -1
- package/web-ui/build/static/hpkp-RL8DG2Fy.js +0 -1
- package/web-ui/build/static/hsp-DMAT8yb3.js +0 -1
- package/web-ui/build/static/hsts-SOCNnT21.js +0 -1
- package/web-ui/build/static/htmlbars-Bsrm5Qs8.js +0 -1
- package/web-ui/build/static/http-CYjIQwPj.js +0 -1
- package/web-ui/build/static/http-Hu8W9pON.js +0 -1
- package/web-ui/build/static/hy-CDbyyAxf.js +0 -1
- package/web-ui/build/static/ichigojam-CpPBjr7T.js +0 -1
- package/web-ui/build/static/icon-UI22EXz2.js +0 -1
- package/web-ui/build/static/icu-message-format-DAU066Wq.js +0 -1
- package/web-ui/build/static/idris-BuMEL37s.js +0 -1
- package/web-ui/build/static/iecst-CEqwKb_G.js +0 -1
- package/web-ui/build/static/ignore-CcCxTW7I.js +0 -1
- package/web-ui/build/static/index-C9Fa_kgD.css +0 -1
- package/web-ui/build/static/index-DexoK8pu.js +0 -834
- package/web-ui/build/static/index-DgeaGxMy.js +0 -13
- package/web-ui/build/static/index-RM91zq9j.js +0 -1
- package/web-ui/build/static/inform7-BdnukB1N.js +0 -1
- package/web-ui/build/static/inform7-Chkw-Df3.js +0 -1
- package/web-ui/build/static/ini--KUo0NJD.js +0 -1
- package/web-ui/build/static/ini-eo_rWFNv.js +0 -1
- package/web-ui/build/static/io-CWDVYxeI.js +0 -1
- package/web-ui/build/static/irpf90-CWFfmPjK.js +0 -1
- package/web-ui/build/static/isbl-BNkdk_dr.js +0 -1
- package/web-ui/build/static/j-Bg02P4UL.js +0 -1
- package/web-ui/build/static/java-BIDWcDHj.js +0 -1
- package/web-ui/build/static/java-D4bhM1sC.js +0 -1
- package/web-ui/build/static/javadoc-DxxfkSj4.js +0 -1
- package/web-ui/build/static/javadoclike-C3v2LXMS.js +0 -1
- package/web-ui/build/static/javascript-CSu6Pvd7.js +0 -1
- package/web-ui/build/static/javastacktrace-C50AqeNg.js +0 -1
- package/web-ui/build/static/jboss-cli-D4aAEeAL.js +0 -1
- package/web-ui/build/static/jexl-F8wyoUqO.js +0 -1
- package/web-ui/build/static/jolie-CdEDMXNQ.js +0 -1
- package/web-ui/build/static/jq-D95l3yQ0.js +0 -1
- package/web-ui/build/static/js-extras-55OlT8yf.js +0 -1
- package/web-ui/build/static/js-templates-4m7AkoaU.js +0 -1
- package/web-ui/build/static/jsdoc-BC6Ab1D0.js +0 -1
- package/web-ui/build/static/json-BHS2wD8g.js +0 -1
- package/web-ui/build/static/json-CPEJ9diH.js +0 -1
- package/web-ui/build/static/json5-EDQFzkuf.js +0 -1
- package/web-ui/build/static/jsonp-Cn_lpjaf.js +0 -1
- package/web-ui/build/static/jsstacktrace-pqdhqbKV.js +0 -1
- package/web-ui/build/static/jsx-Cop--oM_.js +0 -1
- package/web-ui/build/static/julia-B728rR99.js +0 -1
- package/web-ui/build/static/julia-Cq6vOawm.js +0 -1
- package/web-ui/build/static/julia-repl-BfOfjY_7.js +0 -1
- package/web-ui/build/static/keepalived-6ZwoBjFL.js +0 -1
- package/web-ui/build/static/keyman-DmOLCkH_.js +0 -1
- package/web-ui/build/static/kotlin-Bt385M6s.js +0 -1
- package/web-ui/build/static/kotlin-DsTE9me6.js +0 -1
- package/web-ui/build/static/kumir-DGpgb_2O.js +0 -1
- package/web-ui/build/static/kusto-Bb1U0J5m.js +0 -1
- package/web-ui/build/static/lasso-B4Rh4fa1.js +0 -1
- package/web-ui/build/static/latex-BlKwUVQO.js +0 -1
- package/web-ui/build/static/latex-D4EkT2Sx.js +0 -1
- package/web-ui/build/static/latte-8APUTRqH.js +0 -1
- package/web-ui/build/static/ldif-C1AH3r9Q.js +0 -1
- package/web-ui/build/static/leaf-DgHqqnCU.js +0 -1
- package/web-ui/build/static/less-BmLC9UX9.js +0 -1
- package/web-ui/build/static/less-D7wanA1u.js +0 -1
- package/web-ui/build/static/lilypond-CPpwdP3M.js +0 -1
- package/web-ui/build/static/liquid-C9g89s0-.js +0 -1
- package/web-ui/build/static/lisp-Ck1UA6zq.js +0 -1
- package/web-ui/build/static/lisp-tlR-SVFU.js +0 -1
- package/web-ui/build/static/livecodeserver-CfcVUDKK.js +0 -1
- package/web-ui/build/static/livescript-BPfp_PIe.js +0 -1
- package/web-ui/build/static/livescript-BVClM17E.js +0 -1
- package/web-ui/build/static/llvm-1CmNV1WZ.js +0 -1
- package/web-ui/build/static/llvm-DzaT3xf4.js +0 -1
- package/web-ui/build/static/log-x35sd55_.js +0 -1
- package/web-ui/build/static/lolcode-DfGz4a2C.js +0 -1
- package/web-ui/build/static/lsl-BJ13xzsn.js +0 -1
- package/web-ui/build/static/lua-DHTiU4iK.js +0 -1
- package/web-ui/build/static/lua-DttbbyOa.js +0 -1
- package/web-ui/build/static/magma-CM6u6Urv.js +0 -1
- package/web-ui/build/static/makefile--_TmwP5m.js +0 -1
- package/web-ui/build/static/makefile-DoB_xjMl.js +0 -1
- package/web-ui/build/static/markdown-BnyhT66e.js +0 -1
- package/web-ui/build/static/markdown-DvTREwgd.js +0 -1
- package/web-ui/build/static/markup-templating-yOvzgP3Z.js +0 -1
- package/web-ui/build/static/mathematica-BtY5tmVE.js +0 -1
- package/web-ui/build/static/matlab-DK98sDbn.js +0 -1
- package/web-ui/build/static/matlab-sBcSHRlC.js +0 -1
- package/web-ui/build/static/maxima-DMUOymL4.js +0 -1
- package/web-ui/build/static/maxscript-DaIC7eX6.js +0 -1
- package/web-ui/build/static/mel-BuONpgVc.js +0 -1
- package/web-ui/build/static/mel-Ckh0frDB.js +0 -1
- package/web-ui/build/static/mercury-CDFt4KAe.js +0 -1
- package/web-ui/build/static/mermaid-BqSA7Pr5.js +0 -1
- package/web-ui/build/static/mipsasm-Dj6mne2g.js +0 -1
- package/web-ui/build/static/mizar-CIQIQU-V.js +0 -1
- package/web-ui/build/static/mizar-CLTLHCGu.js +0 -1
- package/web-ui/build/static/mojolicious-DxjS7wDV.js +0 -1
- package/web-ui/build/static/mongodb-BAEipI91.js +0 -1
- package/web-ui/build/static/monkey-BBGnwc6s.js +0 -1
- package/web-ui/build/static/monkey-CvxTCuiS.js +0 -1
- package/web-ui/build/static/moonscript-CqDVk1K9.js +0 -1
- package/web-ui/build/static/moonscript-DJyxvZQc.js +0 -1
- package/web-ui/build/static/n1ql-AFWwB4Xn.js +0 -1
- package/web-ui/build/static/n1ql-VuVk9_MG.js +0 -1
- package/web-ui/build/static/n4js-BH6hpdgG.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-kVewh9V1.js +0 -1
- package/web-ui/build/static/naniscript-B_oQ4TiW.js +0 -1
- package/web-ui/build/static/nasm-B1_bJvcz.js +0 -1
- package/web-ui/build/static/neon-CbXfhQIm.js +0 -1
- package/web-ui/build/static/nevod-5Fv5cPWk.js +0 -1
- package/web-ui/build/static/nginx-BfifkBy-.js +0 -1
- package/web-ui/build/static/nginx-D9toNO0V.js +0 -1
- package/web-ui/build/static/nim-BFN2inD1.js +0 -1
- package/web-ui/build/static/nim-do_UhCvy.js +0 -1
- package/web-ui/build/static/nix-D6RLwwOZ.js +0 -1
- package/web-ui/build/static/nix-djoKaPeE.js +0 -1
- package/web-ui/build/static/node-repl-DDbffQSR.js +0 -1
- package/web-ui/build/static/nsis-BiO6b68i.js +0 -1
- package/web-ui/build/static/nsis-CHzeu7js.js +0 -1
- package/web-ui/build/static/objectivec-B7vXzYuT.js +0 -1
- package/web-ui/build/static/objectivec-BLn212SY.js +0 -1
- package/web-ui/build/static/ocaml-BvpR0Yig.js +0 -1
- package/web-ui/build/static/ocaml-DWZF00Ti.js +0 -1
- package/web-ui/build/static/opencl-C2K2Ctu5.js +0 -1
- package/web-ui/build/static/openqasm-Cbtnnn3m.js +0 -1
- package/web-ui/build/static/openscad-CEPC0-yW.js +0 -1
- package/web-ui/build/static/oxygene-KfcdTXi0.js +0 -1
- package/web-ui/build/static/oz-B-azwNjQ.js +0 -1
- package/web-ui/build/static/parigp-IWtYGphS.js +0 -1
- package/web-ui/build/static/parser-CUCdnJ6l.js +0 -1
- package/web-ui/build/static/parser3--a7jm4Uq.js +0 -1
- package/web-ui/build/static/pascal-BbezKExl.js +0 -1
- package/web-ui/build/static/pascaligo-Bd8IN8hq.js +0 -1
- package/web-ui/build/static/pcaxis-CfT0dd7B.js +0 -1
- package/web-ui/build/static/peoplecode-Dq29i2LW.js +0 -1
- package/web-ui/build/static/perl-BZLc5sMP.js +0 -1
- package/web-ui/build/static/perl-JJmLLJne.js +0 -1
- package/web-ui/build/static/pf-seOENy0q.js +0 -1
- package/web-ui/build/static/pgsql-BtkzXwKY.js +0 -1
- package/web-ui/build/static/php-8b9a1w98.js +0 -1
- package/web-ui/build/static/php-extras-5D00a1Fm.js +0 -1
- package/web-ui/build/static/php-imFv4WXA.js +0 -1
- package/web-ui/build/static/php-template-CI-0RdMu.js +0 -1
- package/web-ui/build/static/phpdoc-DdcPBfc-.js +0 -1
- package/web-ui/build/static/plaintext-Ca1WAvT6.js +0 -1
- package/web-ui/build/static/plsql-CZV7QAnN.js +0 -1
- package/web-ui/build/static/pony-DiomUkGt.js +0 -1
- package/web-ui/build/static/powerquery-CKXX2_O_.js +0 -1
- package/web-ui/build/static/powershell-2Ctsosr0.js +0 -1
- package/web-ui/build/static/powershell-DVPkgaB6.js +0 -1
- package/web-ui/build/static/processing-BAuxATGX.js +0 -1
- package/web-ui/build/static/processing-DBzyjRsf.js +0 -1
- package/web-ui/build/static/profile-Cq2gkRUb.js +0 -1
- package/web-ui/build/static/prolog-ByKO_5p_.js +0 -1
- package/web-ui/build/static/prolog-CDCLze6j.js +0 -1
- package/web-ui/build/static/promql-BYOPu10L.js +0 -1
- package/web-ui/build/static/properties-kP8T8mqV.js +0 -1
- package/web-ui/build/static/properties-zdANIr61.js +0 -1
- package/web-ui/build/static/protobuf-DhAYlNOg.js +0 -1
- package/web-ui/build/static/protobuf-a1lLQN1f.js +0 -1
- package/web-ui/build/static/psl-DpP1u6wu.js +0 -1
- package/web-ui/build/static/pug-BobY0hsa.js +0 -1
- package/web-ui/build/static/puppet-CDimLnep.js +0 -1
- package/web-ui/build/static/puppet-D7DLS3gG.js +0 -1
- package/web-ui/build/static/pure-4QGsilHw.js +0 -1
- package/web-ui/build/static/purebasic-D0wI4z6w.js +0 -1
- package/web-ui/build/static/purebasic-Du_RxI7h.js +0 -1
- package/web-ui/build/static/purescript-CM92Fn9c.js +0 -1
- package/web-ui/build/static/python-Bvcn81x2.js +0 -1
- package/web-ui/build/static/python-CkfwrdRF.js +0 -1
- package/web-ui/build/static/python-repl-C48-EfyF.js +0 -1
- package/web-ui/build/static/q-B2-zP3za.js +0 -1
- package/web-ui/build/static/q-KuKa9s_e.js +0 -1
- package/web-ui/build/static/qml-D8j38-Sx.js +0 -1
- package/web-ui/build/static/qml-DTP6fbZN.js +0 -1
- package/web-ui/build/static/qore-DY-n97IK.js +0 -1
- package/web-ui/build/static/qsharp-Mn8hUKww.js +0 -1
- package/web-ui/build/static/r-BBPYkuMA.js +0 -1
- package/web-ui/build/static/r-CheuVCRq.js +0 -1
- package/web-ui/build/static/racket-2UxWXIqI.js +0 -1
- package/web-ui/build/static/reason-CudKWaht.js +0 -1
- package/web-ui/build/static/reasonml-BDZgwPxq.js +0 -1
- package/web-ui/build/static/regex-DpKrn61Z.js +0 -1
- package/web-ui/build/static/rego-CS2iMzor.js +0 -1
- package/web-ui/build/static/renpy-0CbyBFae.js +0 -1
- package/web-ui/build/static/rest-Ckpz2bGS.js +0 -1
- package/web-ui/build/static/rib-g77eioCq.js +0 -1
- package/web-ui/build/static/rip-L-KlpyJn.js +0 -1
- package/web-ui/build/static/roboconf-BkNeb0Yn.js +0 -1
- package/web-ui/build/static/roboconf-CE-yfGxs.js +0 -1
- package/web-ui/build/static/robotframework-ZhLv32cH.js +0 -1
- package/web-ui/build/static/routeros-C_1I4hFK.js +0 -1
- package/web-ui/build/static/rsl-CxEYmrJa.js +0 -1
- package/web-ui/build/static/ruby-Cgxmv3hM.js +0 -1
- package/web-ui/build/static/ruby-Cs4qnUzE.js +0 -1
- package/web-ui/build/static/ruleslanguage-DPK5B1Dg.js +0 -1
- package/web-ui/build/static/rust-BbVN6hMu.js +0 -1
- package/web-ui/build/static/rust-C6MrX2UK.js +0 -1
- package/web-ui/build/static/sas-CGov9per.js +0 -1
- package/web-ui/build/static/sas-Cp88q4DD.js +0 -1
- package/web-ui/build/static/sass-COOJqQer.js +0 -1
- package/web-ui/build/static/scala-BvOmMtdv.js +0 -1
- package/web-ui/build/static/scala-D5gnz3xs.js +0 -1
- package/web-ui/build/static/scheme-CNBfxsvv.js +0 -1
- package/web-ui/build/static/scheme-DiKuURfA.js +0 -1
- package/web-ui/build/static/scilab-vGKouaTh.js +0 -1
- package/web-ui/build/static/scss-B4PKgroe.js +0 -1
- package/web-ui/build/static/scss-BvRxfJ1U.js +0 -1
- package/web-ui/build/static/shell-B5TooOs0.js +0 -1
- package/web-ui/build/static/shell-session-TNT_ahRW.js +0 -1
- package/web-ui/build/static/smali-CiIXEKzG.js +0 -1
- package/web-ui/build/static/smali-EGdSXgM9.js +0 -1
- package/web-ui/build/static/smalltalk-DVAXFBVS.js +0 -1
- package/web-ui/build/static/smalltalk-Dfy8hlRv.js +0 -1
- package/web-ui/build/static/smarty-Rc2y-rm6.js +0 -1
- package/web-ui/build/static/sml-BoYe_d8x.js +0 -1
- package/web-ui/build/static/sml-CaIv1GsI.js +0 -1
- package/web-ui/build/static/solidity-Dem-6tsD.js +0 -1
- package/web-ui/build/static/solution-file-DfDjJASp.js +0 -1
- package/web-ui/build/static/soy-CkrJH5eW.js +0 -1
- package/web-ui/build/static/sparql-Dvg1P5oN.js +0 -1
- package/web-ui/build/static/splunk-spl-rB2pJQdl.js +0 -1
- package/web-ui/build/static/sqf-Cj_KV-kC.js +0 -1
- package/web-ui/build/static/sqf-DA_tj5Fb.js +0 -1
- package/web-ui/build/static/sql-CYDE0gzH.js +0 -1
- package/web-ui/build/static/sql-D8byAq-B.js +0 -1
- package/web-ui/build/static/sql_more-bMORpicj.js +0 -1
- package/web-ui/build/static/squirrel-rgwbGN0q.js +0 -1
- package/web-ui/build/static/stan-C-OYiHTu.js +0 -1
- package/web-ui/build/static/stan-CT8cMsn7.js +0 -1
- package/web-ui/build/static/stata-BJwZeN-z.js +0 -1
- package/web-ui/build/static/step21-WP26kxkW.js +0 -1
- package/web-ui/build/static/stylus-Cw9up-Iv.js +0 -1
- package/web-ui/build/static/stylus-CyFEQpH2.js +0 -1
- package/web-ui/build/static/subunit-B2XhtaLx.js +0 -1
- package/web-ui/build/static/swift-Bpyyuvtg.js +0 -1
- package/web-ui/build/static/swift-D-jiKNlA.js +0 -1
- package/web-ui/build/static/systemd-DE3AeWrd.js +0 -1
- package/web-ui/build/static/t4-cs-BSG7rkB_.js +0 -1
- package/web-ui/build/static/t4-templating-Cy7LuqAv.js +0 -1
- package/web-ui/build/static/t4-vb-ZLfMjXrh.js +0 -1
- package/web-ui/build/static/taggerscript-q2zFfkel.js +0 -1
- package/web-ui/build/static/tap-CzjhWyhf.js +0 -1
- package/web-ui/build/static/tap-ttXfPums.js +0 -1
- package/web-ui/build/static/tcl-6ta1XDva.js +0 -1
- package/web-ui/build/static/tcl-Cvx4AN_Q.js +0 -1
- package/web-ui/build/static/textile-zWm4gRbJ.js +0 -1
- package/web-ui/build/static/thrift-Crj4hRsm.js +0 -1
- package/web-ui/build/static/toml-hVfLOJr-.js +0 -1
- package/web-ui/build/static/tp-D5aJh4yF.js +0 -1
- package/web-ui/build/static/tremor-B9gWC4v1.js +0 -1
- package/web-ui/build/static/tsx-DtNWBAJO.js +0 -1
- package/web-ui/build/static/tt2-eH1L7Bpm.js +0 -1
- package/web-ui/build/static/turtle-BYCk4r6f.js +0 -1
- package/web-ui/build/static/twig-BQ-dq4no.js +0 -1
- package/web-ui/build/static/twig-n3AiXKyV.js +0 -1
- package/web-ui/build/static/typescript-CPQ0vD90.js +0 -1
- package/web-ui/build/static/typescript-juxiNWRf.js +0 -1
- package/web-ui/build/static/typoscript-C5h9SqFN.js +0 -1
- package/web-ui/build/static/unrealscript-9ht7jiai.js +0 -1
- package/web-ui/build/static/uorazor-36B6okgA.js +0 -1
- package/web-ui/build/static/uri-DEwrtmz_.js +0 -1
- package/web-ui/build/static/v-CvhXAFWo.js +0 -1
- package/web-ui/build/static/vala-CU_jVQ3c.js +0 -1
- package/web-ui/build/static/vala-H_yoFBZf.js +0 -1
- package/web-ui/build/static/vbnet-BNI0Gy5q.js +0 -1
- package/web-ui/build/static/vbnet-D-4O1Hpc.js +0 -1
- package/web-ui/build/static/vbscript-1zyalaSG.js +0 -1
- package/web-ui/build/static/vbscript-html-ea5_TYi7.js +0 -1
- package/web-ui/build/static/velocity-BlEdS1Un.js +0 -1
- package/web-ui/build/static/verilog-BGSIJuDJ.js +0 -1
- package/web-ui/build/static/verilog-C1vff5Z3.js +0 -1
- package/web-ui/build/static/vhdl-5H4C8O-_.js +0 -1
- package/web-ui/build/static/vhdl-DHiBEhsE.js +0 -1
- package/web-ui/build/static/vim-Bd1MNlxj.js +0 -1
- package/web-ui/build/static/vim-DBP2ZsgQ.js +0 -1
- package/web-ui/build/static/visual-basic-DI34-9vJ.js +0 -1
- package/web-ui/build/static/warpscript-DBQ-KbS6.js +0 -1
- package/web-ui/build/static/wasm-CY5W57_Y.js +0 -1
- package/web-ui/build/static/web-idl-CF9xaLpZ.js +0 -1
- package/web-ui/build/static/wiki-xfSWwdeC.js +0 -1
- package/web-ui/build/static/wolfram-DZ6ghwRH.js +0 -1
- package/web-ui/build/static/wren-qULNE4ZV.js +0 -1
- package/web-ui/build/static/x86asm-DD2-d5-3.js +0 -1
- package/web-ui/build/static/xeora-CMja58lL.js +0 -1
- package/web-ui/build/static/xl-DKZpXGv8.js +0 -1
- package/web-ui/build/static/xml-Xf5ErmV_.js +0 -1
- package/web-ui/build/static/xml-doc-Bl_99SZE.js +0 -1
- package/web-ui/build/static/xojo-PwcPgmIF.js +0 -1
- package/web-ui/build/static/xquery-BshbqrZe.js +0 -1
- package/web-ui/build/static/xquery-DY2-GgvB.js +0 -1
- package/web-ui/build/static/yaml-9mp-mYjQ.js +0 -1
- package/web-ui/build/static/yaml-BnH4Y8-L.js +0 -1
- package/web-ui/build/static/yang-CRK7RS7V.js +0 -1
- package/web-ui/build/static/zephir-B560hCdS.js +0 -1
- package/web-ui/build/static/zig-CBG6H3iO.js +0 -1
|
@@ -81,6 +81,15 @@ jest.unstable_mockModule('../baseTool.js', () => ({
|
|
|
81
81
|
this.lastUsed = null;
|
|
82
82
|
this.usageCount = 0;
|
|
83
83
|
}
|
|
84
|
+
// Mirror real BaseTool#getEffectiveConfig so the per-agent config gate
|
|
85
|
+
// in fileSystemTool.execute() works under test. Real helper lives in
|
|
86
|
+
// src/tools/baseTool.js — change in lockstep if you touch it.
|
|
87
|
+
getEffectiveConfig(context, fallbacks = {}) {
|
|
88
|
+
const perAgent = (context && context.toolConfig && typeof context.toolConfig === 'object' && !Array.isArray(context.toolConfig))
|
|
89
|
+
? context.toolConfig
|
|
90
|
+
: {};
|
|
91
|
+
return { ...fallbacks, ...(this.config || {}), ...perAgent };
|
|
92
|
+
}
|
|
84
93
|
}
|
|
85
94
|
}));
|
|
86
95
|
|
|
@@ -714,4 +723,93 @@ describe('FileSystemTool', () => {
|
|
|
714
723
|
expect(actions).toContain('stats');
|
|
715
724
|
});
|
|
716
725
|
});
|
|
726
|
+
|
|
727
|
+
// Per-agent overrides via context.toolConfig (agent.toolConfig.filesystem)
|
|
728
|
+
// — merged into effective config by BaseTool#getEffectiveConfig at
|
|
729
|
+
// execute time, then applied as a per-action gate above the existing
|
|
730
|
+
// path-access and size checks.
|
|
731
|
+
describe('per-agent toolConfig overrides', () => {
|
|
732
|
+
test('per-agent blockedExtensions blocks a previously-allowed extension', async () => {
|
|
733
|
+
const { tool, context } = createTestSetup();
|
|
734
|
+
const result = await tool.execute(
|
|
735
|
+
{ actions: [{ type: 'read', filePath: '/tmp/test/secret.env' }] },
|
|
736
|
+
{ ...context, toolConfig: { blockedExtensions: ['.env'] } }
|
|
737
|
+
);
|
|
738
|
+
expect(result.actions[0].success).toBe(false);
|
|
739
|
+
expect(result.actions[0].error).toMatch(/blocked by agent policy/);
|
|
740
|
+
// No actual read attempted.
|
|
741
|
+
expect(fsMock.readFile).not.toHaveBeenCalled();
|
|
742
|
+
});
|
|
743
|
+
|
|
744
|
+
test('per-agent allowedExtensions rejects anything outside the list', async () => {
|
|
745
|
+
const { tool, context } = createTestSetup();
|
|
746
|
+
const result = await tool.execute(
|
|
747
|
+
{ actions: [{ type: 'read', filePath: '/tmp/test/app.js' }] },
|
|
748
|
+
{ ...context, toolConfig: { allowedExtensions: ['.ts'] } }
|
|
749
|
+
);
|
|
750
|
+
expect(result.actions[0].success).toBe(false);
|
|
751
|
+
expect(result.actions[0].error).toMatch(/not in the agent's allowed list/);
|
|
752
|
+
expect(fsMock.readFile).not.toHaveBeenCalled();
|
|
753
|
+
});
|
|
754
|
+
|
|
755
|
+
test('per-agent allowedExtensions accepts matches', async () => {
|
|
756
|
+
const { tool, context } = createTestSetup();
|
|
757
|
+
const result = await tool.execute(
|
|
758
|
+
{ actions: [{ type: 'read', filePath: '/tmp/test/app.js' }] },
|
|
759
|
+
{ ...context, toolConfig: { allowedExtensions: ['.js'] } }
|
|
760
|
+
);
|
|
761
|
+
expect(result.actions[0].success).toBe(true);
|
|
762
|
+
});
|
|
763
|
+
|
|
764
|
+
test('per-agent maxFileSize rejects oversized write payload', async () => {
|
|
765
|
+
const { tool, context } = createTestSetup();
|
|
766
|
+
const bigContent = 'x'.repeat(500);
|
|
767
|
+
const result = await tool.execute(
|
|
768
|
+
{
|
|
769
|
+
actions: [{ type: 'write', outputPath: 'big.txt', content: bigContent }],
|
|
770
|
+
},
|
|
771
|
+
{ ...context, toolConfig: { maxFileSize: 100 } }
|
|
772
|
+
);
|
|
773
|
+
expect(result.actions[0].success).toBe(false);
|
|
774
|
+
expect(result.actions[0].error).toMatch(/too large/);
|
|
775
|
+
expect(result.actions[0].error).toMatch(/per-agent maxFileSize/);
|
|
776
|
+
expect(fsMock.writeFile).not.toHaveBeenCalled();
|
|
777
|
+
});
|
|
778
|
+
|
|
779
|
+
test('per-agent maxFileSize accepts payloads within limit', async () => {
|
|
780
|
+
const { tool, context } = createTestSetup();
|
|
781
|
+
const content = 'hello';
|
|
782
|
+
// Mirror the mock setup used by the existing write tests so the
|
|
783
|
+
// verify-after-write step finds the file with matching size.
|
|
784
|
+
fsMock.access.mockRejectedValueOnce(new Error('ENOENT'));
|
|
785
|
+
fsMock.stat.mockResolvedValue(mockStatResult({ size: Buffer.byteLength(content) }));
|
|
786
|
+
fsMock.readFile.mockResolvedValue(content);
|
|
787
|
+
|
|
788
|
+
const result = await tool.execute(
|
|
789
|
+
{ actions: [{ type: 'write', outputPath: 'ok.txt', content }] },
|
|
790
|
+
{ ...context, toolConfig: { maxFileSize: 1_000_000 } }
|
|
791
|
+
);
|
|
792
|
+
expect(result.actions[0].success).toBe(true);
|
|
793
|
+
expect(fsMock.writeFile).toHaveBeenCalled();
|
|
794
|
+
});
|
|
795
|
+
|
|
796
|
+
test('blocked wins over allowed when both set', async () => {
|
|
797
|
+
const { tool, context } = createTestSetup();
|
|
798
|
+
const result = await tool.execute(
|
|
799
|
+
{ actions: [{ type: 'read', filePath: '/tmp/test/app.js' }] },
|
|
800
|
+
{ ...context, toolConfig: { allowedExtensions: ['.js'], blockedExtensions: ['.js'] } }
|
|
801
|
+
);
|
|
802
|
+
expect(result.actions[0].success).toBe(false);
|
|
803
|
+
expect(result.actions[0].error).toMatch(/blocked by agent policy/);
|
|
804
|
+
});
|
|
805
|
+
|
|
806
|
+
test('no toolConfig → original behaviour preserved', async () => {
|
|
807
|
+
const { tool, context } = createTestSetup();
|
|
808
|
+
const result = await tool.execute(
|
|
809
|
+
{ actions: [{ type: 'read', filePath: '/tmp/test/app.js' }] },
|
|
810
|
+
context
|
|
811
|
+
);
|
|
812
|
+
expect(result.actions[0].success).toBe(true);
|
|
813
|
+
});
|
|
814
|
+
});
|
|
717
815
|
});
|
|
@@ -0,0 +1,363 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration tests for the memoryTool `reminisce` action.
|
|
3
|
+
*
|
|
4
|
+
* Exercises the full path: tool.execute({action: 'reminisce', ...}) →
|
|
5
|
+
* _executeReminisce → agentPool.getAgent → conversationQuery.<mode> →
|
|
6
|
+
* shaped result. The per-mode semantics are unit-tested exhaustively in
|
|
7
|
+
* services/__tests__/conversationQuery.test.js; these tests focus on the
|
|
8
|
+
* wiring: action validation, context requirements, agent fetching, and
|
|
9
|
+
* error paths.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
13
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
14
|
+
|
|
15
|
+
jest.unstable_mockModule('../../services/memoryService.js', () => ({
|
|
16
|
+
getMemoryService: jest.fn(() => ({
|
|
17
|
+
initialize: jest.fn().mockResolvedValue(undefined),
|
|
18
|
+
})),
|
|
19
|
+
}));
|
|
20
|
+
|
|
21
|
+
const { default: MemoryTool } = await import('../memoryTool.js');
|
|
22
|
+
|
|
23
|
+
function makeMessages(n) {
|
|
24
|
+
return Array.from({ length: n }, (_, i) => ({
|
|
25
|
+
id: `msg_${String(i).padStart(4, '0')}`,
|
|
26
|
+
role: i % 2 === 0 ? 'user' : 'assistant',
|
|
27
|
+
content: `message ${i}${i === 5 ? ' contains special keyword' : ''}`,
|
|
28
|
+
createdAt: new Date(Date.UTC(2026, 0, 1, 0, 0, i)).toISOString(),
|
|
29
|
+
tokenUsage: { totalTokens: 10 },
|
|
30
|
+
toolExecutions: i === 7 ? [{ toolId: 'terminal', input: 'ls -la' }] : [],
|
|
31
|
+
}));
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function makeSetup({ messages = null, agentExists = true } = {}) {
|
|
35
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
36
|
+
const agent = agentExists ? {
|
|
37
|
+
id: 'agent-1',
|
|
38
|
+
conversations: messages ? { full: { messages } } : { full: { messages: makeMessages(20) } },
|
|
39
|
+
} : null;
|
|
40
|
+
const agentPool = {
|
|
41
|
+
getAgent: jest.fn().mockResolvedValue(agent),
|
|
42
|
+
};
|
|
43
|
+
const context = { agentId: 'agent-1', agentPool };
|
|
44
|
+
return { tool, agent, agentPool, context };
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
describe('memoryTool reminisce — wiring', () => {
|
|
48
|
+
let tool, context, agentPool;
|
|
49
|
+
beforeEach(() => {
|
|
50
|
+
({ tool, context, agentPool } = makeSetup());
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
test('overview mode returns archive stats + timeline', async () => {
|
|
54
|
+
const out = await tool.execute({ action: 'reminisce', mode: 'overview' }, context);
|
|
55
|
+
expect(out.success).toBe(true);
|
|
56
|
+
expect(out.mode).toBe('overview');
|
|
57
|
+
expect(out.result.totalMessages).toBe(20);
|
|
58
|
+
expect(out.result.timeline.length).toBeGreaterThan(0);
|
|
59
|
+
expect(out.result.timeline[0].messageId).toBe('msg_0000');
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
test('range mode paginates', async () => {
|
|
63
|
+
const out = await tool.execute(
|
|
64
|
+
{ action: 'reminisce', mode: 'range', offset: 5, limit: 3 },
|
|
65
|
+
context
|
|
66
|
+
);
|
|
67
|
+
expect(out.success).toBe(true);
|
|
68
|
+
expect(out.result.messages.length).toBe(3);
|
|
69
|
+
expect(out.result.messages[0].messageId).toBe('msg_0005');
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
test('search finds matches in content', async () => {
|
|
73
|
+
const out = await tool.execute(
|
|
74
|
+
{ action: 'reminisce', mode: 'search', query: 'special keyword' },
|
|
75
|
+
context
|
|
76
|
+
);
|
|
77
|
+
expect(out.success).toBe(true);
|
|
78
|
+
expect(out.result.matches.length).toBeGreaterThan(0);
|
|
79
|
+
expect(out.result.matches[0].messageId).toBe('msg_0005');
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
test('around resolves a bookmarked messageId', async () => {
|
|
83
|
+
const out = await tool.execute(
|
|
84
|
+
{ action: 'reminisce', mode: 'around', messageId: 'msg_0010', before: 2, after: 2 },
|
|
85
|
+
context
|
|
86
|
+
);
|
|
87
|
+
expect(out.success).toBe(true);
|
|
88
|
+
expect(out.result.targetFound).toBe(true);
|
|
89
|
+
expect(out.result.messages.map(m => m.messageId)).toContain('msg_0010');
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
test('byTool lists tool calls', async () => {
|
|
93
|
+
const out = await tool.execute(
|
|
94
|
+
{ action: 'reminisce', mode: 'byTool' },
|
|
95
|
+
context
|
|
96
|
+
);
|
|
97
|
+
expect(out.success).toBe(true);
|
|
98
|
+
expect(out.result.toolCalls.length).toBe(1);
|
|
99
|
+
expect(out.result.toolCalls[0].toolId).toBe('terminal');
|
|
100
|
+
expect(out.result.toolCalls[0].messageId).toBe('msg_0007');
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
test('read returns the whole message when no window is specified', async () => {
|
|
104
|
+
const out = await tool.execute(
|
|
105
|
+
{ action: 'reminisce', mode: 'read', messageId: 'msg_0005' },
|
|
106
|
+
context
|
|
107
|
+
);
|
|
108
|
+
expect(out.success).toBe(true);
|
|
109
|
+
expect(out.result.targetFound).toBe(true);
|
|
110
|
+
expect(out.result.message.messageId).toBe('msg_0005');
|
|
111
|
+
expect(out.result.message.contentWindow.kind).toBe('full');
|
|
112
|
+
expect(out.result.message.content).toContain('special keyword');
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
test('read with lineFrom/lineTo returns a line slice', async () => {
|
|
116
|
+
// Replace msg_0005 with a multi-line message so the slice is meaningful.
|
|
117
|
+
const bigContent = Array.from({ length: 50 }, (_, i) => `line ${i + 1}`).join('\n');
|
|
118
|
+
const localMessages = makeMessages(20);
|
|
119
|
+
localMessages[5] = { ...localMessages[5], content: bigContent };
|
|
120
|
+
const local = makeSetup({ messages: localMessages });
|
|
121
|
+
|
|
122
|
+
const out = await local.tool.execute(
|
|
123
|
+
{ action: 'reminisce', mode: 'read', messageId: 'msg_0005',
|
|
124
|
+
lineFrom: 10, lineTo: 14 },
|
|
125
|
+
local.context
|
|
126
|
+
);
|
|
127
|
+
expect(out.result.message.contentWindow.kind).toBe('lines');
|
|
128
|
+
expect(out.result.message.contentWindow.totalLines).toBe(50);
|
|
129
|
+
const lines = out.result.message.content.split('\n');
|
|
130
|
+
expect(lines).toEqual(['line 10', 'line 11', 'line 12', 'line 13', 'line 14']);
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
test('read with contentFrom/contentTo returns a char slice', async () => {
|
|
134
|
+
const localMessages = makeMessages(20);
|
|
135
|
+
localMessages[5] = { ...localMessages[5], content: 'abcdefghijklmnopqrstuvwxyz' };
|
|
136
|
+
const local = makeSetup({ messages: localMessages });
|
|
137
|
+
|
|
138
|
+
const out = await local.tool.execute(
|
|
139
|
+
{ action: 'reminisce', mode: 'read', messageId: 'msg_0005',
|
|
140
|
+
contentFrom: 5, contentTo: 10 },
|
|
141
|
+
local.context
|
|
142
|
+
);
|
|
143
|
+
expect(out.result.message.contentWindow.kind).toBe('chars');
|
|
144
|
+
expect(out.result.message.content).toBe('fghij');
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
test('read with unknown messageId returns targetFound=false (not a crash)', async () => {
|
|
148
|
+
const out = await tool.execute(
|
|
149
|
+
{ action: 'reminisce', mode: 'read', messageId: 'msg_hallucinated' },
|
|
150
|
+
context
|
|
151
|
+
);
|
|
152
|
+
expect(out.success).toBe(true);
|
|
153
|
+
expect(out.result.targetFound).toBe(false);
|
|
154
|
+
expect(out.result.message).toBeNull();
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
test('read surfaces hasReasoning + reasoningTokens but omits text by default', async () => {
|
|
158
|
+
const localMessages = makeMessages(20);
|
|
159
|
+
localMessages[5] = {
|
|
160
|
+
...localMessages[5],
|
|
161
|
+
reasoning: 'Chain of thought: first I need to analyze...',
|
|
162
|
+
reasoningTokens: 512,
|
|
163
|
+
};
|
|
164
|
+
const local = makeSetup({ messages: localMessages });
|
|
165
|
+
const out = await local.tool.execute(
|
|
166
|
+
{ action: 'reminisce', mode: 'read', messageId: 'msg_0005' },
|
|
167
|
+
local.context
|
|
168
|
+
);
|
|
169
|
+
expect(out.result.message.hasReasoning).toBe(true);
|
|
170
|
+
expect(out.result.message.reasoningTokens).toBe(512);
|
|
171
|
+
expect(out.result.message.reasoning).toBeUndefined();
|
|
172
|
+
});
|
|
173
|
+
|
|
174
|
+
test('read with includeReasoning=true returns the reasoning text', async () => {
|
|
175
|
+
const localMessages = makeMessages(20);
|
|
176
|
+
const thought = 'Step 1: analyze. Step 2: decide. Step 3: act.';
|
|
177
|
+
localMessages[5] = {
|
|
178
|
+
...localMessages[5],
|
|
179
|
+
reasoning: thought,
|
|
180
|
+
reasoningTokens: 200,
|
|
181
|
+
};
|
|
182
|
+
const local = makeSetup({ messages: localMessages });
|
|
183
|
+
const out = await local.tool.execute(
|
|
184
|
+
{ action: 'reminisce', mode: 'read', messageId: 'msg_0005', includeReasoning: true },
|
|
185
|
+
local.context
|
|
186
|
+
);
|
|
187
|
+
expect(out.result.message.reasoning).toBe(thought);
|
|
188
|
+
});
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
describe('memoryTool reminisce — error paths', () => {
|
|
192
|
+
test('invalid mode returns a clean error', async () => {
|
|
193
|
+
const { tool, context } = makeSetup();
|
|
194
|
+
const out = await tool.execute({ action: 'reminisce', mode: 'bogus' }, context);
|
|
195
|
+
expect(out.success).toBe(false);
|
|
196
|
+
expect(out.error).toMatch(/mode must be one of/);
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
test('missing mode returns a clean error (not a crash)', async () => {
|
|
200
|
+
const { tool, context } = makeSetup();
|
|
201
|
+
const out = await tool.execute({ action: 'reminisce' }, context);
|
|
202
|
+
expect(out.success).toBe(false);
|
|
203
|
+
expect(out.error).toMatch(/mode must be one of/);
|
|
204
|
+
});
|
|
205
|
+
|
|
206
|
+
test('missing agentPool in context returns a clean error', async () => {
|
|
207
|
+
const { tool } = makeSetup();
|
|
208
|
+
const out = await tool.execute(
|
|
209
|
+
{ action: 'reminisce', mode: 'overview' },
|
|
210
|
+
{ agentId: 'agent-1' /* no agentPool */ }
|
|
211
|
+
);
|
|
212
|
+
expect(out.success).toBe(false);
|
|
213
|
+
expect(out.error).toMatch(/agentPool/);
|
|
214
|
+
});
|
|
215
|
+
|
|
216
|
+
test('agent not found returns a clean error', async () => {
|
|
217
|
+
const { tool, context } = makeSetup({ agentExists: false });
|
|
218
|
+
const out = await tool.execute({ action: 'reminisce', mode: 'overview' }, context);
|
|
219
|
+
expect(out.success).toBe(false);
|
|
220
|
+
expect(out.error).toMatch(/not found/);
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
test('agent with no conversation archive returns success with empty flag', async () => {
|
|
224
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
225
|
+
const agentPool = {
|
|
226
|
+
getAgent: jest.fn().mockResolvedValue({ id: 'a', conversations: {} }),
|
|
227
|
+
};
|
|
228
|
+
const out = await tool.execute(
|
|
229
|
+
{ action: 'reminisce', mode: 'overview' },
|
|
230
|
+
{ agentId: 'a', agentPool }
|
|
231
|
+
);
|
|
232
|
+
expect(out.success).toBe(true);
|
|
233
|
+
expect(out.result.empty).toBe(true);
|
|
234
|
+
});
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
describe('memoryTool reminisce — archive durability through compaction', () => {
|
|
238
|
+
/*
|
|
239
|
+
* Contract test: even after compaction writes to conversations[model],
|
|
240
|
+
* reminisce must still serve the pre-compaction messages from
|
|
241
|
+
* conversations.full. This simulates the durability invariant that the
|
|
242
|
+
* whole feature rests on.
|
|
243
|
+
*/
|
|
244
|
+
test('reads conversations.full even when per-model compacted views exist', async () => {
|
|
245
|
+
const fullMessages = makeMessages(10);
|
|
246
|
+
const compactedMessages = [
|
|
247
|
+
{ id: 'compacted_1', role: 'system', content: '[summary of 10 messages]',
|
|
248
|
+
createdAt: new Date().toISOString(), tokenUsage: { totalTokens: 200 } },
|
|
249
|
+
];
|
|
250
|
+
const agent = {
|
|
251
|
+
id: 'a',
|
|
252
|
+
conversations: {
|
|
253
|
+
full: { messages: fullMessages },
|
|
254
|
+
'gpt-5': { messages: compactedMessages }, // compacted view
|
|
255
|
+
'claude-opus': { messages: compactedMessages }, // another compacted view
|
|
256
|
+
},
|
|
257
|
+
};
|
|
258
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
259
|
+
const context = { agentId: 'a', agentPool: { getAgent: () => Promise.resolve(agent) } };
|
|
260
|
+
|
|
261
|
+
const out = await tool.execute({ action: 'reminisce', mode: 'overview' }, context);
|
|
262
|
+
expect(out.success).toBe(true);
|
|
263
|
+
// totalMessages reflects the FULL archive, not the compacted view.
|
|
264
|
+
expect(out.result.totalMessages).toBe(10);
|
|
265
|
+
// A messageId from the original archive must still resolve via around.
|
|
266
|
+
const aroundOut = await tool.execute(
|
|
267
|
+
{ action: 'reminisce', mode: 'around', messageId: 'msg_0005', before: 1, after: 1 },
|
|
268
|
+
context
|
|
269
|
+
);
|
|
270
|
+
expect(aroundOut.result.targetFound).toBe(true);
|
|
271
|
+
expect(aroundOut.result.messages.some(m => m.messageId === 'msg_0005')).toBe(true);
|
|
272
|
+
});
|
|
273
|
+
|
|
274
|
+
test('bookmark stability across simulated conversation growth', async () => {
|
|
275
|
+
// An agent bookmarks msg_0005 in turn 1. Conversation grows to 200
|
|
276
|
+
// messages over many turns. reminisce still resolves the bookmark.
|
|
277
|
+
const messages = makeMessages(20);
|
|
278
|
+
const bookmark = 'msg_0005';
|
|
279
|
+
const agent = { id: 'a', conversations: { full: { messages } } };
|
|
280
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
281
|
+
const context = { agentId: 'a', agentPool: { getAgent: () => Promise.resolve(agent) } };
|
|
282
|
+
|
|
283
|
+
// Simulate archive growth: append 180 more messages.
|
|
284
|
+
for (let i = 20; i < 200; i++) {
|
|
285
|
+
messages.push({
|
|
286
|
+
id: `msg_${String(i).padStart(4, '0')}`,
|
|
287
|
+
role: 'assistant',
|
|
288
|
+
content: `later message ${i}`,
|
|
289
|
+
createdAt: new Date(Date.UTC(2026, 0, 2, 0, 0, i)).toISOString(),
|
|
290
|
+
tokenUsage: { totalTokens: 10 },
|
|
291
|
+
toolExecutions: [],
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
const out = await tool.execute(
|
|
296
|
+
{ action: 'reminisce', mode: 'around', messageId: bookmark, before: 2, after: 2 },
|
|
297
|
+
context
|
|
298
|
+
);
|
|
299
|
+
expect(out.result.targetFound).toBe(true);
|
|
300
|
+
expect(out.result.center).toBe(bookmark);
|
|
301
|
+
});
|
|
302
|
+
});
|
|
303
|
+
|
|
304
|
+
describe('memoryTool — reminisce registered as a valid action', () => {
|
|
305
|
+
test('getSupportedActions includes reminisce', () => {
|
|
306
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
307
|
+
expect(tool.getSupportedActions()).toContain('reminisce');
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
test('customValidateParameters accepts action=reminisce without error', () => {
|
|
311
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
312
|
+
const result = tool.customValidateParameters({ action: 'reminisce' });
|
|
313
|
+
expect(result.valid).toBe(true);
|
|
314
|
+
});
|
|
315
|
+
|
|
316
|
+
test('getParameterSchema enum includes reminisce', () => {
|
|
317
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
318
|
+
const schema = tool.getParameterSchema();
|
|
319
|
+
expect(schema.properties.action.enum).toContain('reminisce');
|
|
320
|
+
});
|
|
321
|
+
|
|
322
|
+
test('getParameterSchema advertises every reminisce-specific parameter', () => {
|
|
323
|
+
// Without this, the model invoking memory via OpenAI function calling
|
|
324
|
+
// can't know what fields are legal for action=reminisce and will either
|
|
325
|
+
// omit them or hallucinate wrong names. Locked tight.
|
|
326
|
+
const schema = new MemoryTool({}, createMockLogger()).getParameterSchema();
|
|
327
|
+
const props = schema.properties;
|
|
328
|
+
const required = [
|
|
329
|
+
'mode', 'messageId',
|
|
330
|
+
'from', 'to', 'offset', 'limit', 'maxResults', 'role', 'cursor', 'toolId',
|
|
331
|
+
'before', 'after',
|
|
332
|
+
'lineFrom', 'lineTo', 'contentFrom', 'contentTo',
|
|
333
|
+
'detail',
|
|
334
|
+
];
|
|
335
|
+
for (const field of required) {
|
|
336
|
+
expect(props[field]).toBeDefined();
|
|
337
|
+
expect(typeof props[field].description).toBe('string');
|
|
338
|
+
}
|
|
339
|
+
// mode enum must carry all six sub-modes
|
|
340
|
+
expect(props.mode.enum).toEqual(
|
|
341
|
+
expect.arrayContaining(['overview', 'range', 'search', 'around', 'byTool', 'read'])
|
|
342
|
+
);
|
|
343
|
+
});
|
|
344
|
+
|
|
345
|
+
test('getDescription teaches the agent about reminisce + pointer stability', () => {
|
|
346
|
+
const desc = new MemoryTool({}, createMockLogger()).getDescription();
|
|
347
|
+
expect(desc).toMatch(/REMINISCE/i);
|
|
348
|
+
expect(desc).toMatch(/messageId/);
|
|
349
|
+
// All six sub-modes should be present by name.
|
|
350
|
+
expect(desc).toMatch(/overview/);
|
|
351
|
+
expect(desc).toMatch(/search/);
|
|
352
|
+
expect(desc).toMatch(/around/);
|
|
353
|
+
expect(desc).toMatch(/byTool/);
|
|
354
|
+
expect(desc).toMatch(/\bread\b/);
|
|
355
|
+
// Documents that search scope excludes tool results.
|
|
356
|
+
expect(desc).toMatch(/does NOT match tool results|tool-call arguments/i);
|
|
357
|
+
// Around explicitly documents its unit = messages.
|
|
358
|
+
expect(desc).toMatch(/count MESSAGES/);
|
|
359
|
+
// Read documents sub-message granularity — lines AND chars.
|
|
360
|
+
expect(desc).toMatch(/lineFrom/);
|
|
361
|
+
expect(desc).toMatch(/contentFrom/);
|
|
362
|
+
});
|
|
363
|
+
});
|
|
@@ -56,9 +56,9 @@ describe('MemoryTool', () => {
|
|
|
56
56
|
expect(desc).toContain('stats');
|
|
57
57
|
});
|
|
58
58
|
|
|
59
|
-
test('getSupportedActions returns all
|
|
59
|
+
test('getSupportedActions returns all 8 actions', () => {
|
|
60
60
|
expect(tool.getSupportedActions()).toEqual(
|
|
61
|
-
['add', 'update', 'delete', 'list', 'read', 'search', 'stats']
|
|
61
|
+
['add', 'update', 'delete', 'list', 'read', 'search', 'stats', 'reminisce']
|
|
62
62
|
);
|
|
63
63
|
});
|
|
64
64
|
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Contract test for the `memory` function's OpenAI schema — specifically
|
|
3
|
+
* that it advertises the `reminisce` action and its sub-mode params.
|
|
4
|
+
*
|
|
5
|
+
* Why this exists: the OpenAI function schema is what the model sees on
|
|
6
|
+
* the Chat Completions path. If `reminisce` is missing from the enum or
|
|
7
|
+
* the reminisce-specific params are absent, the model can't invoke it
|
|
8
|
+
* correctly regardless of what memoryTool's own validators say. This
|
|
9
|
+
* tripwire catches that class of drift without booting the full CLI.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { describe, test, expect } from '@jest/globals';
|
|
13
|
+
import { OPENAI_FUNCTION_SCHEMAS } from '../openaiFunctionSchemas.js';
|
|
14
|
+
|
|
15
|
+
const memory = OPENAI_FUNCTION_SCHEMAS.find(s => s.name === 'memory');
|
|
16
|
+
|
|
17
|
+
describe('OPENAI_FUNCTION_SCHEMAS — memory function', () => {
|
|
18
|
+
test('memory function schema exists', () => {
|
|
19
|
+
expect(memory).toBeDefined();
|
|
20
|
+
expect(memory.type).toBe('function');
|
|
21
|
+
expect(memory.parameters?.type).toBe('object');
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
test('action enum includes reminisce', () => {
|
|
25
|
+
const actions = memory.parameters.properties.action.enum;
|
|
26
|
+
expect(actions).toContain('reminisce');
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
test('action enum covers every sanctioned action (incl. stats)', () => {
|
|
30
|
+
const actions = memory.parameters.properties.action.enum;
|
|
31
|
+
for (const a of ['add', 'update', 'delete', 'read', 'list', 'search', 'stats', 'reminisce']) {
|
|
32
|
+
expect(actions).toContain(a);
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
test('mode field is present and enumerates the six sub-modes', () => {
|
|
37
|
+
const mode = memory.parameters.properties.mode;
|
|
38
|
+
expect(mode).toBeDefined();
|
|
39
|
+
expect(mode.enum).toEqual(
|
|
40
|
+
expect.arrayContaining(['overview', 'range', 'search', 'around', 'byTool', 'read'])
|
|
41
|
+
);
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
test('every reminisce-specific parameter is documented in the schema', () => {
|
|
45
|
+
// The model can only pass what the schema advertises. If one of these
|
|
46
|
+
// is missing, the feature silently loses that capability on the Chat
|
|
47
|
+
// Completions path.
|
|
48
|
+
const required = [
|
|
49
|
+
'mode',
|
|
50
|
+
'messageId',
|
|
51
|
+
'from', 'to',
|
|
52
|
+
'offset', 'limit', 'maxResults',
|
|
53
|
+
'role', 'cursor', 'toolId',
|
|
54
|
+
'before', 'after',
|
|
55
|
+
'lineFrom', 'lineTo', 'contentFrom', 'contentTo',
|
|
56
|
+
'detail',
|
|
57
|
+
];
|
|
58
|
+
for (const field of required) {
|
|
59
|
+
const prop = memory.parameters.properties[field];
|
|
60
|
+
expect(prop).toBeDefined();
|
|
61
|
+
expect(typeof prop.description).toBe('string');
|
|
62
|
+
expect(prop.description.length).toBeGreaterThan(0);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
test('around before/after descriptions say MESSAGES (not chars/lines)', () => {
|
|
67
|
+
const before = memory.parameters.properties.before.description;
|
|
68
|
+
const after = memory.parameters.properties.after.description;
|
|
69
|
+
expect(before).toMatch(/MESSAGES/);
|
|
70
|
+
expect(after).toMatch(/MESSAGES/);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
test('read line/char params describe their index convention and cap', () => {
|
|
74
|
+
const p = memory.parameters.properties;
|
|
75
|
+
expect(p.lineFrom.description).toMatch(/1-indexed/);
|
|
76
|
+
expect(p.lineTo.description).toMatch(/500 lines/);
|
|
77
|
+
expect(p.contentFrom.description).toMatch(/0-indexed/);
|
|
78
|
+
expect(p.contentTo.description).toMatch(/16000 chars|16 000 chars/);
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
test('top-level description mentions reminisce so the model knows the tool does both', () => {
|
|
82
|
+
expect(memory.description.toLowerCase()).toMatch(/reminisce|archive/);
|
|
83
|
+
});
|
|
84
|
+
});
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Contract test for the TaskManager tool's lifecycle guidance surface.
|
|
3
|
+
*
|
|
4
|
+
* The agent follows the workflow described in the tool's `getDescription()`
|
|
5
|
+
* output verbatim (it's part of the system prompt at every turn). If that
|
|
6
|
+
* text accidentally regresses — a "simplification" PR that flattens the
|
|
7
|
+
* four phases back into the old "list → work → complete" stub — the
|
|
8
|
+
* agent immediately reverts to creating tasks one-at-a-time at the start,
|
|
9
|
+
* burning tool calls and cluttering the transcript.
|
|
10
|
+
*
|
|
11
|
+
* These tests lock the lifecycle keywords into place. They're a tripwire,
|
|
12
|
+
* not a style guide: the exact wording can evolve, but all four phases
|
|
13
|
+
* must remain named, `sync` must be positioned as the first-call tool,
|
|
14
|
+
* and the `in_progress` → `completed` per-step pattern must be present.
|
|
15
|
+
*
|
|
16
|
+
* If someone legitimately reworks the description (different phase names,
|
|
17
|
+
* different order, etc.), they update this test AND confirm the agent
|
|
18
|
+
* instruction in agentScheduler.js is in lockstep.
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
import { describe, test, expect } from '@jest/globals';
|
|
22
|
+
import TaskManagerTool from '../taskManagerTool.js';
|
|
23
|
+
|
|
24
|
+
describe('TaskManagerTool.getDescription — lifecycle guidance contract', () => {
|
|
25
|
+
const desc = new TaskManagerTool({}).getDescription();
|
|
26
|
+
// Case-insensitive match for resilience against rephrasing.
|
|
27
|
+
const has = (needle) => expect(desc).toMatch(new RegExp(needle, 'i'));
|
|
28
|
+
|
|
29
|
+
test('names the four lifecycle phases', () => {
|
|
30
|
+
has('Phase 1 — Plan');
|
|
31
|
+
has('Phase 2 — Execute');
|
|
32
|
+
has('Phase 3 — Refine');
|
|
33
|
+
has('Phase 4 — Finish');
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
test('Phase 1 tells the agent to sync the whole plan in ONE call', () => {
|
|
37
|
+
// Plan phase must mention sync + "one call" concept + discourage per-task create at start.
|
|
38
|
+
has('sync');
|
|
39
|
+
has('ONE call');
|
|
40
|
+
// The exact wording that discourages per-task create is free to evolve;
|
|
41
|
+
// what matters is that "one-by-one" (or equivalent) and the word create
|
|
42
|
+
// both appear in the Plan phase area.
|
|
43
|
+
has('one-by-one|one at a time');
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
test('Phase 2 describes the in_progress → work → completed per-step pattern', () => {
|
|
47
|
+
has('in_progress');
|
|
48
|
+
has('completed');
|
|
49
|
+
has('one at a time|one task at a time|per step');
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
test('Phase 3 covers mid-flight refinement (both single-task create and resync)', () => {
|
|
53
|
+
has('create');
|
|
54
|
+
has('sync');
|
|
55
|
+
// warns against per-turn sync spam
|
|
56
|
+
has("Don't `sync` every turn");
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
test('Phase 4 points at jobdone when everything is completed', () => {
|
|
60
|
+
has('jobdone');
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
test('preserves the loop-forever warning (operational guard)', () => {
|
|
64
|
+
has('MANDATORY');
|
|
65
|
+
has('loop forever');
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
test('preserves memory-integration guidance (unrelated feature must survive)', () => {
|
|
69
|
+
has('memory:');
|
|
70
|
+
});
|
|
71
|
+
});
|