@researai/deepscientist 1.5.16 → 1.6.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/AGENTS.md +309 -130
- package/AISB/catalog/aisb.b1.agentic_coding.yaml +244 -0
- package/AISB/catalog/aisb.b10.climate_earth.yaml +235 -0
- package/AISB/catalog/aisb.b11.model_efficiency.yaml +231 -0
- package/AISB/catalog/aisb.b12.embodied_ai.yaml +238 -0
- package/AISB/catalog/aisb.b2.agent_systems.yaml +229 -0
- package/AISB/catalog/aisb.b3.self_evolving_rl.yaml +237 -0
- package/AISB/catalog/aisb.b4.lm_reasoning.yaml +240 -0
- package/AISB/catalog/aisb.b5.math_proof.yaml +235 -0
- package/AISB/catalog/aisb.b6.research_process.yaml +243 -0
- package/AISB/catalog/aisb.b7.multimodal_fusion.yaml +232 -0
- package/AISB/catalog/aisb.b8.lifesci_drug.yaml +275 -0
- package/AISB/catalog/aisb.b9.material_science.yaml +237 -0
- package/AISB/catalog/aisb.t3.001_savvy.yaml +159 -0
- package/AISB/catalog/aisb.t3.001_savvy.zh.yaml +121 -0
- package/AISB/catalog/aisb.t3.002_pinet.yaml +189 -0
- package/AISB/catalog/aisb.t3.002_pinet.zh.yaml +130 -0
- package/AISB/catalog/aisb.t3.004_decentralattn.yaml +184 -0
- package/AISB/catalog/aisb.t3.004_decentralattn.zh.yaml +153 -0
- package/AISB/catalog/aisb.t3.005_tsae.yaml +193 -0
- package/AISB/catalog/aisb.t3.005_tsae.zh.yaml +139 -0
- package/AISB/catalog/aisb.t3.006_physense.yaml +194 -0
- package/AISB/catalog/aisb.t3.006_physense.zh.yaml +118 -0
- package/AISB/catalog/aisb.t3.007_reasoningiqa.yaml +169 -0
- package/AISB/catalog/aisb.t3.007_reasoningiqa.zh.yaml +133 -0
- package/AISB/catalog/aisb.t3.008_meanflows.yaml +188 -0
- package/AISB/catalog/aisb.t3.008_meanflows.zh.yaml +140 -0
- package/AISB/catalog/aisb.t3.009_scoremissing.yaml +179 -0
- package/AISB/catalog/aisb.t3.009_scoremissing.zh.yaml +119 -0
- package/AISB/catalog/aisb.t3.010_suitabilityfilter.yaml +221 -0
- package/AISB/catalog/aisb.t3.010_suitabilityfilter.zh.yaml +141 -0
- package/AISB/catalog/aisb.t3.011_osd.yaml +206 -0
- package/AISB/catalog/aisb.t3.011_osd.zh.yaml +163 -0
- package/AISB/catalog/aisb.t3.012_efficientqat.yaml +206 -0
- package/AISB/catalog/aisb.t3.012_efficientqat.zh.yaml +159 -0
- package/AISB/catalog/aisb.t3.013_appl.yaml +152 -0
- package/AISB/catalog/aisb.t3.013_appl.zh.yaml +126 -0
- package/AISB/catalog/aisb.t3.014_piguard.yaml +207 -0
- package/AISB/catalog/aisb.t3.014_piguard.zh.yaml +164 -0
- package/AISB/catalog/aisb.t3.015_frspec.yaml +209 -0
- package/AISB/catalog/aisb.t3.015_frspec.zh.yaml +163 -0
- package/AISB/catalog/aisb.t3.016_mathfusion.yaml +166 -0
- package/AISB/catalog/aisb.t3.016_mathfusion.zh.yaml +145 -0
- package/AISB/catalog/aisb.t3.017_multimodalglp.yaml +171 -0
- package/AISB/catalog/aisb.t3.017_multimodalglp.zh.yaml +122 -0
- package/AISB/catalog/aisb.t3.018_cotsynth.yaml +206 -0
- package/AISB/catalog/aisb.t3.018_cotsynth.zh.yaml +162 -0
- package/AISB/catalog/aisb.t3.019_dyscaleut.yaml +211 -0
- package/AISB/catalog/aisb.t3.019_dyscaleut.zh.yaml +148 -0
- package/AISB/catalog/aisb.t3.020_aristotle.yaml +173 -0
- package/AISB/catalog/aisb.t3.020_aristotle.zh.yaml +119 -0
- package/AISB/catalog/aisb.t3.021_tokenrecycling.yaml +160 -0
- package/AISB/catalog/aisb.t3.021_tokenrecycling.zh.yaml +129 -0
- package/AISB/catalog/aisb.t3.022_chainofreasoning.yaml +204 -0
- package/AISB/catalog/aisb.t3.022_chainofreasoning.zh.yaml +161 -0
- package/AISB/catalog/aisb.t3.023_guidedembed.yaml +211 -0
- package/AISB/catalog/aisb.t3.023_guidedembed.zh.yaml +189 -0
- package/AISB/catalog/aisb.t3.024_outputcentric.yaml +148 -0
- package/AISB/catalog/aisb.t3.024_outputcentric.zh.yaml +131 -0
- package/AISB/catalog/aisb.t3.025_deeper.yaml +143 -0
- package/AISB/catalog/aisb.t3.025_deeper.zh.yaml +116 -0
- package/AISB/catalog/aisb.t3.026_gartkg.yaml +195 -0
- package/AISB/catalog/aisb.t3.026_gartkg.zh.yaml +127 -0
- package/AISB/catalog/aisb.t3.027_citeeval.yaml +182 -0
- package/AISB/catalog/aisb.t3.027_citeeval.zh.yaml +135 -0
- package/AISB/catalog/aisb.t3.028_sbam.yaml +206 -0
- package/AISB/catalog/aisb.t3.028_sbam.zh.yaml +166 -0
- package/AISB/catalog/aisb.t3.029_cdqgeoembed.yaml +224 -0
- package/AISB/catalog/aisb.t3.029_cdqgeoembed.zh.yaml +142 -0
- package/AISB/catalog/aisb.t3.030_processrm.yaml +211 -0
- package/AISB/catalog/aisb.t3.030_processrm.zh.yaml +166 -0
- package/AISB/catalog/aisb.t3.031_circuitstability.yaml +172 -0
- package/AISB/catalog/aisb.t3.031_circuitstability.zh.yaml +134 -0
- package/AISB/catalog/aisb.t3.032_ptsolver.yaml +169 -0
- package/AISB/catalog/aisb.t3.032_ptsolver.zh.yaml +135 -0
- package/AISB/catalog/aisb.t3.033_gcse.yaml +144 -0
- package/AISB/catalog/aisb.t3.033_gcse.zh.yaml +126 -0
- package/AISB/catalog/aisb.t3.034_ensemblewm.yaml +183 -0
- package/AISB/catalog/aisb.t3.034_ensemblewm.zh.yaml +146 -0
- package/AISB/catalog/aisb.t3.035_moralvalueswa.yaml +207 -0
- package/AISB/catalog/aisb.t3.035_moralvalueswa.zh.yaml +165 -0
- package/AISB/catalog/aisb.t3.036_weakstrongpref.yaml +210 -0
- package/AISB/catalog/aisb.t3.036_weakstrongpref.zh.yaml +194 -0
- package/AISB/catalog/aisb.t3.037_dementiamask.yaml +172 -0
- package/AISB/catalog/aisb.t3.037_dementiamask.zh.yaml +132 -0
- package/AISB/catalog/aisb.t3.038_tinysam.yaml +284 -0
- package/AISB/catalog/aisb.t3.038_tinysam.zh.yaml +240 -0
- package/AISB/catalog/aisb.t3.039_calf.yaml +224 -0
- package/AISB/catalog/aisb.t3.039_calf.zh.yaml +194 -0
- package/AISB/catalog/aisb.t3.040_graniteguardian.yaml +199 -0
- package/AISB/catalog/aisb.t3.040_graniteguardian.zh.yaml +174 -0
- package/AISB/catalog/aisb.t3.041_amdm.yaml +149 -0
- package/AISB/catalog/aisb.t3.041_amdm.zh.yaml +137 -0
- package/AISB/catalog/aisb.t3.042_xpatch.yaml +216 -0
- package/AISB/catalog/aisb.t3.042_xpatch.zh.yaml +182 -0
- package/AISB/catalog/aisb.t3.043_vhm.yaml +268 -0
- package/AISB/catalog/aisb.t3.043_vhm.zh.yaml +193 -0
- package/AISB/catalog/aisb.t3.044_rgvi.yaml +224 -0
- package/AISB/catalog/aisb.t3.044_rgvi.zh.yaml +176 -0
- package/AISB/catalog/aisb.t3.045_pslstm.yaml +203 -0
- package/AISB/catalog/aisb.t3.045_pslstm.zh.yaml +179 -0
- package/AISB/catalog/aisb.t3.046_nonstatts.yaml +208 -0
- package/AISB/catalog/aisb.t3.046_nonstatts.zh.yaml +194 -0
- package/AISB/catalog/aisb.t3.047_timepfn.yaml +156 -0
- package/AISB/catalog/aisb.t3.047_timepfn.zh.yaml +124 -0
- package/AISB/catalog/aisb.t3.048_proxyspex.yaml +148 -0
- package/AISB/catalog/aisb.t3.048_proxyspex.zh.yaml +125 -0
- package/AISB/catalog/aisb.t3.049_hogwildinference.yaml +183 -0
- package/AISB/catalog/aisb.t3.049_hogwildinference.zh.yaml +138 -0
- package/AISB/catalog/aisb.t3.050_causalpfn.yaml +214 -0
- package/AISB/catalog/aisb.t3.050_causalpfn.zh.yaml +190 -0
- package/AISB/catalog/aisb.t3.051_flashtp.yaml +169 -0
- package/AISB/catalog/aisb.t3.051_flashtp.zh.yaml +124 -0
- package/AISB/catalog/aisb.t3.052_nsdiff.yaml +155 -0
- package/AISB/catalog/aisb.t3.052_nsdiff.zh.yaml +138 -0
- package/AISB/catalog/aisb.t3.053_k2vae.yaml +158 -0
- package/AISB/catalog/aisb.t3.053_k2vae.zh.yaml +132 -0
- package/AISB/catalog/aisb.t3.054_timebase.yaml +178 -0
- package/AISB/catalog/aisb.t3.054_timebase.zh.yaml +158 -0
- package/AISB/catalog/aisb.t3.055_csbrain.yaml +238 -0
- package/AISB/catalog/aisb.t3.055_csbrain.zh.yaml +184 -0
- package/AISB/catalog/aisb.t3.056_infosam.yaml +224 -0
- package/AISB/catalog/aisb.t3.056_infosam.zh.yaml +189 -0
- package/AISB/catalog/aisb.t3.057_mdreid.yaml +129 -0
- package/AISB/catalog/aisb.t3.057_mdreid.zh.yaml +117 -0
- package/AISB/catalog/aisb.t3.058_mindglitch.yaml +171 -0
- package/AISB/catalog/aisb.t3.058_mindglitch.zh.yaml +145 -0
- package/AISB/catalog/aisb.t3.059_selfsupervised.yaml +154 -0
- package/AISB/catalog/aisb.t3.059_selfsupervised.zh.yaml +125 -0
- package/AISB/catalog/aisb.t3.060_iaggad.yaml +121 -0
- package/AISB/catalog/aisb.t3.060_iaggad.zh.yaml +100 -0
- package/AISB/catalog/aisb.t3.061_hsgkn.yaml +136 -0
- package/AISB/catalog/aisb.t3.061_hsgkn.zh.yaml +113 -0
- package/AISB/catalog/aisb.t3.062_visionts.yaml +237 -0
- package/AISB/catalog/aisb.t3.062_visionts.zh.yaml +216 -0
- package/AISB/catalog/aisb.t3.063_tsrag.yaml +162 -0
- package/AISB/catalog/aisb.t3.063_tsrag.zh.yaml +138 -0
- package/AISB/catalog/aisb.t3.064_pir.yaml +221 -0
- package/AISB/catalog/aisb.t3.064_pir.zh.yaml +197 -0
- package/AISB/catalog/aisb.t3.065_proteinbinding.yaml +234 -0
- package/AISB/catalog/aisb.t3.065_proteinbinding.zh.yaml +167 -0
- package/AISB/catalog/aisb.t3.066_tropicalattention.yaml +267 -0
- package/AISB/catalog/aisb.t3.066_tropicalattention.zh.yaml +229 -0
- package/AISB/catalog/aisb.t3.067_kanad.yaml +193 -0
- package/AISB/catalog/aisb.t3.067_kanad.zh.yaml +167 -0
- package/AISB/catalog/aisb.t3.068_sempo.yaml +187 -0
- package/AISB/catalog/aisb.t3.068_sempo.zh.yaml +148 -0
- package/AISB/catalog/aisb.t3.069_treehfd.yaml +129 -0
- package/AISB/catalog/aisb.t3.069_treehfd.zh.yaml +111 -0
- package/AISB/catalog/aisb.t3.070_certifiedunlearning.yaml +224 -0
- package/AISB/catalog/aisb.t3.070_certifiedunlearning.zh.yaml +171 -0
- package/AISB/catalog/aisb.t3.071_neuralmjd.yaml +142 -0
- package/AISB/catalog/aisb.t3.071_neuralmjd.zh.yaml +120 -0
- package/AISB/catalog/aisb.t3.072_fedgmt.yaml +181 -0
- package/AISB/catalog/aisb.t3.072_fedgmt.zh.yaml +158 -0
- package/AISB/catalog/aisb.t3.073_rld.yaml +161 -0
- package/AISB/catalog/aisb.t3.073_rld.zh.yaml +129 -0
- package/AISB/catalog/aisb.t3.074_lsvi.yaml +163 -0
- package/AISB/catalog/aisb.t3.074_lsvi.zh.yaml +129 -0
- package/AISB/catalog/aisb.t3.075_treeslicedentropy.yaml +201 -0
- package/AISB/catalog/aisb.t3.075_treeslicedentropy.zh.yaml +148 -0
- package/AISB/catalog/aisb.t3.076_aanet.yaml +169 -0
- package/AISB/catalog/aisb.t3.076_aanet.zh.yaml +129 -0
- package/AISB/catalog/aisb.t3.077_cmnn.yaml +199 -0
- package/AISB/catalog/aisb.t3.077_cmnn.zh.yaml +165 -0
- package/AISB/catalog/aisb.t3.078_conformalanomaly.yaml +146 -0
- package/AISB/catalog/aisb.t3.078_conformalanomaly.zh.yaml +117 -0
- package/AISB/catalog/aisb.t3.079_dpfkmeans.yaml +131 -0
- package/AISB/catalog/aisb.t3.079_dpfkmeans.zh.yaml +104 -0
- package/AISB/catalog/aisb.t3.080_latentscorereweight.yaml +169 -0
- package/AISB/catalog/aisb.t3.080_latentscorereweight.zh.yaml +123 -0
- package/AISB/catalog/aisb.t3.081_qmamba.yaml +150 -0
- package/AISB/catalog/aisb.t3.081_qmamba.zh.yaml +117 -0
- package/AISB/catalog/aisb.t3.082_onlinellmrouting.yaml +160 -0
- package/AISB/catalog/aisb.t3.082_onlinellmrouting.zh.yaml +133 -0
- package/AISB/catalog/aisb.t3.083_starformer.yaml +178 -0
- package/AISB/catalog/aisb.t3.083_starformer.zh.yaml +140 -0
- package/AISB/catalog/aisb.t3.084_ift.yaml +139 -0
- package/AISB/catalog/aisb.t3.084_ift.zh.yaml +111 -0
- package/AISB/catalog/aisb.t3.085_neuralsurv.yaml +183 -0
- package/AISB/catalog/aisb.t3.085_neuralsurv.zh.yaml +143 -0
- package/AISB/catalog/aisb.t3.086_stella.yaml +197 -0
- package/AISB/catalog/aisb.t3.086_stella.zh.yaml +142 -0
- package/AISB/catalog/aisb.t3.087_moses.yaml +167 -0
- package/AISB/catalog/aisb.t3.087_moses.zh.yaml +132 -0
- package/AISB/catalog/aisb.t3.088_channelnorm.yaml +140 -0
- package/AISB/catalog/aisb.t3.088_channelnorm.zh.yaml +109 -0
- package/AISB/catalog/aisb.t3.089_causalvelocity.yaml +730 -0
- package/AISB/catalog/aisb.t3.089_causalvelocity.zh.yaml +668 -0
- package/AISB/catalog/aisb.t3.090_rstib.yaml +144 -0
- package/AISB/catalog/aisb.t3.090_rstib.zh.yaml +109 -0
- package/AISB/catalog/aisb.t3.091_timeawarecausal.yaml +132 -0
- package/AISB/catalog/aisb.t3.091_timeawarecausal.zh.yaml +107 -0
- package/AISB/catalog/aisb.t3.092_kmeanslocalopt.yaml +138 -0
- package/AISB/catalog/aisb.t3.092_kmeanslocalopt.zh.yaml +110 -0
- package/AISB/catalog/aisb.t3.093_fedwmsam.yaml +134 -0
- package/AISB/catalog/aisb.t3.093_fedwmsam.zh.yaml +106 -0
- package/AISB/catalog/aisb.t3.094_boundre.yaml +147 -0
- package/AISB/catalog/aisb.t3.094_boundre.zh.yaml +114 -0
- package/AISB/catalog/aisb.t3.095_fastfeaturecp.yaml +153 -0
- package/AISB/catalog/aisb.t3.095_fastfeaturecp.zh.yaml +118 -0
- package/AISB/catalog/aisb.t3.096_m3svm.yaml +189 -0
- package/AISB/catalog/aisb.t3.096_m3svm.zh.yaml +149 -0
- package/AISB/catalog/aisb.t3.097_wassersteintl.yaml +212 -0
- package/AISB/catalog/aisb.t3.097_wassersteintl.zh.yaml +169 -0
- package/AISB/catalog/aisb.t3.098_xmahalanobis.yaml +171 -0
- package/AISB/catalog/aisb.t3.098_xmahalanobis.zh.yaml +127 -0
- package/AISB/catalog/aisb.t3.099_ollalanding.yaml +248 -0
- package/AISB/catalog/aisb.t3.099_ollalanding.zh.yaml +182 -0
- package/AISB/catalog/aisb.t3.100_invmissingdata.yaml +179 -0
- package/AISB/catalog/aisb.t3.100_invmissingdata.zh.yaml +150 -0
- package/AISB/catalog/aisb.t3.101_acia.yaml +164 -0
- package/AISB/catalog/aisb.t3.101_acia.zh.yaml +109 -0
- package/AISB/catalog/aisb.t3.102_stochasticff.yaml +178 -0
- package/AISB/catalog/aisb.t3.102_stochasticff.zh.yaml +130 -0
- package/AISB/catalog/aisb.t3.103_qdcp.yaml +150 -0
- package/AISB/catalog/aisb.t3.103_qdcp.zh.yaml +116 -0
- package/AISB/catalog/aisb.t3.104_balancedactiveinf.yaml +137 -0
- package/AISB/catalog/aisb.t3.104_balancedactiveinf.zh.yaml +104 -0
- package/AISB/catalog/aisb.t3.105_binaryclasseval.yaml +161 -0
- package/AISB/catalog/aisb.t3.105_binaryclasseval.zh.yaml +130 -0
- package/AISB/image/001_aisb.t3.001_savvy.jpg +0 -0
- package/AISB/image/002_aisb.t3.002_pinet.jpg +0 -0
- package/AISB/image/003_aisb.t3.003_dmsqd.jpg +0 -0
- package/AISB/image/004_aisb.t3.004_decentralattn.jpg +0 -0
- package/AISB/image/005_aisb.t3.005_tsae.jpg +0 -0
- package/AISB/image/006_aisb.t3.006_physense.jpg +0 -0
- package/AISB/image/007_aisb.t3.007_reasoningiqa.jpg +0 -0
- package/AISB/image/008_aisb.t3.008_meanflows.jpg +0 -0
- package/AISB/image/009_aisb.t3.009_scoremissing.jpg +0 -0
- package/AISB/image/010_aisb.t3.010_suitabilityfilter.jpg +0 -0
- package/AISB/image/011_aisb.t3.011_osd.jpg +0 -0
- package/AISB/image/012_aisb.t3.012_efficientqat.jpg +0 -0
- package/AISB/image/013_aisb.t3.013_appl.jpg +0 -0
- package/AISB/image/014_aisb.t3.014_piguard.jpg +0 -0
- package/AISB/image/015_aisb.t3.015_frspec.jpg +0 -0
- package/AISB/image/016_aisb.t3.016_mathfusion.jpg +0 -0
- package/AISB/image/017_aisb.t3.017_multimodalglp.jpg +0 -0
- package/AISB/image/018_aisb.t3.018_cotsynth.jpg +0 -0
- package/AISB/image/019_aisb.t3.019_dyscaleut.jpg +0 -0
- package/AISB/image/020_aisb.t3.020_aristotle.jpg +0 -0
- package/AISB/image/021_aisb.t3.021_tokenrecycling.jpg +0 -0
- package/AISB/image/022_aisb.t3.022_chainofreasoning.jpg +0 -0
- package/AISB/image/023_aisb.t3.023_guidedembed.jpg +0 -0
- package/AISB/image/024_aisb.t3.024_outputcentric.jpg +0 -0
- package/AISB/image/025_aisb.t3.025_deeper.jpg +0 -0
- package/AISB/image/026_aisb.t3.026_gartkg.jpg +0 -0
- package/AISB/image/027_aisb.t3.027_citeeval.jpg +0 -0
- package/AISB/image/028_aisb.t3.028_sbam.jpg +0 -0
- package/AISB/image/029_aisb.t3.029_cdqgeoembed.jpg +0 -0
- package/AISB/image/030_aisb.t3.030_processrm.jpg +0 -0
- package/AISB/image/031_aisb.t3.031_circuitstability.jpg +0 -0
- package/AISB/image/032_aisb.t3.032_ptsolver.jpg +0 -0
- package/AISB/image/033_aisb.t3.033_gcse.jpg +0 -0
- package/AISB/image/034_aisb.t3.034_ensemblewm.jpg +0 -0
- package/AISB/image/035_aisb.t3.035_moralvalueswa.jpg +0 -0
- package/AISB/image/036_aisb.t3.036_weakstrongpref.jpg +0 -0
- package/AISB/image/037_aisb.t3.037_dementiamask.jpg +0 -0
- package/AISB/image/038_aisb.t3.038_tinysam.jpg +0 -0
- package/AISB/image/039_aisb.t3.039_calf.jpg +0 -0
- package/AISB/image/040_aisb.t3.040_graniteguardian.jpg +0 -0
- package/AISB/image/041_aisb.t3.041_amdm.jpg +0 -0
- package/AISB/image/042_aisb.t3.042_xpatch.jpg +0 -0
- package/AISB/image/043_aisb.t3.043_vhm.jpg +0 -0
- package/AISB/image/044_aisb.t3.044_rgvi.jpg +0 -0
- package/AISB/image/045_aisb.t3.045_pslstm.jpg +0 -0
- package/AISB/image/046_aisb.t3.046_nonstatts.jpg +0 -0
- package/AISB/image/047_aisb.t3.047_timepfn.jpg +0 -0
- package/AISB/image/048_aisb.t3.048_proxyspex.jpg +0 -0
- package/AISB/image/049_aisb.t3.049_hogwildinference.jpg +0 -0
- package/AISB/image/050_aisb.t3.050_causalpfn.jpg +0 -0
- package/AISB/image/051_aisb.t3.051_flashtp.jpg +0 -0
- package/AISB/image/052_aisb.t3.052_nsdiff.jpg +0 -0
- package/AISB/image/053_aisb.t3.053_k2vae.jpg +0 -0
- package/AISB/image/054_aisb.t3.054_timebase.jpg +0 -0
- package/AISB/image/055_aisb.t3.055_csbrain.jpg +0 -0
- package/AISB/image/056_aisb.t3.056_infosam.jpg +0 -0
- package/AISB/image/057_aisb.t3.057_mdreid.jpg +0 -0
- package/AISB/image/058_aisb.t3.058_mindglitch.jpg +0 -0
- package/AISB/image/059_aisb.t3.059_selfsupervised.jpg +0 -0
- package/AISB/image/060_aisb.t3.060_iaggad.jpg +0 -0
- package/AISB/image/061_aisb.t3.061_hsgkn.jpg +0 -0
- package/AISB/image/062_aisb.t3.062_visionts.jpg +0 -0
- package/AISB/image/063_aisb.t3.063_tsrag.jpg +0 -0
- package/AISB/image/064_aisb.t3.064_pir.jpg +0 -0
- package/AISB/image/065_aisb.t3.065_proteinbinding.jpg +0 -0
- package/AISB/image/066_aisb.t3.066_tropicalattention.jpg +0 -0
- package/AISB/image/067_aisb.t3.067_kanad.jpg +0 -0
- package/AISB/image/068_aisb.t3.068_sempo.jpg +0 -0
- package/AISB/image/069_aisb.t3.069_treehfd.jpg +0 -0
- package/AISB/image/070_aisb.t3.070_certifiedunlearning.jpg +0 -0
- package/AISB/image/071_aisb.t3.071_neuralmjd.jpg +0 -0
- package/AISB/image/072_aisb.t3.072_fedgmt.jpg +0 -0
- package/AISB/image/073_aisb.t3.073_rld.jpg +0 -0
- package/AISB/image/074_aisb.t3.074_lsvi.jpg +0 -0
- package/AISB/image/075_aisb.t3.075_treeslicedentropy.jpg +0 -0
- package/AISB/image/076_aisb.t3.076_aanet.jpg +0 -0
- package/AISB/image/077_aisb.t3.077_cmnn.jpg +0 -0
- package/AISB/image/078_aisb.t3.078_conformalanomaly.jpg +0 -0
- package/AISB/image/079_aisb.t3.079_dpfkmeans.jpg +0 -0
- package/AISB/image/080_aisb.t3.080_latentscorereweight.jpg +0 -0
- package/AISB/image/081_aisb.t3.081_qmamba.jpg +0 -0
- package/AISB/image/082_aisb.t3.082_onlinellmrouting.jpg +0 -0
- package/AISB/image/083_aisb.t3.083_starformer.jpg +0 -0
- package/AISB/image/084_aisb.t3.084_ift.jpg +0 -0
- package/AISB/image/085_aisb.t3.085_neuralsurv.jpg +0 -0
- package/AISB/image/086_aisb.t3.086_stella.jpg +0 -0
- package/AISB/image/087_aisb.t3.087_moses.jpg +0 -0
- package/AISB/image/088_aisb.t3.088_channelnorm.jpg +0 -0
- package/AISB/image/089_aisb.t3.089_causalvelocity.jpg +0 -0
- package/AISB/image/090_aisb.t3.090_rstib.jpg +0 -0
- package/AISB/image/091_aisb.t3.091_timeawarecausal.jpg +0 -0
- package/AISB/image/092_aisb.t3.092_kmeanslocalopt.jpg +0 -0
- package/AISB/image/093_aisb.t3.093_fedwmsam.jpg +0 -0
- package/AISB/image/094_aisb.t3.094_boundre.jpg +0 -0
- package/AISB/image/095_aisb.t3.095_fastfeaturecp.jpg +0 -0
- package/AISB/image/096_aisb.t3.096_m3svm.jpg +0 -0
- package/AISB/image/097_aisb.t3.097_wassersteintl.jpg +0 -0
- package/AISB/image/098_aisb.t3.098_xmahalanobis.jpg +0 -0
- package/AISB/image/099_aisb.t3.099_ollalanding.jpg +0 -0
- package/AISB/image/100_aisb.t3.100_invmissingdata.jpg +0 -0
- package/AISB/image/101_aisb.t3.101_acia.jpg +0 -0
- package/AISB/image/102_aisb.t3.102_stochasticff.jpg +0 -0
- package/AISB/image/103_aisb.t3.103_qdcp.jpg +0 -0
- package/AISB/image/104_aisb.t3.104_balancedactiveinf.jpg +0 -0
- package/AISB/image/105_aisb.t3.105_binaryclasseval.jpg +0 -0
- package/AISB/image/106_aisb.t1.reasoning_lite.jpg +0 -0
- package/AISB/image/107_aisb.t2.paper_audit.jpg +0 -0
- package/AISB/image/108_aisb.t3.multi_gpu_search.jpg +0 -0
- package/AISB/image/109_aisb.t3.tdc_admet.jpg +0 -0
- package/AISB/image/aisb.b1.agentic_coding.svg +16 -0
- package/AISB/image/aisb.b10.climate_earth.svg +16 -0
- package/AISB/image/aisb.b11.model_efficiency.svg +16 -0
- package/AISB/image/aisb.b12.embodied_ai.svg +16 -0
- package/AISB/image/aisb.b2.agent_systems.svg +16 -0
- package/AISB/image/aisb.b3.self_evolving_rl.svg +16 -0
- package/AISB/image/aisb.b4.lm_reasoning.svg +16 -0
- package/AISB/image/aisb.b5.math_proof.svg +16 -0
- package/AISB/image/aisb.b6.research_process.svg +16 -0
- package/AISB/image/aisb.b7.multimodal_fusion.svg +16 -0
- package/AISB/image/aisb.b8.lifesci_drug.svg +16 -0
- package/AISB/image/aisb.b9.material_science.svg +16 -0
- package/README.md +196 -32
- package/bin/ds.js +924 -66
- package/docs/en/00_QUICK_START.md +195 -18
- package/docs/en/01_SETTINGS_REFERENCE.md +468 -96
- package/docs/en/02_START_RESEARCH_GUIDE.md +26 -5
- package/docs/en/03_QQ_CONNECTOR_GUIDE.md +14 -3
- package/docs/en/04_LINGZHU_CONNECTOR_GUIDE.md +2 -0
- package/docs/en/05_TUI_GUIDE.md +171 -2
- package/docs/en/07_MEMORY_AND_MCP.md +38 -2
- package/docs/en/09_DOCTOR.md +78 -7
- package/docs/en/10_WEIXIN_CONNECTOR_GUIDE.md +38 -1
- package/docs/en/11_LICENSE_AND_RISK.md +4 -0
- package/docs/en/12_GUIDED_WORKFLOW_TOUR.md +15 -0
- package/docs/en/14_PROMPT_SKILLS_AND_MCP_GUIDE.md +9 -0
- package/docs/en/15_CODEX_PROVIDER_SETUP.md +624 -180
- package/docs/en/16_TELEGRAM_CONNECTOR_GUIDE.md +14 -0
- package/docs/en/17_WHATSAPP_CONNECTOR_GUIDE.md +14 -0
- package/docs/en/18_FEISHU_CONNECTOR_GUIDE.md +14 -0
- package/docs/en/21_LOCAL_MODEL_BACKENDS_GUIDE.md +386 -0
- package/docs/en/22_BENCHSTORE_YAML_REFERENCE.md +469 -0
- package/docs/en/23_BENCHSTORE_GITHUB_RELEASES_SPEC.md +316 -0
- package/docs/en/24_CLAUDE_CODE_PROVIDER_SETUP.md +469 -0
- package/docs/en/25_OPENCODE_PROVIDER_SETUP.md +653 -0
- package/docs/en/26_CITATION_AND_ATTRIBUTION.md +119 -0
- package/docs/en/27_KIMI_CODE_PROVIDER_SETUP.md +180 -0
- package/docs/en/28_DISCORD_CONNECTOR_GUIDE.md +61 -0
- package/docs/en/29_SLACK_CONNECTOR_GUIDE.md +60 -0
- package/docs/en/30_SETTINGS_CONTROL_CENTER_GUIDE.md +371 -0
- package/docs/en/{19_LOCAL_BROWSER_AUTH.md → 31_LOCAL_BROWSER_AUTH.md} +1 -1
- package/docs/en/32_WINDOWS_WSL2_DEPLOYMENT_GUIDE.md +273 -0
- package/docs/en/33_WORKSPACE_EXPLORER_QA.md +121 -0
- package/docs/en/91_DEVELOPMENT.md +266 -0
- package/docs/en/99_ACKNOWLEDGEMENTS.md +24 -19
- package/docs/en/README.md +48 -7
- package/docs/images/admin/admin-connectors-health-en.png +0 -0
- package/docs/images/admin/admin-controllers-en.png +0 -0
- package/docs/images/admin/admin-diagnostics-en.png +0 -0
- package/docs/images/admin/admin-errors-en.png +0 -0
- package/docs/images/admin/admin-issues-en.png +0 -0
- package/docs/images/admin/admin-logs-en.png +0 -0
- package/docs/images/admin/admin-quest-detail-en.png +0 -0
- package/docs/images/admin/admin-quests-en.png +0 -0
- package/docs/images/admin/admin-repairs-en.png +0 -0
- package/docs/images/admin/admin-runtime-en.png +0 -0
- package/docs/images/admin/admin-search-en.png +0 -0
- package/docs/images/admin/admin-stats-en.png +0 -0
- package/docs/images/admin/admin-summary-en.png +0 -0
- package/docs/images/connectors/connector-discord-en.png +0 -0
- package/docs/images/connectors/connector-feishu-en.png +0 -0
- package/docs/images/connectors/connector-lingzhu-en.png +0 -0
- package/docs/images/connectors/connector-qq-en.png +0 -0
- package/docs/images/connectors/connector-slack-en.png +0 -0
- package/docs/images/connectors/connector-telegram-en.png +0 -0
- package/docs/images/connectors/connector-weixin-en.png +0 -0
- package/docs/images/connectors/connector-whatsapp-en.png +0 -0
- package/docs/images/settings/settings-baselines-en.png +0 -0
- package/docs/images/settings/settings-config-en.png +0 -0
- package/docs/images/settings/settings-connectors-overview-en.png +0 -0
- package/docs/images/settings/settings-deepxiv-en.png +0 -0
- package/docs/images/settings/settings-mcp-servers-en.png +0 -0
- package/docs/images/settings/settings-plugins-en.png +0 -0
- package/docs/images/settings/settings-runners-en.png +0 -0
- package/docs/zh/00_QUICK_START.md +142 -18
- package/docs/zh/01_SETTINGS_REFERENCE.md +219 -98
- package/docs/zh/02_START_RESEARCH_GUIDE.md +26 -5
- package/docs/zh/05_TUI_GUIDE.md +171 -2
- package/docs/zh/07_MEMORY_AND_MCP.md +29 -2
- package/docs/zh/09_DOCTOR.md +54 -8
- package/docs/zh/10_WEIXIN_CONNECTOR_GUIDE.md +24 -1
- package/docs/zh/11_LICENSE_AND_RISK.md +4 -0
- package/docs/zh/12_GUIDED_WORKFLOW_TOUR.md +15 -0
- package/docs/zh/14_PROMPT_SKILLS_AND_MCP_GUIDE.md +9 -0
- package/docs/zh/15_CODEX_PROVIDER_SETUP.md +552 -181
- package/docs/zh/21_LOCAL_MODEL_BACKENDS_GUIDE.md +384 -0
- package/docs/zh/22_BENCHSTORE_YAML_REFERENCE.md +459 -0
- package/docs/zh/23_BENCHSTORE_GITHUB_RELEASES_SPEC.md +287 -0
- package/docs/zh/23_CLAUDE_RUNNER_GUIDE.md +103 -0
- package/docs/zh/24_CLAUDE_CODE_PROVIDER_SETUP.md +460 -0
- package/docs/zh/25_OPENCODE_PROVIDER_SETUP.md +660 -0
- package/docs/zh/26_CITATION_AND_ATTRIBUTION.md +102 -0
- package/docs/zh/27_KIMI_CODE_PROVIDER_SETUP.md +51 -0
- package/docs/zh/{19_LOCAL_BROWSER_AUTH.md → 31_LOCAL_BROWSER_AUTH.md} +1 -1
- package/docs/zh/32_WINDOWS_WSL2_DEPLOYMENT_GUIDE.md +264 -0
- package/docs/zh/33_WORKSPACE_EXPLORER_QA.md +127 -0
- package/docs/zh/99_ACKNOWLEDGEMENTS.md +23 -19
- package/docs/zh/README.md +33 -7
- package/install.sh +168 -20
- package/package.json +5 -1
- package/pyproject.toml +2 -1
- package/src/deepscientist/__init__.py +1 -1
- package/src/deepscientist/acp/envelope.py +13 -0
- package/src/deepscientist/admin/__init__.py +3 -0
- package/src/deepscientist/admin/charts.py +681 -0
- package/src/deepscientist/admin/logs.py +119 -0
- package/src/deepscientist/admin/repairs.py +217 -0
- package/src/deepscientist/admin/service.py +1310 -0
- package/src/deepscientist/admin/system_info.py +700 -0
- package/src/deepscientist/admin/tasks.py +465 -0
- package/src/deepscientist/admin/tool_metrics.py +600 -0
- package/src/deepscientist/artifact/guidance.py +8 -4
- package/src/deepscientist/artifact/schemas.py +115 -0
- package/src/deepscientist/artifact/service.py +4268 -260
- package/src/deepscientist/bash_exec/monitor.py +30 -3
- package/src/deepscientist/bash_exec/service.py +134 -1
- package/src/deepscientist/benchstore/__init__.py +4 -0
- package/src/deepscientist/benchstore/prompt_builder.py +224 -0
- package/src/deepscientist/benchstore/service.py +1716 -0
- package/src/deepscientist/bridges/connectors.py +8 -2
- package/src/deepscientist/channels/weixin_ilink.py +8 -1
- package/src/deepscientist/cli.py +92 -17
- package/src/deepscientist/codex_cli_compat.py +187 -74
- package/src/deepscientist/config/models.py +82 -11
- package/src/deepscientist/config/service.py +1077 -93
- package/src/deepscientist/connector/weixin_support.py +48 -17
- package/src/deepscientist/daemon/api/handlers.py +827 -235
- package/src/deepscientist/daemon/api/router.py +81 -1
- package/src/deepscientist/daemon/app.py +1512 -85
- package/src/deepscientist/diagnostics/__init__.py +6 -0
- package/src/deepscientist/diagnostics/runner_failures.py +277 -0
- package/src/deepscientist/doctor.py +407 -56
- package/src/deepscientist/evidence_packets.py +590 -0
- package/src/deepscientist/home.py +52 -4
- package/src/deepscientist/kimi_cli_compat.py +50 -0
- package/src/deepscientist/latex_runtime.py +2 -2
- package/src/deepscientist/mcp/context.py +2 -0
- package/src/deepscientist/mcp/schemas.py +114 -0
- package/src/deepscientist/mcp/server.py +1566 -126
- package/src/deepscientist/memory/service.py +203 -16
- package/src/deepscientist/process_control.py +8 -1
- package/src/deepscientist/prompts/builder.py +850 -88
- package/src/deepscientist/quest/__init__.py +2 -2
- package/src/deepscientist/quest/layout.py +12 -1
- package/src/deepscientist/quest/node_traces.py +10 -0
- package/src/deepscientist/quest/service.py +1852 -161
- package/src/deepscientist/quest/stage_views.py +1 -1
- package/src/deepscientist/runners/__init__.py +18 -0
- package/src/deepscientist/runners/base.py +89 -1
- package/src/deepscientist/runners/builtins.py +13 -1
- package/src/deepscientist/runners/claude.py +391 -0
- package/src/deepscientist/runners/codex.py +480 -35
- package/src/deepscientist/runners/codex_telemetry.py +127 -0
- package/src/deepscientist/runners/kimi.py +334 -0
- package/src/deepscientist/runners/metadata.py +68 -0
- package/src/deepscientist/runners/opencode.py +414 -0
- package/src/deepscientist/runners/runtime_overrides.py +100 -0
- package/src/deepscientist/runners/simple_cli.py +538 -0
- package/src/deepscientist/runtime_storage.py +303 -0
- package/src/deepscientist/shared.py +80 -16
- package/src/deepscientist/skills/installer.py +37 -0
- package/src/deepscientist/skills/registry.py +2 -0
- package/src/deepscientist/tinytex.py +2 -2
- package/src/deepscientist/tui.py +10 -3
- package/src/prompts/benchstore/system.md +77 -0
- package/src/prompts/connectors/qq.md +33 -2
- package/src/prompts/connectors/weixin.md +208 -23
- package/src/prompts/contracts/admin_ops.md +74 -0
- package/src/prompts/contracts/admin_ops_knowledge.md +138 -0
- package/src/prompts/contracts/shared_interaction.md +5 -10
- package/src/prompts/start_setup/system.md +422 -0
- package/src/prompts/system.md +411 -304
- package/src/prompts/system_copilot.md +89 -0
- package/src/skills/analysis-campaign/SKILL.md +239 -578
- package/src/skills/analysis-campaign/references/artifact-flow-examples.md +102 -0
- package/src/skills/analysis-campaign/references/boundary-cases.md +98 -0
- package/src/skills/analysis-campaign/references/campaign-checklist-template.md +39 -24
- package/src/skills/analysis-campaign/references/campaign-design.md +26 -10
- package/src/skills/analysis-campaign/references/campaign-plan-template.md +53 -54
- package/src/skills/analysis-campaign/references/operational-guidance.md +97 -0
- package/src/skills/analysis-campaign/references/writing-facing-slice-examples.md +10 -20
- package/src/skills/baseline/SKILL.md +183 -461
- package/src/skills/baseline/references/artifact-flow-examples.md +106 -0
- package/src/skills/baseline/references/artifact-payload-examples.md +1 -1
- package/src/skills/baseline/references/baseline-checklist-template.md +27 -35
- package/src/skills/baseline/references/baseline-plan-template.md +37 -76
- package/src/skills/baseline/references/boundary-cases.md +86 -0
- package/src/skills/baseline/references/codebase-audit-checklist.md +2 -6
- package/src/skills/baseline/references/comparability-contract.md +7 -12
- package/src/skills/baseline/references/operational-guidance.md +56 -0
- package/src/skills/baseline/references/route-selection.md +5 -25
- package/src/skills/decision/SKILL.md +113 -306
- package/src/skills/decision/references/checkpoint-memory-template.md +47 -0
- package/src/skills/decision/references/operational-guidance.md +94 -0
- package/src/skills/decision/references/research-route-criteria.md +7 -8
- package/src/skills/decision/references/strategic-decision-template.md +13 -26
- package/src/skills/experiment/SKILL.md +132 -670
- package/src/skills/experiment/references/execution-playbook.md +374 -0
- package/src/skills/experiment/references/main-experiment-checklist-template.md +26 -2
- package/src/skills/experiment/references/main-experiment-plan-template.md +28 -17
- package/src/skills/experiment/references/operational-guidance.md +108 -0
- package/src/skills/finalize/SKILL.md +62 -0
- package/src/skills/finalize/references/checkpoint-memory-template.md +49 -0
- package/src/skills/finalize/references/resume-packet-template.md +7 -0
- package/src/skills/idea/SKILL.md +228 -15
- package/src/skills/idea/references/controlled-brainstorming-playbook.md +78 -0
- package/src/skills/idea/references/current-board-packet-template.md +61 -0
- package/src/skills/idea/references/high-value-idea-sourcing.md +119 -0
- package/src/skills/idea/references/idea-generation-playbook.md +21 -0
- package/src/skills/idea/references/idea-thinking-flow.md +6 -0
- package/src/skills/idea/references/literature-survey-template.md +3 -0
- package/src/skills/idea/references/objective-contract-template.md +54 -0
- package/src/skills/idea/references/outline-seeding-example.md +56 -0
- package/src/skills/idea/references/pre-idea-draft-template.md +105 -0
- package/src/skills/idea/references/related-work-playbook.md +75 -2
- package/src/skills/idea/references/research-history-playbook.md +114 -0
- package/src/skills/idea/references/selection-gate.md +58 -6
- package/src/skills/intake-audit/SKILL.md +43 -2
- package/src/skills/intake-audit/references/state-audit-template.md +10 -0
- package/src/skills/nature-data/SKILL.md +128 -0
- package/src/skills/nature-data/UPSTREAM_LICENSE.txt +21 -0
- package/src/skills/nature-data/agents/openai.yaml +4 -0
- package/src/skills/nature-data/references/chinese-author-alignment.md +84 -0
- package/src/skills/nature-data/references/fair-metadata-checklist.md +105 -0
- package/src/skills/nature-data/references/policy-principles.md +103 -0
- package/src/skills/nature-data/references/repository-and-identifiers.md +96 -0
- package/src/skills/nature-data/references/source-basis.md +54 -0
- package/src/skills/nature-data/references/statement-patterns.md +153 -0
- package/src/skills/nature-figure/SKILL.md +197 -0
- package/src/skills/nature-figure/UPSTREAM_LICENSE.txt +21 -0
- package/src/skills/nature-figure/agents/openai.yaml +4 -0
- package/src/skills/nature-figure/evals/evals.json +37 -0
- package/src/skills/nature-figure/references/api.md +428 -0
- package/src/skills/nature-figure/references/backend-selection.md +100 -0
- package/src/skills/nature-figure/references/chart-types.md +281 -0
- package/src/skills/nature-figure/references/common-patterns.md +349 -0
- package/src/skills/nature-figure/references/design-theory.md +436 -0
- package/src/skills/nature-figure/references/figure-contract.md +93 -0
- package/src/skills/nature-figure/references/nature-2026-observations.md +112 -0
- package/src/skills/nature-figure/references/qa-contract.md +119 -0
- package/src/skills/nature-figure/references/r-template-index.md +66 -0
- package/src/skills/nature-figure/references/r-workflow.md +161 -0
- package/src/skills/nature-figure/references/tutorials.md +250 -0
- package/src/skills/nature-paper2ppt/SKILL.md +507 -0
- package/src/skills/nature-paper2ppt/UPSTREAM_LICENSE.txt +21 -0
- package/src/skills/nature-paper2ppt/agents/openai.yaml +4 -0
- package/src/skills/nature-polishing/SKILL.md +385 -0
- package/src/skills/nature-polishing/UPSTREAM_LICENSE.txt +21 -0
- package/src/skills/nature-polishing/agents/openai.yaml +4 -0
- package/src/skills/nature-polishing/references/phrasebank-playbook.md +162 -0
- package/src/skills/nature-polishing/references/section-moves.md +240 -0
- package/src/skills/nature-polishing/references/style-guardrails.md +94 -0
- package/src/skills/nature-polishing/references/writing-strategy.md +148 -0
- package/src/skills/optimize/SKILL.md +177 -1568
- package/src/skills/optimize/references/brief-shaping-playbook.md +95 -0
- package/src/skills/optimize/references/candidate-board-template.md +13 -0
- package/src/skills/optimize/references/candidate-ranking-template.md +51 -0
- package/src/skills/optimize/references/codegen-route-playbook.md +50 -0
- package/src/skills/optimize/references/debug-response-template.md +29 -0
- package/src/skills/optimize/references/frontier-review-template.md +32 -0
- package/src/skills/optimize/references/fusion-playbook.md +36 -0
- package/src/skills/optimize/references/method-brief-template.md +73 -0
- package/src/skills/optimize/references/operational-guidance.md +621 -0
- package/src/skills/optimize/references/optimization-memory-template.md +30 -0
- package/src/skills/optimize/references/optimize-checklist-template.md +18 -0
- package/src/skills/optimize/references/plateau-response-playbook.md +28 -0
- package/src/skills/optimize/references/prompt-patterns.md +49 -0
- package/src/skills/paper-outline/SKILL.md +227 -0
- package/src/skills/paper-outline/references/outline-patterns.md +87 -0
- package/src/skills/paper-plot/SKILL.md +79 -0
- package/src/skills/paper-plot/agents/openai.yaml +4 -0
- package/src/skills/paper-plot/references/bar_grouped_hatch.md +96 -0
- package/src/skills/paper-plot/references/bar_paired_delta.md +72 -0
- package/src/skills/paper-plot/references/line_confidence_band.md +75 -0
- package/src/skills/paper-plot/references/line_loss_with_inset.md +65 -0
- package/src/skills/paper-plot/references/line_training_curve.md +44 -0
- package/src/skills/paper-plot/references/radar_dual_series.md +59 -0
- package/src/skills/paper-plot/references/scatter_broken_axis.md +59 -0
- package/src/skills/paper-plot/references/scatter_tsne_cluster.md +72 -0
- package/src/skills/paper-plot/scripts/bar_memevolve.py +109 -0
- package/src/skills/paper-plot/scripts/bar_spice.py +166 -0
- package/src/skills/paper-plot/scripts/line_aime.py +94 -0
- package/src/skills/paper-plot/scripts/line_loss_inset.py +157 -0
- package/src/skills/paper-plot/scripts/line_selfdistill.py +168 -0
- package/src/skills/paper-plot/scripts/radar_dora.py +151 -0
- package/src/skills/paper-plot/scripts/scatter_break.py +169 -0
- package/src/skills/paper-plot/scripts/scatter_tsne.py +133 -0
- package/src/skills/rebuttal/SKILL.md +9 -0
- package/src/skills/references/tool-usage-by-stage.md +438 -0
- package/src/skills/review/SKILL.md +105 -7
- package/src/skills/science/PROVENANCE.md +44 -0
- package/src/skills/science/SKILL.md +137 -0
- package/src/skills/science/references/artifact-science-tool.md +110 -0
- package/src/skills/science/references/claim-type-discipline.md +56 -0
- package/src/skills/science/references/domain-index.md +422 -0
- package/src/skills/science/references/hpc-via-bash-exec.md +42 -0
- package/src/skills/science/references/package-check-playbook.md +64 -0
- package/src/skills/science/references/package-index.min.json +3616 -0
- package/src/skills/science/references/packages/abinit.md +80 -0
- package/src/skills/science/references/packages/acts.md +73 -0
- package/src/skills/science/references/packages/aiida-core.md +80 -0
- package/src/skills/science/references/packages/alamode.md +80 -0
- package/src/skills/science/references/packages/amuse.md +88 -0
- package/src/skills/science/references/packages/anndata.md +88 -0
- package/src/skills/science/references/packages/arbor.md +80 -0
- package/src/skills/science/references/packages/arc.md +73 -0
- package/src/skills/science/references/packages/astropy.md +88 -0
- package/src/skills/science/references/packages/astroquery.md +88 -0
- package/src/skills/science/references/packages/atomate2.md +80 -0
- package/src/skills/science/references/packages/atomsmltr.md +73 -0
- package/src/skills/science/references/packages/awkward.md +73 -0
- package/src/skills/science/references/packages/batman.md +88 -0
- package/src/skills/science/references/packages/biopython.md +88 -0
- package/src/skills/science/references/packages/bloqade.md +73 -0
- package/src/skills/science/references/packages/brian2.md +73 -0
- package/src/skills/science/references/packages/bullet3.md +73 -0
- package/src/skills/science/references/packages/calculix.md +80 -0
- package/src/skills/science/references/packages/cantera.md +73 -0
- package/src/skills/science/references/packages/cavity-md-ipi.md +80 -0
- package/src/skills/science/references/packages/ccdproc.md +88 -0
- package/src/skills/science/references/packages/celerite2.md +88 -0
- package/src/skills/science/references/packages/cellrank.md +73 -0
- package/src/skills/science/references/packages/cesm.md +80 -0
- package/src/skills/science/references/packages/chemicals.md +73 -0
- package/src/skills/science/references/packages/chempy.md +73 -0
- package/src/skills/science/references/packages/cirq.md +73 -0
- package/src/skills/science/references/packages/coffea.md +73 -0
- package/src/skills/science/references/packages/cp2k.md +88 -0
- package/src/skills/science/references/packages/custodian.md +80 -0
- package/src/skills/science/references/packages/dart.md +73 -0
- package/src/skills/science/references/packages/datamol.md +88 -0
- package/src/skills/science/references/packages/dd4hep.md +73 -0
- package/src/skills/science/references/packages/dealii.md +80 -0
- package/src/skills/science/references/packages/deepchem.md +88 -0
- package/src/skills/science/references/packages/delphes.md +73 -0
- package/src/skills/science/references/packages/devito.md +80 -0
- package/src/skills/science/references/packages/dftb.md +88 -0
- package/src/skills/science/references/packages/dftd4.md +88 -0
- package/src/skills/science/references/packages/dftk-jl.md +80 -0
- package/src/skills/science/references/packages/dolfinx.md +80 -0
- package/src/skills/science/references/packages/drake.md +73 -0
- package/src/skills/science/references/packages/dumux.md +73 -0
- package/src/skills/science/references/packages/elk.md +80 -0
- package/src/skills/science/references/packages/elmerfem.md +80 -0
- package/src/skills/science/references/packages/enzo-e.md +88 -0
- package/src/skills/science/references/packages/espresso.md +80 -0
- package/src/skills/science/references/packages/exoplanet.md +88 -0
- package/src/skills/science/references/packages/fairroot.md +73 -0
- package/src/skills/science/references/packages/fbpic.md +80 -0
- package/src/skills/science/references/packages/fdtdbath-meep.md +80 -0
- package/src/skills/science/references/packages/geant4.md +73 -0
- package/src/skills/science/references/packages/geosx.md +80 -0
- package/src/skills/science/references/packages/gprmax.md +80 -0
- package/src/skills/science/references/packages/gromacs.md +80 -0
- package/src/skills/science/references/packages/gwaslab.md +73 -0
- package/src/skills/science/references/packages/gz-sim.md +73 -0
- package/src/skills/science/references/packages/hail.md +88 -0
- package/src/skills/science/references/packages/hiphive.md +80 -0
- package/src/skills/science/references/packages/hoomd-blue.md +80 -0
- package/src/skills/science/references/packages/itensor.md +73 -0
- package/src/skills/science/references/packages/itensors-jl.md +73 -0
- package/src/skills/science/references/packages/jdftx.md +73 -0
- package/src/skills/science/references/packages/jobflow.md +80 -0
- package/src/skills/science/references/packages/kadanoffbaym-jl.md +73 -0
- package/src/skills/science/references/packages/kite.md +80 -0
- package/src/skills/science/references/packages/kratos.md +80 -0
- package/src/skills/science/references/packages/kwant.md +73 -0
- package/src/skills/science/references/packages/lammps.md +80 -0
- package/src/skills/science/references/packages/lightkurve.md +88 -0
- package/src/skills/science/references/packages/limix.md +73 -0
- package/src/skills/science/references/packages/maxwelllink.md +80 -0
- package/src/skills/science/references/packages/mcdc.md +73 -0
- package/src/skills/science/references/packages/meep.md +80 -0
- package/src/skills/science/references/packages/mfem.md +80 -0
- package/src/skills/science/references/packages/mitgcm.md +73 -0
- package/src/skills/science/references/packages/modflow6.md +73 -0
- package/src/skills/science/references/packages/molecool.md +73 -0
- package/src/skills/science/references/packages/mom6.md +73 -0
- package/src/skills/science/references/packages/moose.md +80 -0
- package/src/skills/science/references/packages/mpas-model.md +73 -0
- package/src/skills/science/references/packages/mujoco.md +73 -0
- package/src/skills/science/references/packages/mumax3.md +73 -0
- package/src/skills/science/references/packages/nekrs.md +80 -0
- package/src/skills/science/references/packages/nessi.md +73 -0
- package/src/skills/science/references/packages/nest-simulator.md +73 -0
- package/src/skills/science/references/packages/netket.md +73 -0
- package/src/skills/science/references/packages/neuron.md +73 -0
- package/src/skills/science/references/packages/nextflow.md +88 -0
- package/src/skills/science/references/packages/nwchem.md +88 -0
- package/src/skills/science/references/packages/openbabel.md +88 -0
- package/src/skills/science/references/packages/openems.md +80 -0
- package/src/skills/science/references/packages/openff-toolkit.md +88 -0
- package/src/skills/science/references/packages/openfoam-dev.md +80 -0
- package/src/skills/science/references/packages/openmc.md +73 -0
- package/src/skills/science/references/packages/openmm.md +80 -0
- package/src/skills/science/references/packages/openmoc.md +73 -0
- package/src/skills/science/references/packages/openmx.md +80 -0
- package/src/skills/science/references/packages/opensees.md +80 -0
- package/src/skills/science/references/packages/opensn.md +80 -0
- package/src/skills/science/references/packages/opm-simulators.md +73 -0
- package/src/skills/science/references/packages/oqupy.md +73 -0
- package/src/skills/science/references/packages/packmol.md +80 -0
- package/src/skills/science/references/packages/palabos.md +80 -0
- package/src/skills/science/references/packages/parflow.md +80 -0
- package/src/skills/science/references/packages/pennylane.md +88 -0
- package/src/skills/science/references/packages/perceval.md +73 -0
- package/src/skills/science/references/packages/phono3py.md +73 -0
- package/src/skills/science/references/packages/phonopy.md +73 -0
- package/src/skills/science/references/packages/photutils.md +88 -0
- package/src/skills/science/references/packages/picongpu.md +80 -0
- package/src/skills/science/references/packages/plink-ng.md +88 -0
- package/src/skills/science/references/packages/precice.md +73 -0
- package/src/skills/science/references/packages/psc.md +80 -0
- package/src/skills/science/references/packages/psi4.md +88 -0
- package/src/skills/science/references/packages/pybinding.md +73 -0
- package/src/skills/science/references/packages/pyfr.md +80 -0
- package/src/skills/science/references/packages/pyhf.md +73 -0
- package/src/skills/science/references/packages/pyiron_base.md +80 -0
- package/src/skills/science/references/packages/pylcp.md +73 -0
- package/src/skills/science/references/packages/pylith.md +80 -0
- package/src/skills/science/references/packages/pynbody.md +88 -0
- package/src/skills/science/references/packages/pysam.md +88 -0
- package/src/skills/science/references/packages/pyscf.md +88 -0
- package/src/skills/science/references/packages/q-e.md +73 -0
- package/src/skills/science/references/packages/qibo.md +73 -0
- package/src/skills/science/references/packages/qiskit.md +73 -0
- package/src/skills/science/references/packages/quantica-jl.md +73 -0
- package/src/skills/science/references/packages/quantumoptics-jl.md +73 -0
- package/src/skills/science/references/packages/quimb.md +73 -0
- package/src/skills/science/references/packages/qulacs.md +73 -0
- package/src/skills/science/references/packages/qutip.md +73 -0
- package/src/skills/science/references/packages/rdkit.md +88 -0
- package/src/skills/science/references/packages/rmg-py.md +73 -0
- package/src/skills/science/references/packages/root.md +73 -0
- package/src/skills/science/references/packages/scanpy.md +88 -0
- package/src/skills/science/references/packages/scikit-allel.md +88 -0
- package/src/skills/science/references/packages/scikit-bio.md +88 -0
- package/src/skills/science/references/packages/scqubits.md +73 -0
- package/src/skills/science/references/packages/scuff-em.md +80 -0
- package/src/skills/science/references/packages/scvi-tools.md +73 -0
- package/src/skills/science/references/packages/seissol.md +73 -0
- package/src/skills/science/references/packages/sfepy.md +80 -0
- package/src/skills/science/references/packages/sisl.md +73 -0
- package/src/skills/science/references/packages/smilei.md +80 -0
- package/src/skills/science/references/packages/snakemake.md +88 -0
- package/src/skills/science/references/packages/specfem3d-globe.md +80 -0
- package/src/skills/science/references/packages/specutils.md +88 -0
- package/src/skills/science/references/packages/spglib.md +80 -0
- package/src/skills/science/references/packages/squidpy.md +88 -0
- package/src/skills/science/references/packages/starry.md +88 -0
- package/src/skills/science/references/packages/strawberryfields.md +73 -0
- package/src/skills/science/references/packages/su2.md +80 -0
- package/src/skills/science/references/packages/sunny-jl.md +73 -0
- package/src/skills/science/references/packages/sw4.md +73 -0
- package/src/skills/science/references/packages/swift.md +88 -0
- package/src/skills/science/references/packages/tdnegf.md +73 -0
- package/src/skills/science/references/packages/tenpy.md +73 -0
- package/src/skills/science/references/packages/thermo.md +73 -0
- package/src/skills/science/references/packages/tkwant.md +73 -0
- package/src/skills/science/references/packages/tvb-root.md +73 -0
- package/src/skills/science/references/packages/uproot5.md +73 -0
- package/src/skills/science/references/packages/vampire.md +80 -0
- package/src/skills/science/references/packages/wannier_tools.md +73 -0
- package/src/skills/science/references/packages/warpx.md +80 -0
- package/src/skills/science/references/packages/wrf.md +73 -0
- package/src/skills/science/references/packages/xtb.md +88 -0
- package/src/skills/science/references/packages/yt.md +73 -0
- package/src/skills/science/references/science-task-brief-template.md +71 -0
- package/src/skills/scout/SKILL.md +83 -425
- package/src/skills/scout/references/literature-scout-template.md +5 -24
- package/src/skills/scout/references/operational-guidance.md +191 -0
- package/src/skills/scout/references/paper-triage-playbook.md +11 -35
- package/src/skills/write/SKILL.md +744 -1246
- package/src/skills/write/references/experiments_analysis_patterns.md +129 -0
- package/src/skills/write/references/oral_package_patterns.md +252 -0
- package/src/skills/write/references/oral_writing_principles.md +291 -0
- package/src/skills/write/references/section_rewrite_checklist.md +234 -0
- package/src/tui/dist/app/AppContainer.js +1314 -27
- package/src/tui/dist/components/Composer.js +26 -1
- package/src/tui/dist/components/ConfigScreen.js +2 -1
- package/src/tui/dist/components/InputPrompt.js +25 -9
- package/src/tui/dist/components/MainContent.js +18 -3
- package/src/tui/dist/components/QuestScreen.js +3 -2
- package/src/tui/dist/components/UtilityScreen.js +37 -0
- package/src/tui/dist/hooks/useSafeInput.js +10 -0
- package/src/tui/dist/index.js +13 -1
- package/src/tui/dist/layouts/DefaultAppLayout.js +11 -8
- package/src/tui/dist/lib/api.js +89 -1
- package/src/tui/package.json +1 -1
- package/src/ui/dist/assets/{AnalysisPlugin-DnSm0GZn.js → AnalysisPlugin-CA94NGmI.js} +1 -1
- package/src/ui/dist/assets/CliPlugin-DHBzphZU.js +79 -0
- package/src/ui/dist/assets/CodeEditorPlugin-BOFwD2rn.js +2 -0
- package/src/ui/dist/assets/{CodeViewerPlugin-itb0tltR.js → CodeViewerPlugin-CqDpgjik.js} +4 -4
- package/src/ui/dist/assets/{DocViewerPlugin-DqKkiCI6.js → DocViewerPlugin-UDBgt8-4.js} +3 -3
- package/src/ui/dist/assets/GitCommitViewerPlugin-BmHtZ0bZ.js +6 -0
- package/src/ui/dist/assets/{GitDiffViewerPlugin-DxL2ezFG.js → GitDiffViewerPlugin-CAxjNorQ.js} +2 -2
- package/src/ui/dist/assets/{GitSnapshotViewer-B_RQm1YZ.js → GitSnapshotViewer-CweA6VON.js} +2 -2
- package/src/ui/dist/assets/{ImageViewerPlugin-tHqlXY3n.js → ImageViewerPlugin-C8wHGvGN.js} +5 -5
- package/src/ui/dist/assets/LabPlugin-COyyLUol.js +32 -0
- package/src/ui/dist/assets/{LatexPlugin-B495DTXC.js → LatexPlugin-BQjAaA5J.js} +4 -4
- package/src/ui/dist/assets/{MarkdownViewerPlugin-DG28-61B.js → MarkdownViewerPlugin-Dy1NE2dI.js} +3 -3
- package/src/ui/dist/assets/{MarketplacePlugin-BiOGT-Kj.js → MarketplacePlugin-DMIZtEJ2.js} +2 -2
- package/src/ui/dist/assets/NotebookEditor-CFHMq_Qt.js +91 -0
- package/src/ui/dist/assets/{NotebookEditor-CVsj8h_T.js → NotebookEditor-WFyd8Ybt.js} +23 -23
- package/src/ui/dist/assets/{PdfLoader-CASDQmxJ.js → PdfLoader-CLE5u5TS.js} +3 -3
- package/src/ui/dist/assets/{PdfMarkdownPlugin-BFhwoKsY.js → PdfMarkdownPlugin-_iNK_H83.js} +1 -1
- package/src/ui/dist/assets/PdfViewerPlugin-DgWsbInT.js +22 -0
- package/src/ui/dist/assets/SearchPlugin-DrZmn5iw.js +11 -0
- package/src/ui/dist/assets/{TextViewerPlugin-CB4DYfWO.js → TextViewerPlugin-D1-T3aC7.js} +4 -4
- package/src/ui/dist/assets/branding/runner-claude.svg +107 -0
- package/src/ui/dist/assets/branding/runner-codex.svg +10 -0
- package/src/ui/dist/assets/branding/runner-kimi.svg +14 -0
- package/src/ui/dist/assets/branding/runner-opencode.svg +7 -0
- package/src/ui/dist/assets/cli-store-CoZ-x5Ip.js +1 -0
- package/src/ui/dist/assets/{code-DLC6G24T.js → code-DbsmSd3Y.js} +1 -1
- package/src/ui/dist/assets/file-diff-panel-DsvyRz47.js +1 -0
- package/src/ui/dist/assets/{wrap-text-CwMn-iqb.js → file-jump-queue-DeQBikaw.js} +3 -3
- package/src/ui/dist/assets/{file-socket-Cu4Qln7Y.js → file-socket-DA5XIx88.js} +1 -1
- package/src/ui/dist/assets/fonts/ds-fonts.css +50 -4
- package/src/ui/dist/assets/images/deepxiv/register-guide.png +0 -0
- package/src/ui/dist/assets/index-39vY9LmZ.js +1 -0
- package/src/ui/dist/assets/{index-wQ7RIIRd.js → index-BsO46tJA.js} +1 -1
- package/src/ui/dist/assets/index-CHzJ2xtB.js +3530 -0
- package/src/ui/dist/assets/index-DH-zxoZ3.css +33 -0
- package/src/ui/dist/assets/{plugin-notebook-HbW2K-1c.js → plugin-notebook-JRhysCqj.js} +2 -2
- package/src/ui/dist/assets/{project-sync-CsX08Qno.js → project-sync-DPmWKmKD.js} +1 -1
- package/src/ui/dist/assets/{zoom-out-R-GWEhzS.js → zoom-out-DAukFWen.js} +3 -3
- package/src/ui/dist/index.html +3 -3
- package/src/skills/analysis-campaign/references/artifact-orchestration.md +0 -58
- package/src/skills/baseline/references/memory-playbook.md +0 -40
- package/src/skills/baseline/references/publishable-baseline-package.md +0 -30
- package/src/skills/write/references/outline-evidence-contract-example.md +0 -107
- package/src/skills/write/references/paper-experiment-matrix-template.md +0 -131
- package/src/skills/write/references/paper-section-playbook.md +0 -64
- package/src/skills/write/references/reviewer-first-writing.md +0 -64
- package/src/skills/write/references/revision-checklist.md +0 -70
- package/src/skills/write/references/section-contracts.md +0 -82
- package/src/skills/write/references/sentence-level-proofing.md +0 -49
- package/src/ui/dist/assets/AiManusChatView-COFACy7V.js +0 -204
- package/src/ui/dist/assets/CliPlugin-CvwCmDQ5.js +0 -109
- package/src/ui/dist/assets/CodeEditorPlugin-cOqSa0xq.js +0 -2
- package/src/ui/dist/assets/GitCommitViewerPlugin-DVgNHBCS.js +0 -1
- package/src/ui/dist/assets/LabCopilotPanel-ClMbq5Yu.js +0 -14
- package/src/ui/dist/assets/LabPlugin-L_SuE8ow.js +0 -22
- package/src/ui/dist/assets/NotebookEditor-C-4Kt1p9.js +0 -81
- package/src/ui/dist/assets/PdfViewerPlugin-DcOzU9vd.js +0 -17
- package/src/ui/dist/assets/SearchPlugin-CHj7M58O.js +0 -16
- package/src/ui/dist/assets/VNCViewer-CjlbyCB3.js +0 -11
- package/src/ui/dist/assets/bot-CFkZY-JP.js +0 -6
- package/src/ui/dist/assets/chevron-up-Dq5ofbht.js +0 -6
- package/src/ui/dist/assets/file-content-Dv4LoZec.js +0 -1
- package/src/ui/dist/assets/file-diff-panel-Denq-lC3.js +0 -1
- package/src/ui/dist/assets/file-jump-queue-DA-SdG__.js +0 -1
- package/src/ui/dist/assets/git-commit-horizontal-BUh6G52n.js +0 -6
- package/src/ui/dist/assets/image-B9HUUddG.js +0 -6
- package/src/ui/dist/assets/index-B2B1sg-M.js +0 -1
- package/src/ui/dist/assets/index-Cgla8biy.css +0 -33
- package/src/ui/dist/assets/index-DRyx7vAc.js +0 -1
- package/src/ui/dist/assets/index-Gbl53BNp.js +0 -2496
- package/src/ui/dist/assets/pdf-effect-queue-ZtnHFCAi.js +0 -6
- package/src/ui/dist/assets/popover-DL6h35vr.js +0 -1
- package/src/ui/dist/assets/select-DvmXt1yY.js +0 -11
- package/src/ui/dist/assets/sigma-7jpXazui.js +0 -6
- package/src/ui/dist/assets/trash-xA7kFt8i.js +0 -11
- package/src/ui/dist/assets/useCliAccess-DsMwDjOp.js +0 -1
- package/src/ui/dist/assets/useFileDiffOverlay-FuhcnKiw.js +0 -1
|
@@ -0,0 +1,590 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import hashlib
|
|
4
|
+
import json
|
|
5
|
+
import re
|
|
6
|
+
from pathlib import Path
|
|
7
|
+
from typing import Any
|
|
8
|
+
|
|
9
|
+
from .shared import ensure_dir, read_json, utc_now, write_json
|
|
10
|
+
|
|
11
|
+
DEFAULT_EVIDENCE_PACKET_THRESHOLD_BYTES = 48_000
|
|
12
|
+
DEFAULT_RUNNER_TOOL_RESULT_THRESHOLD_BYTES = 8_000
|
|
13
|
+
_MAX_SUMMARY_CHARS = 900
|
|
14
|
+
_MAX_BLOCKERS = 12
|
|
15
|
+
_RAW_PAYLOAD_UNSET = object()
|
|
16
|
+
_READ_CACHE_SCHEMA_VERSION = 1
|
|
17
|
+
_HOT_TOOL_RESULT_THRESHOLDS_BYTES = {
|
|
18
|
+
"artifact.get_quest_state": 4_000,
|
|
19
|
+
"artifact.get_global_status": 4_000,
|
|
20
|
+
"artifact.get_paper_contract_health": 4_000,
|
|
21
|
+
"artifact.validate_manuscript_coverage": 4_000,
|
|
22
|
+
"artifact.list_paper_outlines": 2_000,
|
|
23
|
+
"bash_exec.bash_exec": 2_000,
|
|
24
|
+
}
|
|
25
|
+
_FULL_DETAIL_FORCE_COMPACT_TOOLS = {
|
|
26
|
+
"artifact.get_quest_state",
|
|
27
|
+
"artifact.get_global_status",
|
|
28
|
+
"artifact.get_paper_contract_health",
|
|
29
|
+
"artifact.validate_manuscript_coverage",
|
|
30
|
+
"artifact.list_paper_outlines",
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
def payload_json_bytes(payload: Any) -> bytes:
|
|
35
|
+
try:
|
|
36
|
+
return json.dumps(payload, ensure_ascii=False, sort_keys=True, default=str).encode("utf-8")
|
|
37
|
+
except Exception:
|
|
38
|
+
return str(payload).encode("utf-8", errors="replace")
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
def payload_sha256(payload: Any) -> str:
|
|
42
|
+
return hashlib.sha256(payload_json_bytes(payload)).hexdigest()
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
def _normalized_tool_name(tool_name: str | None) -> str:
|
|
46
|
+
return str(tool_name or "").strip()
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
def _compact_threshold_for_tool(tool_name: str, *, default_threshold: int) -> int:
|
|
50
|
+
hot_threshold = _HOT_TOOL_RESULT_THRESHOLDS_BYTES.get(_normalized_tool_name(tool_name))
|
|
51
|
+
if hot_threshold is None:
|
|
52
|
+
return int(default_threshold)
|
|
53
|
+
return min(int(default_threshold), hot_threshold)
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
def _tool_force_compaction(*, tool_name: str, full_detail_requested: bool | None, force: bool) -> bool:
|
|
57
|
+
if force:
|
|
58
|
+
return True
|
|
59
|
+
return bool(full_detail_requested) and _normalized_tool_name(tool_name) in _FULL_DETAIL_FORCE_COMPACT_TOOLS
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
def _slug(value: str) -> str:
|
|
63
|
+
normalized = re.sub(r"[^A-Za-z0-9_.-]+", "-", str(value or "").strip())
|
|
64
|
+
return normalized.strip("-")[:80] or "payload"
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
def _strip_read_cache_volatile(value: Any) -> Any:
|
|
68
|
+
volatile_keys = {
|
|
69
|
+
"created_at",
|
|
70
|
+
"updated_at",
|
|
71
|
+
"generated_at",
|
|
72
|
+
"completed_at",
|
|
73
|
+
"read_cache",
|
|
74
|
+
"run_age_seconds",
|
|
75
|
+
"status_age_seconds",
|
|
76
|
+
"silent_seconds",
|
|
77
|
+
"progress_age_seconds",
|
|
78
|
+
"signal_age_seconds",
|
|
79
|
+
}
|
|
80
|
+
if isinstance(value, dict):
|
|
81
|
+
return {
|
|
82
|
+
key: _strip_read_cache_volatile(item)
|
|
83
|
+
for key, item in value.items()
|
|
84
|
+
if str(key) not in volatile_keys and not str(key).endswith("_age_seconds")
|
|
85
|
+
}
|
|
86
|
+
if isinstance(value, list):
|
|
87
|
+
return [_strip_read_cache_volatile(item) for item in value]
|
|
88
|
+
return value
|
|
89
|
+
|
|
90
|
+
|
|
91
|
+
def _read_cache_path(*, quest_root: Path, tool_name: str, detail: str | None, cache_key: Any) -> Path:
|
|
92
|
+
key_hash = payload_sha256({"tool_name": tool_name, "detail": detail, "cache_key": cache_key})[:20]
|
|
93
|
+
return quest_root / ".ds" / "read_cache" / f"{_slug(tool_name)}-{key_hash}.json"
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
def _command_fingerprint(payload: dict[str, Any]) -> str:
|
|
97
|
+
return payload_sha256(
|
|
98
|
+
{
|
|
99
|
+
"command": " ".join(str(payload.get("command") or "").split()),
|
|
100
|
+
"cwd": str(payload.get("cwd") or payload.get("workdir") or "").strip(),
|
|
101
|
+
}
|
|
102
|
+
)
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
def _sidecar_path(
|
|
106
|
+
*,
|
|
107
|
+
quest_root: Path,
|
|
108
|
+
run_id: str | None,
|
|
109
|
+
tool_name: str,
|
|
110
|
+
payload_hash: str,
|
|
111
|
+
item_id: str | None = None,
|
|
112
|
+
) -> Path:
|
|
113
|
+
run_segment = _slug(run_id or "manual")
|
|
114
|
+
item_segment = _slug(item_id or payload_hash[:12])
|
|
115
|
+
tool_segment = _slug(tool_name)
|
|
116
|
+
return quest_root / ".ds" / "evidence_packets" / run_segment / f"{tool_segment}-{item_segment}.json"
|
|
117
|
+
|
|
118
|
+
|
|
119
|
+
def _collect_blockers(value: Any, blockers: list[str]) -> None:
|
|
120
|
+
if len(blockers) >= _MAX_BLOCKERS:
|
|
121
|
+
return
|
|
122
|
+
if isinstance(value, dict):
|
|
123
|
+
for key, item in value.items():
|
|
124
|
+
lowered = str(key or "").lower()
|
|
125
|
+
if any(marker in lowered for marker in ("block", "gap", "missing", "error", "invalid", "unresolved")):
|
|
126
|
+
if isinstance(item, str) and item.strip():
|
|
127
|
+
blockers.append(item.strip())
|
|
128
|
+
elif isinstance(item, list):
|
|
129
|
+
for child in item:
|
|
130
|
+
if len(blockers) >= _MAX_BLOCKERS:
|
|
131
|
+
break
|
|
132
|
+
if isinstance(child, str) and child.strip():
|
|
133
|
+
blockers.append(child.strip())
|
|
134
|
+
elif isinstance(child, dict):
|
|
135
|
+
title = str(child.get("title") or child.get("summary") or child.get("reason") or "").strip()
|
|
136
|
+
status = str(child.get("status") or "").strip()
|
|
137
|
+
if title:
|
|
138
|
+
blockers.append(f"{status}: {title}".strip(": "))
|
|
139
|
+
elif isinstance(item, dict):
|
|
140
|
+
title = str(item.get("title") or item.get("summary") or item.get("reason") or "").strip()
|
|
141
|
+
if title:
|
|
142
|
+
blockers.append(title)
|
|
143
|
+
if isinstance(item, (dict, list)):
|
|
144
|
+
_collect_blockers(item, blockers)
|
|
145
|
+
if len(blockers) >= _MAX_BLOCKERS:
|
|
146
|
+
break
|
|
147
|
+
elif isinstance(value, list):
|
|
148
|
+
for item in value:
|
|
149
|
+
_collect_blockers(item, blockers)
|
|
150
|
+
if len(blockers) >= _MAX_BLOCKERS:
|
|
151
|
+
break
|
|
152
|
+
|
|
153
|
+
|
|
154
|
+
def extract_key_blockers(payload: Any) -> list[str]:
|
|
155
|
+
blockers: list[str] = []
|
|
156
|
+
_collect_blockers(payload, blockers)
|
|
157
|
+
seen: set[str] = set()
|
|
158
|
+
ordered: list[str] = []
|
|
159
|
+
for blocker in blockers:
|
|
160
|
+
text = " ".join(str(blocker).split())
|
|
161
|
+
if not text or text in seen:
|
|
162
|
+
continue
|
|
163
|
+
seen.add(text)
|
|
164
|
+
ordered.append(text[:240])
|
|
165
|
+
if len(ordered) >= _MAX_BLOCKERS:
|
|
166
|
+
break
|
|
167
|
+
return ordered
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
def _first_text(payload: dict[str, Any], keys: tuple[str, ...]) -> str | None:
|
|
171
|
+
for key in keys:
|
|
172
|
+
value = payload.get(key)
|
|
173
|
+
if isinstance(value, str) and value.strip():
|
|
174
|
+
return " ".join(value.split())
|
|
175
|
+
return None
|
|
176
|
+
|
|
177
|
+
|
|
178
|
+
def summarize_payload(payload: Any, *, tool_name: str) -> str:
|
|
179
|
+
if not isinstance(payload, dict):
|
|
180
|
+
text = str(payload).strip()
|
|
181
|
+
return (text[: _MAX_SUMMARY_CHARS - 1].rstrip() + "...") if len(text) > _MAX_SUMMARY_CHARS else text
|
|
182
|
+
|
|
183
|
+
parts: list[str] = []
|
|
184
|
+
ok_value = payload.get("ok")
|
|
185
|
+
if isinstance(ok_value, bool):
|
|
186
|
+
parts.append(f"ok={ok_value}")
|
|
187
|
+
status = _first_text(payload, ("status", "state", "detail", "summary", "message"))
|
|
188
|
+
if status:
|
|
189
|
+
parts.append(f"status={status}")
|
|
190
|
+
for key in ("count", "total", "item_count", "log_line_count"):
|
|
191
|
+
if key in payload and isinstance(payload.get(key), int | float | str):
|
|
192
|
+
parts.append(f"{key}={payload.get(key)}")
|
|
193
|
+
for key in ("items", "results", "entries", "files"):
|
|
194
|
+
value = payload.get(key)
|
|
195
|
+
if isinstance(value, list):
|
|
196
|
+
parts.append(f"{key}={len(value)}")
|
|
197
|
+
break
|
|
198
|
+
|
|
199
|
+
blockers = extract_key_blockers(payload)
|
|
200
|
+
if blockers:
|
|
201
|
+
parts.append(f"key_blockers={len(blockers)}")
|
|
202
|
+
parts.append(f"first_blocker={blockers[0]}")
|
|
203
|
+
|
|
204
|
+
summary = f"{tool_name}: " + "; ".join(str(part) for part in parts if str(part).strip())
|
|
205
|
+
if summary.strip() == f"{tool_name}:":
|
|
206
|
+
summary = f"{tool_name}: compact evidence packet available in sidecar."
|
|
207
|
+
if len(summary) > _MAX_SUMMARY_CHARS:
|
|
208
|
+
summary = summary[: _MAX_SUMMARY_CHARS - 3].rstrip() + "..."
|
|
209
|
+
return summary
|
|
210
|
+
|
|
211
|
+
|
|
212
|
+
def _ok_from_payload_or_status(payload: Any, *, status: str | None = None) -> bool | None:
|
|
213
|
+
if isinstance(payload, dict):
|
|
214
|
+
ok_value = payload.get("ok")
|
|
215
|
+
if isinstance(ok_value, bool):
|
|
216
|
+
return ok_value
|
|
217
|
+
success_value = payload.get("success")
|
|
218
|
+
if isinstance(success_value, bool):
|
|
219
|
+
return success_value
|
|
220
|
+
for key in ("status", "state"):
|
|
221
|
+
value = payload.get(key)
|
|
222
|
+
if isinstance(value, str):
|
|
223
|
+
normalized = value.strip().lower()
|
|
224
|
+
if normalized in {"failed", "failure", "error", "errored", "cancelled", "canceled", "invalid"}:
|
|
225
|
+
return False
|
|
226
|
+
if normalized in {"completed", "complete", "success", "succeeded", "ok", "ready"}:
|
|
227
|
+
return True
|
|
228
|
+
normalized_status = str(status or "").strip().lower()
|
|
229
|
+
if normalized_status in {"failed", "failure", "error", "errored", "cancelled", "canceled", "invalid"}:
|
|
230
|
+
return False
|
|
231
|
+
if normalized_status in {"completed", "complete", "success", "succeeded", "ok", "ready"}:
|
|
232
|
+
return True
|
|
233
|
+
return None
|
|
234
|
+
|
|
235
|
+
|
|
236
|
+
def compact_evidence_payload(
|
|
237
|
+
payload: Any,
|
|
238
|
+
*,
|
|
239
|
+
quest_root: Path,
|
|
240
|
+
run_id: str | None,
|
|
241
|
+
tool_name: str,
|
|
242
|
+
detail: str | None = None,
|
|
243
|
+
item_id: str | None = None,
|
|
244
|
+
force: bool = False,
|
|
245
|
+
threshold_bytes: int = DEFAULT_EVIDENCE_PACKET_THRESHOLD_BYTES,
|
|
246
|
+
reason: str | None = None,
|
|
247
|
+
full_detail_requested: bool | None = None,
|
|
248
|
+
status: str | None = None,
|
|
249
|
+
) -> tuple[Any, dict[str, Any]]:
|
|
250
|
+
payload_bytes = len(payload_json_bytes(payload))
|
|
251
|
+
threshold = max(1, int(threshold_bytes))
|
|
252
|
+
if not force and payload_bytes <= threshold:
|
|
253
|
+
return payload, {
|
|
254
|
+
"compacted": False,
|
|
255
|
+
"payload_bytes": payload_bytes,
|
|
256
|
+
"threshold_bytes": threshold,
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
digest = payload_sha256(payload)
|
|
260
|
+
sidecar_path = _sidecar_path(
|
|
261
|
+
quest_root=quest_root,
|
|
262
|
+
run_id=run_id,
|
|
263
|
+
tool_name=tool_name,
|
|
264
|
+
payload_hash=digest,
|
|
265
|
+
item_id=item_id,
|
|
266
|
+
)
|
|
267
|
+
ensure_dir(sidecar_path.parent)
|
|
268
|
+
key_blockers = extract_key_blockers(payload)
|
|
269
|
+
summary = summarize_payload(payload, tool_name=tool_name)
|
|
270
|
+
write_json(
|
|
271
|
+
sidecar_path,
|
|
272
|
+
{
|
|
273
|
+
"version": 1,
|
|
274
|
+
"created_at": utc_now(),
|
|
275
|
+
"tool_name": tool_name,
|
|
276
|
+
"detail": detail,
|
|
277
|
+
"summary": summary,
|
|
278
|
+
"key_blockers": key_blockers,
|
|
279
|
+
"payload_sha256": digest,
|
|
280
|
+
"payload_bytes": payload_bytes,
|
|
281
|
+
"payload": payload,
|
|
282
|
+
},
|
|
283
|
+
)
|
|
284
|
+
index_path = sidecar_path.parent / "index.json"
|
|
285
|
+
existing_index = read_json(index_path, {})
|
|
286
|
+
existing_items = (
|
|
287
|
+
[dict(item) for item in (existing_index.get("items") or []) if isinstance(item, dict)]
|
|
288
|
+
if isinstance(existing_index, dict)
|
|
289
|
+
else []
|
|
290
|
+
)
|
|
291
|
+
entry = {
|
|
292
|
+
"tool_name": tool_name,
|
|
293
|
+
"detail": detail,
|
|
294
|
+
"summary": summary,
|
|
295
|
+
"sidecar_path": str(sidecar_path),
|
|
296
|
+
"payload_sha256": digest,
|
|
297
|
+
"payload_bytes": payload_bytes,
|
|
298
|
+
"key_blockers": key_blockers,
|
|
299
|
+
"created_at": utc_now(),
|
|
300
|
+
}
|
|
301
|
+
write_json(
|
|
302
|
+
index_path,
|
|
303
|
+
{
|
|
304
|
+
"version": 1,
|
|
305
|
+
"updated_at": utc_now(),
|
|
306
|
+
"run_id": run_id,
|
|
307
|
+
"items": [*existing_items, entry][-200:],
|
|
308
|
+
},
|
|
309
|
+
)
|
|
310
|
+
evidence_packet = {
|
|
311
|
+
"version": 1,
|
|
312
|
+
"tool_name": tool_name,
|
|
313
|
+
"detail": detail,
|
|
314
|
+
"summary": summary,
|
|
315
|
+
"sidecar_path": str(sidecar_path),
|
|
316
|
+
"index_path": str(index_path),
|
|
317
|
+
"payload_sha256": digest,
|
|
318
|
+
"payload_bytes": payload_bytes,
|
|
319
|
+
"key_blockers": key_blockers,
|
|
320
|
+
"full_detail_requested": bool(full_detail_requested),
|
|
321
|
+
"compaction_reason": reason or "context_budget",
|
|
322
|
+
"drill_down_rule": "Read sidecar_path only when the compact facts are insufficient for the next decision.",
|
|
323
|
+
}
|
|
324
|
+
compacted = {
|
|
325
|
+
"compacted": True,
|
|
326
|
+
"evidence_packet": evidence_packet,
|
|
327
|
+
}
|
|
328
|
+
ok_value = _ok_from_payload_or_status(payload, status=status)
|
|
329
|
+
if ok_value is not None:
|
|
330
|
+
compacted["ok"] = ok_value
|
|
331
|
+
return compacted, {
|
|
332
|
+
"compacted": True,
|
|
333
|
+
"sidecar_path": str(sidecar_path),
|
|
334
|
+
"payload_sha256": digest,
|
|
335
|
+
"payload_bytes": payload_bytes,
|
|
336
|
+
"summary": summary,
|
|
337
|
+
"key_blocker_count": len(key_blockers),
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
|
|
341
|
+
def compact_runner_tool_event(
|
|
342
|
+
event: dict[str, Any],
|
|
343
|
+
*,
|
|
344
|
+
quest_root: Path,
|
|
345
|
+
run_id: str,
|
|
346
|
+
threshold_bytes: int = DEFAULT_RUNNER_TOOL_RESULT_THRESHOLD_BYTES,
|
|
347
|
+
raw_payload: Any = _RAW_PAYLOAD_UNSET,
|
|
348
|
+
) -> tuple[dict[str, Any], dict[str, Any]]:
|
|
349
|
+
if str(event.get("type") or "") != "runner.tool_result":
|
|
350
|
+
return event, {"compacted": False}
|
|
351
|
+
output = str(event.get("output") or "")
|
|
352
|
+
tool_name = str(event.get("tool_name") or event.get("mcp_tool") or "tool").strip() or "tool"
|
|
353
|
+
args = str(event.get("args") or "")
|
|
354
|
+
full_detail_requested = "detail" in args and "full" in args.lower()
|
|
355
|
+
output_bytes = len(output.encode("utf-8", errors="replace"))
|
|
356
|
+
has_raw_payload = raw_payload is not _RAW_PAYLOAD_UNSET
|
|
357
|
+
source_payload = raw_payload if has_raw_payload else _RAW_PAYLOAD_UNSET
|
|
358
|
+
source_payload_bytes = len(payload_json_bytes(source_payload)) if has_raw_payload else 0
|
|
359
|
+
threshold = max(1, int(threshold_bytes))
|
|
360
|
+
if output_bytes <= threshold and source_payload_bytes <= threshold:
|
|
361
|
+
return event, {
|
|
362
|
+
"compacted": False,
|
|
363
|
+
"output_bytes": output_bytes,
|
|
364
|
+
"source_payload_bytes": source_payload_bytes,
|
|
365
|
+
"threshold_bytes": threshold,
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
if not has_raw_payload:
|
|
369
|
+
try:
|
|
370
|
+
source_payload = json.loads(output)
|
|
371
|
+
except json.JSONDecodeError:
|
|
372
|
+
source_payload = {"text": output}
|
|
373
|
+
compacted_payload, meta = compact_evidence_payload(
|
|
374
|
+
source_payload,
|
|
375
|
+
quest_root=quest_root,
|
|
376
|
+
run_id=run_id,
|
|
377
|
+
tool_name=tool_name,
|
|
378
|
+
item_id=str(event.get("event_id") or event.get("tool_call_id") or ""),
|
|
379
|
+
force=True,
|
|
380
|
+
threshold_bytes=threshold_bytes,
|
|
381
|
+
reason="runner_tool_result_context_budget",
|
|
382
|
+
full_detail_requested=full_detail_requested,
|
|
383
|
+
status=str(event.get("status") or ""),
|
|
384
|
+
)
|
|
385
|
+
compacted_event = dict(event)
|
|
386
|
+
compacted_event["output"] = json.dumps(compacted_payload, ensure_ascii=False, indent=2)
|
|
387
|
+
compacted_event["output_bytes"] = output_bytes
|
|
388
|
+
compacted_event["output_sha256"] = hashlib.sha256(output.encode("utf-8", errors="replace")).hexdigest()
|
|
389
|
+
if has_raw_payload:
|
|
390
|
+
compacted_event["source_payload_bytes"] = source_payload_bytes
|
|
391
|
+
compacted_event["source_payload_sha256"] = payload_sha256(source_payload)
|
|
392
|
+
compacted_event["output_compacted"] = True
|
|
393
|
+
compacted_event["evidence_packet"] = (
|
|
394
|
+
compacted_payload.get("evidence_packet") if isinstance(compacted_payload, dict) else None
|
|
395
|
+
)
|
|
396
|
+
return compacted_event, {
|
|
397
|
+
**meta,
|
|
398
|
+
"output_bytes": output_bytes,
|
|
399
|
+
"source_payload_bytes": source_payload_bytes,
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
|
|
403
|
+
def compact_mcp_tool_result(
|
|
404
|
+
payload: dict[str, Any],
|
|
405
|
+
*,
|
|
406
|
+
quest_root: Path,
|
|
407
|
+
run_id: str | None,
|
|
408
|
+
tool_name: str,
|
|
409
|
+
detail: str | None = None,
|
|
410
|
+
force: bool = False,
|
|
411
|
+
threshold_bytes: int | None = None,
|
|
412
|
+
reason: str | None = None,
|
|
413
|
+
full_detail_requested: bool | None = None,
|
|
414
|
+
) -> dict[str, Any]:
|
|
415
|
+
normalized_detail = str(detail or "").strip().lower() or None
|
|
416
|
+
requested_full_detail = bool(full_detail_requested) or normalized_detail == "full"
|
|
417
|
+
default_threshold = DEFAULT_EVIDENCE_PACKET_THRESHOLD_BYTES if threshold_bytes is None else int(threshold_bytes)
|
|
418
|
+
effective_threshold = (
|
|
419
|
+
_compact_threshold_for_tool(tool_name, default_threshold=default_threshold)
|
|
420
|
+
if requested_full_detail
|
|
421
|
+
else default_threshold
|
|
422
|
+
)
|
|
423
|
+
compacted, _meta = compact_evidence_payload(
|
|
424
|
+
payload,
|
|
425
|
+
quest_root=quest_root,
|
|
426
|
+
run_id=run_id,
|
|
427
|
+
tool_name=tool_name,
|
|
428
|
+
detail=normalized_detail,
|
|
429
|
+
force=_tool_force_compaction(
|
|
430
|
+
tool_name=tool_name,
|
|
431
|
+
full_detail_requested=requested_full_detail,
|
|
432
|
+
force=force,
|
|
433
|
+
),
|
|
434
|
+
threshold_bytes=effective_threshold,
|
|
435
|
+
reason=reason,
|
|
436
|
+
full_detail_requested=requested_full_detail,
|
|
437
|
+
)
|
|
438
|
+
return compacted if isinstance(compacted, dict) else payload
|
|
439
|
+
|
|
440
|
+
|
|
441
|
+
def cached_compact_mcp_tool_result(
|
|
442
|
+
payload: dict[str, Any],
|
|
443
|
+
*,
|
|
444
|
+
quest_root: Path,
|
|
445
|
+
run_id: str | None,
|
|
446
|
+
tool_name: str,
|
|
447
|
+
detail: str | None = None,
|
|
448
|
+
cache_key: Any = None,
|
|
449
|
+
source_path: Path | None = None,
|
|
450
|
+
force: bool = False,
|
|
451
|
+
threshold_bytes: int | None = None,
|
|
452
|
+
reason: str | None = None,
|
|
453
|
+
full_detail_requested: bool | None = None,
|
|
454
|
+
) -> dict[str, Any]:
|
|
455
|
+
normalized_detail = str(detail or "").strip().lower() or None
|
|
456
|
+
if _normalized_tool_name(tool_name) == "bash_exec.bash_exec":
|
|
457
|
+
payload = dict(payload)
|
|
458
|
+
if not payload.get("cwd"):
|
|
459
|
+
payload["cwd"] = str(quest_root)
|
|
460
|
+
if not payload.get("command_fingerprint"):
|
|
461
|
+
payload["command_fingerprint"] = _command_fingerprint(payload)
|
|
462
|
+
resolved_source = source_path.expanduser().resolve() if source_path is not None else None
|
|
463
|
+
source_stat = resolved_source.stat() if resolved_source is not None and resolved_source.exists() else None
|
|
464
|
+
stable_payload = _strip_read_cache_volatile(payload)
|
|
465
|
+
payload_fingerprint = payload_sha256(stable_payload)
|
|
466
|
+
original_bytes = len(payload_json_bytes(payload))
|
|
467
|
+
resolved_cache_key = cache_key if cache_key is not None else {"detail": normalized_detail}
|
|
468
|
+
cache_path = _read_cache_path(
|
|
469
|
+
quest_root=quest_root,
|
|
470
|
+
tool_name=tool_name,
|
|
471
|
+
detail=normalized_detail,
|
|
472
|
+
cache_key=resolved_cache_key,
|
|
473
|
+
)
|
|
474
|
+
cached = read_json(cache_path, {})
|
|
475
|
+
cache_hit = (
|
|
476
|
+
isinstance(cached, dict)
|
|
477
|
+
and int(cached.get("schema_version") or 0) == _READ_CACHE_SCHEMA_VERSION
|
|
478
|
+
and cached.get("payload_fingerprint") == payload_fingerprint
|
|
479
|
+
)
|
|
480
|
+
read_cache = {
|
|
481
|
+
"schema_version": _READ_CACHE_SCHEMA_VERSION,
|
|
482
|
+
"cache_hit": cache_hit,
|
|
483
|
+
"cache_path": str(cache_path),
|
|
484
|
+
"payload_fingerprint": payload_fingerprint,
|
|
485
|
+
"payload_bytes": original_bytes,
|
|
486
|
+
"source_path": str(resolved_source) if resolved_source is not None else None,
|
|
487
|
+
"source_mtime_ns": getattr(source_stat, "st_mtime_ns", None) if source_stat is not None else None,
|
|
488
|
+
"source_size": getattr(source_stat, "st_size", None) if source_stat is not None else None,
|
|
489
|
+
}
|
|
490
|
+
if cache_hit:
|
|
491
|
+
cached_evidence_packet = (
|
|
492
|
+
dict(cached.get("evidence_packet") or {})
|
|
493
|
+
if isinstance(cached.get("evidence_packet"), dict)
|
|
494
|
+
else None
|
|
495
|
+
)
|
|
496
|
+
if cached_evidence_packet is None:
|
|
497
|
+
sidecar_payload, _sidecar_meta = compact_evidence_payload(
|
|
498
|
+
payload,
|
|
499
|
+
quest_root=quest_root,
|
|
500
|
+
run_id=run_id,
|
|
501
|
+
tool_name=tool_name,
|
|
502
|
+
detail=normalized_detail,
|
|
503
|
+
force=True,
|
|
504
|
+
threshold_bytes=1,
|
|
505
|
+
reason="read_cache_sidecar_ref",
|
|
506
|
+
full_detail_requested=full_detail_requested,
|
|
507
|
+
)
|
|
508
|
+
if isinstance(sidecar_payload, dict) and isinstance(sidecar_payload.get("evidence_packet"), dict):
|
|
509
|
+
cached_evidence_packet = dict(sidecar_payload["evidence_packet"])
|
|
510
|
+
cached["evidence_packet"] = cached_evidence_packet
|
|
511
|
+
write_json(cache_path, cached)
|
|
512
|
+
read_cache["saved_bytes"] = max(0, original_bytes)
|
|
513
|
+
if cached_evidence_packet:
|
|
514
|
+
read_cache["sidecar_path"] = cached_evidence_packet.get("sidecar_path")
|
|
515
|
+
read_cache["payload_sha256"] = cached_evidence_packet.get("payload_sha256")
|
|
516
|
+
ok_value = _ok_from_payload_or_status(payload)
|
|
517
|
+
result = {
|
|
518
|
+
"ok": ok_value if ok_value is not None else True,
|
|
519
|
+
"compacted": True,
|
|
520
|
+
"delta_marker": True,
|
|
521
|
+
"delta_kind": "unchanged_read_cache",
|
|
522
|
+
"tool_name": tool_name,
|
|
523
|
+
"detail": normalized_detail,
|
|
524
|
+
"fingerprint": payload_fingerprint,
|
|
525
|
+
"summary": cached.get("summary") or summarize_payload(payload, tool_name=tool_name),
|
|
526
|
+
"read_cache": read_cache,
|
|
527
|
+
"command_fingerprint": payload.get("command_fingerprint"),
|
|
528
|
+
"cwd": payload.get("cwd"),
|
|
529
|
+
}
|
|
530
|
+
if cached_evidence_packet:
|
|
531
|
+
result["evidence_packet"] = cached_evidence_packet
|
|
532
|
+
return result
|
|
533
|
+
|
|
534
|
+
compacted = compact_mcp_tool_result(
|
|
535
|
+
payload,
|
|
536
|
+
quest_root=quest_root,
|
|
537
|
+
run_id=run_id,
|
|
538
|
+
tool_name=tool_name,
|
|
539
|
+
detail=normalized_detail,
|
|
540
|
+
force=force,
|
|
541
|
+
threshold_bytes=threshold_bytes,
|
|
542
|
+
reason=reason,
|
|
543
|
+
full_detail_requested=full_detail_requested,
|
|
544
|
+
)
|
|
545
|
+
evidence_packet = (
|
|
546
|
+
dict(compacted.get("evidence_packet") or {})
|
|
547
|
+
if isinstance(compacted, dict) and isinstance(compacted.get("evidence_packet"), dict)
|
|
548
|
+
else None
|
|
549
|
+
)
|
|
550
|
+
if evidence_packet is None:
|
|
551
|
+
sidecar_payload, _sidecar_meta = compact_evidence_payload(
|
|
552
|
+
payload,
|
|
553
|
+
quest_root=quest_root,
|
|
554
|
+
run_id=run_id,
|
|
555
|
+
tool_name=tool_name,
|
|
556
|
+
detail=normalized_detail,
|
|
557
|
+
force=True,
|
|
558
|
+
threshold_bytes=1,
|
|
559
|
+
reason="read_cache_sidecar_ref",
|
|
560
|
+
full_detail_requested=full_detail_requested,
|
|
561
|
+
)
|
|
562
|
+
if isinstance(sidecar_payload, dict) and isinstance(sidecar_payload.get("evidence_packet"), dict):
|
|
563
|
+
evidence_packet = dict(sidecar_payload["evidence_packet"])
|
|
564
|
+
read_cache["saved_bytes"] = 0
|
|
565
|
+
if evidence_packet:
|
|
566
|
+
read_cache["sidecar_path"] = evidence_packet.get("sidecar_path")
|
|
567
|
+
read_cache["payload_sha256"] = evidence_packet.get("payload_sha256")
|
|
568
|
+
compacted["read_cache"] = read_cache
|
|
569
|
+
if evidence_packet and compacted.get("compacted") is True and "evidence_packet" not in compacted:
|
|
570
|
+
compacted["evidence_packet"] = evidence_packet
|
|
571
|
+
ensure_dir(cache_path.parent)
|
|
572
|
+
write_json(
|
|
573
|
+
cache_path,
|
|
574
|
+
{
|
|
575
|
+
"schema_version": _READ_CACHE_SCHEMA_VERSION,
|
|
576
|
+
"created_at": utc_now(),
|
|
577
|
+
"updated_at": utc_now(),
|
|
578
|
+
"tool_name": tool_name,
|
|
579
|
+
"detail": normalized_detail,
|
|
580
|
+
"cache_key": resolved_cache_key,
|
|
581
|
+
"payload_fingerprint": payload_fingerprint,
|
|
582
|
+
"payload_bytes": original_bytes,
|
|
583
|
+
"summary": summarize_payload(payload, tool_name=tool_name),
|
|
584
|
+
"source_path": str(resolved_source) if resolved_source is not None else None,
|
|
585
|
+
"source_mtime_ns": getattr(source_stat, "st_mtime_ns", None) if source_stat is not None else None,
|
|
586
|
+
"source_size": getattr(source_stat, "st_size", None) if source_stat is not None else None,
|
|
587
|
+
"evidence_packet": evidence_packet,
|
|
588
|
+
},
|
|
589
|
+
)
|
|
590
|
+
return compacted
|
|
@@ -6,6 +6,17 @@ from pathlib import Path
|
|
|
6
6
|
from .shared import ensure_dir
|
|
7
7
|
|
|
8
8
|
|
|
9
|
+
def _candidate_repo_root_from_launcher() -> Path | None:
|
|
10
|
+
launcher_path = str(os.environ.get("DEEPSCIENTIST_LAUNCHER_PATH") or "").strip()
|
|
11
|
+
if not launcher_path:
|
|
12
|
+
return None
|
|
13
|
+
launcher = Path(launcher_path).expanduser().resolve()
|
|
14
|
+
for candidate in (launcher.parent.parent, *launcher.parents):
|
|
15
|
+
if _looks_like_repo_root(candidate):
|
|
16
|
+
return candidate
|
|
17
|
+
return None
|
|
18
|
+
|
|
19
|
+
|
|
9
20
|
def _looks_like_repo_root(path: Path) -> bool:
|
|
10
21
|
return (
|
|
11
22
|
(path / "pyproject.toml").exists()
|
|
@@ -21,14 +32,20 @@ def repo_root() -> Path:
|
|
|
21
32
|
if _looks_like_repo_root(candidate):
|
|
22
33
|
return candidate
|
|
23
34
|
|
|
35
|
+
launcher_candidate = _candidate_repo_root_from_launcher()
|
|
36
|
+
if launcher_candidate is not None:
|
|
37
|
+
return launcher_candidate
|
|
38
|
+
|
|
24
39
|
cwd = Path.cwd().resolve()
|
|
25
40
|
if _looks_like_repo_root(cwd):
|
|
26
41
|
return cwd
|
|
27
42
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
43
|
+
module_path = Path(__file__).resolve()
|
|
44
|
+
for candidate in module_path.parents:
|
|
45
|
+
if _looks_like_repo_root(candidate):
|
|
46
|
+
return candidate
|
|
47
|
+
|
|
48
|
+
return module_path.parents[2]
|
|
32
49
|
|
|
33
50
|
|
|
34
51
|
def default_home() -> Path:
|
|
@@ -50,6 +67,37 @@ def ensure_home_layout(home: Path) -> dict[str, Path]:
|
|
|
50
67
|
for kind in ("papers", "ideas", "decisions", "episodes", "knowledge", "templates"):
|
|
51
68
|
ensure_dir(memory / kind)
|
|
52
69
|
|
|
70
|
+
framework_quirks = home / "framework_quirks.md"
|
|
71
|
+
if not framework_quirks.exists():
|
|
72
|
+
framework_quirks.write_text(
|
|
73
|
+
"# Framework Quirks\n\n"
|
|
74
|
+
"Append-only durable file for framework-layer pitfalls (validator path quirks, "
|
|
75
|
+
"closure-protocol gotchas, anything that cannot or will not be fixed in code "
|
|
76
|
+
"and that future quests should know about before exercising the same surfaces).\n\n"
|
|
77
|
+
"Each entry should name the surface, the symptom, and the workaround in 2-5 lines. "
|
|
78
|
+
"Stage skills (idea, decision, finalize) instruct agents to read this file before "
|
|
79
|
+
"committing to a route that would touch the relevant surface.\n\n"
|
|
80
|
+
"If a quirk should instead be fixed at the framework level, file an issue and fix the code; "
|
|
81
|
+
"do not add it here as a permanent shim.\n",
|
|
82
|
+
encoding="utf-8",
|
|
83
|
+
)
|
|
84
|
+
|
|
85
|
+
system_quirks = home / "system_quirks.md"
|
|
86
|
+
if not system_quirks.exists():
|
|
87
|
+
system_quirks.write_text(
|
|
88
|
+
"# System Quirks\n\n"
|
|
89
|
+
"Append-only durable file for confirmed DeepScientist runtime or system bugs "
|
|
90
|
+
"that may help future admin/debug issue reports.\n\n"
|
|
91
|
+
"Each entry should include: expected behavior, actual behavior, reproduction, "
|
|
92
|
+
"impact, workaround, suggested fix, evidence paths, and status. Keep entries "
|
|
93
|
+
"redacted: do not store secrets, tokens, private hostnames, raw logs, or private "
|
|
94
|
+
"paths unless they are necessary and already safe to disclose.\n\n"
|
|
95
|
+
"Prefer fixing code over recording permanent quirks. Use this file for confirmed "
|
|
96
|
+
"system behavior that is not yet fixed or for a short-lived workaround while the "
|
|
97
|
+
"fix lands.\n",
|
|
98
|
+
encoding="utf-8",
|
|
99
|
+
)
|
|
100
|
+
|
|
53
101
|
quests = ensure_dir(home / "quests")
|
|
54
102
|
plugins = ensure_dir(home / "plugins")
|
|
55
103
|
logs = ensure_dir(home / "logs")
|