tactus 0.35.1__tar.gz → 0.37.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.35.1 → tactus-0.37.0}/.github/workflows/release.yml +5 -2
- {tactus-0.35.1 → tactus-0.37.0}/.gitignore +2 -0
- {tactus-0.35.1 → tactus-0.37.0}/CHANGELOG.md +24 -0
- {tactus-0.35.1 → tactus-0.37.0}/PKG-INFO +11 -5
- {tactus-0.35.1 → tactus-0.37.0}/pyproject.toml +16 -7
- {tactus-0.35.1 → tactus-0.37.0}/tactus/__init__.py +1 -1
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/base.py +20 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/broker.py +1 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/host.py +3 -1
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/ipc.py +18 -3
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/sse.py +13 -5
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/control_loop.py +44 -30
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/mcp_manager.py +24 -7
- {tactus-0.35.1 → tactus-0.37.0}/tactus/backends/http_backend.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus/backends/pytorch_backend.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus/broker/client.py +3 -3
- {tactus-0.35.1 → tactus-0.37.0}/tactus/broker/server.py +17 -5
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/dsl_stubs.py +3 -3
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/execution_context.py +32 -27
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/lua_sandbox.py +42 -34
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/message_history_manager.py +51 -28
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/output_validator.py +65 -51
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/registry.py +29 -29
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/runtime.py +69 -61
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/broker_lm.py +13 -7
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/config.py +7 -4
- {tactus-0.35.1 → tactus-0.37.0}/tactus/ide/server.py +63 -33
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/host.py +19 -16
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/message_history.py +11 -14
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/model.py +1 -1
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/procedure.py +11 -8
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/session.py +9 -9
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/state.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/tool_handle.py +27 -24
- {tactus-0.35.1 → tactus-0.37.0}/tactus/sandbox/container_runner.py +11 -6
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/context.py +6 -6
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/evaluation_runner.py +5 -5
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/mock_hitl.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/models.py +2 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/steps/builtin.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/test_runner.py +6 -4
- {tactus-0.35.1 → tactus-0.37.0}/tactus/utils/asyncio_helpers.py +2 -1
- {tactus-0.35.1 → tactus-0.37.0}/tactus/utils/safe_libraries.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/backend/tactus_backend.spec +4 -1
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/events.py +5 -2
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_base_channel.py +5 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_host_channel.py +12 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_ipc_channel.py +2 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_sse_channel.py +13 -15
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_control_loop.py +66 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_mcp_manager.py +2 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_integration.py +3 -2
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_additional.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_helpers.py +3 -3
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_unit.py +1 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_utils.py +2 -2
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_stdio_transport.py +22 -4
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_tcp_integration.py +5 -4
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_brokered_lm_unit.py +6 -4
- {tactus-0.35.1 → tactus-0.37.0}/tests/conftest.py +2 -1
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_agent_execution.py +5 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/fixtures/test_mcp_server.py +4 -1
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_run_stream.py +177 -2
- {tactus-0.35.1 → tactus-0.37.0}/tests/test_mcp_integration.py +9 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_all_examples.py +10 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_dataset.py +1 -1
- tactus-0.37.0/tests/utils/test_asyncio_helpers.py +50 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/utils/test_safe_file_library.py +0 -1
- tactus-0.35.1/coverage.json +0 -1
- {tactus-0.35.1 → tactus-0.37.0}/.claude/agents.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/.coveragerc +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/.tactus/config.yml.example +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/AGENTS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/CHANGES_SUMMARY.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/CHECKPOINT_RESUME_PLAN.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/CURRENT_STATUS_AND_NEXT_STEPS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/DETERMINISTIC_REQUEST_ID_FIX.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/EXECUTION_TRACE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/IMPLEMENTATION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/LICENSE +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/Makefile +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/PHASE0_IPC_CHANNEL_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/PHASE2_INTEGRATION_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/PHASE3_IDE_HITL_INTEGRATION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/SPECIFICATION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/TECHNICAL_DEBT.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/behave.ini +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/coverage_badge.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/AGENTS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/BDD_TESTING.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/CONFIGURATION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/CONTROL_LOOP_PHASE1_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/DURABILITY.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/FILE_IO.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/MANUAL_CHECKPOINT_TESTING.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/OMNICHANNEL_HITL_PLAN.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/SANDBOXING.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/STREAMING.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/TOOLS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/TOOL_ROADMAP.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/archive/CHECKPOINT_RESUME_STATUS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/archive/CHECKPOINT_TESTING_PLAN.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/archive/CONTROL_LOOP_INTEGRATION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/archive/HITL_CHECKPOINT_FIX_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/archive/HITL_FIX_SUMMARY.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/archive/LLM_CHECKPOINTING_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs/development-mode.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs_output/classify.html +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/docs_output/index.html +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/.tactus/config.yml +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/.tactus/config.yml.example +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/01-basics-hello-world.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/02-basics-simple-logic.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/03-basics-parameters.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/04-basics-simple-agent.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/05-basics-multi-model.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/06-basics-streaming.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/07-basics-bedrock.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/08-basics-models.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/09-basics-google-gemini.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/10-feature-state.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/11-feature-message-history-transforms.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/11-feature-message-history.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/12-feature-structured-output.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/13-feature-session.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/14-feature-per-turn-tools-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/14-feature-per-turn-tools.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/15-feature-local-tools.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/16-feature-toolsets-advanced.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/17-feature-toolsets-dsl.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/18-feature-lua-tools-individual.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/18-feature-lua-tools-inline.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/18-feature-lua-tools-toolset.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/19-feature-direct-tool-calls.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/20-bdd-complete.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/21-bdd-passing.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/22-bdd-fuzzy-matching.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/30-eval-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/31-eval-demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/32-eval-success-rate.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/33-eval-thresholds.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/34-eval-dataset.jsonl +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/34-eval-dataset.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/35-eval-trace.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/36-eval-advanced.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/37-eval-comprehensive.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/39-model-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/40-mcp-test.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/40-model-text-classifier.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/41-mcp-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/41-model-pytorch.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/43-sub-procedure-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/44-sub-procedure-composition.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/45-sub-procedure-recursive.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/46-checkpoint-explicit.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/47-checkpoint-expensive-ops.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/48-script-mode-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/50-inputs-showcase.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/51-inputs-calculator.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/52-file-io-basics.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/53-tsv-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/54-json-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/55-parquet-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/56-hdf5-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/57-excel-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/58-text-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/60-tool-sources.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/61-inline-toolset-lua.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/62-mcp-toolset-by-server.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/63-toolset-import-from-file.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/64-require-modules.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/65-optional-state-demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/66-host-tools-via-broker.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/67-host-tool-source.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/70-mocking-static.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/71-mocking-temporal.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/72-mocking-conditional.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/90-hitl-debug.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/90-hitl-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/90-hitl-test-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/90-hitl-ultra-debug.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/90-super-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/90-test-params.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/91-control-loop-demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/92-test-inputs-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/92-test-inputs.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/92-test-multiple.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/93-test-ide-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/93-test-individual-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/93-test-input-summary.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/94-test-custom-components.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/95-agent-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/99-misc-test-loading.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/agent_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/app_config.ini +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/classify_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/data/sample.csv +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/demo_output.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/fuzzy_matching_demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/fuzzy_matching_demo_simple_spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/fuzzy_simple_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/helpers/math_module.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/helpers/product.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/helpers/string_module.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/helpers/sum.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/helpers/text_tools.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/hitl_toolset.lua +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/inventory_summary.tsv +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/llm_classify_binary.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/llm_classify_multiclass.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/llm_classify_with_metadata.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/mock-config.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/models/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/models/create_sentiment_model.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/output_summary.txt +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-raw-module.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-raw-streaming.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-basic.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-hitl-types.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-many-checkpoints.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-mixed.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-multi-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-resume-timeout.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-temperature-multi-calls.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/test-temperature-variation.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/tools/calculations.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/tools/data_analysis.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/tools/search.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/with_dependencies/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/with_dependencies/simple_http_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/examples/with_dependencies/time_lookup.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/01_state_management.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/02_checkpointing.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/03_human_in_the_loop.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/04_control_flow.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/05_tool_integration.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/06_retry_logic.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/07_file_operations.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/08_agent_primitives.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/09_workflow_execution.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/10_lua_integration.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/11_storage_backends.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/12_json_operations.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/13_logging.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/15_procedure_calls.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/16_session_management.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/17_lua_dsl_validation.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/18_example_procedures.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/19_ide_server.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/20_parameters.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/21_outputs.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/23_prompts.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/24_bdd_specifications.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/25_bdd_custom_steps.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/26_bdd_evaluation.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/27_default_settings.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/28_custom_prompts.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/29_execution_settings.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/30_session_filters.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/31_matchers.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/32_result_object.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/33_output_type.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/42_model_primitive.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/43_sub_procedure_checkpointing.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/46_explicit_checkpoint.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/48_script_mode.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/51_dspy_lm_config.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/52_dspy_signature.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/53_dspy_module.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/54_dspy_history.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/55_dspy_prediction.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/56_dspy_agent.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/57_chat_assistant.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/60_formatting.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/61_classify_primitive.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/61_cli_run_exit_codes.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/62_cli_info.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/67_message_history_transforms.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/68_ide_file_tools.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/69_ide_assistant_service.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/70_ide_chat_api.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/71_ide_config_api.feature +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/documentation/IDE_SERVER_BEHAVIOR.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/documentation/Lua DSL/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/environment.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/agent_primitives_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/chat_assistant_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/checkpointing_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/classify_primitive_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/cli_info_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/cli_run_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/control_flow_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/dspy_agent_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/dspy_history_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/dspy_lm_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/dspy_module_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/dspy_prediction_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/dspy_signature_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/example_procedures_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/file_operations_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/formatting_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/human_in_the_loop_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/ide_assistant_service_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/ide_chat_api_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/ide_config_api_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/ide_file_tools_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/ide_server_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/json_operations_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/logging_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/lua_dsl_validation_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/lua_integration_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/mocking_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/procedure_calls_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/result_and_output_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/retry_logic_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/session_management_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/state_management_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/storage_backend_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/support/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/support/harnesses.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/tool_integration_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/features/steps/workflow_execution_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/planning/BROKER_AND_TOOL_RUNNERS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/planning/CONVERSATION_HISTORY_TRANSFORMS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/planning/FORMATTER.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/scripts/audit_examples_mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/scripts/convert_examples.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/scripts/run_coverage.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/scripts/run_precommit_suite.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/scripts/timeout.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/start-web-ide.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/broker_log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/channels/cli.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/cli_hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/cli_log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/cost_collector_log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/file_storage.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/http_callback_log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/ide_log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/lua_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/mcp.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/memory.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/adapters/plugins.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/backends/model_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/broker/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/broker/protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/broker/stdio.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/cli/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/cli/app.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/cli/commands/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/cli/control.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/config_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/dependencies/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/dependencies/registry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/exceptions.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/template_resolver.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/core/yaml_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docker/Dockerfile +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docker/Dockerfile.pypi +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docker/entrypoint.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/extractor.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/html_renderer.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/templates/base.html +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/templates/index.html +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/docs/templates/module.html +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/agent.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/history.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/module.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/prediction.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/dspy/signature.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/formatting/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/formatting/formatter.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/ide/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/ide/coding_assistant.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/ide/config_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/control.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/file.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/handles.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/human.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/json.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/procedure_callable.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/retry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/step.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/system.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/tool.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/primitives/toolset.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/chat_recorder.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/config.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/control.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/cost.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/log_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/notification.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/result.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/protocols/storage.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/providers/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/providers/base.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/providers/bedrock.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/providers/google.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/providers/openai.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/sandbox/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/sandbox/config.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/sandbox/docker_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/sandbox/entrypoint.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/sandbox/protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/classify/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/classify/classify.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/classify/classify.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/classify/fuzzy.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/classify/llm.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/classify/primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/core/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/core/base.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/core/confidence.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/core/models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/core/retry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/core/validation.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/extract/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/extract/llm.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/extract/primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/csv.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/excel.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/file.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/fs.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/hdf5.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/json.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/parquet.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/io/tsv.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/loader.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/classify/base.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/classify/fuzzy.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/classify/index.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/classify/init.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/classify/llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/classify.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/extract/base.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/extract/index.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/extract/init.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/extract/llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/extract.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/generate/base.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/generate/index.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/generate/init.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/generate/llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/generate.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/tools/done.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/stdlib/tac/tactus/tools/log.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/behave_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/eval_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/evaluators.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/events.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/gherkin_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/mock_agent.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/mock_dependencies.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/mock_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/mock_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/pydantic_eval_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/steps/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/steps/custom.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/testing/steps/registry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/tracing/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/tracing/trace_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/utils/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/utils/cost_calculator.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/utils/model_pricing.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/utils/safe_file_library.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/LuaLexerBase.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/LuaParserBase.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/error_listener.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaLexer.interp +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaLexer.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaLexer.tokens +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaLexerBase.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaParser.interp +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaParser.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaParser.tokens +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaParserBase.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/LuaParserVisitor.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/generated/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/grammar/LuaLexer.g4 +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/grammar/LuaParser.g4 +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/semantic_visitor.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus/validation/validator.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/.gitignore +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/BUILD_GUIDE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/DISTRIBUTION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/ELECTRON_INTEGRATION.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/RUN_ELECTRON.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/SETUP_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/backend/hook-lupa.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/package-lock.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/package.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/preload/preload.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/preload/tsconfig.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/rebuild-and-test.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/resources/app-icon.icns +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/resources/app-icon.ico +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/resources/app-icon.png +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/scripts/build-backend.mjs +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/scripts/build-frontend.mjs +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/scripts/generate-icons.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/scripts/test-ci-build.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/src/backend-manager.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/src/main.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/src/menu.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/src/preferences-window.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-desktop/tsconfig.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/ARCHITECTURE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/CHANGELOG.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/DEV_MODE.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/QUICK_START.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/RESTART_INSTRUCTIONS.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/TROUBLESHOOTING.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/assistant_service.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/assistant_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/chat_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/config_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/logging_capture.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/lsp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/requirements.txt +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/tactus_lsp_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/backend/text_editor_tool.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/dev.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/.storybook/main.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/.storybook/preview.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/.storybook/vitest.setup.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/README.md +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/components.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/demo.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/index.html +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/jest.config.js +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/package-lock.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/package.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/postcss.config.js +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/App.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/Editor.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/LSPClient.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/LSPClientHTTP.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/TactusLanguage.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/commands/registry.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/AboutDialog.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/AuthErrorDialog.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ChatSidebar.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/CheckpointSummary.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/CollapsibleRun.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/Duration.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/Duration.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/FileTree.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/FileTree.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/MessageFeed.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/PreferencesView.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ProcedureInputsDisplay.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ProcedureInputsDisplay.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ProcedureInputsModal.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ProcedureInputsModal.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ProcedureTab.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ProcedureTab.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ResizeHandle.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ResultsSidebar.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ResultsSidebar.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/TestOptionsModal.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/Timestamp.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/Timestamp.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/TopMenuBar.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ai-elements/confirmation.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/chat/ChatInterface.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/chat/MessageInput.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/chat/MessageList.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/CheckpointDetails.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/CheckpointDetails.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/CheckpointList.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/CheckpointList.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/DebuggerPanel.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/DebuggerPanel.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/RunSelector.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/RunSelector.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/StatisticsPanel.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/debugger/StatisticsPanel.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/AgentStreamingComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/BaseEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/CheckpointEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/CollapsibleTestScenario.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ContainerStatusEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/CostEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/CostEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/EvaluationEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/EvaluationEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/EventRenderer.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ExecutionEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ExecutionEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ExecutionSummaryEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ExecutionSummaryEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/HITLEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/HITLEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/LoadingEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/LoadingEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/LogCluster.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/LogEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/LogEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/OutputEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/OutputEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/TestEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/TestEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/TestProgressContainer.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ToolCallEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ValidationEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/events/ValidationEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/registry.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/ApprovalComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/InputComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/SelectComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/index.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/index.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/selectors/ImageSelectorComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/standard-library/selectors/index.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/hitl/types.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/AgentsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/EvaluationsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/MetadataSections.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/OutputsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/ParametersSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/SpecificationsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/StagesSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/metadata/ToolsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/preferences/ConfigFieldView.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/preferences/SourceBadge.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/preferences/YamlCodeEditor.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/scenarios/EvaluateScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/scenarios/RunScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/scenarios/TestScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/scenarios/ValidationScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/theme-provider.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/ai/conversation.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/ai/message.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/ai/prompt-input.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/alert.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/badge.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/button.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/dialog.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/dropdown-menu.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/input.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/label.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/logo.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/logo.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/menubar.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/scroll-area.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/select.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/separator.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/switch.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/tabs.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/components/ui/tooltip.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/hooks/useChatSSE.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/hooks/useEventStream.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/hooks/useTracing.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/index.css +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/lib/utils.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/main.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/types/events.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/types/metadata.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/types/preferences.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/types/results.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/types/tracing.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/utils/clipboard.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/utils/runExport.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/utils/yamlSync.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/validation/TactusValidator.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/validation/generated/LuaParser.interp +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/validation/generated/LuaParser.tokens +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/validation/types.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/src/vite-env.d.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/tailwind.config.js +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/tests/runExport.test.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/tsconfig.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/tsconfig.node.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/vendor/tactus-hitl-components/package.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/vendor/tactus-hitl-components/src/index.tsx +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/vendor/tactus-hitl-components/src/styles.css +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/vite.config.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/frontend/vitest.shims.d.ts +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/package.json +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tactus-ide/start-dev.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/test-ci.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/test_classify_loading.tac +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/test_run_inputs.sh +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_broker_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_channels_init.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/channels/test_cli_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_broker_log.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_cli_hitl_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_cli_log_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_file_storage.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_log_handlers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_lua_tools_adapter.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_mcp_adapter.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_memory_storage.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/adapters/test_plugins.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/backends/test_http_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/backends/test_pytorch_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_client_extra.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_client_unit.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_host_tool_source.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_anyio_handlers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_asyncio_handlers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_server_connection.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/broker/test_broker_tcp_unit.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_app_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_app_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_app_inputs.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_app_run.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_app_sandbox.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_config_loading.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_control_main.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_display_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_format_info.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_ide_main.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_input_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_inputs.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_logging.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_main_entry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_run_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_sandbox_validate.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_stdlib_control.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_test_eval_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_cli_trace_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_control_cli.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_sandbox_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_validate_command.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/cli/test_version_command.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/dependencies/test_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_config_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_determinism_safety.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_dsl_stubs_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_dsl_stubs_minimal.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_dsl_stubs_utils.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_execution_context.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_lua_sandbox_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_lua_sandbox_security.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_message_history_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_output_validator.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_registry_builder_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_dependencies.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_enhance_handles.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_execute_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_execute_workflow.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_init.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_inject_primitives.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_inputs.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_named_procedures.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_output_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_setup_agents_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_setup_agents_tools_output.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_templates.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_tool_source.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_runtime_toolsets.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_script_mode.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_template_resolver.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/core/test_yaml_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/docs/test_docs_extractor.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/docs/test_docs_init.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/docs/test_docs_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/docs/test_html_renderer.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_agent_handle.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_agent_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_agent_mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_agent_utilities.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_broker_lm.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_config.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_config_utilities.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_history.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_mock_field_normalization.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_module_parameter.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_module_utilities.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_prediction_messages.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_signature.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/dspy/test_streaming.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/fixtures/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/fixtures/brave_search_mcp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/fixtures/filesystem_mcp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_assistant_service.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_assistant_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_chat_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_coding_assistant.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_config_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_config_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_config_server_api.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_events.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_basics.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_error_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_hitl_chat_stream.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_lsp_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_lsp_chat.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_metadata.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_misc.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_stream_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_stream_failures.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_stream_success.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_trace_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_traces.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_ide_server_validate.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_logging_capture.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_lsp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_tactus_lsp_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/ide_backend/test_text_editor_tool.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/integration/test_named_procedures.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/mocks/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/mocks/llm_mocks.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_checkpoint_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_control_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_file_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_handles.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_host_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_human_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_json_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_log_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_message_history_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_model_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_procedure_callable.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_procedure_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_retry_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_session_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_state_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_step_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_system_alert.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_system_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_tool_handle.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_tool_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_toolset_dsl.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/primitives/test_toolset_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/protocols/test_protocol_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/protocols/test_protocol_stubs.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/protocols/test_protocols_misc.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/protocols/test_storage_protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/providers/test_provider_configurations.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/providers/test_providers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_config.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_container_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_container_runner_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_container_runner_run_container.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_docker_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_docker_sandbox_smoke.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_entrypoint.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/sandbox/test_protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/test_classify_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/test_fuzzy_algorithms.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/test_fuzzy_classifier.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/test_fuzzy_demo.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/test_fuzzy_import_error.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/classify/test_llm_classifier_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/core/test_base.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/core/test_confidence.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/core/test_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/core/test_retry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/core/test_validation.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/extract/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/extract/test_extract_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/extract/test_llm_extractor.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_excel.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_excel_parquet_hdf5.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_file.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_file_csv_tsv.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_fs.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_hdf5.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_import_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/io/test_serializers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/test_loader.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/stdlib/test_require_python.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/test_checkpoints_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/test_formatter.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/test_tracing.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/conftest.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_behave_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_behave_integration_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_builtin_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_builtin_steps_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_builtin_steps_regex.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_agent_mocks.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_capture.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_edge_cases.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_fallbacks.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_internals.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_missing_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_context_run_wrapper.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_custom_steps_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_custom_steps_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_e2e.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_eval_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluation_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluation_runner_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluation_runner_edges.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluators.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluators_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluators_import_error.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluators_more.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_evaluators_traceaware.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_gherkin_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_gherkin_parser_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_agent.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_agent_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_dependencies.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_dependencies_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_registry_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_mock_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_models.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_import_error.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_loaders.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_task.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_thresholds.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_pydantic_eval_runner_trace.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_runtime_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_step_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_test_runner_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_test_runner_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_test_runner_run.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/testing/test_test_runner_statuses.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/tracing/test_trace_manager_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/utils/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/utils/test_cost_calculator.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/utils/test_model_pricing.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/utils/test_safe_file_library_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/utils/test_safe_libraries.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_semantic_visitor.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_semantic_visitor_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_semantic_visitor_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_semantic_visitor_more.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_tool_curried_syntax_disallowed.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_validator_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.37.0}/tests/validation/test_validator_helpers.py +0 -0
|
@@ -13,8 +13,11 @@ permissions:
|
|
|
13
13
|
|
|
14
14
|
jobs:
|
|
15
15
|
quality-checks:
|
|
16
|
-
name: Quality Checks
|
|
16
|
+
name: Quality Checks (Python ${{ matrix.python-version }})
|
|
17
17
|
runs-on: ubuntu-latest
|
|
18
|
+
strategy:
|
|
19
|
+
matrix:
|
|
20
|
+
python-version: ['3.9', '3.10', '3.11', '3.12']
|
|
18
21
|
|
|
19
22
|
steps:
|
|
20
23
|
- name: Checkout code
|
|
@@ -25,7 +28,7 @@ jobs:
|
|
|
25
28
|
- name: Set up Python
|
|
26
29
|
uses: actions/setup-python@v5
|
|
27
30
|
with:
|
|
28
|
-
python-version:
|
|
31
|
+
python-version: ${{ matrix.python-version }}
|
|
29
32
|
cache: 'pip'
|
|
30
33
|
|
|
31
34
|
- name: Install dependencies
|
|
@@ -2,6 +2,30 @@
|
|
|
2
2
|
|
|
3
3
|
<!-- version list -->
|
|
4
4
|
|
|
5
|
+
## v0.37.0 (2026-02-01)
|
|
6
|
+
|
|
7
|
+
### Bug Fixes
|
|
8
|
+
|
|
9
|
+
- Export BaseExceptionGroup
|
|
10
|
+
([`6391e98`](https://github.com/AnthusAI/Tactus/commit/6391e98eca65b359994970820e04b68a5c16a295))
|
|
11
|
+
|
|
12
|
+
- Stabilize mcp manager tests
|
|
13
|
+
([`4d9a695`](https://github.com/AnthusAI/Tactus/commit/4d9a695163ca62478994a1de27a186c98be09cd2))
|
|
14
|
+
|
|
15
|
+
### Features
|
|
16
|
+
|
|
17
|
+
- Support python 3.9
|
|
18
|
+
([`bcbdd60`](https://github.com/AnthusAI/Tactus/commit/bcbdd606b1c12abad0337fbe15b44c801a0c67b8))
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
## v0.36.0 (2026-01-31)
|
|
22
|
+
|
|
23
|
+
### Features
|
|
24
|
+
|
|
25
|
+
- Test CI on supported Python versions
|
|
26
|
+
([`37c1791`](https://github.com/AnthusAI/Tactus/commit/37c1791810690e26965415046fee02351415eeb5))
|
|
27
|
+
|
|
28
|
+
|
|
5
29
|
## v0.35.1 (2026-01-31)
|
|
6
30
|
|
|
7
31
|
### Bug Fixes
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: tactus
|
|
3
|
-
Version: 0.
|
|
3
|
+
Version: 0.37.0
|
|
4
4
|
Summary: Tactus: Lua-based DSL for agentic workflows
|
|
5
5
|
Project-URL: Homepage, https://github.com/AnthusAI/Tactus
|
|
6
6
|
Project-URL: Documentation, https://github.com/AnthusAI/Tactus/tree/main/docs
|
|
@@ -14,26 +14,32 @@ Classifier: Development Status :: 3 - Alpha
|
|
|
14
14
|
Classifier: Intended Audience :: Developers
|
|
15
15
|
Classifier: License :: OSI Approved :: MIT License
|
|
16
16
|
Classifier: Programming Language :: Python :: 3
|
|
17
|
+
Classifier: Programming Language :: Python :: 3.9
|
|
18
|
+
Classifier: Programming Language :: Python :: 3.10
|
|
17
19
|
Classifier: Programming Language :: Python :: 3.11
|
|
18
20
|
Classifier: Programming Language :: Python :: 3.12
|
|
19
21
|
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
|
|
20
22
|
Classifier: Topic :: Software Development :: Libraries :: Python Modules
|
|
21
|
-
Requires-Python: >=3.
|
|
23
|
+
Requires-Python: >=3.9
|
|
22
24
|
Requires-Dist: antlr4-python3-runtime==4.13.1
|
|
23
25
|
Requires-Dist: behave>=1.2.6
|
|
24
26
|
Requires-Dist: boto3>=1.28.0
|
|
25
|
-
Requires-Dist: dotyaml>=0.1.
|
|
27
|
+
Requires-Dist: dotyaml>=0.1.4
|
|
26
28
|
Requires-Dist: dspy>=2.5
|
|
27
29
|
Requires-Dist: flask-cors>=4.0.0
|
|
28
30
|
Requires-Dist: flask>=3.0.0
|
|
29
31
|
Requires-Dist: gherkin-official>=28.0.0
|
|
30
32
|
Requires-Dist: h5py>=3.10
|
|
31
33
|
Requires-Dist: jinja2>=3.0
|
|
34
|
+
Requires-Dist: litellm>=1.81.5
|
|
35
|
+
Requires-Dist: logfire>=4.20.0
|
|
32
36
|
Requires-Dist: lupa>=2.6
|
|
33
37
|
Requires-Dist: markdown>=3.0
|
|
34
38
|
Requires-Dist: nanoid>=2.0.0
|
|
35
39
|
Requires-Dist: nest-asyncio>=1.5.0
|
|
36
40
|
Requires-Dist: openpyxl>=3.1
|
|
41
|
+
Requires-Dist: opentelemetry-api>=1.39.1
|
|
42
|
+
Requires-Dist: opentelemetry-sdk>=1.39.1
|
|
37
43
|
Requires-Dist: pyarrow>=14.0
|
|
38
44
|
Requires-Dist: pydantic-ai-slim[bedrock,evals]
|
|
39
45
|
Requires-Dist: pydantic>=2.0
|
|
@@ -44,9 +50,9 @@ Requires-Dist: typer
|
|
|
44
50
|
Provides-Extra: dev
|
|
45
51
|
Requires-Dist: antlr4-tools>=0.2.1; extra == 'dev'
|
|
46
52
|
Requires-Dist: behave>=1.2.6; extra == 'dev'
|
|
47
|
-
Requires-Dist: black==
|
|
53
|
+
Requires-Dist: black==24.10.0; extra == 'dev'
|
|
48
54
|
Requires-Dist: coverage>=7.4; extra == 'dev'
|
|
49
|
-
Requires-Dist: fastmcp>=2.3.5; extra == 'dev'
|
|
55
|
+
Requires-Dist: fastmcp>=2.3.5; (python_version >= '3.10') and extra == 'dev'
|
|
50
56
|
Requires-Dist: pytest-asyncio>=0.23; extra == 'dev'
|
|
51
57
|
Requires-Dist: pytest-xdist>=3.0; extra == 'dev'
|
|
52
58
|
Requires-Dist: pytest>=8.0; extra == 'dev'
|
|
@@ -4,10 +4,10 @@ build-backend = "hatchling.build"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "tactus"
|
|
7
|
-
version = "0.
|
|
7
|
+
version = "0.37.0"
|
|
8
8
|
description = "Tactus: Lua-based DSL for agentic workflows"
|
|
9
9
|
readme = "README.md"
|
|
10
|
-
requires-python = ">=3.
|
|
10
|
+
requires-python = ">=3.9"
|
|
11
11
|
license = {text = "MIT"}
|
|
12
12
|
authors = [
|
|
13
13
|
{name = "Anthus", email = "info@anthus.ai"}
|
|
@@ -18,6 +18,8 @@ classifiers = [
|
|
|
18
18
|
"Intended Audience :: Developers",
|
|
19
19
|
"License :: OSI Approved :: MIT License",
|
|
20
20
|
"Programming Language :: Python :: 3",
|
|
21
|
+
"Programming Language :: Python :: 3.9",
|
|
22
|
+
"Programming Language :: Python :: 3.10",
|
|
21
23
|
"Programming Language :: Python :: 3.11",
|
|
22
24
|
"Programming Language :: Python :: 3.12",
|
|
23
25
|
"Topic :: Software Development :: Libraries :: Python Modules",
|
|
@@ -29,11 +31,15 @@ dependencies = [
|
|
|
29
31
|
"pyyaml",
|
|
30
32
|
"pydantic>=2.0",
|
|
31
33
|
"pydantic-ai-slim[bedrock,evals]",
|
|
34
|
+
"logfire>=4.20.0",
|
|
35
|
+
"litellm>=1.81.5",
|
|
36
|
+
"opentelemetry-api>=1.39.1",
|
|
37
|
+
"opentelemetry-sdk>=1.39.1",
|
|
32
38
|
# NOTE: We use LiteLLM (via DSPy) for all LLM calls - do not add provider-specific SDKs
|
|
33
39
|
"boto3>=1.28.0",
|
|
34
40
|
"rich>=13.9.4",
|
|
35
41
|
"typer",
|
|
36
|
-
"dotyaml>=0.1.
|
|
42
|
+
"dotyaml>=0.1.4",
|
|
37
43
|
"antlr4-python3-runtime==4.13.1",
|
|
38
44
|
"behave>=1.2.6",
|
|
39
45
|
"gherkin-official>=28.0.0",
|
|
@@ -61,11 +67,11 @@ dev = [
|
|
|
61
67
|
"pytest-xdist>=3.0",
|
|
62
68
|
"behave>=1.2.6",
|
|
63
69
|
"coverage>=7.4",
|
|
64
|
-
"black==
|
|
70
|
+
"black==24.10.0",
|
|
65
71
|
"ruff",
|
|
66
72
|
"python-semantic-release>=9.0.0",
|
|
67
73
|
"antlr4-tools>=0.2.1",
|
|
68
|
-
"fastmcp>=2.3.5",
|
|
74
|
+
"fastmcp>=2.3.5; python_version >= '3.10'",
|
|
69
75
|
]
|
|
70
76
|
# Notification channel optional dependencies
|
|
71
77
|
slack = [
|
|
@@ -109,14 +115,17 @@ markers = [
|
|
|
109
115
|
"docker: Requires a running Docker daemon (opt-in; see TACTUS_RUN_DOCKER_TESTS)",
|
|
110
116
|
"xdist_group: pytest-xdist grouping marker",
|
|
111
117
|
]
|
|
118
|
+
filterwarnings = [
|
|
119
|
+
"ignore:(?s).*DETERMINISM WARNING.*File\\.read\\(\\).*:UserWarning",
|
|
120
|
+
]
|
|
112
121
|
|
|
113
122
|
[tool.black]
|
|
114
123
|
line-length = 100
|
|
115
|
-
target-version = ['
|
|
124
|
+
target-version = ['py39']
|
|
116
125
|
|
|
117
126
|
[tool.ruff]
|
|
118
127
|
line-length = 100
|
|
119
|
-
target-version = "
|
|
128
|
+
target-version = "py39"
|
|
120
129
|
|
|
121
130
|
[tool.ruff.lint.per-file-ignores]
|
|
122
131
|
"features/steps/*.py" = ["F811"] # Allow step_impl redefinition in behave steps
|
|
@@ -9,7 +9,7 @@ requiring separate processes (e.g., Discord WebSocket gateway).
|
|
|
9
9
|
import asyncio
|
|
10
10
|
import logging
|
|
11
11
|
from abc import ABC, abstractmethod
|
|
12
|
-
from typing import AsyncIterator
|
|
12
|
+
from typing import AsyncIterator, Optional
|
|
13
13
|
|
|
14
14
|
from tactus.protocols.control import (
|
|
15
15
|
ControlRequest,
|
|
@@ -54,7 +54,20 @@ class InProcessChannel(ABC):
|
|
|
54
54
|
|
|
55
55
|
def __init__(self):
|
|
56
56
|
"""Initialize the channel with an internal response queue."""
|
|
57
|
-
self._response_queue: asyncio.Queue[ControlResponse] =
|
|
57
|
+
self._response_queue: Optional[asyncio.Queue[ControlResponse]] = None
|
|
58
|
+
self._shutdown_event: Optional[asyncio.Event] = None
|
|
59
|
+
|
|
60
|
+
def _ensure_asyncio_primitives(self) -> None:
|
|
61
|
+
if self._response_queue is not None and self._shutdown_event is not None:
|
|
62
|
+
return
|
|
63
|
+
try:
|
|
64
|
+
asyncio.get_running_loop()
|
|
65
|
+
except RuntimeError as error:
|
|
66
|
+
raise RuntimeError(
|
|
67
|
+
"InProcessChannel requires a running event loop before use. "
|
|
68
|
+
"Initialize it from within an async context."
|
|
69
|
+
) from error
|
|
70
|
+
self._response_queue = asyncio.Queue()
|
|
58
71
|
self._shutdown_event = asyncio.Event()
|
|
59
72
|
|
|
60
73
|
@property
|
|
@@ -105,6 +118,7 @@ class InProcessChannel(ABC):
|
|
|
105
118
|
Yields:
|
|
106
119
|
ControlResponse as they are received
|
|
107
120
|
"""
|
|
121
|
+
self._ensure_asyncio_primitives()
|
|
108
122
|
while not self._shutdown_event.is_set():
|
|
109
123
|
try:
|
|
110
124
|
# Use wait_for with timeout to check shutdown periodically
|
|
@@ -149,6 +163,7 @@ class InProcessChannel(ABC):
|
|
|
149
163
|
Override for additional cleanup (close connections, etc.).
|
|
150
164
|
"""
|
|
151
165
|
logger.info("%s: shutting down", self.channel_id)
|
|
166
|
+
self._ensure_asyncio_primitives()
|
|
152
167
|
self._shutdown_event.set()
|
|
153
168
|
|
|
154
169
|
def push_response(self, response: ControlResponse) -> None:
|
|
@@ -164,6 +179,7 @@ class InProcessChannel(ABC):
|
|
|
164
179
|
response: ControlResponse to add to queue
|
|
165
180
|
"""
|
|
166
181
|
try:
|
|
182
|
+
self._ensure_asyncio_primitives()
|
|
167
183
|
self._response_queue.put_nowait(response)
|
|
168
184
|
except Exception as error:
|
|
169
185
|
logger.error("%s: failed to queue response: %s", self.channel_id, error)
|
|
@@ -180,4 +196,6 @@ class InProcessChannel(ABC):
|
|
|
180
196
|
response: ControlResponse to add to queue
|
|
181
197
|
loop: The event loop to use for thread-safe call
|
|
182
198
|
"""
|
|
199
|
+
if self._response_queue is None:
|
|
200
|
+
loop.call_soon_threadsafe(self._ensure_asyncio_primitives)
|
|
183
201
|
loop.call_soon_threadsafe(self._response_queue.put_nowait, response)
|
|
@@ -90,12 +90,14 @@ class HostControlChannel(InProcessChannel):
|
|
|
90
90
|
request.request_id,
|
|
91
91
|
)
|
|
92
92
|
|
|
93
|
+
self._ensure_asyncio_primitives()
|
|
94
|
+
|
|
93
95
|
# Store for background thread access
|
|
94
96
|
self._current_request = request
|
|
95
97
|
self._cancel_event.clear()
|
|
96
98
|
|
|
97
99
|
# Capture event loop for thread-safe response pushing
|
|
98
|
-
self._event_loop = asyncio.
|
|
100
|
+
self._event_loop = asyncio.get_running_loop()
|
|
99
101
|
|
|
100
102
|
# Display the request (synchronous, before starting thread)
|
|
101
103
|
self._display_request(request)
|
|
@@ -46,10 +46,22 @@ class IPCControlChannel:
|
|
|
46
46
|
|
|
47
47
|
self._server: Optional[asyncio.Server] = None
|
|
48
48
|
self._clients: dict[str, asyncio.StreamWriter] = {} # client_id -> writer
|
|
49
|
-
self._response_queue: asyncio.Queue[ControlResponse] =
|
|
49
|
+
self._response_queue: Optional[asyncio.Queue[ControlResponse]] = None
|
|
50
50
|
self._pending_requests: dict[str, ControlRequest] = {} # request_id -> request
|
|
51
51
|
self._initialized = False
|
|
52
52
|
|
|
53
|
+
def _ensure_response_queue(self) -> asyncio.Queue[ControlResponse]:
|
|
54
|
+
if self._response_queue is None:
|
|
55
|
+
try:
|
|
56
|
+
asyncio.get_running_loop()
|
|
57
|
+
except RuntimeError as error:
|
|
58
|
+
raise RuntimeError(
|
|
59
|
+
"IPCControlChannel requires a running event loop before use. "
|
|
60
|
+
"Initialize it from within an async context."
|
|
61
|
+
) from error
|
|
62
|
+
self._response_queue = asyncio.Queue()
|
|
63
|
+
return self._response_queue
|
|
64
|
+
|
|
53
65
|
@property
|
|
54
66
|
def capabilities(self) -> ChannelCapabilities:
|
|
55
67
|
"""IPC supports all request types and can respond synchronously."""
|
|
@@ -68,6 +80,7 @@ class IPCControlChannel:
|
|
|
68
80
|
return
|
|
69
81
|
|
|
70
82
|
logger.info("%s: initializing...", self.channel_id)
|
|
83
|
+
self._ensure_response_queue()
|
|
71
84
|
|
|
72
85
|
# Remove old socket file if it exists
|
|
73
86
|
if os.path.exists(self.socket_path):
|
|
@@ -168,8 +181,9 @@ class IPCControlChannel:
|
|
|
168
181
|
Yields:
|
|
169
182
|
ControlResponse objects
|
|
170
183
|
"""
|
|
184
|
+
response_queue = self._ensure_response_queue()
|
|
171
185
|
while True:
|
|
172
|
-
response = await
|
|
186
|
+
response = await response_queue.get()
|
|
173
187
|
logger.info(
|
|
174
188
|
"%s: received response for %s",
|
|
175
189
|
self.channel_id,
|
|
@@ -264,6 +278,7 @@ class IPCControlChannel:
|
|
|
264
278
|
self._clients[client_id] = writer
|
|
265
279
|
|
|
266
280
|
try:
|
|
281
|
+
response_queue = self._ensure_response_queue()
|
|
267
282
|
# Send any pending requests to the new client
|
|
268
283
|
for request_id, request_data in self._pending_requests.items():
|
|
269
284
|
try:
|
|
@@ -302,7 +317,7 @@ class IPCControlChannel:
|
|
|
302
317
|
timed_out=message.get("timed_out", False),
|
|
303
318
|
channel_id=self.channel_id,
|
|
304
319
|
)
|
|
305
|
-
await
|
|
320
|
+
await response_queue.put(response)
|
|
306
321
|
logger.info(
|
|
307
322
|
"%s: received response for %s",
|
|
308
323
|
self.channel_id,
|
|
@@ -248,7 +248,14 @@ class SSEControlChannel(InProcessChannel):
|
|
|
248
248
|
"""
|
|
249
249
|
logger.info("%s: received response for %s", self.channel_id, request_id)
|
|
250
250
|
|
|
251
|
-
response =
|
|
251
|
+
response = self._build_response(request_id, value)
|
|
252
|
+
|
|
253
|
+
# Push to queue from sync context (Flask thread)
|
|
254
|
+
# Get the running event loop and schedule the put operation
|
|
255
|
+
self._enqueue_response_from_sync_context(request_id, response)
|
|
256
|
+
|
|
257
|
+
def _build_response(self, request_id: str, value: Any) -> ControlResponse:
|
|
258
|
+
return ControlResponse(
|
|
252
259
|
request_id=request_id,
|
|
253
260
|
value=value,
|
|
254
261
|
responded_at=datetime.now(timezone.utc),
|
|
@@ -256,15 +263,15 @@ class SSEControlChannel(InProcessChannel):
|
|
|
256
263
|
channel_id=self.channel_id,
|
|
257
264
|
)
|
|
258
265
|
|
|
259
|
-
|
|
260
|
-
|
|
266
|
+
def _enqueue_response_from_sync_context(
|
|
267
|
+
self, request_id: str, response: ControlResponse
|
|
268
|
+
) -> None:
|
|
261
269
|
try:
|
|
270
|
+
self._ensure_asyncio_primitives()
|
|
262
271
|
event_loop = asyncio.get_event_loop()
|
|
263
272
|
if event_loop.is_running():
|
|
264
|
-
# Schedule the coroutine in the running loop
|
|
265
273
|
asyncio.run_coroutine_threadsafe(self._response_queue.put(response), event_loop)
|
|
266
274
|
else:
|
|
267
|
-
# If no loop is running, use put_nowait (shouldn't happen)
|
|
268
275
|
self._response_queue.put_nowait(response)
|
|
269
276
|
except Exception as error:
|
|
270
277
|
logger.error(
|
|
@@ -320,4 +327,5 @@ class SSEControlChannel(InProcessChannel):
|
|
|
320
327
|
async def shutdown(self) -> None:
|
|
321
328
|
"""Shutdown SSE channel."""
|
|
322
329
|
logger.info("%s: shutting down", self.channel_id)
|
|
330
|
+
self._ensure_asyncio_primitives()
|
|
323
331
|
self._shutdown_event.set()
|
|
@@ -201,37 +201,12 @@ class ControlLoopHandler:
|
|
|
201
201
|
message[:50],
|
|
202
202
|
)
|
|
203
203
|
|
|
204
|
-
# Run the async request flow
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
if event_loop.is_closed():
|
|
209
|
-
raise RuntimeError("Running event loop is closed")
|
|
204
|
+
# Run the async request flow.
|
|
205
|
+
running_event_loop = self._get_running_event_loop()
|
|
206
|
+
if running_event_loop is not None:
|
|
207
|
+
return self._run_request_in_running_loop(running_event_loop, request)
|
|
210
208
|
|
|
211
|
-
|
|
212
|
-
# This shouldn't normally happen since request_interaction is sync
|
|
213
|
-
import nest_asyncio
|
|
214
|
-
|
|
215
|
-
nest_asyncio.apply()
|
|
216
|
-
return event_loop.run_until_complete(self._request_interaction_async(request))
|
|
217
|
-
except RuntimeError:
|
|
218
|
-
# Not in async context - create a temporary event loop.
|
|
219
|
-
previous_event_loop: asyncio.AbstractEventLoop | None = None
|
|
220
|
-
try:
|
|
221
|
-
previous_event_loop = asyncio.get_event_loop()
|
|
222
|
-
except RuntimeError:
|
|
223
|
-
previous_event_loop = None
|
|
224
|
-
else:
|
|
225
|
-
if getattr(previous_event_loop, "is_closed", lambda: False)():
|
|
226
|
-
previous_event_loop = None
|
|
227
|
-
|
|
228
|
-
event_loop = asyncio.new_event_loop()
|
|
229
|
-
try:
|
|
230
|
-
asyncio.set_event_loop(event_loop)
|
|
231
|
-
return event_loop.run_until_complete(self._request_interaction_async(request))
|
|
232
|
-
finally:
|
|
233
|
-
event_loop.close()
|
|
234
|
-
asyncio.set_event_loop(previous_event_loop)
|
|
209
|
+
return self._run_request_in_new_loop(request)
|
|
235
210
|
|
|
236
211
|
async def _request_interaction_async(self, request: ControlRequest) -> ControlResponse:
|
|
237
212
|
"""
|
|
@@ -312,6 +287,45 @@ class ControlLoopHandler:
|
|
|
312
287
|
|
|
313
288
|
raise ProcedureWaitingForHuman(request.procedure_id, request.request_id)
|
|
314
289
|
|
|
290
|
+
def _get_running_event_loop(self) -> Optional[asyncio.AbstractEventLoop]:
|
|
291
|
+
try:
|
|
292
|
+
event_loop = asyncio.get_running_loop()
|
|
293
|
+
except RuntimeError:
|
|
294
|
+
return None
|
|
295
|
+
|
|
296
|
+
if event_loop.is_closed():
|
|
297
|
+
return None
|
|
298
|
+
return event_loop
|
|
299
|
+
|
|
300
|
+
def _run_request_in_running_loop(
|
|
301
|
+
self, event_loop: asyncio.AbstractEventLoop, request: ControlRequest
|
|
302
|
+
) -> ControlResponse:
|
|
303
|
+
# Already in async context - create task and run it.
|
|
304
|
+
# This shouldn't normally happen since request_interaction is sync.
|
|
305
|
+
import nest_asyncio
|
|
306
|
+
|
|
307
|
+
nest_asyncio.apply()
|
|
308
|
+
return event_loop.run_until_complete(self._request_interaction_async(request))
|
|
309
|
+
|
|
310
|
+
def _run_request_in_new_loop(self, request: ControlRequest) -> ControlResponse:
|
|
311
|
+
# Not in async context - create a temporary event loop.
|
|
312
|
+
previous_event_loop: Optional[asyncio.AbstractEventLoop] = None
|
|
313
|
+
try:
|
|
314
|
+
previous_event_loop = asyncio.get_event_loop()
|
|
315
|
+
except RuntimeError:
|
|
316
|
+
previous_event_loop = None
|
|
317
|
+
else:
|
|
318
|
+
if getattr(previous_event_loop, "is_closed", lambda: False)():
|
|
319
|
+
previous_event_loop = None
|
|
320
|
+
|
|
321
|
+
event_loop = asyncio.new_event_loop()
|
|
322
|
+
try:
|
|
323
|
+
asyncio.set_event_loop(event_loop)
|
|
324
|
+
return event_loop.run_until_complete(self._request_interaction_async(request))
|
|
325
|
+
finally:
|
|
326
|
+
event_loop.close()
|
|
327
|
+
asyncio.set_event_loop(previous_event_loop)
|
|
328
|
+
|
|
315
329
|
async def _fanout(
|
|
316
330
|
self,
|
|
317
331
|
request: ControlRequest,
|
|
@@ -5,18 +5,32 @@ Manages multiple MCP server connections using Pydantic AI's native MCPServerStdi
|
|
|
5
5
|
Handles lifecycle, tool prefixing, and tool call tracking.
|
|
6
6
|
"""
|
|
7
7
|
|
|
8
|
+
from __future__ import annotations
|
|
9
|
+
|
|
8
10
|
import logging
|
|
9
11
|
import os
|
|
10
12
|
import re
|
|
11
13
|
import asyncio
|
|
12
14
|
from contextlib import AsyncExitStack
|
|
13
|
-
from typing import Any
|
|
14
|
-
|
|
15
|
-
from pydantic_ai.mcp import MCPServerStdio
|
|
15
|
+
from typing import Any, Optional
|
|
16
16
|
|
|
17
17
|
logger = logging.getLogger(__name__)
|
|
18
18
|
|
|
19
19
|
|
|
20
|
+
MCPServerStdio: Optional[Any] = None
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def _require_mcp_server_stdio():
|
|
24
|
+
try:
|
|
25
|
+
from pydantic_ai.mcp import MCPServerStdio
|
|
26
|
+
except ImportError as import_error:
|
|
27
|
+
raise RuntimeError(
|
|
28
|
+
"MCP support requires optional dependencies. "
|
|
29
|
+
'Install with `pip install "pydantic-ai-slim[mcp]"`.'
|
|
30
|
+
) from import_error
|
|
31
|
+
return MCPServerStdio
|
|
32
|
+
|
|
33
|
+
|
|
20
34
|
def substitute_env_vars(value: Any) -> Any:
|
|
21
35
|
"""
|
|
22
36
|
Replace ${VAR} with environment variable values.
|
|
@@ -55,8 +69,8 @@ class MCPServerManager:
|
|
|
55
69
|
"""
|
|
56
70
|
self.configs = server_configs
|
|
57
71
|
self.tool_primitive = tool_primitive
|
|
58
|
-
self.servers: list[
|
|
59
|
-
self.server_toolsets: dict[str,
|
|
72
|
+
self.servers: list[Any] = []
|
|
73
|
+
self.server_toolsets: dict[str, Any] = {} # Map server names to toolsets
|
|
60
74
|
self._exit_stack = AsyncExitStack()
|
|
61
75
|
logger.info("MCPServerManager initialized with %s server(s)", len(server_configs))
|
|
62
76
|
|
|
@@ -64,7 +78,7 @@ class MCPServerManager:
|
|
|
64
78
|
"""Connect to all configured MCP servers."""
|
|
65
79
|
for name, config in self.configs.items():
|
|
66
80
|
# Retry a few times for transient stdio startup issues.
|
|
67
|
-
last_error: Exception
|
|
81
|
+
last_error: Optional[Exception] = None
|
|
68
82
|
for attempt in range(1, 4):
|
|
69
83
|
try:
|
|
70
84
|
logger.info(
|
|
@@ -77,6 +91,9 @@ class MCPServerManager:
|
|
|
77
91
|
resolved_config = substitute_env_vars(config)
|
|
78
92
|
|
|
79
93
|
# Create base server
|
|
94
|
+
MCPServerStdio = globals().get("MCPServerStdio")
|
|
95
|
+
if MCPServerStdio is None:
|
|
96
|
+
MCPServerStdio = _require_mcp_server_stdio()
|
|
80
97
|
server = MCPServerStdio(
|
|
81
98
|
command=resolved_config["command"],
|
|
82
99
|
args=resolved_config.get("args", []),
|
|
@@ -190,7 +207,7 @@ class MCPServerManager:
|
|
|
190
207
|
|
|
191
208
|
return trace_tool_call
|
|
192
209
|
|
|
193
|
-
def get_toolsets(self) -> list[
|
|
210
|
+
def get_toolsets(self) -> list[Any]:
|
|
194
211
|
"""
|
|
195
212
|
Return list of connected servers as toolsets.
|
|
196
213
|
|
|
@@ -3,7 +3,7 @@ HTTP model backend for REST endpoint inference.
|
|
|
3
3
|
"""
|
|
4
4
|
|
|
5
5
|
import logging
|
|
6
|
-
from typing import Any
|
|
6
|
+
from typing import Any, Dict, Optional
|
|
7
7
|
|
|
8
8
|
import httpx
|
|
9
9
|
|
|
@@ -13,7 +13,7 @@ logger = logging.getLogger(__name__)
|
|
|
13
13
|
class HTTPModelBackend:
|
|
14
14
|
"""Model backend that calls HTTP REST endpoints."""
|
|
15
15
|
|
|
16
|
-
def __init__(self, endpoint: str, timeout: float = 30.0, headers:
|
|
16
|
+
def __init__(self, endpoint: str, timeout: float = 30.0, headers: Optional[Dict] = None):
|
|
17
17
|
"""
|
|
18
18
|
Initialize HTTP model backend.
|
|
19
19
|
|
|
@@ -4,7 +4,7 @@ PyTorch model backend for .pt file inference.
|
|
|
4
4
|
|
|
5
5
|
import logging
|
|
6
6
|
from pathlib import Path
|
|
7
|
-
from typing import Any
|
|
7
|
+
from typing import Any, List, Optional
|
|
8
8
|
|
|
9
9
|
logger = logging.getLogger(__name__)
|
|
10
10
|
|
|
@@ -12,7 +12,7 @@ logger = logging.getLogger(__name__)
|
|
|
12
12
|
class PyTorchModelBackend:
|
|
13
13
|
"""Model backend that loads and runs PyTorch models."""
|
|
14
14
|
|
|
15
|
-
def __init__(self, path: str, device: str = "cpu", labels:
|
|
15
|
+
def __init__(self, path: str, device: str = "cpu", labels: Optional[List[str]] = None):
|
|
16
16
|
"""
|
|
17
17
|
Initialize PyTorch model backend.
|
|
18
18
|
|
|
@@ -16,7 +16,7 @@ import sys
|
|
|
16
16
|
import threading
|
|
17
17
|
import uuid
|
|
18
18
|
from pathlib import Path
|
|
19
|
-
from typing import Any, AsyncIterator, Optional
|
|
19
|
+
from typing import Any, AsyncIterator, Optional, Union
|
|
20
20
|
|
|
21
21
|
from tactus.broker.protocol import read_message, write_message
|
|
22
22
|
from tactus.broker.stdio import STDIO_REQUEST_PREFIX, STDIO_TRANSPORT_VALUE
|
|
@@ -122,7 +122,7 @@ async def close_stdio_transport() -> None:
|
|
|
122
122
|
|
|
123
123
|
|
|
124
124
|
class BrokerClient:
|
|
125
|
-
def __init__(self, socket_path: str
|
|
125
|
+
def __init__(self, socket_path: Union[str, Path]):
|
|
126
126
|
self.socket_path = str(socket_path)
|
|
127
127
|
|
|
128
128
|
@classmethod
|
|
@@ -158,7 +158,7 @@ class BrokerClient:
|
|
|
158
158
|
except ValueError as error:
|
|
159
159
|
raise ValueError(f"Invalid broker port in endpoint: {self.socket_path}") from error
|
|
160
160
|
|
|
161
|
-
ssl_context: ssl.SSLContext
|
|
161
|
+
ssl_context: Optional[ssl.SSLContext] = None
|
|
162
162
|
if use_tls:
|
|
163
163
|
ssl_context = ssl.create_default_context()
|
|
164
164
|
cafile = os.environ.get("TACTUS_BROKER_TLS_CA_FILE")
|
|
@@ -29,6 +29,18 @@ from tactus.broker.protocol import (
|
|
|
29
29
|
logger = logging.getLogger(__name__)
|
|
30
30
|
|
|
31
31
|
|
|
32
|
+
try:
|
|
33
|
+
from builtins import BaseExceptionGroup as BaseExceptionGroup
|
|
34
|
+
except ImportError: # pragma: no cover - Python < 3.11 fallback
|
|
35
|
+
|
|
36
|
+
class BaseExceptionGroup(Exception):
|
|
37
|
+
"""Minimal BaseExceptionGroup fallback for Python < 3.11."""
|
|
38
|
+
|
|
39
|
+
def __init__(self, message: str, exceptions: list[BaseException]):
|
|
40
|
+
super().__init__(message)
|
|
41
|
+
self.exceptions = exceptions
|
|
42
|
+
|
|
43
|
+
|
|
32
44
|
def _json_dumps(obj: Any) -> str:
|
|
33
45
|
return json.dumps(obj, ensure_ascii=False, separators=(",", ":"))
|
|
34
46
|
|
|
@@ -170,7 +182,7 @@ class _BaseBrokerServer:
|
|
|
170
182
|
control_handler: Optional[Callable[[dict], Awaitable[dict]]] = None,
|
|
171
183
|
):
|
|
172
184
|
self._listener = None
|
|
173
|
-
self._serve_task: asyncio.Task[None]
|
|
185
|
+
self._serve_task: Optional[asyncio.Task[None]] = None
|
|
174
186
|
self._openai = openai_backend or OpenAIChatBackend()
|
|
175
187
|
self._tools = tool_registry or HostToolRegistry.default()
|
|
176
188
|
self._event_handler = event_handler
|
|
@@ -1012,7 +1024,7 @@ class BrokerServer(_BaseBrokerServer):
|
|
|
1012
1024
|
openai_backend=openai_backend, tool_registry=tool_registry, event_handler=event_handler
|
|
1013
1025
|
)
|
|
1014
1026
|
self.socket_path = Path(socket_path)
|
|
1015
|
-
self._server: asyncio.AbstractServer
|
|
1027
|
+
self._server: Optional[asyncio.AbstractServer] = None
|
|
1016
1028
|
|
|
1017
1029
|
async def start(self) -> None:
|
|
1018
1030
|
# Most platforms enforce a short maximum length for AF_UNIX socket paths.
|
|
@@ -1445,7 +1457,7 @@ class TcpBrokerServer(_BaseBrokerServer):
|
|
|
1445
1457
|
*,
|
|
1446
1458
|
host: str = "127.0.0.1",
|
|
1447
1459
|
port: int = 0,
|
|
1448
|
-
ssl_context: ssl.SSLContext
|
|
1460
|
+
ssl_context: Optional[ssl.SSLContext] = None,
|
|
1449
1461
|
openai_backend: Optional[OpenAIChatBackend] = None,
|
|
1450
1462
|
tool_registry: Optional[HostToolRegistry] = None,
|
|
1451
1463
|
event_handler: Optional[Callable[[dict[str, Any]], None]] = None,
|
|
@@ -1460,8 +1472,8 @@ class TcpBrokerServer(_BaseBrokerServer):
|
|
|
1460
1472
|
self.host = host
|
|
1461
1473
|
self.port = port
|
|
1462
1474
|
self.ssl_context = ssl_context
|
|
1463
|
-
self.bound_port: int
|
|
1464
|
-
self._serve_task: asyncio.Task[None]
|
|
1475
|
+
self.bound_port: Optional[int] = None
|
|
1476
|
+
self._serve_task: Optional[asyncio.Task[None]] = None
|
|
1465
1477
|
|
|
1466
1478
|
async def start(self) -> None:
|
|
1467
1479
|
# Create AnyIO TCP listener (doesn't block, just binds to port)
|