@researai/deepscientist 1.5.17 → 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 +132 -11
- package/bin/ds.js +376 -49
- package/docs/en/00_QUICK_START.md +135 -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 +64 -4
- 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 +622 -187
- 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 +105 -2
- 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 +29 -0
- package/docs/en/99_ACKNOWLEDGEMENTS.md +24 -19
- package/docs/en/README.md +44 -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 +92 -17
- 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 +39 -4
- 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 +550 -188
- package/docs/zh/21_LOCAL_MODEL_BACKENDS_GUIDE.md +105 -2
- 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 +29 -7
- package/install.sh +122 -16
- package/package.json +4 -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/channels/weixin_ilink.py +8 -1
- package/src/deepscientist/cli.py +92 -17
- package/src/deepscientist/codex_cli_compat.py +2 -2
- package/src/deepscientist/config/models.py +82 -11
- package/src/deepscientist/config/service.py +927 -91
- package/src/deepscientist/connector/weixin_support.py +48 -17
- package/src/deepscientist/daemon/api/handlers.py +697 -210
- package/src/deepscientist/daemon/api/router.py +76 -1
- package/src/deepscientist/daemon/app.py +1054 -51
- package/src/deepscientist/diagnostics/runner_failures.py +147 -0
- package/src/deepscientist/doctor.py +212 -65
- 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 +836 -92
- 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 +1430 -139
- 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 +421 -21
- 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 +61 -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 -11
- package/src/prompts/start_setup/system.md +422 -0
- package/src/prompts/system.md +409 -315
- package/src/prompts/system_copilot.md +88 -12
- 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-BCKAfjba.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-CbaFRrUU.js → CodeViewerPlugin-CqDpgjik.js} +4 -4
- package/src/ui/dist/assets/{DocViewerPlugin-DAjLVeQD.js → DocViewerPlugin-UDBgt8-4.js} +3 -3
- package/src/ui/dist/assets/GitCommitViewerPlugin-BmHtZ0bZ.js +6 -0
- package/src/ui/dist/assets/{GitDiffViewerPlugin-CQACjoAA.js → GitDiffViewerPlugin-CAxjNorQ.js} +2 -2
- package/src/ui/dist/assets/{GitSnapshotViewer-0r4nLPke.js → GitSnapshotViewer-CweA6VON.js} +2 -2
- package/src/ui/dist/assets/{ImageViewerPlugin-nBOmI2v_.js → ImageViewerPlugin-C8wHGvGN.js} +5 -5
- package/src/ui/dist/assets/LabPlugin-COyyLUol.js +32 -0
- package/src/ui/dist/assets/{LatexPlugin-ZwtV8pIp.js → LatexPlugin-BQjAaA5J.js} +4 -4
- package/src/ui/dist/assets/{MarkdownViewerPlugin-DKqVfKyW.js → MarkdownViewerPlugin-Dy1NE2dI.js} +3 -3
- package/src/ui/dist/assets/{MarketplacePlugin-BwxStZ9D.js → MarketplacePlugin-DMIZtEJ2.js} +2 -2
- package/src/ui/dist/assets/NotebookEditor-CFHMq_Qt.js +91 -0
- package/src/ui/dist/assets/{NotebookEditor-DB9N_T9q.js → NotebookEditor-WFyd8Ybt.js} +3 -3
- package/src/ui/dist/assets/{PdfLoader-eWBONbQP.js → PdfLoader-CLE5u5TS.js} +3 -3
- package/src/ui/dist/assets/{PdfMarkdownPlugin-D22YOZL3.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-C5xqeeUH.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-WlFHE7z_.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-BC-Hltpd.js → file-jump-queue-DeQBikaw.js} +3 -3
- package/src/ui/dist/assets/{file-socket-CfQPKQKj.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-CwNu1aH4.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-C9IdzdZW.js → project-sync-DPmWKmKD.js} +1 -1
- package/src/ui/dist/assets/{zoom-out-E_gaeAxL.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-Bv-Z8YpU.js +0 -204
- package/src/ui/dist/assets/CliPlugin-BCKcpc35.js +0 -109
- package/src/ui/dist/assets/CodeEditorPlugin-DbOfSJ8K.js +0 -2
- package/src/ui/dist/assets/GitCommitViewerPlugin-CIUqbUDO.js +0 -1
- package/src/ui/dist/assets/LabCopilotPanel-BHxOxF4z.js +0 -14
- package/src/ui/dist/assets/LabPlugin-BKoZGs95.js +0 -22
- package/src/ui/dist/assets/NotebookEditor-BEQhaQbt.js +0 -81
- package/src/ui/dist/assets/PdfViewerPlugin-c-RK9DLM.js +0 -17
- package/src/ui/dist/assets/SearchPlugin-CxF9ytAx.js +0 -16
- package/src/ui/dist/assets/VNCViewer-BoLGLnHz.js +0 -11
- package/src/ui/dist/assets/bot-DREQOxzP.js +0 -6
- package/src/ui/dist/assets/chevron-up-C9Qpx4DE.js +0 -6
- package/src/ui/dist/assets/file-content-BZMz3RYp.js +0 -1
- package/src/ui/dist/assets/file-diff-panel-CQhw0jS2.js +0 -1
- package/src/ui/dist/assets/file-jump-queue-DA-SdG__.js +0 -1
- package/src/ui/dist/assets/git-commit-horizontal-DxZ8DCZh.js +0 -6
- package/src/ui/dist/assets/image-Bgl4VIyx.js +0 -6
- package/src/ui/dist/assets/index-BpV6lusQ.css +0 -33
- package/src/ui/dist/assets/index-CBNVuWcP.js +0 -2496
- package/src/ui/dist/assets/index-DrUnlf6K.js +0 -1
- package/src/ui/dist/assets/index-NW-h8VzN.js +0 -1
- package/src/ui/dist/assets/pdf-effect-queue-J8OnM0jE.js +0 -6
- package/src/ui/dist/assets/popover-CLc0pPP8.js +0 -1
- package/src/ui/dist/assets/select-Cs2PmzwL.js +0 -11
- package/src/ui/dist/assets/sigma-ClKcHAXm.js +0 -6
- package/src/ui/dist/assets/trash-DwpbFr3w.js +0 -11
- package/src/ui/dist/assets/useCliAccess-NQ8m0Let.js +0 -1
- package/src/ui/dist/assets/useFileDiffOverlay-FuhcnKiw.js +0 -1
|
@@ -17,13 +17,29 @@ from ..codex_cli_compat import (
|
|
|
17
17
|
provider_profile_metadata_from_home,
|
|
18
18
|
)
|
|
19
19
|
from ..config import ConfigManager
|
|
20
|
+
from ..evidence_packets import compact_runner_tool_event
|
|
20
21
|
from ..gitops import export_git_graph
|
|
21
22
|
from ..process_control import process_session_popen_kwargs
|
|
22
23
|
from ..prompts import PromptBuilder
|
|
23
24
|
from ..runtime_logs import JsonlLogger
|
|
24
|
-
from ..shared import append_jsonl, ensure_dir, generate_id, read_yaml, resolve_runner_binary, utc_now, write_json, write_text
|
|
25
|
+
from ..shared import append_jsonl, ensure_dir, ensure_utf8_subprocess_env, generate_id, read_yaml, resolve_runner_binary, utc_now, write_json, write_text
|
|
25
26
|
from ..web_search import extract_web_search_payload
|
|
26
|
-
from .base import
|
|
27
|
+
from .base import (
|
|
28
|
+
SETTINGS_ISSUE_CUSTOM_PROFILE,
|
|
29
|
+
START_SETUP_PREPARE_PROFILE,
|
|
30
|
+
RunRequest,
|
|
31
|
+
RunResult,
|
|
32
|
+
builtin_mcp_server_names_for_custom_profile,
|
|
33
|
+
extract_start_setup_patch_from_text,
|
|
34
|
+
extract_start_setup_session_patch_from_text,
|
|
35
|
+
resolve_mcp_tool_profile_for_quest,
|
|
36
|
+
)
|
|
37
|
+
from .codex_telemetry import (
|
|
38
|
+
DEFAULT_TURN_TOOL_CALL_BUDGET,
|
|
39
|
+
_finalize_tool_budget_telemetry,
|
|
40
|
+
_new_tool_budget_telemetry,
|
|
41
|
+
_record_tool_budget_event,
|
|
42
|
+
)
|
|
27
43
|
|
|
28
44
|
_TOOL_EVENT_ARGS_TEXT_LIMIT = 8_000
|
|
29
45
|
_TOOL_EVENT_OUTPUT_TEXT_LIMIT = 16_000
|
|
@@ -39,6 +55,7 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
|
|
|
39
55
|
),
|
|
40
56
|
"artifact": (
|
|
41
57
|
"record",
|
|
58
|
+
"science",
|
|
42
59
|
"checkpoint",
|
|
43
60
|
"prepare_branch",
|
|
44
61
|
"activate_branch",
|
|
@@ -46,6 +63,10 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
|
|
|
46
63
|
"list_research_branches",
|
|
47
64
|
"resolve_runtime_refs",
|
|
48
65
|
"get_paper_contract_health",
|
|
66
|
+
"validate_manuscript_coverage",
|
|
67
|
+
"validate_academic_outline",
|
|
68
|
+
"validate_manuscript_language",
|
|
69
|
+
"compile_outline_to_writing_plan",
|
|
49
70
|
"get_quest_state",
|
|
50
71
|
"get_global_status",
|
|
51
72
|
"get_method_scoreboard",
|
|
@@ -62,6 +83,7 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
|
|
|
62
83
|
"publish_baseline",
|
|
63
84
|
"attach_baseline",
|
|
64
85
|
"confirm_baseline",
|
|
86
|
+
"overwrite_baseline",
|
|
65
87
|
"waive_baseline",
|
|
66
88
|
"arxiv",
|
|
67
89
|
"refresh_summary",
|
|
@@ -74,11 +96,82 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
|
|
|
74
96
|
),
|
|
75
97
|
}
|
|
76
98
|
|
|
99
|
+
|
|
100
|
+
def _builtin_mcp_tool_approvals_for_profile(custom_profile: str | None) -> dict[str, tuple[str, ...]]:
|
|
101
|
+
normalized = str(custom_profile or "").strip().lower()
|
|
102
|
+
if normalized == SETTINGS_ISSUE_CUSTOM_PROFILE:
|
|
103
|
+
return {
|
|
104
|
+
"artifact": ("prepare_github_issue",),
|
|
105
|
+
"bash_exec": _BUILTIN_MCP_TOOL_APPROVALS.get("bash_exec", ()),
|
|
106
|
+
}
|
|
107
|
+
if normalized == START_SETUP_PREPARE_PROFILE:
|
|
108
|
+
return {
|
|
109
|
+
"artifact": ("prepare_start_setup_form",),
|
|
110
|
+
"bash_exec": _BUILTIN_MCP_TOOL_APPROVALS.get("bash_exec", ()),
|
|
111
|
+
}
|
|
112
|
+
return _BUILTIN_MCP_TOOL_APPROVALS
|
|
113
|
+
|
|
77
114
|
_PROVIDER_ENV_CONFLICT_KEYS = (
|
|
78
115
|
"OPENAI_API_KEY",
|
|
79
116
|
"OPENAI_BASE_URL",
|
|
80
117
|
)
|
|
81
118
|
_CHAT_WIRE_TOOL_CALL_GUARD_MARKER = "## Codex Chat-Wire Tool Call Compatibility"
|
|
119
|
+
_WINDOWS_GBK_SAFE_REPLACEMENTS: dict[str, str] = {
|
|
120
|
+
"•": "-",
|
|
121
|
+
"…": "...",
|
|
122
|
+
"→": "->",
|
|
123
|
+
"←": "<-",
|
|
124
|
+
"↔": "<->",
|
|
125
|
+
"≤": "<=",
|
|
126
|
+
"≥": ">=",
|
|
127
|
+
"—": "-",
|
|
128
|
+
"–": "-",
|
|
129
|
+
"✓": "[ok]",
|
|
130
|
+
"✗": "[x]",
|
|
131
|
+
"✨": "*",
|
|
132
|
+
"🚀": "[launch]",
|
|
133
|
+
"📄": "[file]",
|
|
134
|
+
"📊": "[chart]",
|
|
135
|
+
"📌": "[pin]",
|
|
136
|
+
"💡": "[idea]",
|
|
137
|
+
"📎": "[attachment]",
|
|
138
|
+
"̀": "",
|
|
139
|
+
"́": "",
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
|
|
143
|
+
def _usage_metrics_from_event(event: dict[str, Any]) -> dict[str, int]:
|
|
144
|
+
candidates: list[dict[str, Any]] = []
|
|
145
|
+
for key in ("usage", "token_usage", "turn_usage"):
|
|
146
|
+
value = event.get(key)
|
|
147
|
+
if isinstance(value, dict):
|
|
148
|
+
candidates.append(value)
|
|
149
|
+
item = event.get("item")
|
|
150
|
+
if isinstance(item, dict):
|
|
151
|
+
for key in ("usage", "token_usage", "turn_usage"):
|
|
152
|
+
value = item.get(key)
|
|
153
|
+
if isinstance(value, dict):
|
|
154
|
+
candidates.append(value)
|
|
155
|
+
aliases = {
|
|
156
|
+
"input_tokens": ("input_tokens", "prompt_tokens"),
|
|
157
|
+
"cached_input_tokens": ("cached_input_tokens", "cached_tokens", "cached_prompt_tokens"),
|
|
158
|
+
"output_tokens": ("output_tokens", "completion_tokens"),
|
|
159
|
+
"total_tokens": ("total_tokens",),
|
|
160
|
+
}
|
|
161
|
+
merged: dict[str, int] = {}
|
|
162
|
+
for candidate in candidates:
|
|
163
|
+
for target, source_keys in aliases.items():
|
|
164
|
+
if target in merged:
|
|
165
|
+
continue
|
|
166
|
+
for key in source_keys:
|
|
167
|
+
value = candidate.get(key)
|
|
168
|
+
if isinstance(value, int):
|
|
169
|
+
merged[target] = value
|
|
170
|
+
break
|
|
171
|
+
if isinstance(value, float):
|
|
172
|
+
merged[target] = int(value)
|
|
173
|
+
break
|
|
174
|
+
return merged
|
|
82
175
|
|
|
83
176
|
|
|
84
177
|
def _compact_text(value: object, *, limit: int = 1200) -> str:
|
|
@@ -96,6 +189,29 @@ def _compact_text(value: object, *, limit: int = 1200) -> str:
|
|
|
96
189
|
return text[: limit - 1].rstrip() + "…"
|
|
97
190
|
|
|
98
191
|
|
|
192
|
+
def _sanitize_text_for_windows_gbk(text: str) -> tuple[str, dict[str, str]]:
|
|
193
|
+
source = str(text or "")
|
|
194
|
+
if not source:
|
|
195
|
+
return source, {}
|
|
196
|
+
try:
|
|
197
|
+
source.encode("gbk")
|
|
198
|
+
return source, {}
|
|
199
|
+
except UnicodeEncodeError:
|
|
200
|
+
pass
|
|
201
|
+
|
|
202
|
+
replacements: dict[str, str] = {}
|
|
203
|
+
rendered: list[str] = []
|
|
204
|
+
for char in source:
|
|
205
|
+
try:
|
|
206
|
+
char.encode("gbk")
|
|
207
|
+
rendered.append(char)
|
|
208
|
+
except UnicodeEncodeError:
|
|
209
|
+
replacement = _WINDOWS_GBK_SAFE_REPLACEMENTS.get(char, "?")
|
|
210
|
+
replacements.setdefault(char, replacement)
|
|
211
|
+
rendered.append(replacement)
|
|
212
|
+
return "".join(rendered), replacements
|
|
213
|
+
|
|
214
|
+
|
|
99
215
|
def _truncate_leaf_text(text: str, *, limit: int) -> str:
|
|
100
216
|
if limit <= 0 or len(text) <= limit:
|
|
101
217
|
return text
|
|
@@ -464,6 +580,56 @@ def _mcp_result_payload(item: dict[str, Any]) -> dict[str, Any]:
|
|
|
464
580
|
return {}
|
|
465
581
|
|
|
466
582
|
|
|
583
|
+
def _parse_single_text_content(value: Any) -> Any | None:
|
|
584
|
+
if not isinstance(value, list) or len(value) != 1:
|
|
585
|
+
return None
|
|
586
|
+
item = value[0]
|
|
587
|
+
if not isinstance(item, dict):
|
|
588
|
+
return None
|
|
589
|
+
text = item.get("text")
|
|
590
|
+
if not isinstance(text, str) or not text.strip():
|
|
591
|
+
return None
|
|
592
|
+
try:
|
|
593
|
+
return json.loads(text)
|
|
594
|
+
except json.JSONDecodeError:
|
|
595
|
+
return text
|
|
596
|
+
|
|
597
|
+
|
|
598
|
+
def _raw_tool_result_payload(event: dict[str, Any]) -> Any | None:
|
|
599
|
+
item = event.get("item") if isinstance(event.get("item"), dict) else {}
|
|
600
|
+
item_type = str(item.get("type") or event.get("item_type") or "")
|
|
601
|
+
if item_type == "mcp_tool_call":
|
|
602
|
+
result = item.get("result")
|
|
603
|
+
if isinstance(result, dict):
|
|
604
|
+
structured = result.get("structured_content") or result.get("structuredContent")
|
|
605
|
+
if structured is not None:
|
|
606
|
+
return structured
|
|
607
|
+
parsed_content = _parse_single_text_content(result.get("content"))
|
|
608
|
+
if parsed_content is not None:
|
|
609
|
+
return parsed_content
|
|
610
|
+
return result
|
|
611
|
+
if result is not None:
|
|
612
|
+
return result
|
|
613
|
+
|
|
614
|
+
for value in (
|
|
615
|
+
item.get("result"),
|
|
616
|
+
item.get("aggregated_output"),
|
|
617
|
+
item.get("changes"),
|
|
618
|
+
item.get("output"),
|
|
619
|
+
item.get("content"),
|
|
620
|
+
item.get("error"),
|
|
621
|
+
event.get("result"),
|
|
622
|
+
event.get("aggregated_output"),
|
|
623
|
+
event.get("changes"),
|
|
624
|
+
event.get("output"),
|
|
625
|
+
event.get("content"),
|
|
626
|
+
event.get("error"),
|
|
627
|
+
):
|
|
628
|
+
if value is not None:
|
|
629
|
+
return value
|
|
630
|
+
return None
|
|
631
|
+
|
|
632
|
+
|
|
467
633
|
def _mcp_tool_metadata(
|
|
468
634
|
*,
|
|
469
635
|
quest_id: str,
|
|
@@ -743,6 +909,8 @@ class CodexRunner:
|
|
|
743
909
|
"stdout": subprocess.PIPE,
|
|
744
910
|
"stderr": subprocess.PIPE,
|
|
745
911
|
"text": True,
|
|
912
|
+
"encoding": "utf-8",
|
|
913
|
+
"errors": "replace",
|
|
746
914
|
**process_session_popen_kwargs(hide_window=True),
|
|
747
915
|
}
|
|
748
916
|
|
|
@@ -762,7 +930,16 @@ class CodexRunner:
|
|
|
762
930
|
retry_context=request.retry_context,
|
|
763
931
|
)
|
|
764
932
|
prompt = self._apply_chat_wire_tool_call_guard(prompt, runner_config=runner_config)
|
|
933
|
+
prompt_to_send = prompt
|
|
934
|
+
prompt_sanitization: dict[str, str] = {}
|
|
935
|
+
sanitized_prompt_path: str | None = None
|
|
936
|
+
if os.name == "nt":
|
|
937
|
+
prompt_to_send, prompt_sanitization = _sanitize_text_for_windows_gbk(prompt)
|
|
765
938
|
write_text(run_root / "prompt.md", prompt)
|
|
939
|
+
if prompt_sanitization:
|
|
940
|
+
sanitized_path = run_root / "prompt.windows-gbk-sanitized.md"
|
|
941
|
+
write_text(sanitized_path, prompt_to_send)
|
|
942
|
+
sanitized_prompt_path = str(sanitized_path)
|
|
766
943
|
|
|
767
944
|
codex_home = self._prepare_project_codex_home(
|
|
768
945
|
workspace_root,
|
|
@@ -771,7 +948,7 @@ class CodexRunner:
|
|
|
771
948
|
run_id=request.run_id,
|
|
772
949
|
runner_config=runner_config,
|
|
773
950
|
)
|
|
774
|
-
command = self._build_command(request,
|
|
951
|
+
command = self._build_command(request, prompt_to_send, runner_config=runner_config)
|
|
775
952
|
write_json(
|
|
776
953
|
run_root / "command.json",
|
|
777
954
|
{
|
|
@@ -783,8 +960,39 @@ class CodexRunner:
|
|
|
783
960
|
"turn_reason": request.turn_reason,
|
|
784
961
|
"turn_intent": request.turn_intent,
|
|
785
962
|
"turn_mode": request.turn_mode,
|
|
963
|
+
"windows_gbk_prompt_sanitized": bool(prompt_sanitization),
|
|
964
|
+
"windows_gbk_sanitized_prompt_path": sanitized_prompt_path,
|
|
965
|
+
"windows_gbk_replacements": prompt_sanitization,
|
|
786
966
|
},
|
|
787
967
|
)
|
|
968
|
+
configured_tool_budget = runner_config.get("tool_call_budget")
|
|
969
|
+
if not isinstance(configured_tool_budget, int):
|
|
970
|
+
configured_tool_budget = DEFAULT_TURN_TOOL_CALL_BUDGET
|
|
971
|
+
tool_budget_telemetry = _new_tool_budget_telemetry(tool_call_budget=configured_tool_budget)
|
|
972
|
+
telemetry: dict[str, Any] = {
|
|
973
|
+
"version": 1,
|
|
974
|
+
"quest_id": request.quest_id,
|
|
975
|
+
"run_id": request.run_id,
|
|
976
|
+
"skill_id": request.skill_id,
|
|
977
|
+
"turn_reason": request.turn_reason,
|
|
978
|
+
"turn_intent": request.turn_intent,
|
|
979
|
+
"turn_mode": request.turn_mode,
|
|
980
|
+
"model": request.model,
|
|
981
|
+
"model_inherited": str(request.model or "").strip().lower()
|
|
982
|
+
in {"", "inherit", "default", "codex-default", "inherit_local_codex_default"},
|
|
983
|
+
"reasoning_effort": request.reasoning_effort,
|
|
984
|
+
"runner_profile": str(runner_config.get("profile") or "").strip() or None,
|
|
985
|
+
"prompt_bytes": len(prompt.encode("utf-8", errors="replace")),
|
|
986
|
+
"stdout_event_count": 0,
|
|
987
|
+
"stdout_bytes": 0,
|
|
988
|
+
"tool_result_count": 0,
|
|
989
|
+
"tool_result_bytes_total": 0,
|
|
990
|
+
"compacted_tool_result_count": 0,
|
|
991
|
+
"full_detail_tool_call_count": 0,
|
|
992
|
+
**tool_budget_telemetry,
|
|
993
|
+
"token_usage": {},
|
|
994
|
+
"created_at": utc_now(),
|
|
995
|
+
}
|
|
788
996
|
|
|
789
997
|
env = dict(**os.environ)
|
|
790
998
|
runner_env = runner_config.get("env") if isinstance(runner_config.get("env"), dict) else {}
|
|
@@ -799,6 +1007,7 @@ class CodexRunner:
|
|
|
799
1007
|
env["CODEX_HOME"] = str(codex_home)
|
|
800
1008
|
env = self._sanitize_provider_env(env, runner_config=runner_config)
|
|
801
1009
|
env["DEEPSCIENTIST_HOME"] = str(self.home)
|
|
1010
|
+
env["DEEPSCIENTIST_REPO_ROOT"] = str(self.repo_root)
|
|
802
1011
|
env["DS_HOME"] = str(self.home)
|
|
803
1012
|
env["DS_QUEST_ID"] = request.quest_id
|
|
804
1013
|
env["DS_QUEST_ROOT"] = str(request.quest_root)
|
|
@@ -812,6 +1021,7 @@ class CodexRunner:
|
|
|
812
1021
|
env["DS_CONVERSATION_ID"] = f"quest:{request.quest_id}"
|
|
813
1022
|
env["DS_AGENT_ROLE"] = request.skill_id
|
|
814
1023
|
env["DS_TEAM_MODE"] = "single"
|
|
1024
|
+
env = ensure_utf8_subprocess_env(env)
|
|
815
1025
|
popen_kwargs = self._subprocess_popen_kwargs(workspace_root=workspace_root, env=env)
|
|
816
1026
|
process = subprocess.Popen(command, **popen_kwargs)
|
|
817
1027
|
with self._process_lock:
|
|
@@ -820,11 +1030,6 @@ class CodexRunner:
|
|
|
820
1030
|
assert process.stdout is not None
|
|
821
1031
|
assert process.stderr is not None
|
|
822
1032
|
try:
|
|
823
|
-
process.stdin.write(prompt)
|
|
824
|
-
process.stdin.close()
|
|
825
|
-
|
|
826
|
-
output_parts: list[str] = []
|
|
827
|
-
final_output_parts: list[str] = []
|
|
828
1033
|
history_events = history_root / "events.jsonl"
|
|
829
1034
|
stdout_events = run_root / "stdout.jsonl"
|
|
830
1035
|
quest_events = request.quest_root / ".ds" / "events.jsonl"
|
|
@@ -843,15 +1048,74 @@ class CodexRunner:
|
|
|
843
1048
|
"created_at": utc_now(),
|
|
844
1049
|
},
|
|
845
1050
|
)
|
|
1051
|
+
if prompt_sanitization:
|
|
1052
|
+
append_jsonl(
|
|
1053
|
+
quest_events,
|
|
1054
|
+
{
|
|
1055
|
+
"event_id": generate_id("evt"),
|
|
1056
|
+
"type": "runner.prompt_sanitized",
|
|
1057
|
+
"quest_id": request.quest_id,
|
|
1058
|
+
"run_id": request.run_id,
|
|
1059
|
+
"source": "codex",
|
|
1060
|
+
"skill_id": request.skill_id,
|
|
1061
|
+
"summary": (
|
|
1062
|
+
"Windows GBK-compatible prompt sanitization replaced non-encodable characters "
|
|
1063
|
+
"before sending the prompt to Codex."
|
|
1064
|
+
),
|
|
1065
|
+
"replacements": prompt_sanitization,
|
|
1066
|
+
"created_at": utc_now(),
|
|
1067
|
+
},
|
|
1068
|
+
)
|
|
1069
|
+
|
|
1070
|
+
try:
|
|
1071
|
+
process.stdin.write(prompt_to_send)
|
|
1072
|
+
except UnicodeEncodeError as exc:
|
|
1073
|
+
if os.name == "nt" and not prompt_sanitization:
|
|
1074
|
+
prompt_to_send, prompt_sanitization = _sanitize_text_for_windows_gbk(prompt)
|
|
1075
|
+
if not prompt_sanitization:
|
|
1076
|
+
raise exc
|
|
1077
|
+
sanitized_path = run_root / "prompt.windows-gbk-sanitized.md"
|
|
1078
|
+
write_text(sanitized_path, prompt_to_send)
|
|
1079
|
+
append_jsonl(
|
|
1080
|
+
quest_events,
|
|
1081
|
+
{
|
|
1082
|
+
"event_id": generate_id("evt"),
|
|
1083
|
+
"type": "runner.prompt_sanitized",
|
|
1084
|
+
"quest_id": request.quest_id,
|
|
1085
|
+
"run_id": request.run_id,
|
|
1086
|
+
"source": "codex",
|
|
1087
|
+
"skill_id": request.skill_id,
|
|
1088
|
+
"summary": (
|
|
1089
|
+
"Windows GBK-compatible prompt sanitization retried after a UnicodeEncodeError "
|
|
1090
|
+
"while writing the prompt to Codex."
|
|
1091
|
+
),
|
|
1092
|
+
"replacements": prompt_sanitization,
|
|
1093
|
+
"created_at": utc_now(),
|
|
1094
|
+
},
|
|
1095
|
+
)
|
|
1096
|
+
process.stdin.write(prompt_to_send)
|
|
1097
|
+
else:
|
|
1098
|
+
raise exc
|
|
1099
|
+
process.stdin.close()
|
|
1100
|
+
|
|
1101
|
+
output_parts: list[str] = []
|
|
1102
|
+
final_output_parts: list[str] = []
|
|
846
1103
|
|
|
847
1104
|
for raw_line in process.stdout:
|
|
848
1105
|
line = raw_line.rstrip("\n")
|
|
849
1106
|
if not line:
|
|
850
1107
|
continue
|
|
1108
|
+
telemetry["stdout_event_count"] = int(telemetry.get("stdout_event_count") or 0) + 1
|
|
1109
|
+
telemetry["stdout_bytes"] = int(telemetry.get("stdout_bytes") or 0) + len(
|
|
1110
|
+
line.encode("utf-8", errors="replace")
|
|
1111
|
+
)
|
|
851
1112
|
try:
|
|
852
1113
|
payload = json.loads(line)
|
|
853
1114
|
except json.JSONDecodeError:
|
|
854
1115
|
payload = {"raw": line}
|
|
1116
|
+
usage_metrics = _usage_metrics_from_event(payload)
|
|
1117
|
+
if usage_metrics:
|
|
1118
|
+
telemetry["token_usage"] = usage_metrics
|
|
855
1119
|
timestamp = utc_now()
|
|
856
1120
|
append_jsonl(history_events, {"timestamp": timestamp, "event": payload})
|
|
857
1121
|
append_jsonl(stdout_events, {"timestamp": timestamp, "line": line})
|
|
@@ -871,6 +1135,39 @@ class CodexRunner:
|
|
|
871
1135
|
created_at=timestamp,
|
|
872
1136
|
)
|
|
873
1137
|
if tool_event is not None:
|
|
1138
|
+
if str(tool_event.get("type") or "") == "runner.tool_call":
|
|
1139
|
+
_record_tool_budget_event(telemetry, tool_event)
|
|
1140
|
+
args_text = str(tool_event.get("args") or "")
|
|
1141
|
+
if "detail" in args_text and "full" in args_text.lower():
|
|
1142
|
+
telemetry["full_detail_tool_call_count"] = int(
|
|
1143
|
+
telemetry.get("full_detail_tool_call_count") or 0
|
|
1144
|
+
) + 1
|
|
1145
|
+
if str(tool_event.get("type") or "") == "runner.tool_result":
|
|
1146
|
+
raw_tool_payload = _raw_tool_result_payload(payload)
|
|
1147
|
+
compaction_kwargs: dict[str, Any] = {}
|
|
1148
|
+
if raw_tool_payload is not None:
|
|
1149
|
+
compaction_kwargs["raw_payload"] = raw_tool_payload
|
|
1150
|
+
compacted_tool_event, compaction_meta = compact_runner_tool_event(
|
|
1151
|
+
tool_event,
|
|
1152
|
+
quest_root=request.quest_root,
|
|
1153
|
+
run_id=request.run_id,
|
|
1154
|
+
**compaction_kwargs,
|
|
1155
|
+
)
|
|
1156
|
+
tool_event = compacted_tool_event
|
|
1157
|
+
telemetry["tool_result_count"] = int(telemetry.get("tool_result_count") or 0) + 1
|
|
1158
|
+
telemetry["tool_result_bytes_total"] = int(
|
|
1159
|
+
telemetry.get("tool_result_bytes_total") or 0
|
|
1160
|
+
) + int(
|
|
1161
|
+
compaction_meta.get("source_payload_bytes")
|
|
1162
|
+
or compaction_meta.get("output_bytes")
|
|
1163
|
+
or compaction_meta.get("payload_bytes")
|
|
1164
|
+
or 0
|
|
1165
|
+
)
|
|
1166
|
+
if bool(compaction_meta.get("compacted")):
|
|
1167
|
+
telemetry["compacted_tool_result_count"] = int(
|
|
1168
|
+
telemetry.get("compacted_tool_result_count") or 0
|
|
1169
|
+
) + 1
|
|
1170
|
+
_record_tool_budget_event(telemetry, tool_event)
|
|
874
1171
|
append_jsonl(quest_events, tool_event)
|
|
875
1172
|
message_events, message_output_parts = _message_events(
|
|
876
1173
|
payload,
|
|
@@ -901,6 +1198,18 @@ class CodexRunner:
|
|
|
901
1198
|
)
|
|
902
1199
|
or summary_text
|
|
903
1200
|
)
|
|
1201
|
+
self._apply_start_setup_patch_fallback_if_present(
|
|
1202
|
+
request=request,
|
|
1203
|
+
output_text=output_text,
|
|
1204
|
+
quest_events=quest_events,
|
|
1205
|
+
)
|
|
1206
|
+
telemetry["exit_code"] = exit_code
|
|
1207
|
+
telemetry["stderr_bytes"] = len(stderr_text.encode("utf-8", errors="replace"))
|
|
1208
|
+
telemetry["output_text_bytes"] = len(output_text.encode("utf-8", errors="replace"))
|
|
1209
|
+
telemetry["completed_at"] = utc_now()
|
|
1210
|
+
_finalize_tool_budget_telemetry(telemetry)
|
|
1211
|
+
telemetry_path = run_root / "telemetry.json"
|
|
1212
|
+
write_json(telemetry_path, telemetry)
|
|
904
1213
|
append_jsonl(
|
|
905
1214
|
quest_events,
|
|
906
1215
|
{
|
|
@@ -917,6 +1226,37 @@ class CodexRunner:
|
|
|
917
1226
|
"created_at": utc_now(),
|
|
918
1227
|
},
|
|
919
1228
|
)
|
|
1229
|
+
append_jsonl(
|
|
1230
|
+
quest_events,
|
|
1231
|
+
{
|
|
1232
|
+
"event_id": generate_id("evt"),
|
|
1233
|
+
"type": "runner.turn_telemetry",
|
|
1234
|
+
"quest_id": request.quest_id,
|
|
1235
|
+
"run_id": request.run_id,
|
|
1236
|
+
"source": "codex",
|
|
1237
|
+
"skill_id": request.skill_id,
|
|
1238
|
+
"model": request.model,
|
|
1239
|
+
"prompt_bytes": telemetry.get("prompt_bytes"),
|
|
1240
|
+
"stdout_bytes": telemetry.get("stdout_bytes"),
|
|
1241
|
+
"tool_call_budget": telemetry.get("tool_call_budget"),
|
|
1242
|
+
"tool_call_count": telemetry.get("tool_call_count"),
|
|
1243
|
+
"tool_count": telemetry.get("tool_count"),
|
|
1244
|
+
"tool_call_budget_remaining": telemetry.get("tool_call_budget_remaining"),
|
|
1245
|
+
"tool_call_budget_exceeded": telemetry.get("tool_call_budget_exceeded"),
|
|
1246
|
+
"unique_command_count": telemetry.get("unique_command_count"),
|
|
1247
|
+
"read_tool_call_count": telemetry.get("read_tool_call_count"),
|
|
1248
|
+
"repeated_read_result_count": telemetry.get("repeated_read_result_count"),
|
|
1249
|
+
"repeated_read_ratio": telemetry.get("repeated_read_ratio"),
|
|
1250
|
+
"tool_result_bytes_total": telemetry.get("tool_result_bytes_total"),
|
|
1251
|
+
"compacted_tool_result_count": telemetry.get("compacted_tool_result_count"),
|
|
1252
|
+
"saved_bytes": telemetry.get("saved_bytes"),
|
|
1253
|
+
"full_detail_tool_call_count": telemetry.get("full_detail_tool_call_count"),
|
|
1254
|
+
"full_detail_count": telemetry.get("full_detail_count"),
|
|
1255
|
+
"token_usage": telemetry.get("token_usage"),
|
|
1256
|
+
"telemetry_path": str(telemetry_path),
|
|
1257
|
+
"created_at": utc_now(),
|
|
1258
|
+
},
|
|
1259
|
+
)
|
|
920
1260
|
write_text(history_root / "assistant.md", (output_text or "") + ("\n" if output_text else ""))
|
|
921
1261
|
write_text(run_root / "stderr.txt", stderr_text)
|
|
922
1262
|
result_payload = {
|
|
@@ -926,6 +1266,7 @@ class CodexRunner:
|
|
|
926
1266
|
"exit_code": exit_code,
|
|
927
1267
|
"history_root": str(history_root),
|
|
928
1268
|
"run_root": str(run_root),
|
|
1269
|
+
"telemetry_path": str(telemetry_path),
|
|
929
1270
|
"output_text": output_text,
|
|
930
1271
|
"stderr_text": stderr_text,
|
|
931
1272
|
"completed_at": utc_now(),
|
|
@@ -1027,6 +1368,50 @@ class CodexRunner:
|
|
|
1027
1368
|
process.wait(timeout=3)
|
|
1028
1369
|
return interrupted
|
|
1029
1370
|
|
|
1371
|
+
def _apply_start_setup_patch_fallback_if_present(
|
|
1372
|
+
self,
|
|
1373
|
+
*,
|
|
1374
|
+
request: RunRequest,
|
|
1375
|
+
output_text: str,
|
|
1376
|
+
quest_events: Path,
|
|
1377
|
+
) -> None:
|
|
1378
|
+
quest_yaml = read_yaml(request.quest_root / "quest.yaml", {})
|
|
1379
|
+
startup_contract = quest_yaml.get("startup_contract") if isinstance(quest_yaml.get("startup_contract"), dict) else {}
|
|
1380
|
+
if not isinstance(startup_contract.get("start_setup_session"), dict):
|
|
1381
|
+
return
|
|
1382
|
+
patch = extract_start_setup_patch_from_text(output_text)
|
|
1383
|
+
session_patch = extract_start_setup_session_patch_from_text(output_text)
|
|
1384
|
+
if not patch and not session_patch:
|
|
1385
|
+
return
|
|
1386
|
+
result = self.artifact_service.apply_start_setup_form_patch(
|
|
1387
|
+
request.quest_root,
|
|
1388
|
+
form_patch=patch,
|
|
1389
|
+
session_patch=session_patch,
|
|
1390
|
+
message="Applied from runner fallback `start_setup_patch` block.",
|
|
1391
|
+
)
|
|
1392
|
+
patch_keys = sorted(result.get("form_patch", {}).keys()) if isinstance(result.get("form_patch"), dict) else sorted((patch or {}).keys())
|
|
1393
|
+
append_jsonl(
|
|
1394
|
+
quest_events,
|
|
1395
|
+
{
|
|
1396
|
+
"event_id": generate_id("evt"),
|
|
1397
|
+
"type": "runner.turn_postprocess_info",
|
|
1398
|
+
"quest_id": request.quest_id,
|
|
1399
|
+
"run_id": request.run_id,
|
|
1400
|
+
"source": "codex",
|
|
1401
|
+
"skill_id": request.skill_id,
|
|
1402
|
+
"summary": (
|
|
1403
|
+
"Applied the fenced `start_setup_patch` fallback block to the quest startup form "
|
|
1404
|
+
"so the suggested form stays synchronized even when Codex answered with a patch block "
|
|
1405
|
+
"instead of a direct MCP tool call."
|
|
1406
|
+
),
|
|
1407
|
+
"details": {
|
|
1408
|
+
"warning_code": "start_setup_patch_fallback_applied",
|
|
1409
|
+
"patch_keys": patch_keys,
|
|
1410
|
+
},
|
|
1411
|
+
"created_at": utc_now(),
|
|
1412
|
+
},
|
|
1413
|
+
)
|
|
1414
|
+
|
|
1030
1415
|
def _build_command(self, request: RunRequest, prompt: str, *, runner_config: dict[str, Any] | None = None) -> list[str]:
|
|
1031
1416
|
workspace_root = request.worktree_root or request.quest_root
|
|
1032
1417
|
resolved_binary = resolve_runner_binary(self.binary, runner_name="codex")
|
|
@@ -1063,7 +1448,9 @@ class CodexRunner:
|
|
|
1063
1448
|
tool_timeout_sec = self._positive_timeout_seconds(resolved_runner_config.get("mcp_tool_timeout_sec"))
|
|
1064
1449
|
if tool_timeout_sec is not None:
|
|
1065
1450
|
timeout_value = int(tool_timeout_sec) if float(tool_timeout_sec).is_integer() else float(tool_timeout_sec)
|
|
1066
|
-
|
|
1451
|
+
custom_profile = resolve_mcp_tool_profile_for_quest(request.quest_root)
|
|
1452
|
+
server_names = builtin_mcp_server_names_for_custom_profile(custom_profile)
|
|
1453
|
+
for server_name in server_names:
|
|
1067
1454
|
command.extend(["-c", f"mcp_servers.{server_name}.tool_timeout_sec={timeout_value}"])
|
|
1068
1455
|
if request.sandbox_mode:
|
|
1069
1456
|
command.extend(["--sandbox", request.sandbox_mode])
|
|
@@ -1162,8 +1549,9 @@ class CodexRunner:
|
|
|
1162
1549
|
resolved_runner_config = runner_config if isinstance(runner_config, dict) else self._load_runner_config()
|
|
1163
1550
|
tool_timeout_sec = self._positive_timeout_seconds(resolved_runner_config.get("mcp_tool_timeout_sec"))
|
|
1164
1551
|
|
|
1165
|
-
shared_env = {
|
|
1552
|
+
shared_env = ensure_utf8_subprocess_env({
|
|
1166
1553
|
"DEEPSCIENTIST_HOME": str(self.home),
|
|
1554
|
+
"DEEPSCIENTIST_REPO_ROOT": str(self.repo_root),
|
|
1167
1555
|
"DS_HOME": str(self.home),
|
|
1168
1556
|
"DS_QUEST_ID": quest_id,
|
|
1169
1557
|
"DS_QUEST_ROOT": str(quest_root),
|
|
@@ -1174,26 +1562,38 @@ class CodexRunner:
|
|
|
1174
1562
|
"DS_CONVERSATION_ID": f"quest:{quest_id}",
|
|
1175
1563
|
"DS_AGENT_ROLE": "pi",
|
|
1176
1564
|
"DS_TEAM_MODE": "single",
|
|
1177
|
-
}
|
|
1565
|
+
})
|
|
1566
|
+
custom_profile = resolve_mcp_tool_profile_for_quest(quest_root)
|
|
1567
|
+
if custom_profile:
|
|
1568
|
+
shared_env["DS_CUSTOM_PROFILE"] = custom_profile
|
|
1178
1569
|
if pythonpath:
|
|
1179
1570
|
shared_env["PYTHONPATH"] = pythonpath
|
|
1180
1571
|
|
|
1572
|
+
server_names = builtin_mcp_server_names_for_custom_profile(custom_profile)
|
|
1573
|
+
tool_approvals = _builtin_mcp_tool_approvals_for_profile(custom_profile)
|
|
1181
1574
|
block = "\n".join(
|
|
1182
|
-
[
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
|
|
1189
|
-
|
|
1575
|
+
[marker_start]
|
|
1576
|
+
+ [
|
|
1577
|
+
item
|
|
1578
|
+
for index, name in enumerate(server_names)
|
|
1579
|
+
for item in (
|
|
1580
|
+
[self._mcp_block(name, shared_env, tool_timeout_sec=tool_timeout_sec, approvals=tool_approvals.get(name, ()))]
|
|
1581
|
+
+ ([""] if index < len(server_names) - 1 else [])
|
|
1582
|
+
)
|
|
1190
1583
|
]
|
|
1584
|
+
+ [marker_end]
|
|
1191
1585
|
).strip()
|
|
1192
1586
|
new_text = f"{prefix}\n\n{block}\n" if prefix else f"{block}\n"
|
|
1193
1587
|
write_text(config_path, new_text)
|
|
1194
1588
|
|
|
1195
1589
|
@staticmethod
|
|
1196
|
-
def _mcp_block(
|
|
1590
|
+
def _mcp_block(
|
|
1591
|
+
name: str,
|
|
1592
|
+
env: dict[str, str],
|
|
1593
|
+
*,
|
|
1594
|
+
tool_timeout_sec: float | None = None,
|
|
1595
|
+
approvals: tuple[str, ...] = (),
|
|
1596
|
+
) -> str:
|
|
1197
1597
|
args = ["-m", "deepscientist.mcp.server", "--namespace", name]
|
|
1198
1598
|
lines = [
|
|
1199
1599
|
f"[mcp_servers.{name}]",
|
|
@@ -1212,7 +1612,7 @@ class CodexRunner:
|
|
|
1212
1612
|
)
|
|
1213
1613
|
for key, value in env.items():
|
|
1214
1614
|
lines.append(f"{key} = {json.dumps(value)}")
|
|
1215
|
-
for tool_name in
|
|
1615
|
+
for tool_name in approvals:
|
|
1216
1616
|
lines.extend(
|
|
1217
1617
|
[
|
|
1218
1618
|
"",
|