tactus 0.38.0__tar.gz → 0.40.0__tar.gz
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.
- {tactus-0.38.0 → tactus-0.40.0}/CHANGELOG.md +14 -0
- {tactus-0.38.0 → tactus-0.40.0}/IMPLEMENTATION.md +24 -0
- {tactus-0.38.0 → tactus-0.40.0}/PKG-INFO +1 -1
- {tactus-0.38.0 → tactus-0.40.0}/SPECIFICATION.md +39 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/TASKS_RETRIEVAL_OVERHAUL_BRIEF.md +33 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-noaa-brief.tac +6 -40
- tactus-0.40.0/features/90_task_dependency_planning.feature +41 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/cli_run_steps.py +6 -0
- tactus-0.40.0/features/steps/task_dependency_steps.py +202 -0
- {tactus-0.38.0 → tactus-0.40.0}/pyproject.toml +1 -1
- {tactus-0.38.0 → tactus-0.40.0}/scripts/prepare_noaa_afd_biblicus_corpus.py +10 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/__init__.py +1 -1
- {tactus-0.38.0 → tactus-0.40.0}/tactus/cli/app.py +24 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/dsl_stubs.py +18 -1
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/runtime.py +371 -62
- tactus-0.40.0/tactus/plugins/__init__.py +3 -0
- tactus-0.40.0/tactus/plugins/noaa.py +76 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/biblicus/text.py +61 -42
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/semantic_visitor.py +120 -129
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_app_run.py +4 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli.py +23 -2
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_dsl_stubs_tasks.py +1 -1
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_tasks.py +107 -277
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_semantic_visitor_helpers.py +65 -0
- {tactus-0.38.0 → tactus-0.40.0}/.claude/agents.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/.coveragerc +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/.github/workflows/release.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/.gitignore +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/.tactus/config.yml.example +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/AGENTS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/CHANGES_SUMMARY.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/CHECKPOINT_RESUME_PLAN.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/CURRENT_STATUS_AND_NEXT_STEPS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/DETERMINISTIC_REQUEST_ID_FIX.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/EXECUTION_TRACE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/LICENSE +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/Makefile +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/PHASE0_IPC_CHANNEL_COMPLETE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/PHASE2_INTEGRATION_COMPLETE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/PHASE3_IDE_HITL_INTEGRATION.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/TECHNICAL_DEBT.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/behave.ini +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/coverage_badge.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/AGENTS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/BDD_TESTING.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/BIBLICUS_TEXT.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/CONFIGURATION.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/CONTEXT_DESIGN_PLAN.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/CONTEXT_ENGINE_DEMO.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/CONTROL_LOOP_PHASE1_COMPLETE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/DURABILITY.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/FILE_IO.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/MANUAL_CHECKPOINT_TESTING.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/OMNICHANNEL_HITL_PLAN.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/PR_FAQ_BIBLICUS_STDLIB.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/SANDBOXING.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/STREAMING.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/TOOLS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/TOOL_ROADMAP.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/archive/CHECKPOINT_RESUME_STATUS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/archive/CHECKPOINT_TESTING_PLAN.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/archive/CONTROL_LOOP_INTEGRATION.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/archive/HITL_CHECKPOINT_FIX_COMPLETE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/archive/HITL_FIX_SUMMARY.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/archive/LLM_CHECKPOINTING_COMPLETE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs/development-mode.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs_output/classify.html +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/docs_output/index.html +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/.tactus/config.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/.tactus/config.yml.example +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/01-basics-hello-world.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/02-basics-simple-logic.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/03-basics-parameters.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/04-basics-simple-agent.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/05-basics-multi-model.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/06-basics-streaming.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/07-basics-bedrock.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/08-basics-models.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/09-basics-google-gemini.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/10-feature-state.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/11-feature-message-history-transforms.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/11-feature-message-history.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/12-feature-structured-output.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/13-feature-session.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/14-feature-per-turn-tools-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/14-feature-per-turn-tools.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/15-feature-local-tools.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/16-feature-toolsets-advanced.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/17-feature-toolsets-dsl.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/18-feature-lua-tools-individual.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/18-feature-lua-tools-inline.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/18-feature-lua-tools-toolset.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/19-feature-direct-tool-calls.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/20-bdd-complete.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/21-bdd-passing.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/22-bdd-fuzzy-matching.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/30-eval-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/31-eval-demo.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/32-eval-success-rate.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/33-eval-thresholds.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/34-eval-dataset.jsonl +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/34-eval-dataset.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/35-eval-trace.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/36-eval-advanced.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/37-eval-comprehensive.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/39-model-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/40-mcp-test.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/40-model-text-classifier.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/41-mcp-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/41-model-pytorch.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/43-sub-procedure-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/44-sub-procedure-composition.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/45-sub-procedure-recursive.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/46-checkpoint-explicit.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/47-checkpoint-expensive-ops.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/48-script-mode-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/50-inputs-showcase.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/51-inputs-calculator.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/52-file-io-basics.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/53-tsv-file-io.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/54-json-file-io.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/55-parquet-file-io.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/56-hdf5-file-io.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/57-excel-file-io.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/58-text-file-io.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/60-tool-sources.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/61-inline-toolset-lua.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/62-mcp-toolset-by-server.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/63-toolset-import-from-file.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/64-require-modules.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/65-optional-state-demo.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/66-host-tools-via-broker.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/67-host-tool-source.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/68-biblicus-text-extract.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/69-biblicus-text-annotate.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/70-mocking-static.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/71-mocking-temporal.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/72-mocking-conditional.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/73-biblicus-text-link.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/74-biblicus-text-redact.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/75-biblicus-text-slice.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/76-biblicus-text-markup-helpers.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-hitl-debug.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-hitl-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-hitl-test-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-hitl-ultra-debug.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-super-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/90-test-params.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/91-control-loop-demo.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/92-test-inputs-simple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/92-test-inputs.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/92-test-multiple.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/93-test-ide-hitl.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/93-test-individual-hitl.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/93-test-input-summary.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/94-test-custom-components.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/95-agent-hitl.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/99-misc-test-loading.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/agent_test.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/app_config.ini +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/classify_test.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/data/sample.csv +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/demo_output.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/fuzzy_matching_demo.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/fuzzy_matching_demo_simple_spec.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/fuzzy_simple_test.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/helpers/math_module.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/helpers/product.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/helpers/string_module.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/helpers/sum.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/helpers/text_tools.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/hitl_toolset.lua +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/inventory_summary.tsv +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/llm_classify_binary.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/llm_classify_multiclass.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/llm_classify_with_metadata.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/mock-config.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/models/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/models/create_sentiment_model.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/output_summary.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-raw-module.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-raw-streaming.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-basic.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-hitl-types.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-llm.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-many-checkpoints.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-mixed.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-multi-hitl.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-resume-timeout.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-temperature-multi-calls.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/test-temperature-variation.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/tools/calculations.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/tools/data_analysis.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/tools/search.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/with_dependencies/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/with_dependencies/simple_http_test.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/examples/with_dependencies/time_lookup.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/01_state_management.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/02_checkpointing.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/03_human_in_the_loop.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/04_control_flow.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/05_tool_integration.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/06_retry_logic.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/07_file_operations.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/08_agent_primitives.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/09_workflow_execution.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/10_lua_integration.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/11_storage_backends.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/12_json_operations.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/13_logging.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/15_procedure_calls.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/16_session_management.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/17_lua_dsl_validation.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/18_example_procedures.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/19_ide_server.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/20_parameters.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/21_outputs.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/23_prompts.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/24_bdd_specifications.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/25_bdd_custom_steps.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/26_bdd_evaluation.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/27_default_settings.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/28_custom_prompts.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/29_execution_settings.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/30_session_filters.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/31_matchers.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/32_result_object.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/33_output_type.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/42_model_primitive.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/43_sub_procedure_checkpointing.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/46_explicit_checkpoint.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/48_script_mode.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/51_dspy_lm_config.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/52_dspy_signature.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/53_dspy_module.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/54_dspy_history.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/55_dspy_prediction.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/56_dspy_agent.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/57_chat_assistant.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/60_formatting.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/61_classify_primitive.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/61_cli_run_exit_codes.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/62_cli_info.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/67_message_history_transforms.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/68_ide_file_tools.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/69_ide_assistant_service.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/70_context_retriever.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/70_ide_chat_api.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/71_context_compaction.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/71_ide_config_api.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/72_context_history_compaction.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/73_context_nested_compaction.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/74_context_regeneration.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/75_context_default_regeneration.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/76_context_pack_budget_weights.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/77_context_default_pack_priority.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/78_context_default_pack_weights.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/79_context_nested_context_packs.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/80_context_nested_pack_budget_cap.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/81_context_nested_regeneration.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/82_context_explicit_regeneration.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/83_context_explicit_pack_priority.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/84_context_explicit_pack_weights.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/85_context_expansion.feature +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/documentation/IDE_SERVER_BEHAVIOR.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/documentation/Lua DSL/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/environment.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/agent_primitives_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/chat_assistant_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/checkpointing_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/classify_primitive_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/cli_info_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_compaction_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_default_pack_priority_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_default_pack_weights_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_default_regeneration_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_expansion_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_explicit_pack_priority_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_explicit_pack_weights_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_explicit_regeneration_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_history_compaction_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_nested_compaction_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_nested_context_packs_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_nested_pack_budget_cap_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_nested_regeneration_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_pack_budget_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_regeneration_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/context_retriever_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/control_flow_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/dspy_agent_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/dspy_history_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/dspy_lm_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/dspy_module_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/dspy_prediction_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/dspy_signature_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/example_procedures_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/file_operations_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/formatting_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/human_in_the_loop_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/ide_assistant_service_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/ide_chat_api_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/ide_config_api_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/ide_file_tools_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/ide_server_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/json_operations_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/logging_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/lua_dsl_validation_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/lua_integration_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/mocking_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/procedure_calls_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/result_and_output_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/retry_logic_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/session_management_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/state_management_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/storage_backend_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/support/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/support/harnesses.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/tool_integration_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/features/steps/workflow_execution_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/planning/BROKER_AND_TOOL_RUNNERS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/planning/CONTEXT_COMPACTION_POLICY.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/planning/CONVERSATION_HISTORY_TRANSFORMS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/planning/FORMATTER.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/audit_examples_mocking.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/context_demo_config.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/context_demo_printer.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/convert_examples.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/demo_context_engine.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/demo_context_quality_long.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/demo_context_quality_mfl_variants.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/demo_context_quality_short.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/fetch_noaa_afd_corpus.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/fetch_wikitext2.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/run_coverage.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/run_precommit_suite.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/scripts/timeout.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/start-web-ide.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/broker_log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/base.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/broker.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/cli.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/host.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/ipc.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/channels/sse.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/cli_hitl.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/cli_log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/control_loop.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/cost_collector_log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/file_storage.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/http_callback_log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/ide_log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/lua_tools.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/mcp.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/mcp_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/memory.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/adapters/plugins.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/backends/http_backend.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/backends/model_backend.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/backends/pytorch_backend.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/broker/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/broker/client.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/broker/protocol.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/broker/server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/broker/stdio.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/cli/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/cli/commands/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/cli/control.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/compaction.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/config_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/context_assembler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/context_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/dependencies/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/dependencies/registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/exceptions.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/execution_context.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/lua_sandbox.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/message_history_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/mocking.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/output_validator.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/retrieval.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/retriever_tasks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/template_resolver.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/core/yaml_parser.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docker/Dockerfile +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docker/Dockerfile.pypi +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docker/entrypoint.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/extractor.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/html_renderer.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/templates/base.html +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/templates/index.html +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/docs/templates/module.html +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/agent.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/broker_lm.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/config.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/history.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/module.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/prediction.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/dspy/signature.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/formatting/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/formatting/formatter.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/ide/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/ide/coding_assistant.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/ide/config_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/ide/server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/control.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/file.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/handles.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/host.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/human.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/json.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/message_history.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/model.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/procedure.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/procedure_callable.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/retry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/session.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/state.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/step.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/system.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/tool.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/tool_handle.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/primitives/toolset.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/chat_recorder.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/config.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/control.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/cost.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/hitl.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/log_handler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/notification.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/result.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/protocols/storage.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/providers/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/providers/base.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/providers/bedrock.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/providers/google.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/providers/openai.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/sandbox/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/sandbox/config.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/sandbox/container_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/sandbox/docker_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/sandbox/entrypoint.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/sandbox/protocol.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/biblicus/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/classify/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/classify/classify.spec.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/classify/classify.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/classify/fuzzy.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/classify/llm.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/classify/primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/core/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/core/base.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/core/confidence.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/core/models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/core/retry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/core/validation.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/extract/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/extract/llm.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/extract/primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/csv.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/excel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/file.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/fs.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/hdf5.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/json.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/parquet.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/io/tsv.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/loader.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/biblicus/text.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/biblicus.spec.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/classify/base.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/classify/fuzzy.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/classify/index.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/classify/init.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/classify/llm.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/classify.spec.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/corpora/base.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/corpora/filesystem.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/extract/base.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/extract/index.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/extract/init.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/extract/llm.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/extract.spec.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/generate/base.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/generate/index.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/generate/init.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/generate/llm.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/generate.spec.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/base.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/embedding_index_file.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/embedding_index_inmemory.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/index.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/init.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/sqlite_full_text_search.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/retrievers/tf_vector.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/tools/done.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/stdlib/tac/tactus/tools/log.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/behave_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/context.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/eval_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/evaluation_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/evaluators.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/events.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/gherkin_parser.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/mock_agent.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/mock_dependencies.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/mock_hitl.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/mock_registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/mock_tools.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/pydantic_eval_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/steps/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/steps/builtin.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/steps/custom.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/steps/registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/testing/test_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/tracing/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/tracing/trace_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/utils/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/utils/asyncio_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/utils/cost_calculator.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/utils/model_pricing.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/utils/safe_file_library.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/utils/safe_libraries.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/LuaLexerBase.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/LuaParserBase.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/error_listener.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaLexer.interp +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaLexer.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaLexer.tokens +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaLexerBase.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaParser.interp +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaParser.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaParser.tokens +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaParserBase.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/LuaParserVisitor.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/generated/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/grammar/LuaLexer.g4 +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/grammar/LuaParser.g4 +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus/validation/validator.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/.gitignore +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/BUILD_GUIDE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/DISTRIBUTION.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/ELECTRON_INTEGRATION.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/RUN_ELECTRON.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/SETUP_COMPLETE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/backend/hook-lupa.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/backend/tactus_backend.spec +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/package-lock.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/package.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/preload/preload.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/preload/tsconfig.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/rebuild-and-test.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/resources/app-icon.icns +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/resources/app-icon.ico +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/resources/app-icon.png +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/scripts/build-backend.mjs +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/scripts/build-frontend.mjs +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/scripts/generate-icons.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/scripts/test-ci-build.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/src/backend-manager.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/src/main.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/src/menu.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/src/preferences-window.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-desktop/tsconfig.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/ARCHITECTURE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/CHANGELOG.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/DEV_MODE.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/QUICK_START.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/RESTART_INSTRUCTIONS.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/TROUBLESHOOTING.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/assistant_service.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/assistant_tools.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/chat_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/config_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/events.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/logging_capture.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/lsp_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/requirements.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/tactus_lsp_handler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/backend/text_editor_tool.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/dev.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/.storybook/main.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/.storybook/preview.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/.storybook/vitest.setup.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/README.md +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/components.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/demo.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/index.html +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/jest.config.js +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/package-lock.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/package.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/postcss.config.js +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/App.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/Editor.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/LSPClient.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/LSPClientHTTP.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/TactusLanguage.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/commands/registry.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/AboutDialog.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/AuthErrorDialog.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ChatSidebar.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/CheckpointSummary.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/CollapsibleRun.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/Duration.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/Duration.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/FileTree.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/FileTree.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/MessageFeed.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/PreferencesView.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ProcedureInputsDisplay.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ProcedureInputsDisplay.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ProcedureInputsModal.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ProcedureInputsModal.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ProcedureTab.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ProcedureTab.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ResizeHandle.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ResultsSidebar.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ResultsSidebar.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/TestOptionsModal.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/Timestamp.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/Timestamp.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/TopMenuBar.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ai-elements/confirmation.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/chat/ChatInterface.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/chat/MessageInput.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/chat/MessageList.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/CheckpointDetails.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/CheckpointDetails.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/CheckpointList.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/CheckpointList.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/DebuggerPanel.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/DebuggerPanel.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/RunSelector.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/RunSelector.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/StatisticsPanel.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/debugger/StatisticsPanel.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/AgentStreamingComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/BaseEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/CheckpointEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/CollapsibleTestScenario.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ContainerStatusEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/CostEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/CostEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/EvaluationEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/EvaluationEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/EventRenderer.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ExecutionEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ExecutionEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ExecutionSummaryEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ExecutionSummaryEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/HITLEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/HITLEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/LoadingEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/LoadingEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/LogCluster.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/LogEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/LogEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/OutputEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/OutputEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/TestEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/TestEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/TestProgressContainer.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ToolCallEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ValidationEventComponent.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/events/ValidationEventComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/registry.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/ApprovalComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/InputComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/SelectComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/index.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/index.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/selectors/ImageSelectorComponent.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/standard-library/selectors/index.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/hitl/types.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/AgentsSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/EvaluationsSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/MetadataSections.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/OutputsSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/ParametersSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/SpecificationsSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/StagesSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/metadata/ToolsSection.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/preferences/ConfigFieldView.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/preferences/SourceBadge.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/preferences/YamlCodeEditor.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/scenarios/EvaluateScenarios.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/scenarios/RunScenarios.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/scenarios/TestScenarios.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/scenarios/ValidationScenarios.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/theme-provider.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/ai/conversation.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/ai/message.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/ai/prompt-input.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/alert.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/badge.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/button.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/dialog.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/dropdown-menu.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/input.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/label.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/logo.stories.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/logo.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/menubar.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/scroll-area.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/select.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/separator.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/switch.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/tabs.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/components/ui/tooltip.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/hooks/useChatSSE.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/hooks/useEventStream.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/hooks/useTracing.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/index.css +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/lib/utils.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/main.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/types/events.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/types/metadata.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/types/preferences.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/types/results.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/types/tracing.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/utils/clipboard.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/utils/runExport.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/utils/yamlSync.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/validation/TactusValidator.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/validation/generated/LuaParser.interp +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/validation/generated/LuaParser.tokens +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/validation/types.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/src/vite-env.d.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/tailwind.config.js +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/tests/runExport.test.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/tsconfig.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/tsconfig.node.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/vendor/tactus-hitl-components/package.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/vendor/tactus-hitl-components/src/index.tsx +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/vendor/tactus-hitl-components/src/styles.css +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/vite.config.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/frontend/vitest.shims.d.ts +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/package.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tactus-ide/start-dev.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/test-ci.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/test_classify_loading.tac +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/test_run_inputs.sh +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_base_channel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_broker_channel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_channels_init.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_cli_channel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_host_channel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_ipc_channel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/channels/test_sse_channel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_broker_log.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_cli_hitl_handler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_cli_log_handler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_control_loop.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_file_storage.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_log_handlers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_lua_tools_adapter.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_mcp_adapter.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_mcp_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_memory_storage.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/adapters/test_plugins.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/backends/test_http_backend.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/backends/test_pytorch_backend.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_client_extra.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_client_unit.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_host_tool_source.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_protocol.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_anyio_handlers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_asyncio_handlers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_connection.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_unit.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_server_utils.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_stdio_transport.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_tcp_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_broker_tcp_unit.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/broker/test_brokered_lm_unit.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_app_commands.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_app_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_app_inputs.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_app_sandbox.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_config_loading.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_control_main.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_display_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_format_info.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_ide_main.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_input_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_inputs.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_logging.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_main_entry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_run_errors.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_sandbox_validate.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_stdlib_control.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_task_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_test_eval_commands.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_cli_trace_commands.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_control_cli.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_sandbox_commands.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_sandbox_run_special_cases.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_validate_command.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/cli/test_version_command.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/conftest.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/dependencies/test_registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_compaction.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_config_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_context_assembler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_determinism_safety.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_dsl_stubs_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_dsl_stubs_agent_creation_error_logging.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_dsl_stubs_context_directives.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_dsl_stubs_minimal.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_dsl_stubs_utils.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_execution_context.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_lua_sandbox_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_lua_sandbox_security.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_message_history_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_mocking.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_output_validator.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_registry_builder_errors.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_registry_tasks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_registry_validation_paths.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_retrieval.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_retriever_tasks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_dependencies.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_enhance_handles.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_execute_branches.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_execute_workflow.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_init.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_inject_primitives.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_inputs.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_named_procedures.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_output_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_setup_agents_branches.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_setup_agents_tools_output.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_templates.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_tool_source.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_runtime_toolsets.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_script_mode.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_template_resolver.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/core/test_yaml_parser.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/docs/test_docs_extractor.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/docs/test_docs_init.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/docs/test_docs_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/docs/test_html_renderer.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_agent_context_assembly.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_agent_execution.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_agent_handle.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_agent_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_agent_mocking.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_agent_utilities.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_broker_lm.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_config.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_config_adapter_fallback.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_config_utilities.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_history.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_mock_field_normalization.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_module_logging.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_module_parameter.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_module_utilities.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_prediction_messages.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_signature.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/dspy/test_streaming.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/brave_search_mcp_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/filesystem_mcp_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/01_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/01_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/01_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/02_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/02_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/02_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/03_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/03_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/03_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/04_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/04_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/04_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/05_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/05_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd/MFL/05_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/catalog.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/config.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/runs/6671bbc844560225a7dc978c5049a64c6a3c6799e80337f2b344333cca3f36d9.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/runs/836bb0d7326c574fa553b5d03537b0b42e8fc103c6d1ed369034ebb11857a49f.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/runs/ae010d680ce927f77527cc022d302e553fd8d79067075cf49c0830ed666c20a8.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/runs/b595ab127e28a9572713305bc2656270699fe106a136eb7740a7b6168ecba2f9.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/runs/cb9dacf82d0cd74860c65d12cbc7c223704b16db2b3a36d94c96ab411f19d61b.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/.biblicus/runs/e6df460cac28a87f7141b20a2c30d32d43956303dbdc132040639fbf4f3838a7.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/01_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/01_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/01_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/01_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/02_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/02_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/02_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/02_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/03_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/03_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/03_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/03_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/04_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/04_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/04_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/04_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/05_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/05_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/05_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/0826bb0e-5d5e-462b-aea7-ecdd95d92ccb/05_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/01_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/01_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/01_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/01_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/02_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/02_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/02_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/02_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/03_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/03_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/03_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/03_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/04_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/04_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/04_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/04_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/05_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/05_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/05_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/12c86d9d-710c-4eb6-bc49-18f32b92536e/05_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/01_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/01_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/01_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/01_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/02_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/02_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/02_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/02_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/03_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/03_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/03_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/03_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/04_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/04_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/04_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/04_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/05_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/05_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/05_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/3ae212e2-3723-47df-9e2f-dd460fd84299/05_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/01_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/01_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/01_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/01_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/02_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/02_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/02_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/02_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/03_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/03_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/03_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/03_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/04_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/04_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/04_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/04_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/05_Area_Forecast_Discussion.json +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/05_Area_Forecast_Discussion.json.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/05_Area_Forecast_Discussion.txt +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/noaa_afd_corpus/MFL/raw/imports/dbd8c9e2-7c3e-4884-a22f-2bf851190356/05_Area_Forecast_Discussion.txt.biblicus.yml +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/fixtures/test_mcp_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_assistant_service.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_assistant_tools.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_chat_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_coding_assistant.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_config_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_config_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_config_server_api.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_events.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_basics.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_error_branches.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_hitl.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_hitl_chat_stream.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_lsp_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_lsp_chat.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_metadata.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_misc.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_run_stream.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_stream_errors.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_stream_failures.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_stream_success.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_trace_errors.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_traces.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_ide_server_validate.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_logging_capture.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_lsp_server.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_tactus_lsp_handler.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/ide_backend/test_text_editor_tool.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/integration/test_named_procedures.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/mocks/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/mocks/llm_mocks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_checkpoint_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_control_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_file_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_handles.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_handles_repr.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_host_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_human_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_json_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_log_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_message_history_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_model_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_procedure_callable.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_procedure_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_retry_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_session_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_state_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_step_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_system_alert.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_system_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_tool_handle.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_tool_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_toolset_dsl.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/primitives/test_toolset_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/protocols/test_protocol_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/protocols/test_protocol_stubs.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/protocols/test_protocols_misc.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/protocols/test_storage_protocol.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/providers/test_provider_configurations.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/providers/test_providers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_config.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_container_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_container_runner_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_container_runner_run_container.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_docker_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_docker_sandbox_smoke.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_entrypoint.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_entrypoint_control_flow_exceptions.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/sandbox/test_protocol.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/test_classify_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/test_fuzzy_algorithms.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/test_fuzzy_classifier.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/test_fuzzy_demo.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/test_fuzzy_import_error.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/classify/test_llm_classifier_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/core/test_base.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/core/test_confidence.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/core/test_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/core/test_retry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/core/test_validation.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/extract/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/extract/test_extract_primitive.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/extract/test_llm_extractor.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_excel.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_excel_parquet_hdf5.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_file.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_file_csv_tsv.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_fs.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_hdf5.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_import_errors.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/io/test_serializers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/test_biblicus_text.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/test_loader.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/stdlib/test_require_python.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/test_checkpoints_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/test_formatter.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/test_mcp_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/test_tracing.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/conftest.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_all_examples.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_behave_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_behave_integration_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_builtin_steps.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_builtin_steps_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_builtin_steps_regex.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_agent_mocks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_capture.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_edge_cases.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_fallbacks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_internals.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_missing_branches.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_context_run_wrapper.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_custom_steps_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_custom_steps_manager.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_e2e.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_eval_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluation_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluation_runner_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluation_runner_edges.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluators.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluators_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluators_import_error.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluators_more.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_evaluators_traceaware.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_gherkin_parser.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_gherkin_parser_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_agent.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_agent_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_dependencies.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_dependencies_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_hitl.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_registry_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_mock_tools.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_models.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_dataset.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_errors.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_import_error.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_loaders.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_task.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_thresholds.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_pydantic_eval_runner_trace.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_runtime_integration.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_step_registry.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_test_runner_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_test_runner_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_test_runner_run.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/testing/test_test_runner_statuses.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/tracing/test_trace_manager_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/test_asyncio_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/test_cost_calculator.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/test_model_pricing.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/test_safe_file_library.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/test_safe_file_library_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/utils/test_safe_libraries.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/__init__.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_semantic_visitor.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_semantic_visitor_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_semantic_visitor_context_directives.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_semantic_visitor_more.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_semantic_visitor_tasks.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_tool_curried_syntax_disallowed.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_validator_additional.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_validator_helpers.py +0 -0
- {tactus-0.38.0 → tactus-0.40.0}/tests/validation/test_validator_include_tasks.py +0 -0
|
@@ -2,6 +2,20 @@
|
|
|
2
2
|
|
|
3
3
|
<!-- version list -->
|
|
4
4
|
|
|
5
|
+
## v0.40.0 (2026-02-05)
|
|
6
|
+
|
|
7
|
+
### Bug Fixes
|
|
8
|
+
|
|
9
|
+
- Avoid duplicate run dependency execution
|
|
10
|
+
([`f0ead11`](https://github.com/AnthusAI/Tactus/commit/f0ead110e30a97b9c229dee5efaec7008f486269))
|
|
11
|
+
|
|
12
|
+
- Normalize task kind aliases without biblicus
|
|
13
|
+
([`62296b7`](https://github.com/AnthusAI/Tactus/commit/62296b7528540f0079c73e7f64655a6bc05c1498))
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
## v0.39.0 (2026-02-05)
|
|
17
|
+
|
|
18
|
+
|
|
5
19
|
## v0.38.0 (2026-02-03)
|
|
6
20
|
|
|
7
21
|
### Bug Fixes
|
|
@@ -95,6 +95,30 @@ All checkpoints are tracked by execution position, not name. This enables:
|
|
|
95
95
|
}
|
|
96
96
|
```
|
|
97
97
|
|
|
98
|
+
---
|
|
99
|
+
|
|
100
|
+
## Tasks + Dependency Planning
|
|
101
|
+
|
|
102
|
+
**Status**: ✅ **Implemented (Biblicus-first dependency engine)**
|
|
103
|
+
|
|
104
|
+
### Task declarations
|
|
105
|
+
- **Registry model**: `tactus/core/registry.py` (`TaskDeclaration`)
|
|
106
|
+
- **DSL stubs**: `tactus/core/dsl_stubs.py` (`Task`, `IncludeTasks`)
|
|
107
|
+
- **Runtime registration**: `tactus/core/runtime.py` (`_register_assignment_tasks`)
|
|
108
|
+
|
|
109
|
+
### Dependency planning
|
|
110
|
+
- **Biblicus plan builder**: `biblicus.workflow` (`Task`, `Plan`, `build_plan_for_*`)
|
|
111
|
+
- **Runtime execution**: `tactus/core/runtime.py`
|
|
112
|
+
- `_execute_run_dependencies()` before running main/script mode
|
|
113
|
+
- `_execute_retriever_index()` uses Biblicus plans + handlers
|
|
114
|
+
- `depends_on` executed before task entries
|
|
115
|
+
- `provides` maps custom tasks to dependency kinds (e.g., load)
|
|
116
|
+
|
|
117
|
+
### CLI UX
|
|
118
|
+
- `tactus/cli/app.py` flags:
|
|
119
|
+
- `--auto-deps` to run dependencies automatically
|
|
120
|
+
- `--no-deps` to fail fast when dependencies are missing
|
|
121
|
+
|
|
98
122
|
**Status**: ✅ **Fully Implemented** (Local execution context)
|
|
99
123
|
|
|
100
124
|
**Note**: Lambda Durable Execution Context mentioned in spec is **not implemented**. Only local context exists.
|
|
@@ -101,6 +101,45 @@ Feature: Task Processing
|
|
|
101
101
|
|
|
102
102
|
---
|
|
103
103
|
|
|
104
|
+
## Tasks and Dependency Planning
|
|
105
|
+
|
|
106
|
+
Tasks provide statically discoverable entrypoints that complement Procedures and script mode.
|
|
107
|
+
|
|
108
|
+
### Task syntax
|
|
109
|
+
```lua
|
|
110
|
+
Task "fetch" {
|
|
111
|
+
provides = { kind = "load", corpus = "miami_afd" },
|
|
112
|
+
entry = function()
|
|
113
|
+
return FetchNoaaAfd({ wfo = "MFL", max_items = 5 })
|
|
114
|
+
end
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
run = Task {
|
|
118
|
+
depends_on = {"index"},
|
|
119
|
+
entry = function()
|
|
120
|
+
return Miami("Summarize the recent Miami AFD.")
|
|
121
|
+
end
|
|
122
|
+
}
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
### Dependency behavior
|
|
126
|
+
- Built-in task kinds: `load`, `ingest`, `extract`, `index`, `query`.
|
|
127
|
+
- Aliases normalize to canonical kinds:
|
|
128
|
+
- `fetch`/`sync → load`
|
|
129
|
+
- `build → index`
|
|
130
|
+
- `run → query`
|
|
131
|
+
- `index` depends on `extract`; `extract` depends on `load` when the corpus is empty.
|
|
132
|
+
- Task `provides` declarations allow custom tasks to satisfy dependency kinds.
|
|
133
|
+
|
|
134
|
+
### CLI integration
|
|
135
|
+
- `tactus file.tac index` runs all retrievers that support indexing.
|
|
136
|
+
- `tactus file.tac index:retriever_name` runs a single retriever.
|
|
137
|
+
- `tactus file.tac run` prompts before running dependency tasks unless:
|
|
138
|
+
- `--auto-deps` is set (run dependencies automatically)
|
|
139
|
+
- `--no-deps` is set (fail fast if dependencies are missing)
|
|
140
|
+
|
|
141
|
+
---
|
|
142
|
+
|
|
104
143
|
## Input
|
|
105
144
|
|
|
106
145
|
Input schema defines what the procedure accepts. Validated before execution.
|
|
@@ -30,6 +30,11 @@ This brief is the source of truth for implementation decisions.
|
|
|
30
30
|
- Evidence
|
|
31
31
|
- Configuration
|
|
32
32
|
- Pipeline
|
|
33
|
+
- Load
|
|
34
|
+
- Ingest
|
|
35
|
+
- Extract
|
|
36
|
+
- Index
|
|
37
|
+
- Query
|
|
33
38
|
|
|
34
39
|
Removed from user-facing vocabulary:
|
|
35
40
|
- backend
|
|
@@ -77,6 +82,7 @@ miami_search = TfVector.Retriever {
|
|
|
77
82
|
### Task (explicit)
|
|
78
83
|
```lua
|
|
79
84
|
Task "fetch" {
|
|
85
|
+
provides = { kind = "load", corpus = "miami_afd" },
|
|
80
86
|
Task "NOAA" {
|
|
81
87
|
entry = function()
|
|
82
88
|
return FetchNoaaAfd { wfo = "MFL", max_items = 5, corpus = miami_afd }
|
|
@@ -88,6 +94,7 @@ Task "fetch" {
|
|
|
88
94
|
### Task (assignment sugar)
|
|
89
95
|
```lua
|
|
90
96
|
fetch = Task {
|
|
97
|
+
provides = { kind = "load", corpus = "miami_afd" },
|
|
91
98
|
NOAA = Task {
|
|
92
99
|
entry = function()
|
|
93
100
|
return FetchNoaaAfd { wfo = "MFL", max_items = 5, corpus = miami_afd }
|
|
@@ -170,6 +177,26 @@ The script-mode transform must treat these as declarations (not executable code)
|
|
|
170
177
|
- `tactus file.tac index:retriever_name` runs only that retriever.
|
|
171
178
|
- If a user-defined `Task "index"` exists, it overrides auto-aggregation.
|
|
172
179
|
|
|
180
|
+
## Biblicus-First Task Dependencies (Load → Extract → Index)
|
|
181
|
+
- Biblicus owns dependency planning/execution via `Task` + `Plan` (no TaskSpec).
|
|
182
|
+
- Built-in dependency rules:
|
|
183
|
+
- `query → index` (if no compatible retrieval snapshot exists)
|
|
184
|
+
- `index → extract` (always)
|
|
185
|
+
- `extract → load` (only if corpus empty and a load handler exists)
|
|
186
|
+
- `ingest` has no dependencies
|
|
187
|
+
- Default extraction pipeline is pass-through text if none configured.
|
|
188
|
+
- Task kind aliases normalize to canonical kinds:
|
|
189
|
+
- `fetch`/`sync → load`
|
|
190
|
+
- `build → index`
|
|
191
|
+
- `run → query`
|
|
192
|
+
|
|
193
|
+
### Task dependency hooks (Tactus)
|
|
194
|
+
Tasks can plug into Biblicus dependency planning via:
|
|
195
|
+
- `depends_on = {"load", "extract"}`
|
|
196
|
+
- `provides = { kind = "load", corpus = "miami_afd" }`
|
|
197
|
+
|
|
198
|
+
`provides` lets custom tasks satisfy built-in dependency kinds.
|
|
199
|
+
|
|
173
200
|
## Snapshot Semantics
|
|
174
201
|
- Retrieval build artifacts are called **snapshots** (not runs/indexes).
|
|
175
202
|
- Use `snapshot`, `snapshot_id`, `snapshot_manifest`, `snapshot_artifacts`.
|
|
@@ -192,6 +219,12 @@ Retriever auto-tasks:
|
|
|
192
219
|
- `tactus file.tac index:retriever_a` runs only that retriever.
|
|
193
220
|
- User-defined `Task "index"` overrides auto aggregation.
|
|
194
221
|
|
|
222
|
+
Dependency planning:
|
|
223
|
+
- `tactus file.tac run` prompts when dependencies (load/extract/index) are required.
|
|
224
|
+
- `tactus file.tac run --auto-deps` executes dependency tasks without prompting.
|
|
225
|
+
- `tactus file.tac run --no-deps` fails fast if dependencies are missing.
|
|
226
|
+
- `provides` tasks can satisfy `load` dependencies (e.g. fetch task).
|
|
227
|
+
|
|
195
228
|
Extraction:
|
|
196
229
|
- `pipeline.extract` runs automatically on ingest.
|
|
197
230
|
- No explicit extraction task required.
|
|
@@ -6,47 +6,13 @@
|
|
|
6
6
|
local FilesystemCorpus = require("tactus.corpora.filesystem")
|
|
7
7
|
local TfVector = require("tactus.retrievers.tf_vector")
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
use = "
|
|
11
|
-
description = "
|
|
9
|
+
FetchNoaaAfd = Tool {
|
|
10
|
+
use = "plugin.noaa.fetch_noaa_afd",
|
|
11
|
+
description = "Fetch NOAA AFD fixtures and import into Biblicus"
|
|
12
12
|
}
|
|
13
13
|
|
|
14
|
-
FetchNoaaAfd = function(params)
|
|
15
|
-
Log.info("FetchNoaaAfd: fetching NOAA AFD fixtures")
|
|
16
|
-
python({
|
|
17
|
-
args = {
|
|
18
|
-
"scripts/fetch_noaa_afd_corpus.py",
|
|
19
|
-
"--wfo", params.wfo,
|
|
20
|
-
"--max-items", tostring(params.max_items),
|
|
21
|
-
"--output", "tests/fixtures/noaa_afd",
|
|
22
|
-
}
|
|
23
|
-
})
|
|
24
|
-
Log.info("FetchNoaaAfd: building Biblicus corpus + tf-vector index")
|
|
25
|
-
python({
|
|
26
|
-
args = {
|
|
27
|
-
"scripts/prepare_noaa_afd_biblicus_corpus.py",
|
|
28
|
-
"--retriever", "tf-vector",
|
|
29
|
-
"--wfo", params.wfo,
|
|
30
|
-
"--force",
|
|
31
|
-
}
|
|
32
|
-
})
|
|
33
|
-
return {
|
|
34
|
-
status = "ok",
|
|
35
|
-
wfo = params.wfo,
|
|
36
|
-
max_items = params.max_items,
|
|
37
|
-
}
|
|
38
|
-
end
|
|
39
|
-
|
|
40
14
|
miami_afd = FilesystemCorpus.Corpus {
|
|
41
|
-
root = "tests/fixtures/noaa_afd_corpus/MFL"
|
|
42
|
-
configuration = {
|
|
43
|
-
pipeline = {
|
|
44
|
-
-- Extraction runs automatically on ingest.
|
|
45
|
-
extract = {
|
|
46
|
-
-- Placeholder for composed extraction steps.
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
15
|
+
root = "tests/fixtures/noaa_afd_corpus/MFL"
|
|
50
16
|
}
|
|
51
17
|
|
|
52
18
|
miami_search = TfVector.Retriever {
|
|
@@ -77,12 +43,12 @@ Miami = Agent {
|
|
|
77
43
|
context = miami_context
|
|
78
44
|
}
|
|
79
45
|
|
|
80
|
-
fetch
|
|
46
|
+
Task "fetch" {
|
|
47
|
+
provides = { kind = "load", corpus = "miami_afd" },
|
|
81
48
|
entry = function()
|
|
82
49
|
return FetchNoaaAfd({
|
|
83
50
|
wfo = "MFL",
|
|
84
51
|
max_items = 5,
|
|
85
|
-
corpus = miami_afd
|
|
86
52
|
})
|
|
87
53
|
end
|
|
88
54
|
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
Feature: Task dependency planning
|
|
2
|
+
As a workflow developer
|
|
3
|
+
I want load/extract/index dependencies to be planned and enforced
|
|
4
|
+
So that retrievers are ready before run executes
|
|
5
|
+
|
|
6
|
+
Scenario: Auto-deps builds extraction and index snapshots
|
|
7
|
+
Given a NOAA corpus fixture copy
|
|
8
|
+
And a task workflow that uses the copied corpus
|
|
9
|
+
When I run "tactus run --no-sandbox --auto-deps" on the file
|
|
10
|
+
Then the command should succeed
|
|
11
|
+
And an extraction snapshot should exist
|
|
12
|
+
And a retrieval snapshot should exist
|
|
13
|
+
|
|
14
|
+
Scenario: Prompt accepts dependency execution
|
|
15
|
+
Given a NOAA corpus fixture copy
|
|
16
|
+
And a task workflow that uses the copied corpus
|
|
17
|
+
And I provide CLI input "y"
|
|
18
|
+
When I run "tactus run --no-sandbox" on the file
|
|
19
|
+
Then the command should succeed
|
|
20
|
+
And an extraction snapshot should exist
|
|
21
|
+
|
|
22
|
+
Scenario: No-deps fails fast when dependencies are missing
|
|
23
|
+
Given a NOAA corpus fixture copy
|
|
24
|
+
And a task workflow that uses the copied corpus
|
|
25
|
+
When I run "tactus run --no-sandbox --no-deps" on the file
|
|
26
|
+
Then the command should fail
|
|
27
|
+
And the output should show "Dependencies missing"
|
|
28
|
+
|
|
29
|
+
Scenario: Index task fans out across multiple retrievers
|
|
30
|
+
Given a NOAA corpus fixture copy
|
|
31
|
+
And a task workflow with two retrievers
|
|
32
|
+
When I run "tactus run --no-sandbox --auto-deps index" on the file
|
|
33
|
+
Then the command should succeed
|
|
34
|
+
And at least 2 retrieval snapshots should exist
|
|
35
|
+
|
|
36
|
+
Scenario: Load handler runs for empty corpus
|
|
37
|
+
Given an empty corpus workspace
|
|
38
|
+
And a task workflow with a load provider
|
|
39
|
+
When I run "tactus run --no-sandbox --auto-deps" on the file
|
|
40
|
+
Then the command should succeed
|
|
41
|
+
And the load marker should exist
|
|
@@ -32,7 +32,13 @@ def step_run_tactus_on_file(context, args):
|
|
|
32
32
|
[sys.executable, "-m", "tactus.cli.app", *cli_args],
|
|
33
33
|
capture_output=True,
|
|
34
34
|
text=True,
|
|
35
|
+
input=getattr(context, "cli_input", None),
|
|
35
36
|
)
|
|
36
37
|
context.cli_returncode = result.returncode
|
|
37
38
|
context.cli_stdout = result.stdout
|
|
38
39
|
context.cli_stderr = result.stderr
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
@when('I run "tactus run" on the file')
|
|
43
|
+
def step_run_tactus_on_file_no_args(context):
|
|
44
|
+
step_run_tactus_on_file(context, "")
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Steps for task dependency planning scenarios.
|
|
3
|
+
"""
|
|
4
|
+
|
|
5
|
+
import shutil
|
|
6
|
+
import tempfile
|
|
7
|
+
from pathlib import Path
|
|
8
|
+
|
|
9
|
+
from behave import given, then
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
@given("a NOAA corpus fixture copy")
|
|
13
|
+
def step_copy_noaa_corpus(context):
|
|
14
|
+
fixture_root = Path("tests/fixtures/noaa_afd_corpus/MFL").resolve()
|
|
15
|
+
if not fixture_root.exists():
|
|
16
|
+
raise AssertionError(f"Fixture corpus not found: {fixture_root}")
|
|
17
|
+
|
|
18
|
+
temp_dir = tempfile.mkdtemp(prefix="tactus_noaa_corpus_")
|
|
19
|
+
corpus_root = Path(temp_dir) / "MFL"
|
|
20
|
+
shutil.copytree(fixture_root, corpus_root, dirs_exist_ok=True)
|
|
21
|
+
context.corpus_root = corpus_root
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
@given("an empty corpus workspace")
|
|
25
|
+
def step_empty_corpus_workspace(context):
|
|
26
|
+
temp_dir = tempfile.mkdtemp(prefix="tactus_empty_corpus_")
|
|
27
|
+
corpus_root = Path(temp_dir) / "MFL"
|
|
28
|
+
corpus_root.mkdir(parents=True, exist_ok=True)
|
|
29
|
+
context.corpus_root = corpus_root
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
@given("a task workflow that uses the copied corpus")
|
|
33
|
+
def step_write_dependency_workflow(context):
|
|
34
|
+
if not hasattr(context, "corpus_root"):
|
|
35
|
+
raise AssertionError("Corpus root not set for dependency workflow")
|
|
36
|
+
|
|
37
|
+
workflow_source = f"""local FilesystemCorpus = require("tactus.corpora.filesystem")
|
|
38
|
+
local TfVector = require("tactus.retrievers.tf_vector")
|
|
39
|
+
|
|
40
|
+
miami_afd = FilesystemCorpus.Corpus {{
|
|
41
|
+
root = "{context.corpus_root.as_posix()}"
|
|
42
|
+
}}
|
|
43
|
+
|
|
44
|
+
miami_search = TfVector.Retriever {{
|
|
45
|
+
corpus = miami_afd,
|
|
46
|
+
configuration = {{
|
|
47
|
+
pipeline = {{
|
|
48
|
+
query = {{
|
|
49
|
+
limit = 1,
|
|
50
|
+
maximum_total_characters = 2000
|
|
51
|
+
}}
|
|
52
|
+
}}
|
|
53
|
+
}}
|
|
54
|
+
}}
|
|
55
|
+
|
|
56
|
+
Task "run" {{
|
|
57
|
+
entry = function()
|
|
58
|
+
return {{ status = "ok" }}
|
|
59
|
+
end
|
|
60
|
+
}}
|
|
61
|
+
"""
|
|
62
|
+
|
|
63
|
+
temp_file = tempfile.NamedTemporaryFile(mode="w", suffix=".tac", delete=False)
|
|
64
|
+
temp_file.write(workflow_source)
|
|
65
|
+
temp_file.close()
|
|
66
|
+
context.lua_file = Path(temp_file.name)
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
@given("a task workflow with two retrievers")
|
|
70
|
+
def step_write_multi_retriever_workflow(context):
|
|
71
|
+
if not hasattr(context, "corpus_root"):
|
|
72
|
+
raise AssertionError("Corpus root not set for dependency workflow")
|
|
73
|
+
|
|
74
|
+
workflow_source = f"""local FilesystemCorpus = require("tactus.corpora.filesystem")
|
|
75
|
+
local TfVector = require("tactus.retrievers.tf_vector")
|
|
76
|
+
|
|
77
|
+
miami_afd = FilesystemCorpus.Corpus {{
|
|
78
|
+
root = "{context.corpus_root.as_posix()}"
|
|
79
|
+
}}
|
|
80
|
+
|
|
81
|
+
miami_search = TfVector.Retriever {{
|
|
82
|
+
corpus = miami_afd,
|
|
83
|
+
configuration = {{
|
|
84
|
+
pipeline = {{
|
|
85
|
+
query = {{
|
|
86
|
+
limit = 1,
|
|
87
|
+
maximum_total_characters = 2000
|
|
88
|
+
}}
|
|
89
|
+
}}
|
|
90
|
+
}}
|
|
91
|
+
}}
|
|
92
|
+
|
|
93
|
+
miami_search_two = TfVector.Retriever {{
|
|
94
|
+
corpus = miami_afd,
|
|
95
|
+
configuration = {{
|
|
96
|
+
pipeline = {{
|
|
97
|
+
query = {{
|
|
98
|
+
limit = 2,
|
|
99
|
+
maximum_total_characters = 2000
|
|
100
|
+
}}
|
|
101
|
+
}}
|
|
102
|
+
}}
|
|
103
|
+
}}
|
|
104
|
+
"""
|
|
105
|
+
|
|
106
|
+
temp_file = tempfile.NamedTemporaryFile(mode="w", suffix=".tac", delete=False)
|
|
107
|
+
temp_file.write(workflow_source)
|
|
108
|
+
temp_file.close()
|
|
109
|
+
context.lua_file = Path(temp_file.name)
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
@given("a task workflow with a load provider")
|
|
113
|
+
def step_write_load_provider_workflow(context):
|
|
114
|
+
if not hasattr(context, "corpus_root"):
|
|
115
|
+
raise AssertionError("Corpus root not set for dependency workflow")
|
|
116
|
+
|
|
117
|
+
marker_path = (Path(context.corpus_root) / "loaded.txt").as_posix()
|
|
118
|
+
workflow_source = f"""local FilesystemCorpus = require("tactus.corpora.filesystem")
|
|
119
|
+
local TfVector = require("tactus.retrievers.tf_vector")
|
|
120
|
+
local file = require("tactus.io.file")
|
|
121
|
+
|
|
122
|
+
miami_afd = FilesystemCorpus.Corpus {{
|
|
123
|
+
root = "{context.corpus_root.as_posix()}"
|
|
124
|
+
}}
|
|
125
|
+
|
|
126
|
+
miami_search = TfVector.Retriever {{
|
|
127
|
+
corpus = miami_afd,
|
|
128
|
+
configuration = {{
|
|
129
|
+
pipeline = {{
|
|
130
|
+
query = {{
|
|
131
|
+
limit = 1,
|
|
132
|
+
maximum_total_characters = 2000
|
|
133
|
+
}}
|
|
134
|
+
}}
|
|
135
|
+
}}
|
|
136
|
+
}}
|
|
137
|
+
|
|
138
|
+
Task "fetch" {{
|
|
139
|
+
provides = {{ kind = "load", corpus = "miami_afd" }},
|
|
140
|
+
entry = function()
|
|
141
|
+
file.write("{marker_path}", "loaded")
|
|
142
|
+
return {{ status = "loaded" }}
|
|
143
|
+
end
|
|
144
|
+
}}
|
|
145
|
+
|
|
146
|
+
Task "run" {{
|
|
147
|
+
entry = function()
|
|
148
|
+
return {{ status = "ok" }}
|
|
149
|
+
end
|
|
150
|
+
}}
|
|
151
|
+
"""
|
|
152
|
+
|
|
153
|
+
temp_file = tempfile.NamedTemporaryFile(mode="w", suffix=".tac", delete=False)
|
|
154
|
+
temp_file.write(workflow_source)
|
|
155
|
+
temp_file.close()
|
|
156
|
+
context.lua_file = Path(temp_file.name)
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
@given('I provide CLI input "{value}"')
|
|
160
|
+
def step_set_cli_input(context, value):
|
|
161
|
+
context.cli_input = f"{value}\n"
|
|
162
|
+
|
|
163
|
+
|
|
164
|
+
@then("an extraction snapshot should exist")
|
|
165
|
+
def step_assert_extraction_snapshot(context):
|
|
166
|
+
corpus_root = Path(context.corpus_root)
|
|
167
|
+
snapshots_root = corpus_root / ".biblicus" / "snapshots" / "extraction"
|
|
168
|
+
if not snapshots_root.exists():
|
|
169
|
+
raise AssertionError("Extraction snapshots directory missing")
|
|
170
|
+
|
|
171
|
+
manifests = list(snapshots_root.glob("**/manifest.json"))
|
|
172
|
+
assert manifests, "No extraction snapshot manifests found"
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
@then("a retrieval snapshot should exist")
|
|
176
|
+
def step_assert_retrieval_snapshot(context):
|
|
177
|
+
corpus_root = Path(context.corpus_root)
|
|
178
|
+
snapshots_root = corpus_root / ".biblicus" / "snapshots"
|
|
179
|
+
if not snapshots_root.exists():
|
|
180
|
+
raise AssertionError("Snapshots directory missing")
|
|
181
|
+
|
|
182
|
+
snapshot_files = [path for path in snapshots_root.glob("*.json") if path.is_file()]
|
|
183
|
+
assert snapshot_files, "No retrieval snapshot manifests found"
|
|
184
|
+
|
|
185
|
+
|
|
186
|
+
@then("at least {count:d} retrieval snapshots should exist")
|
|
187
|
+
def step_assert_retrieval_snapshot_count(context, count):
|
|
188
|
+
corpus_root = Path(context.corpus_root)
|
|
189
|
+
snapshots_root = corpus_root / ".biblicus" / "snapshots"
|
|
190
|
+
if not snapshots_root.exists():
|
|
191
|
+
raise AssertionError("Snapshots directory missing")
|
|
192
|
+
|
|
193
|
+
snapshot_files = [path for path in snapshots_root.glob("*.json") if path.is_file()]
|
|
194
|
+
assert (
|
|
195
|
+
len(snapshot_files) >= count
|
|
196
|
+
), f"Expected at least {count} retrieval snapshots, found {len(snapshot_files)}"
|
|
197
|
+
|
|
198
|
+
|
|
199
|
+
@then("the load marker should exist")
|
|
200
|
+
def step_assert_load_marker(context):
|
|
201
|
+
marker_path = Path(context.corpus_root) / "loaded.txt"
|
|
202
|
+
assert marker_path.exists(), f"Load marker not found: {marker_path}"
|
|
@@ -52,6 +52,11 @@ def main() -> None:
|
|
|
52
52
|
help="Snippet length budget for evidence text",
|
|
53
53
|
)
|
|
54
54
|
parser.add_argument("--force", action="store_true", help="Recreate the corpus directory")
|
|
55
|
+
parser.add_argument(
|
|
56
|
+
"--no-index",
|
|
57
|
+
action="store_true",
|
|
58
|
+
help="Only import items into the corpus (skip retriever snapshot build)",
|
|
59
|
+
)
|
|
55
60
|
args = parser.parse_args()
|
|
56
61
|
|
|
57
62
|
source_dir = _resolve_source_dir(args.source, args.wfo)
|
|
@@ -74,6 +79,11 @@ def main() -> None:
|
|
|
74
79
|
for path in (corpus_dir / "raw").rglob("*.biblicus.yml.biblicus.yml"):
|
|
75
80
|
path.unlink(missing_ok=True)
|
|
76
81
|
|
|
82
|
+
if args.no_index:
|
|
83
|
+
print(f"Corpus: {corpus_dir}")
|
|
84
|
+
print("Snapshot id: (skipped)")
|
|
85
|
+
return
|
|
86
|
+
|
|
77
87
|
configuration: dict[str, object] = {}
|
|
78
88
|
if args.retriever in {"embedding-index-file", "embedding-index-inmemory"}:
|
|
79
89
|
configuration["embedding_provider"] = {
|
|
@@ -505,6 +505,12 @@ def run(
|
|
|
505
505
|
real: Optional[list[str]] = typer.Option(
|
|
506
506
|
None, "--real", help="Use real implementation for specific tool(s)"
|
|
507
507
|
),
|
|
508
|
+
auto_deps: bool = typer.Option(
|
|
509
|
+
False, "--auto-deps", help="Automatically run dependency tasks without prompting"
|
|
510
|
+
),
|
|
511
|
+
no_deps: bool = typer.Option(
|
|
512
|
+
False, "--no-deps", help="Fail fast if dependency tasks are required"
|
|
513
|
+
),
|
|
508
514
|
sandbox: Optional[bool] = typer.Option(
|
|
509
515
|
None,
|
|
510
516
|
"--sandbox/--no-sandbox",
|
|
@@ -568,6 +574,15 @@ def run(
|
|
|
568
574
|
console.print(f"[red]Error:[/red] Workflow file not found: {workflow_file}")
|
|
569
575
|
raise typer.Exit(1)
|
|
570
576
|
|
|
577
|
+
if not isinstance(auto_deps, bool):
|
|
578
|
+
auto_deps = False
|
|
579
|
+
if not isinstance(no_deps, bool):
|
|
580
|
+
no_deps = False
|
|
581
|
+
|
|
582
|
+
if auto_deps and no_deps:
|
|
583
|
+
console.print("[red]Error:[/red] --auto-deps and --no-deps cannot be combined")
|
|
584
|
+
raise typer.Exit(1)
|
|
585
|
+
|
|
571
586
|
# Determine format based on extension
|
|
572
587
|
file_format = "lua" if workflow_file.suffix in [".tac", ".lua"] else "yaml"
|
|
573
588
|
|
|
@@ -808,6 +823,15 @@ def run(
|
|
|
808
823
|
tool_paths=tool_paths,
|
|
809
824
|
source_file_path=str(workflow_file),
|
|
810
825
|
)
|
|
826
|
+
runtime.dependency_mode = "auto" if auto_deps else "none" if no_deps else "prompt"
|
|
827
|
+
|
|
828
|
+
def _dependency_prompt_handler(plan, label: str) -> bool:
|
|
829
|
+
pending = [task.kind for task in plan.tasks if task.status != "complete"]
|
|
830
|
+
pending_summary = ", ".join(pending) if pending else "none"
|
|
831
|
+
console.print(f"[yellow]Dependencies required for {label}: {pending_summary}[/yellow]")
|
|
832
|
+
return typer.confirm("Run dependencies now?", default=False)
|
|
833
|
+
|
|
834
|
+
runtime.dependency_prompt_handler = _dependency_prompt_handler
|
|
811
835
|
|
|
812
836
|
# Always create a mock manager so Mocks {} blocks can register tool mocks.
|
|
813
837
|
from tactus.core.mocking import MockManager, set_current_mock_manager
|
|
@@ -413,6 +413,17 @@ def create_dsl_stubs(
|
|
|
413
413
|
# Task "name" { ... }
|
|
414
414
|
if isinstance(name_or_config, str):
|
|
415
415
|
task_name = name_or_config
|
|
416
|
+
if config is None:
|
|
417
|
+
|
|
418
|
+
def _curried(task_config=None):
|
|
419
|
+
if task_config is None or not hasattr(task_config, "items"):
|
|
420
|
+
raise TypeError(
|
|
421
|
+
f"Task '{task_name}' requires a configuration table. "
|
|
422
|
+
'Use: Task "name" { ... } or name = Task { ... }.'
|
|
423
|
+
)
|
|
424
|
+
return _task(task_name, task_config)
|
|
425
|
+
|
|
426
|
+
return _curried
|
|
416
427
|
task_config = config or {}
|
|
417
428
|
if hasattr(task_config, "__setitem__"):
|
|
418
429
|
try:
|
|
@@ -450,7 +461,13 @@ def create_dsl_stubs(
|
|
|
450
461
|
if hasattr(task_config, "items"):
|
|
451
462
|
child_tasks = {}
|
|
452
463
|
for key, value in task_config.items():
|
|
453
|
-
if isinstance(key, str) and hasattr(value, "items"):
|
|
464
|
+
if not (isinstance(key, str) and hasattr(value, "items")):
|
|
465
|
+
continue
|
|
466
|
+
try:
|
|
467
|
+
marker = value["__tactus_task_config"]
|
|
468
|
+
except Exception:
|
|
469
|
+
marker = False
|
|
470
|
+
if marker:
|
|
454
471
|
child_tasks[key] = value
|
|
455
472
|
if child_tasks:
|
|
456
473
|
try:
|