tactus 0.35.1__tar.gz → 0.36.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.36.0}/.github/workflows/release.yml +5 -2
- {tactus-0.35.1 → tactus-0.36.0}/.gitignore +2 -0
- {tactus-0.35.1 → tactus-0.36.0}/CHANGELOG.md +8 -0
- {tactus-0.35.1 → tactus-0.36.0}/PKG-INFO +5 -1
- {tactus-0.35.1 → tactus-0.36.0}/pyproject.toml +8 -1
- {tactus-0.35.1 → tactus-0.36.0}/tactus/__init__.py +1 -1
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/sse.py +11 -5
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/control_loop.py +44 -30
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/execution_context.py +9 -4
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/lua_sandbox.py +42 -34
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/message_history_manager.py +50 -27
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/output_validator.py +63 -49
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/runtime.py +26 -18
- {tactus-0.35.1 → tactus-0.36.0}/tactus/ide/server.py +63 -33
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/host.py +19 -16
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/message_history.py +11 -14
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/procedure.py +10 -7
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/session.py +9 -9
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/tool_handle.py +27 -24
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/mock_hitl.py +2 -2
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/models.py +2 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/utils/safe_libraries.py +2 -2
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/backend/tactus_backend.spec +4 -1
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/events.py +5 -2
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_control_loop.py +66 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/conftest.py +2 -1
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_run_stream.py +177 -2
- {tactus-0.35.1 → tactus-0.36.0}/tests/test_mcp_integration.py +7 -0
- tactus-0.36.0/tests/utils/test_asyncio_helpers.py +50 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/utils/test_safe_file_library.py +0 -1
- tactus-0.35.1/coverage.json +0 -1
- {tactus-0.35.1 → tactus-0.36.0}/.claude/agents.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/.coveragerc +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/.tactus/config.yml.example +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/AGENTS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/CHANGES_SUMMARY.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/CHECKPOINT_RESUME_PLAN.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/CURRENT_STATUS_AND_NEXT_STEPS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/DETERMINISTIC_REQUEST_ID_FIX.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/EXECUTION_TRACE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/IMPLEMENTATION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/LICENSE +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/Makefile +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/PHASE0_IPC_CHANNEL_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/PHASE2_INTEGRATION_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/PHASE3_IDE_HITL_INTEGRATION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/SPECIFICATION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/TECHNICAL_DEBT.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/behave.ini +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/coverage_badge.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/AGENTS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/BDD_TESTING.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/CONFIGURATION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/CONTROL_LOOP_PHASE1_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/DURABILITY.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/FILE_IO.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/MANUAL_CHECKPOINT_TESTING.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/OMNICHANNEL_HITL_PLAN.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/SANDBOXING.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/STREAMING.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/TOOLS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/TOOL_ROADMAP.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/archive/CHECKPOINT_RESUME_STATUS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/archive/CHECKPOINT_TESTING_PLAN.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/archive/CONTROL_LOOP_INTEGRATION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/archive/HITL_CHECKPOINT_FIX_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/archive/HITL_FIX_SUMMARY.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/archive/LLM_CHECKPOINTING_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs/development-mode.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs_output/classify.html +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/docs_output/index.html +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/.tactus/config.yml +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/.tactus/config.yml.example +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/01-basics-hello-world.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/02-basics-simple-logic.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/03-basics-parameters.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/04-basics-simple-agent.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/05-basics-multi-model.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/06-basics-streaming.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/07-basics-bedrock.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/08-basics-models.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/09-basics-google-gemini.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/10-feature-state.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/11-feature-message-history-transforms.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/11-feature-message-history.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/12-feature-structured-output.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/13-feature-session.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/14-feature-per-turn-tools-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/14-feature-per-turn-tools.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/15-feature-local-tools.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/16-feature-toolsets-advanced.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/17-feature-toolsets-dsl.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/18-feature-lua-tools-individual.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/18-feature-lua-tools-inline.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/18-feature-lua-tools-toolset.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/19-feature-direct-tool-calls.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/20-bdd-complete.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/21-bdd-passing.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/22-bdd-fuzzy-matching.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/30-eval-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/31-eval-demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/32-eval-success-rate.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/33-eval-thresholds.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/34-eval-dataset.jsonl +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/34-eval-dataset.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/35-eval-trace.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/36-eval-advanced.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/37-eval-comprehensive.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/39-model-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/40-mcp-test.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/40-model-text-classifier.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/41-mcp-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/41-model-pytorch.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/43-sub-procedure-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/44-sub-procedure-composition.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/45-sub-procedure-recursive.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/46-checkpoint-explicit.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/47-checkpoint-expensive-ops.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/48-script-mode-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/50-inputs-showcase.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/51-inputs-calculator.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/52-file-io-basics.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/53-tsv-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/54-json-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/55-parquet-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/56-hdf5-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/57-excel-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/58-text-file-io.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/60-tool-sources.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/61-inline-toolset-lua.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/62-mcp-toolset-by-server.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/63-toolset-import-from-file.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/64-require-modules.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/65-optional-state-demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/66-host-tools-via-broker.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/67-host-tool-source.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/70-mocking-static.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/71-mocking-temporal.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/72-mocking-conditional.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/90-hitl-debug.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/90-hitl-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/90-hitl-test-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/90-hitl-ultra-debug.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/90-super-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/90-test-params.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/91-control-loop-demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/92-test-inputs-simple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/92-test-inputs.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/92-test-multiple.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/93-test-ide-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/93-test-individual-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/93-test-input-summary.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/94-test-custom-components.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/95-agent-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/99-misc-test-loading.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/agent_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/app_config.ini +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/classify_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/data/sample.csv +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/demo_output.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/fuzzy_matching_demo.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/fuzzy_matching_demo_simple_spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/fuzzy_simple_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/helpers/math_module.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/helpers/product.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/helpers/string_module.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/helpers/sum.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/helpers/text_tools.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/hitl_toolset.lua +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/inventory_summary.tsv +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/llm_classify_binary.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/llm_classify_multiclass.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/llm_classify_with_metadata.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/mock-config.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/models/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/models/create_sentiment_model.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/output_summary.txt +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-raw-module.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-raw-streaming.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-basic.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-hitl-types.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-many-checkpoints.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-mixed.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-multi-hitl.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-resume-timeout.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-temperature-multi-calls.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/test-temperature-variation.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/tools/calculations.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/tools/data_analysis.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/tools/search.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/with_dependencies/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/with_dependencies/simple_http_test.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/examples/with_dependencies/time_lookup.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/01_state_management.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/02_checkpointing.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/03_human_in_the_loop.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/04_control_flow.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/05_tool_integration.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/06_retry_logic.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/07_file_operations.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/08_agent_primitives.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/09_workflow_execution.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/10_lua_integration.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/11_storage_backends.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/12_json_operations.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/13_logging.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/15_procedure_calls.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/16_session_management.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/17_lua_dsl_validation.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/18_example_procedures.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/19_ide_server.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/20_parameters.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/21_outputs.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/23_prompts.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/24_bdd_specifications.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/25_bdd_custom_steps.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/26_bdd_evaluation.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/27_default_settings.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/28_custom_prompts.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/29_execution_settings.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/30_session_filters.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/31_matchers.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/32_result_object.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/33_output_type.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/42_model_primitive.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/43_sub_procedure_checkpointing.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/46_explicit_checkpoint.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/48_script_mode.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/51_dspy_lm_config.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/52_dspy_signature.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/53_dspy_module.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/54_dspy_history.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/55_dspy_prediction.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/56_dspy_agent.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/57_chat_assistant.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/60_formatting.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/61_classify_primitive.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/61_cli_run_exit_codes.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/62_cli_info.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/67_message_history_transforms.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/68_ide_file_tools.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/69_ide_assistant_service.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/70_ide_chat_api.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/71_ide_config_api.feature +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/documentation/IDE_SERVER_BEHAVIOR.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/documentation/Lua DSL/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/environment.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/agent_primitives_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/chat_assistant_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/checkpointing_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/classify_primitive_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/cli_info_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/cli_run_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/control_flow_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/dspy_agent_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/dspy_history_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/dspy_lm_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/dspy_module_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/dspy_prediction_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/dspy_signature_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/example_procedures_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/file_operations_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/formatting_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/human_in_the_loop_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/ide_assistant_service_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/ide_chat_api_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/ide_config_api_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/ide_file_tools_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/ide_server_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/json_operations_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/logging_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/lua_dsl_validation_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/lua_integration_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/mocking_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/procedure_calls_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/result_and_output_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/retry_logic_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/session_management_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/state_management_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/storage_backend_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/support/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/support/harnesses.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/tool_integration_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/features/steps/workflow_execution_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/planning/BROKER_AND_TOOL_RUNNERS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/planning/CONVERSATION_HISTORY_TRANSFORMS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/planning/FORMATTER.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/scripts/audit_examples_mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/scripts/convert_examples.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/scripts/run_coverage.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/scripts/run_precommit_suite.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/scripts/timeout.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/start-web-ide.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/broker_log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/base.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/broker.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/cli.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/host.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/channels/ipc.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/cli_hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/cli_log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/cost_collector_log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/file_storage.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/http_callback_log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/ide_log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/lua_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/mcp.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/mcp_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/memory.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/adapters/plugins.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/backends/http_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/backends/model_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/backends/pytorch_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/broker/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/broker/client.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/broker/protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/broker/server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/broker/stdio.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/cli/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/cli/app.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/cli/commands/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/cli/control.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/config_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/dependencies/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/dependencies/registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/dsl_stubs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/exceptions.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/template_resolver.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/core/yaml_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docker/Dockerfile +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docker/Dockerfile.pypi +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docker/entrypoint.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/extractor.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/html_renderer.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/templates/base.html +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/templates/index.html +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/docs/templates/module.html +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/agent.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/broker_lm.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/config.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/history.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/module.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/prediction.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/dspy/signature.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/formatting/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/formatting/formatter.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/ide/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/ide/coding_assistant.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/ide/config_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/control.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/file.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/handles.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/human.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/json.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/model.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/procedure_callable.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/retry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/state.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/step.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/system.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/tool.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/primitives/toolset.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/chat_recorder.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/config.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/control.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/cost.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/log_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/notification.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/result.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/protocols/storage.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/providers/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/providers/base.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/providers/bedrock.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/providers/google.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/providers/openai.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/sandbox/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/sandbox/config.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/sandbox/container_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/sandbox/docker_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/sandbox/entrypoint.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/sandbox/protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/classify/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/classify/classify.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/classify/classify.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/classify/fuzzy.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/classify/llm.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/classify/primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/core/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/core/base.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/core/confidence.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/core/models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/core/retry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/core/validation.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/extract/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/extract/llm.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/extract/primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/csv.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/excel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/file.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/fs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/hdf5.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/json.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/parquet.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/io/tsv.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/loader.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/classify/base.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/classify/fuzzy.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/classify/index.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/classify/init.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/classify/llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/classify.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/extract/base.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/extract/index.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/extract/init.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/extract/llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/extract.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/generate/base.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/generate/index.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/generate/init.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/generate/llm.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/generate.spec.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/tools/done.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/stdlib/tac/tactus/tools/log.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/behave_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/context.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/eval_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/evaluation_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/evaluators.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/events.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/gherkin_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/mock_agent.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/mock_dependencies.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/mock_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/mock_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/pydantic_eval_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/steps/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/steps/builtin.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/steps/custom.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/steps/registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/testing/test_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/tracing/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/tracing/trace_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/utils/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/utils/asyncio_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/utils/cost_calculator.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/utils/model_pricing.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/utils/safe_file_library.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/LuaLexerBase.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/LuaParserBase.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/error_listener.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaLexer.interp +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaLexer.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaLexer.tokens +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaLexerBase.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaParser.interp +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaParser.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaParser.tokens +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaParserBase.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/LuaParserVisitor.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/generated/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/grammar/LuaLexer.g4 +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/grammar/LuaParser.g4 +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/semantic_visitor.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus/validation/validator.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/.gitignore +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/BUILD_GUIDE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/DISTRIBUTION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/ELECTRON_INTEGRATION.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/RUN_ELECTRON.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/SETUP_COMPLETE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/backend/hook-lupa.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/package-lock.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/package.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/preload/preload.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/preload/tsconfig.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/rebuild-and-test.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/resources/app-icon.icns +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/resources/app-icon.ico +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/resources/app-icon.png +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/scripts/build-backend.mjs +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/scripts/build-frontend.mjs +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/scripts/generate-icons.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/scripts/test-ci-build.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/src/backend-manager.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/src/main.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/src/menu.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/src/preferences-window.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-desktop/tsconfig.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/ARCHITECTURE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/CHANGELOG.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/DEV_MODE.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/QUICK_START.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/RESTART_INSTRUCTIONS.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/TROUBLESHOOTING.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/assistant_service.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/assistant_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/chat_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/config_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/logging_capture.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/lsp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/requirements.txt +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/tactus_lsp_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/backend/text_editor_tool.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/dev.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/.storybook/main.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/.storybook/preview.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/.storybook/vitest.setup.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/README.md +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/components.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/demo.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/index.html +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/jest.config.js +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/package-lock.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/package.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/postcss.config.js +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/App.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/Editor.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/LSPClient.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/LSPClientHTTP.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/TactusLanguage.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/commands/registry.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/AboutDialog.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/AuthErrorDialog.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ChatSidebar.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/CheckpointSummary.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/CollapsibleRun.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/Duration.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/Duration.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/FileTree.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/FileTree.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/MessageFeed.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/PreferencesView.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ProcedureInputsDisplay.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ProcedureInputsDisplay.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ProcedureInputsModal.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ProcedureInputsModal.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ProcedureTab.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ProcedureTab.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ResizeHandle.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ResultsSidebar.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ResultsSidebar.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/TestOptionsModal.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/Timestamp.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/Timestamp.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/TopMenuBar.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ai-elements/confirmation.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/chat/ChatInterface.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/chat/MessageInput.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/chat/MessageList.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/CheckpointDetails.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/CheckpointDetails.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/CheckpointList.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/CheckpointList.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/DebuggerPanel.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/DebuggerPanel.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/RunSelector.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/RunSelector.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/StatisticsPanel.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/debugger/StatisticsPanel.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/AgentStreamingComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/BaseEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/CheckpointEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/CollapsibleTestScenario.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ContainerStatusEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/CostEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/CostEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/EvaluationEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/EvaluationEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/EventRenderer.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ExecutionEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ExecutionEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ExecutionSummaryEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ExecutionSummaryEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/HITLEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/HITLEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/LoadingEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/LoadingEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/LogCluster.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/LogEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/LogEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/OutputEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/OutputEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/TestEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/TestEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/TestProgressContainer.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ToolCallEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ValidationEventComponent.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/events/ValidationEventComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/registry.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/ApprovalComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/InputComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/SelectComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/builtin/index.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/index.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/selectors/ImageSelectorComponent.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/standard-library/selectors/index.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/hitl/types.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/AgentsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/EvaluationsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/MetadataSections.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/OutputsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/ParametersSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/SpecificationsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/StagesSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/metadata/ToolsSection.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/preferences/ConfigFieldView.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/preferences/SourceBadge.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/preferences/YamlCodeEditor.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/scenarios/EvaluateScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/scenarios/RunScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/scenarios/TestScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/scenarios/ValidationScenarios.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/theme-provider.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/ai/conversation.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/ai/message.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/ai/prompt-input.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/alert.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/badge.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/button.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/dialog.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/dropdown-menu.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/input.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/label.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/logo.stories.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/logo.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/menubar.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/scroll-area.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/select.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/separator.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/switch.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/tabs.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/components/ui/tooltip.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/hooks/useChatSSE.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/hooks/useEventStream.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/hooks/useTracing.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/index.css +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/lib/utils.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/main.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/types/events.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/types/metadata.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/types/preferences.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/types/results.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/types/tracing.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/utils/clipboard.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/utils/runExport.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/utils/yamlSync.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/validation/TactusValidator.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/validation/generated/LuaParser.interp +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/validation/generated/LuaParser.tokens +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/validation/types.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/src/vite-env.d.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/tailwind.config.js +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/tests/runExport.test.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/tsconfig.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/tsconfig.node.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/vendor/tactus-hitl-components/package.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/vendor/tactus-hitl-components/src/index.tsx +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/vendor/tactus-hitl-components/src/styles.css +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/vite.config.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/frontend/vitest.shims.d.ts +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/package.json +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tactus-ide/start-dev.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/test-ci.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/test_classify_loading.tac +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/test_run_inputs.sh +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_base_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_broker_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_channels_init.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_cli_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_host_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_ipc_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/channels/test_sse_channel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_broker_log.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_cli_hitl_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_cli_log_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_file_storage.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_log_handlers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_lua_tools_adapter.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_mcp_adapter.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_mcp_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_memory_storage.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/adapters/test_plugins.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/backends/test_http_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/backends/test_pytorch_backend.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_client_extra.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_client_unit.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_host_tool_source.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_anyio_handlers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_asyncio_handlers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_connection.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_unit.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_server_utils.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_stdio_transport.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_tcp_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_broker_tcp_unit.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/broker/test_brokered_lm_unit.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_app_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_app_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_app_inputs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_app_run.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_app_sandbox.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_config_loading.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_control_main.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_display_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_format_info.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_ide_main.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_input_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_inputs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_logging.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_main_entry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_run_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_sandbox_validate.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_stdlib_control.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_test_eval_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_cli_trace_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_control_cli.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_sandbox_commands.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_validate_command.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/cli/test_version_command.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/dependencies/test_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_config_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_determinism_safety.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_dsl_stubs_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_dsl_stubs_minimal.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_dsl_stubs_utils.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_execution_context.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_lua_sandbox_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_lua_sandbox_security.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_message_history_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_output_validator.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_registry_builder_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_dependencies.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_enhance_handles.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_execute_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_execute_workflow.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_init.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_inject_primitives.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_inputs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_named_procedures.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_output_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_setup_agents_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_setup_agents_tools_output.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_templates.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_tool_source.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_runtime_toolsets.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_script_mode.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_template_resolver.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/core/test_yaml_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/docs/test_docs_extractor.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/docs/test_docs_init.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/docs/test_docs_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/docs/test_html_renderer.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_agent_execution.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_agent_handle.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_agent_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_agent_mocking.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_agent_utilities.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_broker_lm.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_config.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_config_utilities.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_history.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_mock_field_normalization.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_module_parameter.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_module_utilities.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_prediction_messages.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_signature.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/dspy/test_streaming.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/fixtures/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/fixtures/brave_search_mcp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/fixtures/filesystem_mcp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/fixtures/test_mcp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_assistant_service.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_assistant_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_chat_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_coding_assistant.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_config_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_config_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_config_server_api.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_events.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_basics.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_error_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_hitl_chat_stream.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_lsp_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_lsp_chat.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_metadata.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_misc.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_stream_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_stream_failures.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_stream_success.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_trace_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_traces.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_ide_server_validate.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_logging_capture.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_lsp_server.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_tactus_lsp_handler.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/ide_backend/test_text_editor_tool.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/integration/test_named_procedures.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/mocks/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/mocks/llm_mocks.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_checkpoint_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_control_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_file_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_handles.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_host_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_human_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_json_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_log_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_message_history_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_model_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_procedure_callable.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_procedure_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_retry_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_session_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_state_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_step_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_system_alert.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_system_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_tool_handle.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_tool_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_toolset_dsl.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/primitives/test_toolset_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/protocols/test_protocol_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/protocols/test_protocol_stubs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/protocols/test_protocols_misc.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/protocols/test_storage_protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/providers/test_provider_configurations.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/providers/test_providers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_config.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_container_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_container_runner_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_container_runner_run_container.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_docker_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_docker_sandbox_smoke.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_entrypoint.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/sandbox/test_protocol.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/test_classify_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/test_fuzzy_algorithms.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/test_fuzzy_classifier.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/test_fuzzy_demo.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/test_fuzzy_import_error.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/classify/test_llm_classifier_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/core/test_base.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/core/test_confidence.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/core/test_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/core/test_retry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/core/test_validation.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/extract/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/extract/test_extract_primitive.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/extract/test_llm_extractor.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_excel.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_excel_parquet_hdf5.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_file.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_file_csv_tsv.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_fs.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_hdf5.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_import_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/io/test_serializers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/test_loader.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/stdlib/test_require_python.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/test_checkpoints_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/test_formatter.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/test_tracing.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/conftest.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_all_examples.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_behave_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_behave_integration_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_builtin_steps.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_builtin_steps_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_builtin_steps_regex.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_agent_mocks.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_capture.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_edge_cases.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_fallbacks.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_internals.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_missing_branches.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_context_run_wrapper.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_custom_steps_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_custom_steps_manager.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_e2e.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_eval_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluation_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluation_runner_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluation_runner_edges.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluators.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluators_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluators_import_error.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluators_more.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_evaluators_traceaware.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_gherkin_parser.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_gherkin_parser_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_agent.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_agent_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_dependencies.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_dependencies_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_hitl.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_registry_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_mock_tools.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_models.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_dataset.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_errors.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_import_error.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_loaders.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_task.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_thresholds.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_pydantic_eval_runner_trace.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_runtime_integration.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_step_registry.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_test_runner_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_test_runner_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_test_runner_run.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/testing/test_test_runner_statuses.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/tracing/test_trace_manager_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/utils/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/utils/test_cost_calculator.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/utils/test_model_pricing.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/utils/test_safe_file_library_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/utils/test_safe_libraries.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/__init__.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/test_semantic_visitor.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/test_semantic_visitor_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/test_semantic_visitor_helpers.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/test_semantic_visitor_more.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/test_tool_curried_syntax_disallowed.py +0 -0
- {tactus-0.35.1 → tactus-0.36.0}/tests/validation/test_validator_additional.py +0 -0
- {tactus-0.35.1 → tactus-0.36.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.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,14 @@
|
|
|
2
2
|
|
|
3
3
|
<!-- version list -->
|
|
4
4
|
|
|
5
|
+
## v0.36.0 (2026-01-31)
|
|
6
|
+
|
|
7
|
+
### Features
|
|
8
|
+
|
|
9
|
+
- Test CI on supported Python versions
|
|
10
|
+
([`37c1791`](https://github.com/AnthusAI/Tactus/commit/37c1791810690e26965415046fee02351415eeb5))
|
|
11
|
+
|
|
12
|
+
|
|
5
13
|
## v0.35.1 (2026-01-31)
|
|
6
14
|
|
|
7
15
|
### Bug Fixes
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: tactus
|
|
3
|
-
Version: 0.
|
|
3
|
+
Version: 0.36.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
|
|
@@ -29,11 +29,15 @@ Requires-Dist: flask>=3.0.0
|
|
|
29
29
|
Requires-Dist: gherkin-official>=28.0.0
|
|
30
30
|
Requires-Dist: h5py>=3.10
|
|
31
31
|
Requires-Dist: jinja2>=3.0
|
|
32
|
+
Requires-Dist: litellm>=1.81.5
|
|
33
|
+
Requires-Dist: logfire>=4.20.0
|
|
32
34
|
Requires-Dist: lupa>=2.6
|
|
33
35
|
Requires-Dist: markdown>=3.0
|
|
34
36
|
Requires-Dist: nanoid>=2.0.0
|
|
35
37
|
Requires-Dist: nest-asyncio>=1.5.0
|
|
36
38
|
Requires-Dist: openpyxl>=3.1
|
|
39
|
+
Requires-Dist: opentelemetry-api>=1.39.1
|
|
40
|
+
Requires-Dist: opentelemetry-sdk>=1.39.1
|
|
37
41
|
Requires-Dist: pyarrow>=14.0
|
|
38
42
|
Requires-Dist: pydantic-ai-slim[bedrock,evals]
|
|
39
43
|
Requires-Dist: pydantic>=2.0
|
|
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "tactus"
|
|
7
|
-
version = "0.
|
|
7
|
+
version = "0.36.0"
|
|
8
8
|
description = "Tactus: Lua-based DSL for agentic workflows"
|
|
9
9
|
readme = "README.md"
|
|
10
10
|
requires-python = ">=3.11"
|
|
@@ -29,6 +29,10 @@ dependencies = [
|
|
|
29
29
|
"pyyaml",
|
|
30
30
|
"pydantic>=2.0",
|
|
31
31
|
"pydantic-ai-slim[bedrock,evals]",
|
|
32
|
+
"logfire>=4.20.0",
|
|
33
|
+
"litellm>=1.81.5",
|
|
34
|
+
"opentelemetry-api>=1.39.1",
|
|
35
|
+
"opentelemetry-sdk>=1.39.1",
|
|
32
36
|
# NOTE: We use LiteLLM (via DSPy) for all LLM calls - do not add provider-specific SDKs
|
|
33
37
|
"boto3>=1.28.0",
|
|
34
38
|
"rich>=13.9.4",
|
|
@@ -109,6 +113,9 @@ markers = [
|
|
|
109
113
|
"docker: Requires a running Docker daemon (opt-in; see TACTUS_RUN_DOCKER_TESTS)",
|
|
110
114
|
"xdist_group: pytest-xdist grouping marker",
|
|
111
115
|
]
|
|
116
|
+
filterwarnings = [
|
|
117
|
+
"ignore:(?s).*DETERMINISM WARNING.*File\\.read\\(\\).*:UserWarning",
|
|
118
|
+
]
|
|
112
119
|
|
|
113
120
|
[tool.black]
|
|
114
121
|
line-length = 100
|
|
@@ -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,14 @@ 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:
|
|
262
270
|
event_loop = asyncio.get_event_loop()
|
|
263
271
|
if event_loop.is_running():
|
|
264
|
-
# Schedule the coroutine in the running loop
|
|
265
272
|
asyncio.run_coroutine_threadsafe(self._response_queue.put(response), event_loop)
|
|
266
273
|
else:
|
|
267
|
-
# If no loop is running, use put_nowait (shouldn't happen)
|
|
268
274
|
self._response_queue.put_nowait(response)
|
|
269
275
|
except Exception as error:
|
|
270
276
|
logger.error(
|
|
@@ -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,
|
|
@@ -155,11 +155,16 @@ class BaseExecutionContext(ExecutionContext):
|
|
|
155
155
|
self.lua_sandbox: Any | None = None
|
|
156
156
|
|
|
157
157
|
# Rich metadata for HITL notifications
|
|
158
|
-
self.
|
|
159
|
-
self.
|
|
160
|
-
self._started_at: datetime = datetime.now(timezone.utc)
|
|
161
|
-
self._input_data: Any = None
|
|
158
|
+
self._initialize_run_metadata(procedure_id)
|
|
159
|
+
self._load_and_reset_metadata(procedure_id)
|
|
162
160
|
|
|
161
|
+
def _initialize_run_metadata(self, procedure_id: str) -> None:
|
|
162
|
+
self.procedure_name = procedure_id
|
|
163
|
+
self.invocation_id = str(uuid.uuid4())
|
|
164
|
+
self._started_at = datetime.now(timezone.utc)
|
|
165
|
+
self._input_data = None
|
|
166
|
+
|
|
167
|
+
def _load_and_reset_metadata(self, procedure_id: str) -> None:
|
|
163
168
|
# Load procedure metadata (contains execution_log and replay_index)
|
|
164
169
|
self.metadata = self.storage.load_procedure_metadata(procedure_id)
|
|
165
170
|
|
|
@@ -241,7 +241,7 @@ class LuaSandbox:
|
|
|
241
241
|
"""Setup safe global functions and utilities."""
|
|
242
242
|
# Keep safe standard library functions
|
|
243
243
|
# (These are already available by default, just documenting them)
|
|
244
|
-
|
|
244
|
+
safe_global_symbols = {
|
|
245
245
|
# Math
|
|
246
246
|
"math", # Math library (will be replaced with safe version if context available)
|
|
247
247
|
"tonumber", # Convert to number
|
|
@@ -264,54 +264,62 @@ class LuaSandbox:
|
|
|
264
264
|
}
|
|
265
265
|
|
|
266
266
|
# Just log what's available - no need to explicitly set
|
|
267
|
-
logger.debug("Safe Lua functions available: %s", ", ".join(
|
|
267
|
+
logger.debug("Safe Lua functions available: %s", ", ".join(safe_global_symbols))
|
|
268
268
|
|
|
269
269
|
# Replace math and os libraries with safe versions if context available
|
|
270
270
|
if self.execution_context is not None:
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
create_safe_os_library,
|
|
274
|
-
)
|
|
271
|
+
self._install_context_safe_libraries()
|
|
272
|
+
return # Skip default os.date setup below
|
|
275
273
|
|
|
276
|
-
|
|
277
|
-
return self.execution_context
|
|
274
|
+
self._install_fallback_os_date()
|
|
278
275
|
|
|
279
|
-
|
|
280
|
-
|
|
276
|
+
def _install_context_safe_libraries(self) -> None:
|
|
277
|
+
"""Install safe math and os libraries based on execution context."""
|
|
278
|
+
from tactus.utils.safe_libraries import (
|
|
279
|
+
create_safe_math_library,
|
|
280
|
+
create_safe_os_library,
|
|
281
|
+
)
|
|
281
282
|
|
|
282
|
-
|
|
283
|
-
|
|
283
|
+
def get_execution_context() -> Any:
|
|
284
|
+
return self.execution_context
|
|
284
285
|
|
|
285
|
-
|
|
286
|
-
|
|
286
|
+
safe_math_dict = create_safe_math_library(get_execution_context, self.strict_determinism)
|
|
287
|
+
safe_os_dict = create_safe_os_library(get_execution_context, self.strict_determinism)
|
|
287
288
|
|
|
288
|
-
|
|
289
|
-
|
|
289
|
+
safe_math_table = self._dict_to_lua_table(safe_math_dict)
|
|
290
|
+
safe_os_table = self._dict_to_lua_table(safe_os_dict)
|
|
290
291
|
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
292
|
+
self.lua.globals()["math"] = safe_math_table
|
|
293
|
+
self.lua.globals()["os"] = safe_os_table
|
|
294
|
+
|
|
295
|
+
logger.debug("Installed safe math and os libraries with determinism checking")
|
|
296
|
+
|
|
297
|
+
def _install_fallback_os_date(self) -> None:
|
|
298
|
+
"""Install a safe os.date() fallback when no execution context is available."""
|
|
299
|
+
safe_os_table = self._build_fallback_os_table()
|
|
300
|
+
self.lua.globals()["os"] = safe_os_table
|
|
301
|
+
logger.debug("Added safe os.date() function")
|
|
294
302
|
|
|
295
|
-
|
|
303
|
+
def _build_fallback_os_table(self) -> Any:
|
|
304
|
+
"""Build a Lua os table with a safe date() implementation."""
|
|
305
|
+
from datetime import datetime, timezone
|
|
306
|
+
|
|
307
|
+
def safe_date(format_string: Optional[str] = None) -> str:
|
|
296
308
|
"""Safe implementation of os.date() for timestamp generation."""
|
|
297
|
-
now = datetime.
|
|
298
|
-
if
|
|
309
|
+
now = datetime.now(timezone.utc)
|
|
310
|
+
if format_string is None:
|
|
299
311
|
# Return default format like Lua's os.date()
|
|
300
312
|
return now.strftime("%a %b %d %H:%M:%S %Y")
|
|
301
|
-
|
|
313
|
+
if format_string == "%Y-%m-%dT%H:%M:%SZ":
|
|
302
314
|
# ISO 8601 format
|
|
303
315
|
return now.strftime("%Y-%m-%dT%H:%M:%SZ")
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
# Create safe os table with only date function
|
|
312
|
-
safe_os = self.lua.table(date=safe_date)
|
|
313
|
-
self.lua.globals()["os"] = safe_os
|
|
314
|
-
logger.debug("Added safe os.date() function")
|
|
316
|
+
# Support Python strftime formats
|
|
317
|
+
try:
|
|
318
|
+
return now.strftime(format_string)
|
|
319
|
+
except Exception: # noqa: E722
|
|
320
|
+
return now.strftime("%a %b %d %H:%M:%S %Y")
|
|
321
|
+
|
|
322
|
+
return self.lua.table(date=safe_date)
|
|
315
323
|
|
|
316
324
|
def setup_assignment_interception(self, callback: Any) -> None:
|
|
317
325
|
"""
|
|
@@ -136,37 +136,60 @@ class MessageHistoryManager:
|
|
|
136
136
|
print(f"Warning: Filter function failed: {exception}")
|
|
137
137
|
return messages
|
|
138
138
|
|
|
139
|
-
|
|
140
|
-
if
|
|
139
|
+
filter_name, filter_value = self._parse_filter_spec(filter_specification)
|
|
140
|
+
if filter_name is None:
|
|
141
141
|
return messages
|
|
142
142
|
|
|
143
|
-
filter_name
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
return
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
143
|
+
if filter_name == "compose":
|
|
144
|
+
return self._apply_composed_filters(messages, filter_value, context)
|
|
145
|
+
|
|
146
|
+
return self._apply_named_filter(messages, filter_name, filter_value)
|
|
147
|
+
|
|
148
|
+
@staticmethod
|
|
149
|
+
def _parse_filter_spec(filter_specification: Any) -> tuple[str | None, Any]:
|
|
150
|
+
if not isinstance(filter_specification, tuple) or len(filter_specification) < 2:
|
|
151
|
+
return None, None
|
|
152
|
+
|
|
153
|
+
return filter_specification[0], filter_specification[1]
|
|
154
|
+
|
|
155
|
+
def _apply_composed_filters(
|
|
156
|
+
self,
|
|
157
|
+
messages: list[ModelMessage],
|
|
158
|
+
filter_steps: Any,
|
|
159
|
+
context: Optional[Any],
|
|
160
|
+
) -> list[ModelMessage]:
|
|
161
|
+
filtered_messages = messages
|
|
162
|
+
for filter_step in filter_steps:
|
|
163
|
+
filtered_messages = self._apply_filter(filtered_messages, filter_step, context)
|
|
164
|
+
return filtered_messages
|
|
165
|
+
|
|
166
|
+
def _apply_named_filter(
|
|
167
|
+
self,
|
|
168
|
+
messages: list[ModelMessage],
|
|
169
|
+
filter_name: str,
|
|
170
|
+
filter_value: Any,
|
|
171
|
+
) -> list[ModelMessage]:
|
|
172
|
+
filter_function = self._filter_dispatch.get(filter_name)
|
|
173
|
+
if filter_function is None:
|
|
168
174
|
return messages
|
|
169
175
|
|
|
176
|
+
if filter_name == "system_prefix":
|
|
177
|
+
return filter_function(messages)
|
|
178
|
+
|
|
179
|
+
return filter_function(messages, filter_value)
|
|
180
|
+
|
|
181
|
+
@property
|
|
182
|
+
def _filter_dispatch(self) -> dict[str, Any]:
|
|
183
|
+
return {
|
|
184
|
+
"last_n": self._filter_last_n,
|
|
185
|
+
"first_n": self._filter_first_n,
|
|
186
|
+
"token_budget": self._filter_by_token_budget,
|
|
187
|
+
"head_tokens": self._filter_head_tokens,
|
|
188
|
+
"tail_tokens": self._filter_tail_tokens,
|
|
189
|
+
"by_role": self._filter_by_role,
|
|
190
|
+
"system_prefix": self._filter_system_prefix,
|
|
191
|
+
}
|
|
192
|
+
|
|
170
193
|
def _filter_last_n(
|
|
171
194
|
self,
|
|
172
195
|
messages: list[ModelMessage],
|
|
@@ -29,13 +29,14 @@ class OutputValidator:
|
|
|
29
29
|
"""
|
|
30
30
|
|
|
31
31
|
# Type mapping from YAML to Python
|
|
32
|
-
|
|
32
|
+
SCHEMA_TYPE_TO_PYTHON_TYPE = {
|
|
33
33
|
"string": str,
|
|
34
34
|
"number": (int, float),
|
|
35
35
|
"boolean": bool,
|
|
36
36
|
"object": dict,
|
|
37
37
|
"array": list,
|
|
38
38
|
}
|
|
39
|
+
TYPE_MAP = SCHEMA_TYPE_TO_PYTHON_TYPE
|
|
39
40
|
|
|
40
41
|
@classmethod
|
|
41
42
|
def _is_scalar_schema(cls, schema: Any) -> bool:
|
|
@@ -91,6 +92,15 @@ class OutputValidator:
|
|
|
91
92
|
return dict(output.items())
|
|
92
93
|
return output
|
|
93
94
|
|
|
95
|
+
@staticmethod
|
|
96
|
+
def _wrap_validated_output(
|
|
97
|
+
wrapped_result: Any | None,
|
|
98
|
+
validated_payload: Any,
|
|
99
|
+
) -> Any:
|
|
100
|
+
if wrapped_result is not None:
|
|
101
|
+
return wrapped_result.model_copy(update={"output": validated_payload})
|
|
102
|
+
return validated_payload
|
|
103
|
+
|
|
94
104
|
def validate(self, output: Any) -> Any:
|
|
95
105
|
"""
|
|
96
106
|
Validate workflow output against schema.
|
|
@@ -108,49 +118,63 @@ class OutputValidator:
|
|
|
108
118
|
# while preserving the wrapper (so callers can still access usage/cost/etc.).
|
|
109
119
|
output, wrapped_result = self._unwrap_result(output)
|
|
110
120
|
|
|
111
|
-
# If no schema defined, accept any output
|
|
112
121
|
if not self.schema:
|
|
113
|
-
|
|
114
|
-
validated_payload = self._normalize_unstructured_output(output)
|
|
122
|
+
return self._validate_without_schema(output, wrapped_result)
|
|
115
123
|
|
|
116
|
-
if wrapped_result is not None:
|
|
117
|
-
return wrapped_result.model_copy(update={"output": validated_payload})
|
|
118
|
-
return validated_payload
|
|
119
|
-
|
|
120
|
-
# Scalar output schema: `output = field.string{...}` etc.
|
|
121
124
|
if self._is_scalar_schema(self.schema):
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
125
|
+
return self._validate_scalar_schema(output, wrapped_result)
|
|
126
|
+
|
|
127
|
+
return self._validate_structured_schema(output, wrapped_result)
|
|
128
|
+
|
|
129
|
+
def _validate_without_schema(
|
|
130
|
+
self,
|
|
131
|
+
output: Any,
|
|
132
|
+
wrapped_result: Any | None,
|
|
133
|
+
) -> Any:
|
|
134
|
+
"""Accept any output when no schema is defined."""
|
|
135
|
+
logger.debug("No output schema defined, skipping validation")
|
|
136
|
+
validated_payload = self._normalize_unstructured_output(output)
|
|
137
|
+
return self._wrap_validated_output(wrapped_result, validated_payload)
|
|
138
|
+
|
|
139
|
+
def _validate_scalar_schema(
|
|
140
|
+
self,
|
|
141
|
+
output: Any,
|
|
142
|
+
wrapped_result: Any | None,
|
|
143
|
+
) -> Any:
|
|
144
|
+
"""Validate scalar outputs (`field.string{}` etc.)."""
|
|
145
|
+
# Lua tables are not valid scalar outputs.
|
|
146
|
+
if hasattr(output, "items") and not isinstance(output, dict):
|
|
147
|
+
output = dict(output.items())
|
|
148
|
+
|
|
149
|
+
is_required = self.schema.get("required", False)
|
|
150
|
+
if output is None and not is_required:
|
|
151
|
+
return None
|
|
152
|
+
|
|
153
|
+
expected_type = self.schema.get("type")
|
|
154
|
+
if expected_type and not self._check_type(output, expected_type):
|
|
155
|
+
raise OutputValidationError(
|
|
156
|
+
f"Output should be {expected_type}, got {type(output).__name__}"
|
|
157
|
+
)
|
|
129
158
|
|
|
130
|
-
|
|
131
|
-
|
|
159
|
+
if "enum" in self.schema and self.schema["enum"]:
|
|
160
|
+
allowed_values = self.schema["enum"]
|
|
161
|
+
if output not in allowed_values:
|
|
132
162
|
raise OutputValidationError(
|
|
133
|
-
f"Output
|
|
163
|
+
f"Output has invalid value '{output}'. Allowed values: {allowed_values}"
|
|
134
164
|
)
|
|
135
165
|
|
|
136
|
-
|
|
137
|
-
allowed_values = self.schema["enum"]
|
|
138
|
-
if output not in allowed_values:
|
|
139
|
-
raise OutputValidationError(
|
|
140
|
-
f"Output has invalid value '{output}'. Allowed values: {allowed_values}"
|
|
141
|
-
)
|
|
142
|
-
|
|
143
|
-
validated_payload = output
|
|
144
|
-
if wrapped_result is not None:
|
|
145
|
-
return wrapped_result.model_copy(update={"output": validated_payload})
|
|
146
|
-
return validated_payload
|
|
166
|
+
return self._wrap_validated_output(wrapped_result, output)
|
|
147
167
|
|
|
148
|
-
|
|
168
|
+
def _validate_structured_schema(
|
|
169
|
+
self,
|
|
170
|
+
output: Any,
|
|
171
|
+
wrapped_result: Any | None,
|
|
172
|
+
) -> Any:
|
|
173
|
+
"""Validate dict/table outputs against a schema."""
|
|
149
174
|
if hasattr(output, "items") or isinstance(output, dict):
|
|
150
175
|
logger.debug("Converting Lua tables to Python dicts recursively")
|
|
151
176
|
output = self._convert_lua_tables(output)
|
|
152
177
|
|
|
153
|
-
# Output must be a dict/table
|
|
154
178
|
if not isinstance(output, dict):
|
|
155
179
|
raise OutputValidationError(
|
|
156
180
|
f"Output must be an object/table, got {type(output).__name__}"
|
|
@@ -159,7 +183,6 @@ class OutputValidator:
|
|
|
159
183
|
validation_errors: list[str] = []
|
|
160
184
|
validated_output: dict[str, Any] = {}
|
|
161
185
|
|
|
162
|
-
# Check required fields and validate types
|
|
163
186
|
for field_name, field_def in self.schema.items():
|
|
164
187
|
if not isinstance(field_def, dict) or "type" not in field_def:
|
|
165
188
|
validation_errors.append(
|
|
@@ -167,28 +190,23 @@ class OutputValidator:
|
|
|
167
190
|
f"Use field.{field_def.get('type', 'string')}{{}} instead."
|
|
168
191
|
)
|
|
169
192
|
continue
|
|
170
|
-
is_required = bool(field_def.get("required", False))
|
|
171
193
|
|
|
194
|
+
is_required = bool(field_def.get("required", False))
|
|
172
195
|
if is_required and field_name not in output:
|
|
173
196
|
validation_errors.append(f"Required field '{field_name}' is missing")
|
|
174
197
|
continue
|
|
175
198
|
|
|
176
|
-
# Skip validation if field not present and not required
|
|
177
199
|
if field_name not in output:
|
|
178
200
|
continue
|
|
179
201
|
|
|
180
202
|
value = output[field_name]
|
|
181
|
-
|
|
182
|
-
# Type checking
|
|
183
203
|
expected_type = field_def.get("type")
|
|
184
|
-
if expected_type:
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
)
|
|
204
|
+
if expected_type and not self._check_type(value, expected_type):
|
|
205
|
+
actual_type = type(value).__name__
|
|
206
|
+
validation_errors.append(
|
|
207
|
+
f"Field '{field_name}' should be {expected_type}, got {actual_type}"
|
|
208
|
+
)
|
|
190
209
|
|
|
191
|
-
# Enum validation
|
|
192
210
|
if "enum" in field_def and field_def["enum"]:
|
|
193
211
|
allowed_values = field_def["enum"]
|
|
194
212
|
if value not in allowed_values:
|
|
@@ -197,10 +215,8 @@ class OutputValidator:
|
|
|
197
215
|
f"Allowed values: {allowed_values}"
|
|
198
216
|
)
|
|
199
217
|
|
|
200
|
-
# Add to validated output (only declared fields)
|
|
201
218
|
validated_output[field_name] = value
|
|
202
219
|
|
|
203
|
-
# Filter undeclared fields (only return declared fields)
|
|
204
220
|
for field_name in output:
|
|
205
221
|
if field_name not in self.schema:
|
|
206
222
|
logger.debug("Filtering undeclared field '%s' from output", field_name)
|
|
@@ -210,9 +226,7 @@ class OutputValidator:
|
|
|
210
226
|
raise OutputValidationError(error_message)
|
|
211
227
|
|
|
212
228
|
logger.info("Output validation passed for %s fields", len(validated_output))
|
|
213
|
-
|
|
214
|
-
return wrapped_result.model_copy(update={"output": validated_output})
|
|
215
|
-
return validated_output
|
|
229
|
+
return self._wrap_validated_output(wrapped_result, validated_output)
|
|
216
230
|
|
|
217
231
|
def _check_type(self, value: Any, expected_type: str) -> bool:
|
|
218
232
|
"""
|