core-runtime 0.1.1__py3-none-any.whl
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.
- api/__init__.py +4 -0
- api/cli/__init__.py +10 -0
- api/cli/audit_client.py +92 -0
- api/cli/census_client.py +77 -0
- api/cli/client.py +508 -0
- api/cli/coverage_client.py +121 -0
- api/cli/daemon_client.py +42 -0
- api/cli/fix_client.py +101 -0
- api/cli/inspect_client.py +143 -0
- api/cli/integration_client.py +42 -0
- api/cli/integrity_client.py +45 -0
- api/cli/proposals_client.py +101 -0
- api/cli/quality_client.py +83 -0
- api/cli/refactor_client.py +82 -0
- api/cli/sync_client.py +106 -0
- api/dependencies.py +37 -0
- api/errors.py +74 -0
- api/main.py +88 -0
- api/v1/__init__.py +4 -0
- api/v1/audit_routes.py +302 -0
- api/v1/census_routes.py +207 -0
- api/v1/coverage_routes.py +352 -0
- api/v1/daemon_routes.py +86 -0
- api/v1/development_routes.py +70 -0
- api/v1/fix_routes.py +428 -0
- api/v1/inspect_routes.py +220 -0
- api/v1/integration_routes.py +56 -0
- api/v1/integrity_routes.py +72 -0
- api/v1/knowledge_routes.py +36 -0
- api/v1/lint_routes.py +40 -0
- api/v1/proposals_routes.py +267 -0
- api/v1/quality_routes.py +272 -0
- api/v1/refactor_routes.py +225 -0
- api/v1/sync_routes.py +261 -0
- body/__init__.py +4 -0
- body/analyzers/__init__.py +25 -0
- body/analyzers/base_analyzer.py +28 -0
- body/analyzers/constitutional_path_analyzer.py +63 -0
- body/analyzers/file_analyzer.py +211 -0
- body/analyzers/knowledge_graph_analyzer.py +86 -0
- body/analyzers/prompt_analyzer.py +155 -0
- body/analyzers/symbol_extractor.py +280 -0
- body/atomic/__init__.py +74 -0
- body/atomic/build_tests_action.py +354 -0
- body/atomic/check_actions.py +142 -0
- body/atomic/crate_ops.py +59 -0
- body/atomic/executor.py +470 -0
- body/atomic/file_ops.py +153 -0
- body/atomic/fix_actions.py +1142 -0
- body/atomic/import_resolver.py +200 -0
- body/atomic/metadata_ops.py +161 -0
- body/atomic/modularity_fix.py +839 -0
- body/atomic/modularity_splitter.py +521 -0
- body/atomic/proposal_lifecycle_actions.py +171 -0
- body/atomic/registry.py +326 -0
- body/atomic/remediate_cognitive_role.py +104 -0
- body/atomic/sandbox_lifecycle.py +252 -0
- body/atomic/split_plan.py +155 -0
- body/atomic/sync_actions/__init__.py +22 -0
- body/atomic/sync_actions/chunking_helpers.py +218 -0
- body/atomic/sync_actions/sync_actions.py +431 -0
- body/atomic/test_actions.py +47 -0
- body/autonomy/__init__.py +16 -0
- body/autonomy/audit_analyzer.py +343 -0
- body/autonomy/micro_proposal_executor.py +316 -0
- body/crate_processing/canary_executor.py +144 -0
- body/evaluators/__init__.py +27 -0
- body/evaluators/atomic_actions_evaluator.py +162 -0
- body/evaluators/atomic_actions_format.py +45 -0
- body/evaluators/atomic_actions_rules.py +278 -0
- body/evaluators/base_evaluator.py +67 -0
- body/evaluators/clarity_evaluator.py +83 -0
- body/evaluators/constitutional_evaluator.py +227 -0
- body/evaluators/failure_evaluator.py +136 -0
- body/evaluators/performance_evaluator.py +341 -0
- body/evaluators/security_evaluator.py +393 -0
- body/flows/__init__.py +33 -0
- body/flows/executor.py +275 -0
- body/flows/registry.py +272 -0
- body/flows/result.py +113 -0
- body/governance/__init__.py +29 -0
- body/governance/body_contracts_service.py +317 -0
- body/governance/code_validator.py +118 -0
- body/governance/engine_dispatcher.py +128 -0
- body/governance/intent_guard.py +592 -0
- body/governance/intent_pattern_validators.py +197 -0
- body/governance/key_management_service.py +100 -0
- body/governance/path_validator.py +187 -0
- body/governance/remediation_service.py +263 -0
- body/governance/runtime_validator.py +184 -0
- body/infrastructure/bootstrap.py +135 -0
- body/infrastructure/lifespan.py +85 -0
- body/infrastructure/repositories/__init__.py +1 -0
- body/infrastructure/repositories/decision_trace_repository.py +210 -0
- body/infrastructure/repositories/refusal_repository.py +294 -0
- body/introspection/__init__.py +4 -0
- body/introspection/capability_discovery_service.py +107 -0
- body/introspection/discovery/from_kgb.py +33 -0
- body/introspection/discovery/from_source_scan.py +40 -0
- body/introspection/discovery/loader.py +62 -0
- body/introspection/discovery/registry.py +22 -0
- body/introspection/discovery/semantics.py +21 -0
- body/introspection/discovery/sync.py +47 -0
- body/introspection/drift_detector.py +81 -0
- body/introspection/drift_service.py +48 -0
- body/introspection/export_vectors.py +133 -0
- body/introspection/generate_capability_docs.py +130 -0
- body/introspection/generate_correction_map.py +98 -0
- body/introspection/graph_analysis_service.py +66 -0
- body/introspection/knowledge_graph_service.py +170 -0
- body/introspection/semantic_clusterer.py +128 -0
- body/introspection/symbol_index_builder.py +244 -0
- body/introspection/sync/engine.py +92 -0
- body/introspection/sync/scanner.py +56 -0
- body/introspection/sync/visitor.py +83 -0
- body/introspection/sync_service.py +62 -0
- body/invokers/__init__.py +4 -0
- body/invokers/capability_invoker.py +4 -0
- body/maintenance/command_sync_service.py +73 -0
- body/maintenance/dotenv_sync_service.py +99 -0
- body/maintenance/idempotency_harness.py +70 -0
- body/maintenance/maintenance_service.py +123 -0
- body/maintenance/memory_cleanup_service.py +131 -0
- body/maintenance/refactor_settings_access.py +274 -0
- body/maintenance/scripts/__init__.py +5 -0
- body/maintenance/scripts/context_export.py +278 -0
- body/maintenance/scripts/vector_verify.py +73 -0
- body/maintenance/sync_vectors.py +338 -0
- body/models/__init__.py +4 -0
- body/project_lifecycle/__init__.py +4 -0
- body/project_lifecycle/bootstrap_service.py +157 -0
- body/project_lifecycle/definition_service.py +264 -0
- body/project_lifecycle/integration_service.py +113 -0
- body/project_lifecycle/scaffolding_service.py +187 -0
- body/quality/coverage_analyzer.py +177 -0
- body/repositories/__init__.py +4 -0
- body/self_healing/atomic_actions_fixer.py +113 -0
- body/self_healing/body_ui_fixer.py +193 -0
- body/self_healing/capability_parser.py +65 -0
- body/self_healing/code_style_service.py +51 -0
- body/self_healing/complexity_filter.py +70 -0
- body/self_healing/docstring_service.py +345 -0
- body/self_healing/duplicate_id_service.py +407 -0
- body/self_healing/duplicates_service.py +165 -0
- body/self_healing/handlers/__init__.py +1 -0
- body/self_healing/handlers/id_assignment_handler.py +201 -0
- body/self_healing/handlers/import_sorting_handler.py +181 -0
- body/self_healing/header_service.py +308 -0
- body/self_healing/id_tagging_service.py +227 -0
- body/self_healing/knowledge_consolidation_service.py +80 -0
- body/self_healing/logging_service.py +292 -0
- body/self_healing/owner_tagging_service.py +5 -0
- body/self_healing/placeholder_fixer_service.py +27 -0
- body/self_healing/prune_private_capabilities.py +144 -0
- body/self_healing/purge_legacy_tags_service.py +146 -0
- body/self_healing/remediation_models.py +238 -0
- body/self_healing/test_context/__init__.py +10 -0
- body/self_healing/test_context/detectors.py +74 -0
- body/self_healing/test_context/examples.py +53 -0
- body/self_healing/test_context/formatter.py +65 -0
- body/self_healing/test_context/metrics.py +62 -0
- body/self_healing/test_context/models.py +83 -0
- body/self_healing/test_context/parsers.py +70 -0
- body/self_healing/test_context_analyzer.py +79 -0
- body/self_healing/test_failure_analyzer.py +259 -0
- body/self_healing/test_target_analyzer.py +118 -0
- body/self_healing/vulture_healer.py +161 -0
- body/services/__init__.py +4 -0
- body/services/artifact_service.py +155 -0
- body/services/blackboard_service/__init__.py +22 -0
- body/services/blackboard_service/blackboard_claim_service.py +216 -0
- body/services/blackboard_service/blackboard_proposal_service.py +305 -0
- body/services/blackboard_service/blackboard_query_service.py +333 -0
- body/services/blackboard_service/blackboard_service.py +602 -0
- body/services/capabilities.py +51 -0
- body/services/cim/__init__.py +22 -0
- body/services/cim/baselines.py +102 -0
- body/services/cim/census_service.py +190 -0
- body/services/cim/cim_constants.py +116 -0
- body/services/cim/cim_path_utils.py +123 -0
- body/services/cim/diff.py +152 -0
- body/services/cim/history.py +94 -0
- body/services/cim/models.py +319 -0
- body/services/cim/policy.py +149 -0
- body/services/cim/scanners.py +332 -0
- body/services/coherence_service.py +552 -0
- body/services/consequence_log_service.py +189 -0
- body/services/constitutional_rule_loader.py +141 -0
- body/services/constitutional_validator.py +366 -0
- body/services/crate_creation_service.py +217 -0
- body/services/crate_processing_service.py +279 -0
- body/services/crawl_service/__init__.py +10 -0
- body/services/crawl_service/main_module.py +531 -0
- body/services/crawl_service/orchestrator.py +452 -0
- body/services/crawl_service/symbol_processing.py +279 -0
- body/services/database_service.py +242 -0
- body/services/doc_service.py +57 -0
- body/services/file_service.py +260 -0
- body/services/governance_claims_service.py +240 -0
- body/services/governance_init.py +41 -0
- body/services/health_log_service.py +167 -0
- body/services/intent_schema_validator.py +211 -0
- body/services/llm_client.py +87 -0
- body/services/mind_state_service.py +129 -0
- body/services/policy_expression_evaluator.py +154 -0
- body/services/proposal_supervision_service.py +187 -0
- body/services/representation_coherence_service.py +209 -0
- body/services/service_registry.py +431 -0
- body/services/session_attached_service.py +51 -0
- body/services/symbol_query_service.py +218 -0
- body/services/symbol_service.py +94 -0
- body/services/validation/__init__.py +14 -0
- body/services/validation/python_validator.py +89 -0
- body/services/validation/validation_policies.py +121 -0
- body/services/worker_registry_service.py +184 -0
- body/validators/__init__.py +1 -0
- body/validators/logic_conservation_validator.py +201 -0
- body/workers/call_site_rewriter.py +527 -0
- body/workers/prompt_artifact_writer.py +323 -0
- cli/__init__.py +4 -0
- cli/admin_cli.py +98 -0
- cli/cli_user.py +121 -0
- cli/commands/__init__.py +4 -0
- cli/commands/audit_reporter.py +272 -0
- cli/commands/check/__init__.py +115 -0
- cli/commands/check/audit.py +130 -0
- cli/commands/check/converters.py +129 -0
- cli/commands/check/diagnostics_commands.py +70 -0
- cli/commands/check/formatters.py +310 -0
- cli/commands/check/imports.py +73 -0
- cli/commands/check/quality.py +71 -0
- cli/commands/check/quality_gates.py +107 -0
- cli/commands/check/rule.py +136 -0
- cli/commands/check/utils.py +28 -0
- cli/commands/check_atomic_actions.py +167 -0
- cli/commands/components.py +66 -0
- cli/commands/coverage/__init__.py +22 -0
- cli/commands/coverage/analysis_commands.py +87 -0
- cli/commands/coverage/check_commands.py +173 -0
- cli/commands/coverage/generation_commands.py +155 -0
- cli/commands/coverage/services/__init__.py +15 -0
- cli/commands/coverage/services/coverage_checker.py +50 -0
- cli/commands/coverage/services/coverage_reporter.py +81 -0
- cli/commands/coverage/services/gaps_analyzer.py +114 -0
- cli/commands/daemon.py +908 -0
- cli/commands/develop.py +127 -0
- cli/commands/diagnostics.py +32 -0
- cli/commands/fix/__init__.py +84 -0
- cli/commands/fix/all_commands.py +94 -0
- cli/commands/fix/atomic_actions.py +48 -0
- cli/commands/fix/audit.py +146 -0
- cli/commands/fix/body_ui.py +93 -0
- cli/commands/fix/code_style.py +52 -0
- cli/commands/fix/db_tools.py +90 -0
- cli/commands/fix/fix_ir.py +79 -0
- cli/commands/fix/handler_discovery.py +54 -0
- cli/commands/fix/imports.py +55 -0
- cli/commands/fix/list_commands.py +54 -0
- cli/commands/fix/metadata.py +160 -0
- cli/commands/fix/modularity.py +88 -0
- cli/commands/fix/settings_access.py +65 -0
- cli/commands/fix_governed.py +103 -0
- cli/commands/fix_logging.py +24 -0
- cli/commands/governance.py +294 -0
- cli/commands/guard.py +125 -0
- cli/commands/inspect/__init__.py +79 -0
- cli/commands/inspect/_helpers.py +226 -0
- cli/commands/inspect/analysis.py +158 -0
- cli/commands/inspect/decisions.py +140 -0
- cli/commands/inspect/diagnostics.py +126 -0
- cli/commands/inspect/drift.py +100 -0
- cli/commands/inspect/patterns.py +102 -0
- cli/commands/inspect/refusals.py +211 -0
- cli/commands/inspect/repo_census.py +175 -0
- cli/commands/inspect/status.py +48 -0
- cli/commands/interactive_test.py +85 -0
- cli/commands/mind.py +49 -0
- cli/commands/refactor.py +234 -0
- cli/commands/refactor_support/__init__.py +7 -0
- cli/commands/refactor_support/analyzer.py +107 -0
- cli/commands/refactor_support/config.py +67 -0
- cli/commands/refactor_support/display.py +170 -0
- cli/commands/refactor_support/recommendations.py +55 -0
- cli/commands/run.py +60 -0
- cli/commands/search.py +103 -0
- cli/commands/status.py +86 -0
- cli/commands/submit.py +23 -0
- cli/interactive.py +177 -0
- cli/logic/__init__.py +7 -0
- cli/logic/agent.py +110 -0
- cli/logic/audit_capability_domains.py +106 -0
- cli/logic/audit_renderer.py +150 -0
- cli/logic/autonomy/actions.py +36 -0
- cli/logic/autonomy/views.py +116 -0
- cli/logic/body_contracts_checker.py +23 -0
- cli/logic/build.py +27 -0
- cli/logic/byor.py +148 -0
- cli/logic/capability.py +27 -0
- cli/logic/cli_utils.py +210 -0
- cli/logic/context.py +7 -0
- cli/logic/db.py +154 -0
- cli/logic/db_manage.py +22 -0
- cli/logic/decision_inspect_logic.py +62 -0
- cli/logic/diagnostics.py +148 -0
- cli/logic/diagnostics_policy.py +100 -0
- cli/logic/diagnostics_registry.py +165 -0
- cli/logic/duplicates.py +19 -0
- cli/logic/embeddings_cli.py +43 -0
- cli/logic/governance/__init__.py +16 -0
- cli/logic/governance/engine.py +216 -0
- cli/logic/governance/forensics_service.py +67 -0
- cli/logic/governance/limb_status_service.py +83 -0
- cli/logic/governance/renderer.py +115 -0
- cli/logic/governance/traceability_service.py +78 -0
- cli/logic/governance_logic.py +33 -0
- cli/logic/hub/__init__.py +14 -0
- cli/logic/hub/app.py +107 -0
- cli/logic/hub/formatter.py +29 -0
- cli/logic/hub/introspection.py +20 -0
- cli/logic/hub/repository.py +17 -0
- cli/logic/init.py +22 -0
- cli/logic/interactive_test/__init__.py +21 -0
- cli/logic/interactive_test/session.py +102 -0
- cli/logic/interactive_test/steps/__init__.py +23 -0
- cli/logic/interactive_test/steps/execution.py +53 -0
- cli/logic/interactive_test/steps/generation.py +88 -0
- cli/logic/interactive_test/steps/healing.py +79 -0
- cli/logic/interactive_test/steps/utils.py +31 -0
- cli/logic/interactive_test/steps/verification.py +71 -0
- cli/logic/interactive_test/ui.py +203 -0
- cli/logic/interactive_test/workflow.py +168 -0
- cli/logic/interactive_test_logic.py +41 -0
- cli/logic/knowledge.py +47 -0
- cli/logic/legacy_scan_logic.py +306 -0
- cli/logic/list_audits.py +49 -0
- cli/logic/log_audit.py +53 -0
- cli/logic/new.py +8 -0
- cli/logic/project_docs.py +28 -0
- cli/logic/reconcile.py +127 -0
- cli/logic/refusal_inspect_logic.py +208 -0
- cli/logic/report.py +47 -0
- cli/logic/status.py +47 -0
- cli/logic/symbol_drift.py +77 -0
- cli/logic/sync.py +48 -0
- cli/logic/sync_domains.py +72 -0
- cli/logic/sync_manifest.py +31 -0
- cli/logic/tools.py +133 -0
- cli/logic/utils_migration.py +43 -0
- cli/logic/validate.py +107 -0
- cli/logic/vector_drift.py +109 -0
- cli/logic/yaml_processor.py +5 -0
- cli/renderers/audit_detail.py +37 -0
- cli/renderers/audit_overview.py +39 -0
- cli/resources/__init__.py +27 -0
- cli/resources/admin/__init__.py +23 -0
- cli/resources/admin/coverage.py +63 -0
- cli/resources/admin/debt_scan.py +195 -0
- cli/resources/admin/forensics.py +97 -0
- cli/resources/admin/health.py +66 -0
- cli/resources/admin/hub.py +9 -0
- cli/resources/admin/meta.py +47 -0
- cli/resources/admin/patterns.py +28 -0
- cli/resources/admin/refusals.py +31 -0
- cli/resources/admin/self_check.py +175 -0
- cli/resources/admin/status.py +66 -0
- cli/resources/admin/summary.py +67 -0
- cli/resources/admin/traces.py +46 -0
- cli/resources/admin/validate_env.py +56 -0
- cli/resources/code/__init__.py +31 -0
- cli/resources/code/actions.py +48 -0
- cli/resources/code/audit.py +416 -0
- cli/resources/code/audit_duplicates.py +22 -0
- cli/resources/code/check_imports.py +75 -0
- cli/resources/code/check_ui.py +62 -0
- cli/resources/code/clarity.py +51 -0
- cli/resources/code/complexity.py +55 -0
- cli/resources/code/docstrings.py +51 -0
- cli/resources/code/fix_atomic.py +51 -0
- cli/resources/code/format.py +62 -0
- cli/resources/code/hub.py +10 -0
- cli/resources/code/integrity.py +75 -0
- cli/resources/code/lint.py +37 -0
- cli/resources/code/logging.py +49 -0
- cli/resources/code/refactor.py +32 -0
- cli/resources/code/test.py +30 -0
- cli/resources/coherence/__init__.py +13 -0
- cli/resources/coherence/check.py +111 -0
- cli/resources/coherence/hub.py +13 -0
- cli/resources/coherence/repair_counts.py +73 -0
- cli/resources/coherence/report.py +144 -0
- cli/resources/coherence/seed.py +297 -0
- cli/resources/coherence/supersede.py +124 -0
- cli/resources/coherence/triage.py +81 -0
- cli/resources/constitution/__init__.py +19 -0
- cli/resources/constitution/audit.py +49 -0
- cli/resources/constitution/query.py +45 -0
- cli/resources/constitution/status.py +34 -0
- cli/resources/constitution/validate.py +36 -0
- cli/resources/context/__init__.py +21 -0
- cli/resources/context/build.py +374 -0
- cli/resources/context/cache.py +156 -0
- cli/resources/context/explain.py +140 -0
- cli/resources/context/hub.py +11 -0
- cli/resources/context/search.py +114 -0
- cli/resources/database/__init__.py +13 -0
- cli/resources/database/cleanup.py +107 -0
- cli/resources/database/export.py +61 -0
- cli/resources/database/hub.py +11 -0
- cli/resources/database/migrate.py +57 -0
- cli/resources/database/status.py +101 -0
- cli/resources/database/sync.py +84 -0
- cli/resources/database/sync_env.py +76 -0
- cli/resources/database/sync_registry.py +48 -0
- cli/resources/dev/__init__.py +14 -0
- cli/resources/dev/hub.py +11 -0
- cli/resources/dev/refactor.py +92 -0
- cli/resources/dev/stability.py +60 -0
- cli/resources/dev/strategic_audit.py +113 -0
- cli/resources/dev/sync.py +51 -0
- cli/resources/dev/test.py +34 -0
- cli/resources/intent/__init__.py +11 -0
- cli/resources/intent/hub.py +9 -0
- cli/resources/intent/sync_vocabulary.py +396 -0
- cli/resources/project/__init__.py +19 -0
- cli/resources/project/docs.py +41 -0
- cli/resources/project/new.py +40 -0
- cli/resources/project/onboard.py +31 -0
- cli/resources/proposals/__init__.py +28 -0
- cli/resources/proposals/create.py +82 -0
- cli/resources/proposals/integrate.py +49 -0
- cli/resources/proposals/list.py +76 -0
- cli/resources/proposals/manage.py +117 -0
- cli/resources/runtime/__init__.py +9 -0
- cli/resources/runtime/health.py +925 -0
- cli/resources/secrets/__init__.py +10 -0
- cli/resources/secrets/hub.py +9 -0
- cli/resources/secrets/manage.py +309 -0
- cli/resources/symbols/__init__.py +13 -0
- cli/resources/symbols/audit.py +46 -0
- cli/resources/symbols/fix_ids.py +43 -0
- cli/resources/symbols/hub.py +11 -0
- cli/resources/symbols/resolve_duplicates.py +30 -0
- cli/resources/symbols/sync.py +39 -0
- cli/resources/symbols/tag.py +47 -0
- cli/resources/vectors/__init__.py +11 -0
- cli/resources/vectors/cleanup.py +95 -0
- cli/resources/vectors/hub.py +9 -0
- cli/resources/vectors/query.py +105 -0
- cli/resources/vectors/status.py +30 -0
- cli/resources/vectors/sync.py +57 -0
- cli/resources/vectors/sync_code.py +67 -0
- cli/resources/workers/__init__.py +13 -0
- cli/resources/workers/blackboard.py +253 -0
- cli/resources/workers/remediate.py +337 -0
- cli/resources/workers/run.py +140 -0
- cli/utils/__init__.py +32 -0
- cli/utils/annotation_formatter.py +154 -0
- cli/utils/decorators.py +184 -0
- cli/utils/display.py +79 -0
- cli/utils/exit_codes.py +59 -0
- cli/utils/helpers.py +34 -0
- cli/utils/prompts.py +21 -0
- core_runtime-0.1.1.dist-info/LICENSE +21 -0
- core_runtime-0.1.1.dist-info/METADATA +346 -0
- core_runtime-0.1.1.dist-info/RECORD +962 -0
- core_runtime-0.1.1.dist-info/WHEEL +4 -0
- core_runtime-0.1.1.dist-info/entry_points.txt +4 -0
- mind/__init__.py +4 -0
- mind/coherence/__init__.py +1 -0
- mind/coherence/checker.py +314 -0
- mind/coherence/checks/__init__.py +4 -0
- mind/coherence/checks/base.py +34 -0
- mind/coherence/checks/r1_scoped.py +228 -0
- mind/coherence/checks/row2_grounding.py +69 -0
- mind/coherence/checks/row3_citation.py +119 -0
- mind/coherence/checks/row4_naming.py +126 -0
- mind/coherence/checks/sameconcern.py +136 -0
- mind/coherence/checks/specgap.py +233 -0
- mind/coherence/checks/vocabulary.py +112 -0
- mind/coherence/llm_judge.py +207 -0
- mind/enforcement/audit.py +78 -0
- mind/governance/__init__.py +22 -0
- mind/governance/assumption_extractor.py +326 -0
- mind/governance/audit_context.py +520 -0
- mind/governance/audit_postprocessor.py +36 -0
- mind/governance/audit_report_writer.py +46 -0
- mind/governance/audit_types.py +98 -0
- mind/governance/auditor.py +179 -0
- mind/governance/authority_package_builder.py +502 -0
- mind/governance/constitutional_auditor_dynamic.py +362 -0
- mind/governance/enforcement/__init__.py +24 -0
- mind/governance/enforcement_loader.py +245 -0
- mind/governance/enforcement_methods.py +28 -0
- mind/governance/entry_point_policy.py +62 -0
- mind/governance/executable_rule.py +127 -0
- mind/governance/filtered_audit.py +272 -0
- mind/governance/finding_processor.py +76 -0
- mind/governance/meta_validator.py +259 -0
- mind/governance/micro_proposal_validator.py +169 -0
- mind/governance/policy_coverage_service.py +183 -0
- mind/governance/policy_rule.py +94 -0
- mind/governance/rule_conflict_detector.py +127 -0
- mind/governance/rule_executor.py +306 -0
- mind/governance/rule_extractor.py +376 -0
- mind/governance/stateless_audit.py +206 -0
- mind/governance/violation_report.py +136 -0
- mind/logic/engines/_knowledge_gate_duplication.py +117 -0
- mind/logic/engines/action_gate.py +76 -0
- mind/logic/engines/artifact_gate.py +1168 -0
- mind/logic/engines/ast_gate/__init__.py +9 -0
- mind/logic/engines/ast_gate/base.py +263 -0
- mind/logic/engines/ast_gate/checks/__init__.py +35 -0
- mind/logic/engines/ast_gate/checks/async_checks.py +276 -0
- mind/logic/engines/ast_gate/checks/capability_checks.py +197 -0
- mind/logic/engines/ast_gate/checks/conservation_checks.py +126 -0
- mind/logic/engines/ast_gate/checks/generic_checks.py +244 -0
- mind/logic/engines/ast_gate/checks/import_checks.py +164 -0
- mind/logic/engines/ast_gate/checks/knowledge_source_check.py +88 -0
- mind/logic/engines/ast_gate/checks/logging_checks.py +133 -0
- mind/logic/engines/ast_gate/checks/metadata_checks.py +242 -0
- mind/logic/engines/ast_gate/checks/modularity_checks.py +436 -0
- mind/logic/engines/ast_gate/checks/naming_checks.py +120 -0
- mind/logic/engines/ast_gate/checks/prompt_model_checks.py +83 -0
- mind/logic/engines/ast_gate/checks/protected_namespace_access_check.py +298 -0
- mind/logic/engines/ast_gate/checks/purity_checks.py +421 -0
- mind/logic/engines/ast_gate/checks/purity_enforcement_check.py +56 -0
- mind/logic/engines/ast_gate/checks/runtime_import_boundary.py +198 -0
- mind/logic/engines/ast_gate/checks/schema_conformance_checks.py +130 -0
- mind/logic/engines/ast_gate/engine.py +317 -0
- mind/logic/engines/ast_gate.py +19 -0
- mind/logic/engines/base.py +106 -0
- mind/logic/engines/cli_gate/__init__.py +25 -0
- mind/logic/engines/cli_gate/base_check.py +45 -0
- mind/logic/engines/cli_gate/checks/__init__.py +31 -0
- mind/logic/engines/cli_gate/checks/async_execution.py +65 -0
- mind/logic/engines/cli_gate/checks/dangerous_explicit.py +60 -0
- mind/logic/engines/cli_gate/checks/discovery_strict.py +167 -0
- mind/logic/engines/cli_gate/checks/help_required.py +43 -0
- mind/logic/engines/cli_gate/checks/no_duplicates.py +57 -0
- mind/logic/engines/cli_gate/checks/no_layer_exposure.py +48 -0
- mind/logic/engines/cli_gate/checks/resource_first.py +58 -0
- mind/logic/engines/cli_gate/checks/standard_verbs.py +50 -0
- mind/logic/engines/cli_gate/engine.py +211 -0
- mind/logic/engines/glob_gate.py +214 -0
- mind/logic/engines/knowledge_gate.py +410 -0
- mind/logic/engines/llm_gate.py +407 -0
- mind/logic/engines/llm_gate_stub.py +67 -0
- mind/logic/engines/passive_gate.py +45 -0
- mind/logic/engines/regex_gate.py +97 -0
- mind/logic/engines/registry.py +134 -0
- mind/logic/engines/runtime_gate.py +265 -0
- mind/logic/engines/taxonomy_gate.py +229 -0
- mind/logic/engines/workflow_gate/__init__.py +22 -0
- mind/logic/engines/workflow_gate/base_check.py +42 -0
- mind/logic/engines/workflow_gate/checks/__init__.py +32 -0
- mind/logic/engines/workflow_gate/checks/alignment.py +93 -0
- mind/logic/engines/workflow_gate/checks/audit.py +80 -0
- mind/logic/engines/workflow_gate/checks/canary.py +47 -0
- mind/logic/engines/workflow_gate/checks/coverage.py +74 -0
- mind/logic/engines/workflow_gate/checks/dead_code.py +53 -0
- mind/logic/engines/workflow_gate/checks/import_resolution.py +97 -0
- mind/logic/engines/workflow_gate/checks/linter.py +104 -0
- mind/logic/engines/workflow_gate/checks/quality.py +49 -0
- mind/logic/engines/workflow_gate/checks/ruff_format.py +99 -0
- mind/logic/engines/workflow_gate/checks/tests.py +81 -0
- mind/logic/engines/workflow_gate/engine.py +207 -0
- shared/__init__.py +32 -0
- shared/action_logger.py +61 -0
- shared/action_types.py +199 -0
- shared/activity_logging.py +149 -0
- shared/ai/constitutional_envelope.py +341 -0
- shared/ai/prompt_model.py +585 -0
- shared/ai/response_parser.py +191 -0
- shared/ast_utility.py +279 -0
- shared/atomic_action.py +117 -0
- shared/cli/__init__.py +6 -0
- shared/cli/app_introspection.py +134 -0
- shared/cli/command_meta.py +224 -0
- shared/cli_types.py +92 -0
- shared/component_primitive.py +216 -0
- shared/config.py +216 -0
- shared/config_loader.py +54 -0
- shared/context.py +113 -0
- shared/exceptions.py +100 -0
- shared/governance/__init__.py +9 -0
- shared/governance/coherence_harvester.py +258 -0
- shared/governance_token.py +77 -0
- shared/infrastructure/__init__.py +5 -0
- shared/infrastructure/adapters/__init__.py +5 -0
- shared/infrastructure/adapters/embedding_provider.py +66 -0
- shared/infrastructure/bootstrap_registry.py +57 -0
- shared/infrastructure/clients/__init__.py +5 -0
- shared/infrastructure/clients/qdrant_client.py +455 -0
- shared/infrastructure/config_service.py +382 -0
- shared/infrastructure/config_validator.py +70 -0
- shared/infrastructure/context/__init__.py +45 -0
- shared/infrastructure/context/builder.py +804 -0
- shared/infrastructure/context/cache.py +101 -0
- shared/infrastructure/context/database.py +205 -0
- shared/infrastructure/context/limb_workspace.py +134 -0
- shared/infrastructure/context/models.py +65 -0
- shared/infrastructure/context/providers/__init__.py +18 -0
- shared/infrastructure/context/providers/ast.py +211 -0
- shared/infrastructure/context/providers/db.py +165 -0
- shared/infrastructure/context/providers/vectors.py +195 -0
- shared/infrastructure/context/redactor.py +109 -0
- shared/infrastructure/context/serializers.py +144 -0
- shared/infrastructure/context/service.py +271 -0
- shared/infrastructure/context/validator.py +247 -0
- shared/infrastructure/database/models/__init__.py +80 -0
- shared/infrastructure/database/models/autonomous_proposals.py +83 -0
- shared/infrastructure/database/models/decision_traces.py +129 -0
- shared/infrastructure/database/models/governance.py +183 -0
- shared/infrastructure/database/models/knowledge.py +205 -0
- shared/infrastructure/database/models/learning.py +99 -0
- shared/infrastructure/database/models/llm_config.py +274 -0
- shared/infrastructure/database/models/operations.py +152 -0
- shared/infrastructure/database/models/refusals.py +147 -0
- shared/infrastructure/database/models/system.py +124 -0
- shared/infrastructure/database/models/vectors.py +113 -0
- shared/infrastructure/database/models/workers.py +96 -0
- shared/infrastructure/database/session_manager.py +166 -0
- shared/infrastructure/diagnostic_service.py +103 -0
- shared/infrastructure/events/__init__.py +5 -0
- shared/infrastructure/events/base.py +44 -0
- shared/infrastructure/events/bus.py +76 -0
- shared/infrastructure/git_service.py +385 -0
- shared/infrastructure/intent/action_risk.py +135 -0
- shared/infrastructure/intent/audit_verdict.py +131 -0
- shared/infrastructure/intent/autonomy_dirty_tree.py +104 -0
- shared/infrastructure/intent/canonical_enums.py +116 -0
- shared/infrastructure/intent/cognitive_roles.py +96 -0
- shared/infrastructure/intent/errors.py +13 -0
- shared/infrastructure/intent/filesystem_operations.py +359 -0
- shared/infrastructure/intent/intent_connector.py +157 -0
- shared/infrastructure/intent/intent_repository.py +707 -0
- shared/infrastructure/intent/intent_validator.py +248 -0
- shared/infrastructure/intent/operational_capabilities.py +470 -0
- shared/infrastructure/intent/operational_config.py +1343 -0
- shared/infrastructure/intent/operational_mode.py +66 -0
- shared/infrastructure/intent/task_type_phases.py +180 -0
- shared/infrastructure/intent/test_coverage_paths.py +181 -0
- shared/infrastructure/intent/vocabulary_projection.py +241 -0
- shared/infrastructure/knowledge/knowledge_service.py +155 -0
- shared/infrastructure/knowledge_graph_service.py +214 -0
- shared/infrastructure/llm/client.py +448 -0
- shared/infrastructure/llm/client_registry.py +153 -0
- shared/infrastructure/llm/fallback_client.py +144 -0
- shared/infrastructure/llm/providers/anthropic.py +113 -0
- shared/infrastructure/llm/providers/base.py +130 -0
- shared/infrastructure/llm/providers/ollama.py +265 -0
- shared/infrastructure/llm/providers/openai.py +168 -0
- shared/infrastructure/repositories/__init__.py +5 -0
- shared/infrastructure/repositories/db/__init__.py +5 -0
- shared/infrastructure/repositories/db/common.py +138 -0
- shared/infrastructure/repositories/db/engine.py +26 -0
- shared/infrastructure/repositories/db/migration_service.py +75 -0
- shared/infrastructure/repositories/db/status_service.py +61 -0
- shared/infrastructure/repositories/memory_repository.py +134 -0
- shared/infrastructure/repositories/symbol_definition_repository.py +170 -0
- shared/infrastructure/repositories/task_repository.py +59 -0
- shared/infrastructure/repositories/vector_link_repository.py +83 -0
- shared/infrastructure/rooted_repository.py +50 -0
- shared/infrastructure/secrets_service.py +317 -0
- shared/infrastructure/specs/__init__.py +9 -0
- shared/infrastructure/specs/specs_repository.py +100 -0
- shared/infrastructure/storage/file_classifier.py +32 -0
- shared/infrastructure/storage/file_handler.py +330 -0
- shared/infrastructure/storage/file_provider.py +233 -0
- shared/infrastructure/storage/integrity_service.py +108 -0
- shared/infrastructure/validation/black_formatter.py +41 -0
- shared/infrastructure/validation/quality.py +46 -0
- shared/infrastructure/validation/ruff_linter.py +104 -0
- shared/infrastructure/validation/syntax_checker.py +45 -0
- shared/infrastructure/validation/test_runner.py +167 -0
- shared/infrastructure/validation/yaml_validator.py +45 -0
- shared/infrastructure/vector/__init__.py +15 -0
- shared/infrastructure/vector/adapters/__init__.py +20 -0
- shared/infrastructure/vector/adapters/constitutional/__init__.py +26 -0
- shared/infrastructure/vector/adapters/constitutional/chunker.py +246 -0
- shared/infrastructure/vector/adapters/constitutional/doc_key_resolver.py +109 -0
- shared/infrastructure/vector/adapters/constitutional/item_builder.py +158 -0
- shared/infrastructure/vector/adapters/constitutional/utils.py +39 -0
- shared/infrastructure/vector/adapters/constitutional_adapter.py +309 -0
- shared/infrastructure/vector/adapters/specs_adapter.py +171 -0
- shared/infrastructure/vector/cognitive_adapter.py +119 -0
- shared/infrastructure/vector/vector_index_service.py +230 -0
- shared/logger.py +195 -0
- shared/models/__init__.py +47 -0
- shared/models/action_result.py +77 -0
- shared/models/audit_models.py +106 -0
- shared/models/audit_rendering.py +30 -0
- shared/models/capability_models.py +22 -0
- shared/models/constitutional_validation.py +185 -0
- shared/models/drift_models.py +24 -0
- shared/models/embedding_payload.py +45 -0
- shared/models/execution_models.py +71 -0
- shared/models/pattern_graph.py +62 -0
- shared/models/prompt_model.py +244 -0
- shared/models/refusal_result.py +294 -0
- shared/models/remediation.py +35 -0
- shared/models/validation_result.py +34 -0
- shared/models/vector_models.py +62 -0
- shared/models/workflow_models.py +242 -0
- shared/path_resolver.py +408 -0
- shared/path_utils.py +60 -0
- shared/processors/base_processor.py +171 -0
- shared/processors/yaml_processor.py +72 -0
- shared/protocols/__init__.py +21 -0
- shared/protocols/brain_services.py +35 -0
- shared/protocols/cognitive.py +35 -0
- shared/protocols/executor.py +47 -0
- shared/protocols/interpreter.py +24 -0
- shared/protocols/knowledge.py +21 -0
- shared/protocols/llm.py +25 -0
- shared/protocols/typer_protocols.py +37 -0
- shared/time.py +18 -0
- shared/universal.py +43 -0
- shared/utils/__init__.py +81 -0
- shared/utils/audit_grouping.py +50 -0
- shared/utils/common_knowledge.py +82 -0
- shared/utils/domain_mapper.py +61 -0
- shared/utils/embedding_utils.py +182 -0
- shared/utils/glob_match.py +93 -0
- shared/utils/header_tools.py +177 -0
- shared/utils/parallel_processor.py +60 -0
- shared/utils/parsing.py +189 -0
- shared/utils/path_utils.py +268 -0
- shared/utils/subprocess_utils.py +87 -0
- shared/workers/__init__.py +19 -0
- shared/workers/base.py +533 -0
- shared/workers/declaration_validator.py +124 -0
- shared/workers/loop_hold_telemetry.py +210 -0
- shared/workers/schedule.py +123 -0
- will/__init__.py +4 -0
- will/agents/__init__.py +4 -0
- will/agents/base_planner.py +133 -0
- will/agents/code_generation/__init__.py +15 -0
- will/agents/code_generation/code_generator.py +247 -0
- will/agents/code_generation/context_formatters.py +99 -0
- will/agents/code_generation/correction_engine.py +157 -0
- will/agents/code_generation/extraction.py +165 -0
- will/agents/code_generation/pattern_validator.py +264 -0
- will/agents/code_generation/prompt_builders.py +209 -0
- will/agents/coder_agent.py +229 -0
- will/agents/coder_agent_refusal_handler.py +168 -0
- will/agents/cognitive_orchestrator.py +152 -0
- will/agents/conversational/__init__.py +13 -0
- will/agents/conversational/agent.py +271 -0
- will/agents/conversational/factory.py +72 -0
- will/agents/conversational/helpers.py +116 -0
- will/agents/execution_agent.py +294 -0
- will/agents/governance_mixin.py +132 -0
- will/agents/planner_agent.py +261 -0
- will/agents/resource_selector.py +228 -0
- will/agents/strategic_auditor/__init__.py +15 -0
- will/agents/strategic_auditor/agent.py +199 -0
- will/agents/strategic_auditor/context_gatherer.py +586 -0
- will/agents/strategic_auditor/effects.py +136 -0
- will/agents/strategic_auditor/models.py +61 -0
- will/agents/strategic_auditor/reasoning.py +169 -0
- will/agents/tagger_agent.py +294 -0
- will/agents/traced_agent_mixin.py +33 -0
- will/autonomy/__init__.py +20 -0
- will/autonomy/autonomous_developer.py +127 -0
- will/autonomy/proposal.py +585 -0
- will/autonomy/proposal_execution_pipeline.py +264 -0
- will/autonomy/proposal_executor.py +410 -0
- will/autonomy/proposal_mapper.py +187 -0
- will/autonomy/proposal_repository.py +118 -0
- will/autonomy/proposal_service.py +251 -0
- will/autonomy/proposal_state_manager.py +239 -0
- will/deciders/__init__.py +9 -0
- will/deciders/governance_decider.py +207 -0
- will/governance/__init__.py +13 -0
- will/governance/audit_remediation_runner.py +197 -0
- will/governance/audit_runner.py +368 -0
- will/governance/census_runner.py +278 -0
- will/governance/coverage_runner.py +489 -0
- will/governance/daemon_runner.py +164 -0
- will/governance/fix_runner.py +693 -0
- will/governance/inspect_runner.py +521 -0
- will/governance/integrity_runner.py +66 -0
- will/governance/lint_runner.py +93 -0
- will/governance/refactor_runner.py +372 -0
- will/governance/sync_runner.py +186 -0
- will/interpreters/__init__.py +44 -0
- will/interpreters/cli_args_interpreter.py +106 -0
- will/interpreters/natural_language_interpreter.py +276 -0
- will/interpreters/request_interpreter.py +126 -0
- will/lifecycle/__init__.py +12 -0
- will/lifecycle/integration_runner.py +54 -0
- will/maintenance/metadata_scribe_service.py +64 -0
- will/orchestration/__init__.py +4 -0
- will/orchestration/cognitive_service.py +185 -0
- will/orchestration/decision_tracer.py +257 -0
- will/orchestration/intent_alignment.py +59 -0
- will/orchestration/intent_guard.py +20 -0
- will/orchestration/phase_registry.py +92 -0
- will/orchestration/process_orchestrator.py +270 -0
- will/orchestration/prompt_pipeline.py +174 -0
- will/orchestration/remediation_orchestrator.py +292 -0
- will/orchestration/self_correction_engine.py +154 -0
- will/orchestration/validation_pipeline.py +45 -0
- will/orchestration/workflow_orchestrator.py +277 -0
- will/phases/__init__.py +24 -0
- will/phases/audit_phase.py +152 -0
- will/phases/canary/pytest_runner.py +156 -0
- will/phases/canary/result_builder.py +130 -0
- will/phases/canary/test_discovery.py +104 -0
- will/phases/canary_validation_phase.py +188 -0
- will/phases/code_generation/artifact_saver.py +175 -0
- will/phases/code_generation/code_sensor.py +117 -0
- will/phases/code_generation/file_path_extractor.py +53 -0
- will/phases/code_generation/work_directory_manager.py +83 -0
- will/phases/code_generation_phase.py +480 -0
- will/phases/execution_phase.py +179 -0
- will/phases/interpret_phase.py +266 -0
- will/phases/load_phase.py +102 -0
- will/phases/parse_phase.py +117 -0
- will/phases/planning_phase.py +182 -0
- will/phases/runtime_phase.py +112 -0
- will/phases/sandbox_validation_phase.py +130 -0
- will/phases/style_check_phase.py +209 -0
- will/phases/test_generation_phase.py +159 -0
- will/self_healing/alignment/persistence.py +53 -0
- will/self_healing/alignment/sandbox.py +51 -0
- will/self_healing/alignment/specialists.py +165 -0
- will/self_healing/alignment_orchestrator.py +140 -0
- will/self_healing/audit_remediation_service.py +199 -0
- will/self_healing/batch_remediation_service.py +280 -0
- will/self_healing/capability_reconciliation_service.py +96 -0
- will/self_healing/capability_tagging_service.py +224 -0
- will/self_healing/clarity_service.py +204 -0
- will/self_healing/complexity_service.py +260 -0
- will/self_healing/context_aware_test_generator.py +298 -0
- will/self_healing/coverage_remediation_service.py +97 -0
- will/self_healing/coverage_watcher.py +192 -0
- will/self_healing/enrichment_service.py +211 -0
- will/self_healing/linelength_service.py +168 -0
- will/self_healing/modularity_remediation_service.py +203 -0
- will/self_healing/remediation_evidence_writer.py +144 -0
- will/self_healing/remediation_executor.py +113 -0
- will/self_healing/remediation_interpretation/__init__.py +1 -0
- will/self_healing/remediation_interpretation/file_context_assembler.py +383 -0
- will/self_healing/remediation_interpretation/file_role_detector.py +599 -0
- will/self_healing/remediation_interpretation/finding_normalizer.py +221 -0
- will/self_healing/remediation_interpretation/models.py +198 -0
- will/self_healing/remediation_interpretation/reasoning_brief_builder.py +235 -0
- will/self_healing/remediation_interpretation/responsibility_extractor.py +421 -0
- will/self_healing/remediation_interpretation/service.py +202 -0
- will/self_healing/remediation_interpretation/strategy_catalog.py +252 -0
- will/self_healing/remediation_interpretation/strategy_selector.py +395 -0
- will/self_healing/remediation_pattern_matcher.py +126 -0
- will/self_healing/simple_test_generator.py +252 -0
- will/self_healing/single_file_remediation.py +137 -0
- will/self_healing/test_generation/automatic_repair.py +377 -0
- will/self_healing/test_generation/code_extractor.py +238 -0
- will/self_healing/test_generation/context_builder.py +140 -0
- will/self_healing/test_generation/executor.py +64 -0
- will/self_healing/test_generation/failure_parser.py +37 -0
- will/self_healing/test_generation/generation_workflow.py +140 -0
- will/self_healing/test_generation/generator.py +283 -0
- will/self_healing/test_generation/llm_correction.py +160 -0
- will/self_healing/test_generation/repair_workflow.py +128 -0
- will/self_healing/test_generation/single_test_fixer.py +77 -0
- will/self_healing/test_generation/test_extractor.py +50 -0
- will/self_healing/test_generation/test_scorer.py +53 -0
- will/self_healing/test_generation/test_validator.py +64 -0
- will/self_healing/test_generator.py +12 -0
- will/strategists/__init__.py +46 -0
- will/strategists/base_strategist.py +29 -0
- will/strategists/clarity_strategist.py +55 -0
- will/strategists/complexity_strategist.py +55 -0
- will/strategists/fix_strategist.py +467 -0
- will/strategists/sync_strategist.py +369 -0
- will/strategists/test_strategist.py +140 -0
- will/strategists/validation_strategist.py +315 -0
- will/test_generation/__init__.py +46 -0
- will/test_generation/adaptive_test_generator.py +123 -0
- will/test_generation/artifacts.py +102 -0
- will/test_generation/harness_detection.py +103 -0
- will/test_generation/helpers/__init__.py +14 -0
- will/test_generation/helpers/context_extractor.py +100 -0
- will/test_generation/helpers/test_executor.py +230 -0
- will/test_generation/llm_output.py +62 -0
- will/test_generation/models.py +25 -0
- will/test_generation/persistence.py +248 -0
- will/test_generation/phases/__init__.py +16 -0
- will/test_generation/phases/generation_phase.py +150 -0
- will/test_generation/phases/load_phase.py +53 -0
- will/test_generation/phases/parse_phase.py +50 -0
- will/test_generation/prompt_engine.py +123 -0
- will/test_generation/result_aggregator.py +73 -0
- will/test_generation/sandbox.py +203 -0
- will/test_generation/strategy_link.py +56 -0
- will/test_generation/test_extractor.py +140 -0
- will/test_generation/validation.py +89 -0
- will/tools/__init__.py +13 -0
- will/tools/anchor_builder.py +111 -0
- will/tools/anchor_search.py +73 -0
- will/tools/anchors/discovery.py +55 -0
- will/tools/anchors/storage.py +32 -0
- will/tools/architectural_context_builder.py +94 -0
- will/tools/cognitive_toolbox.py +47 -0
- will/tools/context/code_snippet_extractor.py +83 -0
- will/tools/context/embedding_search.py +76 -0
- will/tools/context/formatter.py +87 -0
- will/tools/context/models.py +38 -0
- will/tools/context/query_builder.py +42 -0
- will/tools/context/retriever.py +182 -0
- will/tools/context/standards.py +53 -0
- will/tools/file_navigator.py +180 -0
- will/tools/layers.py +31 -0
- will/tools/module_anchor_generator.py +137 -0
- will/tools/module_descriptor.py +154 -0
- will/tools/policy_vectorizer.py +184 -0
- will/tools/symbol_finder.py +188 -0
- will/tools/tool_generator.py +103 -0
- will/workers/audit_ingest_worker.py +207 -0
- will/workers/audit_violation_filter.py +108 -0
- will/workers/audit_violation_normalizer.py +108 -0
- will/workers/audit_violation_sensor.py +370 -0
- will/workers/blackboard_shop_manager.py +280 -0
- will/workers/capability_tagger.py +153 -0
- will/workers/circuit_breaker.py +335 -0
- will/workers/coherence_sensor.py +212 -0
- will/workers/commit_reachability_auditor.py +135 -0
- will/workers/db_sync_worker.py +96 -0
- will/workers/governance_embedding/__init__.py +9 -0
- will/workers/governance_embedding/governance_embedder_worker.py +189 -0
- will/workers/intent_inspector.py +599 -0
- will/workers/observer_worker.py +158 -0
- will/workers/prompt_extractor_worker.py +241 -0
- will/workers/proposal_consumer_effects.py +216 -0
- will/workers/proposal_consumer_revival.py +131 -0
- will/workers/proposal_consumer_worker.py +271 -0
- will/workers/proposal_pipeline_shop_manager.py +273 -0
- will/workers/repo_crawler.py +171 -0
- will/workers/repo_embedding/__init__.py +18 -0
- will/workers/repo_embedding/helpers.py +245 -0
- will/workers/repo_embedding/repo_embedder_workers.py +163 -0
- will/workers/test_coverage_sensor.py +208 -0
- will/workers/test_remediator/__init__.py +12 -0
- will/workers/test_remediator/_operations.py +295 -0
- will/workers/test_remediator/worker.py +187 -0
- will/workers/test_runner_sensor.py +430 -0
- will/workers/violation_executor.py +496 -0
- will/workers/violation_remediator.py +394 -0
- will/workers/violation_remediator_blackboard.py +225 -0
- will/workers/violation_remediator_body/__init__.py +12 -0
- will/workers/violation_remediator_body/blackboard.py +139 -0
- will/workers/violation_remediator_body/ceremony.py +154 -0
- will/workers/violation_remediator_body/context.py +70 -0
- will/workers/violation_remediator_body/llm.py +112 -0
- will/workers/violation_remediator_body/models.py +35 -0
- will/workers/violation_remediator_body/worker.py +518 -0
- will/workers/violation_remediator_proposal.py +328 -0
- will/workers/worker_shop_manager.py +244 -0
- will/workflows/__init__.py +23 -0
- will/workflows/dev_sync_reporter.py +274 -0
- will/workflows/dev_sync_workflow.py +118 -0
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
# src/body/introspection/graph_analysis_service.py
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Provides a service for finding semantic clusters of symbols in the codebase
|
|
5
|
+
using K-Means clustering on their vector embeddings.
|
|
6
|
+
"""
|
|
7
|
+
|
|
8
|
+
from __future__ import annotations
|
|
9
|
+
|
|
10
|
+
import numpy as np
|
|
11
|
+
|
|
12
|
+
from shared.infrastructure.clients.qdrant_client import QdrantService
|
|
13
|
+
from shared.infrastructure.intent.operational_config import load_operational_config
|
|
14
|
+
from shared.logger import getLogger
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
try:
|
|
18
|
+
from sklearn.cluster import KMeans
|
|
19
|
+
except ImportError:
|
|
20
|
+
KMeans = None
|
|
21
|
+
logger = getLogger(__name__)
|
|
22
|
+
|
|
23
|
+
_CFG = load_operational_config().misc
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
# ID: ae8922bb-df0c-4edb-a34f-a7114d70faab
|
|
27
|
+
async def find_semantic_clusters(
|
|
28
|
+
qdrant_service: QdrantService,
|
|
29
|
+
n_clusters: int = _CFG.clustering_default_n_clusters,
|
|
30
|
+
) -> list[list[str]]:
|
|
31
|
+
"""
|
|
32
|
+
Finds clusters of semantically similar code symbols using K-Means clustering.
|
|
33
|
+
"""
|
|
34
|
+
if KMeans is None:
|
|
35
|
+
logger.error(
|
|
36
|
+
"scikit-learn is not installed. Cannot perform clustering. Please run 'poetry install --with dev'."
|
|
37
|
+
)
|
|
38
|
+
return []
|
|
39
|
+
logger.info("Finding %s semantic clusters using K-Means...", n_clusters)
|
|
40
|
+
try:
|
|
41
|
+
all_points = await qdrant_service.get_all_vectors()
|
|
42
|
+
if not all_points:
|
|
43
|
+
logger.warning("No vectors found in Qdrant. Cannot perform clustering.")
|
|
44
|
+
return []
|
|
45
|
+
vectors = []
|
|
46
|
+
symbol_keys = []
|
|
47
|
+
for point in all_points:
|
|
48
|
+
if point.payload and "chunk_id" in point.payload and point.vector:
|
|
49
|
+
symbol_keys.append(point.payload["chunk_id"])
|
|
50
|
+
vectors.append(point.vector)
|
|
51
|
+
if not vectors:
|
|
52
|
+
logger.warning("No valid vectors with symbol payloads found.")
|
|
53
|
+
return []
|
|
54
|
+
logger.info("Clustering {len(vectors)} vectors into %s domains...", n_clusters)
|
|
55
|
+
vector_array = np.array(vectors, dtype=np.float32)
|
|
56
|
+
kmeans = KMeans(n_clusters=n_clusters, random_state=42, n_init="auto")
|
|
57
|
+
labels = kmeans.fit_predict(vector_array)
|
|
58
|
+
clusters: list[list[str]] = [[] for _ in range(n_clusters)]
|
|
59
|
+
for i, label in enumerate(labels):
|
|
60
|
+
clusters[label].append(symbol_keys[i])
|
|
61
|
+
logger.info("Found %s semantic clusters.", len(clusters))
|
|
62
|
+
clusters.sort(key=len, reverse=True)
|
|
63
|
+
return [c for c in clusters if c]
|
|
64
|
+
except Exception as e:
|
|
65
|
+
logger.error("Failed to find semantic clusters: %s", e, exc_info=True)
|
|
66
|
+
return []
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
# src/body/introspection/knowledge_graph_service.py
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Knowledge Graph Builder - Sensory-Aware logic service.
|
|
5
|
+
UPDATED: Domain heuristics adapted for layered architecture (Wave 3).
|
|
6
|
+
"""
|
|
7
|
+
|
|
8
|
+
from __future__ import annotations
|
|
9
|
+
|
|
10
|
+
import ast
|
|
11
|
+
from datetime import UTC, datetime
|
|
12
|
+
from pathlib import Path
|
|
13
|
+
from typing import TYPE_CHECKING, Any
|
|
14
|
+
|
|
15
|
+
from shared.ast_utility import (
|
|
16
|
+
FunctionCallVisitor,
|
|
17
|
+
calculate_structural_hash,
|
|
18
|
+
extract_base_classes,
|
|
19
|
+
extract_docstring,
|
|
20
|
+
extract_parameters,
|
|
21
|
+
parse_metadata_comment,
|
|
22
|
+
)
|
|
23
|
+
from shared.logger import getLogger
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
if TYPE_CHECKING:
|
|
27
|
+
from shared.infrastructure.context.limb_workspace import LimbWorkspace
|
|
28
|
+
|
|
29
|
+
logger = getLogger(__name__)
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
# ID: 322f2e00-3996-4c30-8bc6-ec9291be777c
|
|
33
|
+
class KnowledgeGraphBuilder:
|
|
34
|
+
"""
|
|
35
|
+
Scan source code to build a comprehensive in-memory knowledge graph.
|
|
36
|
+
"""
|
|
37
|
+
|
|
38
|
+
def __init__(self, root_path: Path, workspace: LimbWorkspace | None = None) -> None:
|
|
39
|
+
self.root_path = Path(root_path).resolve()
|
|
40
|
+
self.src_dir = self.root_path / "src"
|
|
41
|
+
self.workspace = workspace
|
|
42
|
+
|
|
43
|
+
self.symbols: dict[str, dict[str, Any]] = {}
|
|
44
|
+
self.domain_map = self._load_domain_map()
|
|
45
|
+
self.entry_point_patterns = self._load_entry_point_patterns()
|
|
46
|
+
|
|
47
|
+
def _load_domain_map(self) -> dict[str, str]:
|
|
48
|
+
"""
|
|
49
|
+
Loads the architectural domain map.
|
|
50
|
+
Source structure file has been removed — returns empty map.
|
|
51
|
+
Callers fall back to heuristic domain detection.
|
|
52
|
+
"""
|
|
53
|
+
return {}
|
|
54
|
+
|
|
55
|
+
def _load_entry_point_patterns(self) -> list[dict[str, Any]]:
|
|
56
|
+
"""
|
|
57
|
+
Loads entry point patterns.
|
|
58
|
+
Patterns file has been removed — returns empty list.
|
|
59
|
+
"""
|
|
60
|
+
return []
|
|
61
|
+
|
|
62
|
+
# ID: 75c969e0-5c7c-4f58-9a46-62815947d77a
|
|
63
|
+
def build(self) -> dict[str, Any]:
|
|
64
|
+
"""
|
|
65
|
+
Execute the full scan and return the in-memory graph.
|
|
66
|
+
"""
|
|
67
|
+
mode = "SHADOW" if self.workspace else "STANDARD"
|
|
68
|
+
logger.info("Building knowledge graph (%s mode) for: %s", mode, self.root_path)
|
|
69
|
+
|
|
70
|
+
self.symbols = {}
|
|
71
|
+
|
|
72
|
+
if self.workspace:
|
|
73
|
+
files_to_scan = self.workspace.list_files(directory="src", pattern="*.py")
|
|
74
|
+
for rel_path in files_to_scan:
|
|
75
|
+
self._scan_file_v2(rel_path)
|
|
76
|
+
else:
|
|
77
|
+
if not self.src_dir.exists():
|
|
78
|
+
logger.warning("Source directory not found: %s", self.src_dir)
|
|
79
|
+
return {"metadata": {}, "symbols": {}}
|
|
80
|
+
|
|
81
|
+
for py_file in self.src_dir.rglob("*.py"):
|
|
82
|
+
rel_path = str(py_file.relative_to(self.root_path))
|
|
83
|
+
self._scan_file_v2(rel_path)
|
|
84
|
+
|
|
85
|
+
return {
|
|
86
|
+
"metadata": {
|
|
87
|
+
"generated_at": datetime.now(UTC).isoformat(),
|
|
88
|
+
"repo_root": str(self.root_path),
|
|
89
|
+
"symbol_count": len(self.symbols),
|
|
90
|
+
"mode": mode,
|
|
91
|
+
},
|
|
92
|
+
"symbols": self.symbols,
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
def _scan_file_v2(self, rel_path: str) -> None:
|
|
96
|
+
"""Scan a file using the sensory overlay."""
|
|
97
|
+
try:
|
|
98
|
+
if self.workspace:
|
|
99
|
+
content = self.workspace.read_text(rel_path)
|
|
100
|
+
else:
|
|
101
|
+
content = (self.root_path / rel_path).read_text(encoding="utf-8")
|
|
102
|
+
|
|
103
|
+
tree = ast.parse(content, filename=rel_path)
|
|
104
|
+
source_lines = content.splitlines()
|
|
105
|
+
|
|
106
|
+
for node in ast.walk(tree):
|
|
107
|
+
if isinstance(
|
|
108
|
+
node, (ast.FunctionDef, ast.AsyncFunctionDef, ast.ClassDef)
|
|
109
|
+
):
|
|
110
|
+
self._process_symbol(node, Path(rel_path), source_lines)
|
|
111
|
+
|
|
112
|
+
except Exception as exc:
|
|
113
|
+
logger.error("Failed to process file %s: %s", rel_path, exc)
|
|
114
|
+
|
|
115
|
+
def _determine_domain(self, file_path: Path) -> str:
|
|
116
|
+
"""Determine the architectural domain of a file."""
|
|
117
|
+
abs_file_path = (self.root_path / file_path).resolve()
|
|
118
|
+
|
|
119
|
+
parts = file_path.parts
|
|
120
|
+
if len(parts) >= 3 and parts[0] == "src":
|
|
121
|
+
return parts[2]
|
|
122
|
+
|
|
123
|
+
for domain_path, domain_name in self.domain_map.items():
|
|
124
|
+
if str(abs_file_path).startswith(str(Path(domain_path).resolve())):
|
|
125
|
+
return domain_name
|
|
126
|
+
|
|
127
|
+
return "unknown"
|
|
128
|
+
|
|
129
|
+
def _process_symbol(
|
|
130
|
+
self, node: ast.AST, rel_path: Path, source_lines: list[str]
|
|
131
|
+
) -> None:
|
|
132
|
+
"""Extract metadata for a symbol."""
|
|
133
|
+
if not hasattr(node, "name"):
|
|
134
|
+
return
|
|
135
|
+
|
|
136
|
+
symbol_path_key = f"{rel_path.as_posix()}::{node.name}"
|
|
137
|
+
metadata = parse_metadata_comment(node, source_lines) or {}
|
|
138
|
+
docstring = (extract_docstring(node) or "").strip()
|
|
139
|
+
|
|
140
|
+
call_visitor = FunctionCallVisitor()
|
|
141
|
+
try:
|
|
142
|
+
call_visitor.visit(node)
|
|
143
|
+
except Exception:
|
|
144
|
+
pass
|
|
145
|
+
|
|
146
|
+
symbol_data = {
|
|
147
|
+
"uuid": symbol_path_key,
|
|
148
|
+
"key": metadata.get("capability"),
|
|
149
|
+
"symbol_path": symbol_path_key,
|
|
150
|
+
"name": node.name,
|
|
151
|
+
"type": type(node).__name__,
|
|
152
|
+
"file_path": rel_path.as_posix(),
|
|
153
|
+
"domain": self._determine_domain(rel_path),
|
|
154
|
+
"is_public": not node.name.startswith("_"),
|
|
155
|
+
"title": node.name.replace("_", " ").title(),
|
|
156
|
+
"description": docstring.split("\n")[0] if docstring else None,
|
|
157
|
+
"docstring": docstring,
|
|
158
|
+
"calls": sorted(set(getattr(call_visitor, "calls", []))),
|
|
159
|
+
"line_number": node.lineno,
|
|
160
|
+
"end_line_number": getattr(node, "end_lineno", node.lineno),
|
|
161
|
+
"is_async": isinstance(node, ast.AsyncFunctionDef),
|
|
162
|
+
"parameters": extract_parameters(node) if hasattr(node, "args") else [],
|
|
163
|
+
"is_class": isinstance(node, ast.ClassDef),
|
|
164
|
+
"base_classes": (
|
|
165
|
+
extract_base_classes(node) if isinstance(node, ast.ClassDef) else []
|
|
166
|
+
),
|
|
167
|
+
"structural_hash": calculate_structural_hash(node),
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
self.symbols[symbol_path_key] = symbol_data
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
# src/body/introspection/semantic_clusterer.py
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Performs semantic clustering on exported capability vectors to discover data-driven domains.
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
from __future__ import annotations
|
|
8
|
+
|
|
9
|
+
import json
|
|
10
|
+
from pathlib import Path
|
|
11
|
+
|
|
12
|
+
import numpy as np
|
|
13
|
+
from dotenv import load_dotenv
|
|
14
|
+
|
|
15
|
+
# REFACTORED: Removed direct settings import
|
|
16
|
+
from shared.exceptions import CoreError
|
|
17
|
+
from shared.infrastructure.storage.file_handler import FileHandler
|
|
18
|
+
from shared.logger import getLogger
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
try:
|
|
22
|
+
from sklearn.cluster import KMeans
|
|
23
|
+
except ImportError:
|
|
24
|
+
KMeans = None
|
|
25
|
+
logger = getLogger(__name__)
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
# ID: 04978d4c-740f-48cf-98f3-a85e28885ee6
|
|
29
|
+
class SemanticClusteringError(CoreError):
|
|
30
|
+
"""Raised when semantic clustering cannot complete."""
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
# ID: 41c7d272-0d0d-4d84-9d99-984e9a698bd2
|
|
34
|
+
def run_clustering(
|
|
35
|
+
input_path: Path | str,
|
|
36
|
+
output: Path | str,
|
|
37
|
+
n_clusters: int,
|
|
38
|
+
repo_root: Path | None = None,
|
|
39
|
+
) -> None:
|
|
40
|
+
"""
|
|
41
|
+
Loads exported vectors, runs K-Means clustering, and saves the proposed
|
|
42
|
+
capability-to-domain mappings to a JSON file.
|
|
43
|
+
"""
|
|
44
|
+
if KMeans is None:
|
|
45
|
+
logger.error("scikit-learn is not installed. Aborting.")
|
|
46
|
+
raise SemanticClusteringError(
|
|
47
|
+
"scikit-learn is not installed for clustering.", exit_code=1
|
|
48
|
+
)
|
|
49
|
+
input_path = Path(input_path)
|
|
50
|
+
output_path = Path(output)
|
|
51
|
+
if repo_root is None:
|
|
52
|
+
raise ValueError("repo_root is required")
|
|
53
|
+
file_handler = FileHandler(str(repo_root))
|
|
54
|
+
|
|
55
|
+
logger.info("Starting semantic clustering process...")
|
|
56
|
+
file_handler.ensure_dir(str(output_path.parent.relative_to(repo_root)))
|
|
57
|
+
logger.info(" -> Loading vectors from %s...", input_path)
|
|
58
|
+
vectors = []
|
|
59
|
+
capability_keys = []
|
|
60
|
+
try:
|
|
61
|
+
with input_path.open("r", encoding="utf-8") as f:
|
|
62
|
+
for line in f:
|
|
63
|
+
record = json.loads(line)
|
|
64
|
+
if "vector" in record and "payload" in record:
|
|
65
|
+
if "symbol" in record["payload"]:
|
|
66
|
+
vectors.append(record["vector"])
|
|
67
|
+
capability_keys.append(record["payload"]["symbol"])
|
|
68
|
+
except FileNotFoundError as exc:
|
|
69
|
+
logger.error("Input file not found: %s", input_path)
|
|
70
|
+
raise SemanticClusteringError("Input file not found.", exit_code=1) from exc
|
|
71
|
+
|
|
72
|
+
if not vectors:
|
|
73
|
+
logger.error("No valid vector data found in %s.", input_path)
|
|
74
|
+
raise SemanticClusteringError(
|
|
75
|
+
f"No valid vector data found in {input_path}.", exit_code=1
|
|
76
|
+
)
|
|
77
|
+
logger.info(
|
|
78
|
+
" -> Loaded %s vectors for clustering into %s domains.",
|
|
79
|
+
len(vectors),
|
|
80
|
+
n_clusters,
|
|
81
|
+
)
|
|
82
|
+
X = np.array(vectors)
|
|
83
|
+
kmeans = KMeans(n_clusters=n_clusters, random_state=42, n_init="auto")
|
|
84
|
+
kmeans.fit(X)
|
|
85
|
+
labels = kmeans.labels_
|
|
86
|
+
proposed_domains = {
|
|
87
|
+
key: f"domain_{label}"
|
|
88
|
+
for key, label in zip(capability_keys, labels, strict=False)
|
|
89
|
+
}
|
|
90
|
+
rel_path = str(output_path.relative_to(repo_root))
|
|
91
|
+
file_handler.write_runtime_json(rel_path, proposed_domains)
|
|
92
|
+
logger.info(
|
|
93
|
+
"Successfully generated domain proposals for %s capabilities and saved to %s",
|
|
94
|
+
len(proposed_domains),
|
|
95
|
+
output_path,
|
|
96
|
+
)
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
if __name__ == "__main__":
|
|
100
|
+
import argparse
|
|
101
|
+
|
|
102
|
+
load_dotenv()
|
|
103
|
+
|
|
104
|
+
parser = argparse.ArgumentParser(
|
|
105
|
+
description="Run semantic clustering on exported capability vectors."
|
|
106
|
+
)
|
|
107
|
+
parser.add_argument(
|
|
108
|
+
"input_path",
|
|
109
|
+
type=Path,
|
|
110
|
+
help="Path to the JSONL file containing exported vectors.",
|
|
111
|
+
)
|
|
112
|
+
parser.add_argument(
|
|
113
|
+
"output",
|
|
114
|
+
type=Path,
|
|
115
|
+
help="Path to write the proposed domain mapping JSON file.",
|
|
116
|
+
)
|
|
117
|
+
parser.add_argument(
|
|
118
|
+
"n_clusters",
|
|
119
|
+
type=int,
|
|
120
|
+
help="Number of clusters (domains) to produce.",
|
|
121
|
+
)
|
|
122
|
+
|
|
123
|
+
args = parser.parse_args()
|
|
124
|
+
|
|
125
|
+
try:
|
|
126
|
+
run_clustering(args.input_path, args.output, args.n_clusters)
|
|
127
|
+
except SemanticClusteringError as exc:
|
|
128
|
+
raise SystemExit(exc.exit_code) from exc
|
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
# src/body/introspection/symbol_index_builder.py
|
|
2
|
+
"""
|
|
3
|
+
Builds symbol_index.json from AST + patterns.
|
|
4
|
+
|
|
5
|
+
CONSTITUTIONAL FIX:
|
|
6
|
+
- Aligned with 'governance.artifact_mutation.traceable'.
|
|
7
|
+
- Aligned with 'logic.logging.standard_only' (removed print statements).
|
|
8
|
+
- Replaced direct Path writes with governed FileHandler mutations.
|
|
9
|
+
- Fixed syntax error and ensured Python 3.12 compatibility.
|
|
10
|
+
"""
|
|
11
|
+
|
|
12
|
+
from __future__ import annotations
|
|
13
|
+
|
|
14
|
+
import ast
|
|
15
|
+
import re
|
|
16
|
+
import sys
|
|
17
|
+
from collections.abc import Iterable
|
|
18
|
+
from dataclasses import dataclass
|
|
19
|
+
from pathlib import Path
|
|
20
|
+
from typing import Any
|
|
21
|
+
|
|
22
|
+
from shared.infrastructure.storage.file_handler import FileHandler
|
|
23
|
+
from shared.logger import getLogger
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
logger = getLogger(__name__)
|
|
27
|
+
|
|
28
|
+
try:
|
|
29
|
+
import yaml
|
|
30
|
+
except Exception:
|
|
31
|
+
yaml = None
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
@dataclass
|
|
35
|
+
# ID: 3599bcdc-f7c4-4ee8-94f1-c30cf63c7104
|
|
36
|
+
class Pattern:
|
|
37
|
+
name: str
|
|
38
|
+
description: str
|
|
39
|
+
match: dict[str, Any]
|
|
40
|
+
entry_point_type: str
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
@dataclass
|
|
44
|
+
# ID: b9f1867b-96ed-4fe0-b382-6ebea7d5500f
|
|
45
|
+
class SymbolMeta:
|
|
46
|
+
key: str
|
|
47
|
+
filepath: str
|
|
48
|
+
name: str
|
|
49
|
+
type: str # function | class | method
|
|
50
|
+
base_classes: list[str]
|
|
51
|
+
decorators: list[str]
|
|
52
|
+
is_public_function: bool
|
|
53
|
+
module_path: str
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
def _load_patterns(patterns_path: Path) -> list[Pattern]:
|
|
57
|
+
if yaml is None or not patterns_path.exists():
|
|
58
|
+
return [
|
|
59
|
+
Pattern(
|
|
60
|
+
name="cli_command",
|
|
61
|
+
description="CLI entry points",
|
|
62
|
+
match={"type": "function", "module_path_contains": "src/cli/"},
|
|
63
|
+
entry_point_type="cli_command",
|
|
64
|
+
)
|
|
65
|
+
]
|
|
66
|
+
|
|
67
|
+
data = yaml.safe_load(patterns_path.read_text(encoding="utf-8"))
|
|
68
|
+
items = data.get("patterns", []) if isinstance(data, dict) else []
|
|
69
|
+
return [
|
|
70
|
+
Pattern(
|
|
71
|
+
name=p.get("name", ""),
|
|
72
|
+
description=p.get("description", ""),
|
|
73
|
+
match=p.get("match", {}) or {},
|
|
74
|
+
entry_point_type=p.get("entry_point_type", ""),
|
|
75
|
+
)
|
|
76
|
+
for p in items
|
|
77
|
+
]
|
|
78
|
+
|
|
79
|
+
|
|
80
|
+
def _iter_py_files(root: Path) -> Iterable[Path]:
|
|
81
|
+
for p in root.rglob("*.py"):
|
|
82
|
+
s = str(p.as_posix())
|
|
83
|
+
if any(x in s for x in ["/.venv/", "/venv/", "/.git/", "reports/"]):
|
|
84
|
+
continue
|
|
85
|
+
yield p
|
|
86
|
+
|
|
87
|
+
|
|
88
|
+
class _Visitor(ast.NodeVisitor):
|
|
89
|
+
def __init__(self, filepath: Path) -> None:
|
|
90
|
+
self.filepath = filepath
|
|
91
|
+
self.module_path = filepath.as_posix()
|
|
92
|
+
self.symbols: list[SymbolMeta] = []
|
|
93
|
+
self._class_stack: list[ast.ClassDef] = []
|
|
94
|
+
|
|
95
|
+
# ID: 53ffac44-279f-475f-8479-85ae61fbf17b
|
|
96
|
+
def visit_ClassDef(self, node: ast.ClassDef) -> Any:
|
|
97
|
+
bases = [self._name_of(b) for b in node.bases]
|
|
98
|
+
decorators = [self._name_of(d) for d in node.decorator_list]
|
|
99
|
+
self.symbols.append(
|
|
100
|
+
SymbolMeta(
|
|
101
|
+
key=f"{self.module_path}::{node.name}",
|
|
102
|
+
filepath=self.module_path,
|
|
103
|
+
name=node.name,
|
|
104
|
+
type="class",
|
|
105
|
+
base_classes=bases,
|
|
106
|
+
decorators=decorators,
|
|
107
|
+
is_public_function=not node.name.startswith("_"),
|
|
108
|
+
module_path=self.module_path,
|
|
109
|
+
)
|
|
110
|
+
)
|
|
111
|
+
self._class_stack.append(node)
|
|
112
|
+
self.generic_visit(node)
|
|
113
|
+
self._class_stack.pop()
|
|
114
|
+
|
|
115
|
+
# ID: 50c1acc1-14b2-4998-8741-aa255b1fa719
|
|
116
|
+
def visit_FunctionDef(self, node: ast.FunctionDef) -> Any:
|
|
117
|
+
self._handle_func(node)
|
|
118
|
+
|
|
119
|
+
# ID: 8adec9fb-254d-4d09-896a-0155fcce78bf
|
|
120
|
+
def visit_AsyncFunctionDef(self, node: ast.AsyncFunctionDef) -> Any:
|
|
121
|
+
self._handle_func(node)
|
|
122
|
+
|
|
123
|
+
def _handle_func(self, node: ast.FunctionDef | ast.AsyncFunctionDef) -> None:
|
|
124
|
+
name = node.name
|
|
125
|
+
decorators = [self._name_of(d) for d in node.decorator_list]
|
|
126
|
+
bases: list[str] = []
|
|
127
|
+
if self._class_stack:
|
|
128
|
+
bases = [self._name_of(b) for b in self._class_stack[-1].bases]
|
|
129
|
+
|
|
130
|
+
self.symbols.append(
|
|
131
|
+
SymbolMeta(
|
|
132
|
+
key=f"{self.module_path}::{self._qn(name)}",
|
|
133
|
+
filepath=self.module_path,
|
|
134
|
+
name=name,
|
|
135
|
+
type="method" if self._class_stack else "function",
|
|
136
|
+
base_classes=bases,
|
|
137
|
+
decorators=decorators,
|
|
138
|
+
is_public_function=not name.startswith("_"),
|
|
139
|
+
module_path=self.module_path,
|
|
140
|
+
)
|
|
141
|
+
)
|
|
142
|
+
|
|
143
|
+
def _qn(self, name: str) -> str:
|
|
144
|
+
return f"{self._class_stack[-1].name}.{name}" if self._class_stack else name
|
|
145
|
+
|
|
146
|
+
def _name_of(self, node: ast.AST) -> str:
|
|
147
|
+
if isinstance(node, ast.Name):
|
|
148
|
+
return node.id
|
|
149
|
+
if isinstance(node, ast.Attribute):
|
|
150
|
+
return f"{self._name_of(node.value)}.{node.attr}"
|
|
151
|
+
try:
|
|
152
|
+
return ast.unparse(node)
|
|
153
|
+
except Exception:
|
|
154
|
+
return "unknown"
|
|
155
|
+
|
|
156
|
+
|
|
157
|
+
def _match_pattern(sym: SymbolMeta, pat: Pattern) -> bool:
|
|
158
|
+
m = pat.match
|
|
159
|
+
if "type" in m:
|
|
160
|
+
if m["type"] == "function" and sym.type not in {"function", "method"}:
|
|
161
|
+
return False
|
|
162
|
+
if m["type"] == "class" and sym.type != "class":
|
|
163
|
+
return False
|
|
164
|
+
if "module_path_contains" in m and m["module_path_contains"] not in sym.module_path:
|
|
165
|
+
return False
|
|
166
|
+
if "name_regex" in m and not re.search(m["name_regex"], sym.name):
|
|
167
|
+
return False
|
|
168
|
+
return True
|
|
169
|
+
|
|
170
|
+
|
|
171
|
+
def _classify(symbols: list[SymbolMeta], patterns: list[Pattern]) -> dict[str, dict]:
|
|
172
|
+
index = {}
|
|
173
|
+
for s in symbols:
|
|
174
|
+
for p in patterns:
|
|
175
|
+
if _match_pattern(s, p):
|
|
176
|
+
index[s.key] = {
|
|
177
|
+
"entry_point_type": p.entry_point_type,
|
|
178
|
+
"pattern_name": p.name,
|
|
179
|
+
"entry_point_justification": p.description,
|
|
180
|
+
}
|
|
181
|
+
break
|
|
182
|
+
return index
|
|
183
|
+
|
|
184
|
+
|
|
185
|
+
# ID: 2e550e18-7c09-4ccc-a967-e1d38fac6f8f
|
|
186
|
+
def build_symbol_index(
|
|
187
|
+
project_root: str | Path = ".",
|
|
188
|
+
patterns_path: str | Path = ".intent/mind/knowledge/entry_point_patterns.yaml",
|
|
189
|
+
) -> dict[str, dict]:
|
|
190
|
+
root = Path(project_root).resolve()
|
|
191
|
+
src = root / "src"
|
|
192
|
+
patterns_file = root / patterns_path
|
|
193
|
+
|
|
194
|
+
if not patterns_file.exists():
|
|
195
|
+
# Degrade gracefully if patterns are missing
|
|
196
|
+
patterns = []
|
|
197
|
+
else:
|
|
198
|
+
patterns = _load_patterns(patterns_file)
|
|
199
|
+
|
|
200
|
+
all_symbols: list[SymbolMeta] = []
|
|
201
|
+
for py in _iter_py_files(src):
|
|
202
|
+
try:
|
|
203
|
+
tree = ast.parse(py.read_text(encoding="utf-8"))
|
|
204
|
+
visitor = _Visitor(py)
|
|
205
|
+
visitor.visit(tree)
|
|
206
|
+
all_symbols.extend(visitor.symbols)
|
|
207
|
+
except Exception:
|
|
208
|
+
continue
|
|
209
|
+
|
|
210
|
+
return _classify(all_symbols, patterns)
|
|
211
|
+
|
|
212
|
+
|
|
213
|
+
# ID: aeb56496-e95c-4537-aeb7-81ca8b3a9372
|
|
214
|
+
def main(argv: list[str] | None = None) -> int:
|
|
215
|
+
import argparse
|
|
216
|
+
|
|
217
|
+
parser = argparse.ArgumentParser(description="Build symbol index.")
|
|
218
|
+
parser.add_argument("--project-root", default=".")
|
|
219
|
+
parser.add_argument("--out", default="reports/symbol_index.json")
|
|
220
|
+
args = parser.parse_args(argv or sys.argv[1:])
|
|
221
|
+
|
|
222
|
+
try:
|
|
223
|
+
project_root = Path(args.project_root).resolve()
|
|
224
|
+
index = build_symbol_index(args.project_root)
|
|
225
|
+
fh = FileHandler(str(project_root))
|
|
226
|
+
|
|
227
|
+
# Resolve output path
|
|
228
|
+
out_path = Path(args.out)
|
|
229
|
+
repo_abs = project_root
|
|
230
|
+
|
|
231
|
+
if out_path.is_absolute():
|
|
232
|
+
rel_output = str(out_path.relative_to(repo_abs))
|
|
233
|
+
else:
|
|
234
|
+
rel_output = str(out_path).replace("\\", "/")
|
|
235
|
+
|
|
236
|
+
fh.write_runtime_json(rel_output, index)
|
|
237
|
+
return 0
|
|
238
|
+
except Exception as e:
|
|
239
|
+
logger.error("Failed to build symbol index: %s", e, exc_info=True)
|
|
240
|
+
return 1
|
|
241
|
+
|
|
242
|
+
|
|
243
|
+
if __name__ == "__main__":
|
|
244
|
+
sys.exit(main())
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
# src/body/introspection/sync/engine.py
|
|
2
|
+
|
|
3
|
+
"""Refactored logic for src/features/introspection/sync/engine.py."""
|
|
4
|
+
|
|
5
|
+
from __future__ import annotations
|
|
6
|
+
|
|
7
|
+
from sqlalchemy import text
|
|
8
|
+
from sqlalchemy.ext.asyncio import AsyncSession
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
# ID: 1d4f3f97-e8ce-4ebc-82b4-2d7f41ba55dd
|
|
12
|
+
async def run_db_merge(session: AsyncSession, code_state: list[dict]) -> dict[str, int]:
|
|
13
|
+
"""Executes the set-based merge logic exactly as in the original file."""
|
|
14
|
+
stats = {"scanned": len(code_state), "inserted": 0, "updated": 0, "deleted": 0}
|
|
15
|
+
|
|
16
|
+
await session.execute(
|
|
17
|
+
text(
|
|
18
|
+
"""
|
|
19
|
+
CREATE TEMPORARY TABLE core_symbols_staging (LIKE core.symbols INCLUDING DEFAULTS) ON COMMIT DROP;
|
|
20
|
+
"""
|
|
21
|
+
)
|
|
22
|
+
)
|
|
23
|
+
|
|
24
|
+
if code_state:
|
|
25
|
+
await session.execute(
|
|
26
|
+
text(
|
|
27
|
+
"""
|
|
28
|
+
INSERT INTO core_symbols_staging (id, symbol_path, module, qualname, kind, ast_signature, fingerprint, state, is_public, calls, domain)
|
|
29
|
+
VALUES (:id, :symbol_path, :module, :qualname, :kind, :ast_signature, :fingerprint, :state, :is_public, :calls, :domain)
|
|
30
|
+
"""
|
|
31
|
+
),
|
|
32
|
+
code_state,
|
|
33
|
+
)
|
|
34
|
+
|
|
35
|
+
# 1. Calculate Deleted
|
|
36
|
+
stats["deleted"] = (
|
|
37
|
+
await session.execute(
|
|
38
|
+
text(
|
|
39
|
+
"SELECT COUNT(*) FROM core.symbols WHERE symbol_path NOT IN (SELECT symbol_path FROM core_symbols_staging)"
|
|
40
|
+
)
|
|
41
|
+
)
|
|
42
|
+
).scalar_one()
|
|
43
|
+
# 2. Calculate Inserted
|
|
44
|
+
stats["inserted"] = (
|
|
45
|
+
await session.execute(
|
|
46
|
+
text(
|
|
47
|
+
"SELECT COUNT(*) FROM core_symbols_staging WHERE symbol_path NOT IN (SELECT symbol_path FROM core.symbols)"
|
|
48
|
+
)
|
|
49
|
+
)
|
|
50
|
+
).scalar_one()
|
|
51
|
+
# 3. Calculate Updated
|
|
52
|
+
stats["updated"] = (
|
|
53
|
+
await session.execute(
|
|
54
|
+
text(
|
|
55
|
+
"""
|
|
56
|
+
SELECT COUNT(*) FROM core.symbols s JOIN core_symbols_staging st ON s.symbol_path = st.symbol_path
|
|
57
|
+
WHERE s.fingerprint != st.fingerprint OR s.calls::text != st.calls::text OR s.domain != st.domain OR s.kind != st.kind
|
|
58
|
+
"""
|
|
59
|
+
)
|
|
60
|
+
)
|
|
61
|
+
).scalar_one()
|
|
62
|
+
|
|
63
|
+
# Apply Operations
|
|
64
|
+
await session.execute(
|
|
65
|
+
text(
|
|
66
|
+
"DELETE FROM core.symbols WHERE symbol_path NOT IN (SELECT symbol_path FROM core_symbols_staging)"
|
|
67
|
+
)
|
|
68
|
+
)
|
|
69
|
+
|
|
70
|
+
await session.execute(
|
|
71
|
+
text(
|
|
72
|
+
"""
|
|
73
|
+
UPDATE core.symbols
|
|
74
|
+
SET fingerprint = st.fingerprint, calls = st.calls, domain = st.domain, kind = st.kind,
|
|
75
|
+
last_modified = NOW(), last_embedded = NULL, updated_at = NOW()
|
|
76
|
+
FROM core_symbols_staging st WHERE core.symbols.symbol_path = st.symbol_path
|
|
77
|
+
AND (core.symbols.fingerprint != st.fingerprint OR core.symbols.calls::text != st.calls::text OR core.symbols.domain != st.domain OR core.symbols.kind != st.kind);
|
|
78
|
+
"""
|
|
79
|
+
)
|
|
80
|
+
)
|
|
81
|
+
|
|
82
|
+
await session.execute(
|
|
83
|
+
text(
|
|
84
|
+
"""
|
|
85
|
+
INSERT INTO core.symbols (id, symbol_path, module, qualname, kind, ast_signature, fingerprint, state, is_public, calls, domain, created_at, updated_at, last_modified, first_seen, last_seen)
|
|
86
|
+
SELECT id, symbol_path, module, qualname, kind, ast_signature, fingerprint, state, is_public, calls, domain, NOW(), NOW(), NOW(), NOW(), NOW()
|
|
87
|
+
FROM core_symbols_staging ON CONFLICT (symbol_path) DO NOTHING;
|
|
88
|
+
"""
|
|
89
|
+
)
|
|
90
|
+
)
|
|
91
|
+
|
|
92
|
+
return stats
|