empathy-framework 3.2.3__py3-none-any.whl → 3.8.2__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.
Files changed (328) hide show
  1. coach_wizards/__init__.py +11 -12
  2. coach_wizards/accessibility_wizard.py +12 -12
  3. coach_wizards/api_wizard.py +12 -12
  4. coach_wizards/base_wizard.py +26 -20
  5. coach_wizards/cicd_wizard.py +15 -13
  6. coach_wizards/code_reviewer_README.md +60 -0
  7. coach_wizards/code_reviewer_wizard.py +180 -0
  8. coach_wizards/compliance_wizard.py +12 -12
  9. coach_wizards/database_wizard.py +12 -12
  10. coach_wizards/debugging_wizard.py +12 -12
  11. coach_wizards/documentation_wizard.py +12 -12
  12. coach_wizards/generate_wizards.py +1 -2
  13. coach_wizards/localization_wizard.py +101 -19
  14. coach_wizards/migration_wizard.py +12 -12
  15. coach_wizards/monitoring_wizard.py +12 -12
  16. coach_wizards/observability_wizard.py +12 -12
  17. coach_wizards/performance_wizard.py +12 -12
  18. coach_wizards/prompt_engineering_wizard.py +22 -25
  19. coach_wizards/refactoring_wizard.py +12 -12
  20. coach_wizards/scaling_wizard.py +12 -12
  21. coach_wizards/security_wizard.py +12 -12
  22. coach_wizards/testing_wizard.py +12 -12
  23. {empathy_framework-3.2.3.dist-info → empathy_framework-3.8.2.dist-info}/METADATA +513 -58
  24. empathy_framework-3.8.2.dist-info/RECORD +333 -0
  25. empathy_framework-3.8.2.dist-info/entry_points.txt +22 -0
  26. {empathy_framework-3.2.3.dist-info → empathy_framework-3.8.2.dist-info}/top_level.txt +5 -1
  27. empathy_healthcare_plugin/__init__.py +1 -2
  28. empathy_healthcare_plugin/monitors/__init__.py +9 -0
  29. empathy_healthcare_plugin/monitors/clinical_protocol_monitor.py +315 -0
  30. empathy_healthcare_plugin/monitors/monitoring/__init__.py +44 -0
  31. empathy_healthcare_plugin/monitors/monitoring/protocol_checker.py +300 -0
  32. empathy_healthcare_plugin/monitors/monitoring/protocol_loader.py +214 -0
  33. empathy_healthcare_plugin/monitors/monitoring/sensor_parsers.py +306 -0
  34. empathy_healthcare_plugin/monitors/monitoring/trajectory_analyzer.py +389 -0
  35. empathy_llm_toolkit/__init__.py +7 -7
  36. empathy_llm_toolkit/agent_factory/__init__.py +53 -0
  37. empathy_llm_toolkit/agent_factory/adapters/__init__.py +85 -0
  38. empathy_llm_toolkit/agent_factory/adapters/autogen_adapter.py +312 -0
  39. empathy_llm_toolkit/agent_factory/adapters/crewai_adapter.py +454 -0
  40. empathy_llm_toolkit/agent_factory/adapters/haystack_adapter.py +298 -0
  41. empathy_llm_toolkit/agent_factory/adapters/langchain_adapter.py +362 -0
  42. empathy_llm_toolkit/agent_factory/adapters/langgraph_adapter.py +333 -0
  43. empathy_llm_toolkit/agent_factory/adapters/native.py +228 -0
  44. empathy_llm_toolkit/agent_factory/adapters/wizard_adapter.py +426 -0
  45. empathy_llm_toolkit/agent_factory/base.py +305 -0
  46. empathy_llm_toolkit/agent_factory/crews/__init__.py +67 -0
  47. empathy_llm_toolkit/agent_factory/crews/code_review.py +1113 -0
  48. empathy_llm_toolkit/agent_factory/crews/health_check.py +1246 -0
  49. empathy_llm_toolkit/agent_factory/crews/refactoring.py +1128 -0
  50. empathy_llm_toolkit/agent_factory/crews/security_audit.py +1018 -0
  51. empathy_llm_toolkit/agent_factory/decorators.py +286 -0
  52. empathy_llm_toolkit/agent_factory/factory.py +558 -0
  53. empathy_llm_toolkit/agent_factory/framework.py +192 -0
  54. empathy_llm_toolkit/agent_factory/memory_integration.py +324 -0
  55. empathy_llm_toolkit/agent_factory/resilient.py +320 -0
  56. empathy_llm_toolkit/claude_memory.py +14 -15
  57. empathy_llm_toolkit/cli/__init__.py +8 -0
  58. empathy_llm_toolkit/cli/sync_claude.py +487 -0
  59. empathy_llm_toolkit/code_health.py +177 -22
  60. empathy_llm_toolkit/config/__init__.py +29 -0
  61. empathy_llm_toolkit/config/unified.py +295 -0
  62. empathy_llm_toolkit/contextual_patterns.py +11 -12
  63. empathy_llm_toolkit/core.py +51 -49
  64. empathy_llm_toolkit/git_pattern_extractor.py +16 -12
  65. empathy_llm_toolkit/levels.py +6 -13
  66. empathy_llm_toolkit/pattern_confidence.py +14 -18
  67. empathy_llm_toolkit/pattern_resolver.py +10 -12
  68. empathy_llm_toolkit/pattern_summary.py +13 -11
  69. empathy_llm_toolkit/providers.py +194 -28
  70. empathy_llm_toolkit/routing/__init__.py +32 -0
  71. empathy_llm_toolkit/routing/model_router.py +362 -0
  72. empathy_llm_toolkit/security/IMPLEMENTATION_SUMMARY.md +413 -0
  73. empathy_llm_toolkit/security/PHASE2_COMPLETE.md +384 -0
  74. empathy_llm_toolkit/security/PHASE2_SECRETS_DETECTOR_COMPLETE.md +271 -0
  75. empathy_llm_toolkit/security/QUICK_REFERENCE.md +316 -0
  76. empathy_llm_toolkit/security/README.md +262 -0
  77. empathy_llm_toolkit/security/__init__.py +62 -0
  78. empathy_llm_toolkit/security/audit_logger.py +929 -0
  79. empathy_llm_toolkit/security/audit_logger_example.py +152 -0
  80. empathy_llm_toolkit/security/pii_scrubber.py +640 -0
  81. empathy_llm_toolkit/security/secrets_detector.py +678 -0
  82. empathy_llm_toolkit/security/secrets_detector_example.py +304 -0
  83. empathy_llm_toolkit/security/secure_memdocs.py +1192 -0
  84. empathy_llm_toolkit/security/secure_memdocs_example.py +278 -0
  85. empathy_llm_toolkit/session_status.py +18 -20
  86. empathy_llm_toolkit/state.py +20 -21
  87. empathy_llm_toolkit/wizards/__init__.py +38 -0
  88. empathy_llm_toolkit/wizards/base_wizard.py +364 -0
  89. empathy_llm_toolkit/wizards/customer_support_wizard.py +190 -0
  90. empathy_llm_toolkit/wizards/healthcare_wizard.py +362 -0
  91. empathy_llm_toolkit/wizards/patient_assessment_README.md +64 -0
  92. empathy_llm_toolkit/wizards/patient_assessment_wizard.py +193 -0
  93. empathy_llm_toolkit/wizards/technology_wizard.py +194 -0
  94. empathy_os/__init__.py +76 -77
  95. empathy_os/adaptive/__init__.py +13 -0
  96. empathy_os/adaptive/task_complexity.py +127 -0
  97. empathy_os/{monitoring.py → agent_monitoring.py} +27 -27
  98. empathy_os/cache/__init__.py +117 -0
  99. empathy_os/cache/base.py +166 -0
  100. empathy_os/cache/dependency_manager.py +253 -0
  101. empathy_os/cache/hash_only.py +248 -0
  102. empathy_os/cache/hybrid.py +390 -0
  103. empathy_os/cache/storage.py +282 -0
  104. empathy_os/cli.py +515 -109
  105. empathy_os/cli_unified.py +189 -42
  106. empathy_os/config/__init__.py +63 -0
  107. empathy_os/config/xml_config.py +239 -0
  108. empathy_os/config.py +87 -36
  109. empathy_os/coordination.py +48 -54
  110. empathy_os/core.py +90 -99
  111. empathy_os/cost_tracker.py +20 -23
  112. empathy_os/dashboard/__init__.py +15 -0
  113. empathy_os/dashboard/server.py +743 -0
  114. empathy_os/discovery.py +9 -11
  115. empathy_os/emergence.py +20 -21
  116. empathy_os/exceptions.py +18 -30
  117. empathy_os/feedback_loops.py +27 -30
  118. empathy_os/levels.py +31 -34
  119. empathy_os/leverage_points.py +27 -28
  120. empathy_os/logging_config.py +11 -12
  121. empathy_os/memory/__init__.py +195 -0
  122. empathy_os/memory/claude_memory.py +466 -0
  123. empathy_os/memory/config.py +224 -0
  124. empathy_os/memory/control_panel.py +1298 -0
  125. empathy_os/memory/edges.py +179 -0
  126. empathy_os/memory/graph.py +567 -0
  127. empathy_os/memory/long_term.py +1194 -0
  128. empathy_os/memory/nodes.py +179 -0
  129. empathy_os/memory/redis_bootstrap.py +540 -0
  130. empathy_os/memory/security/__init__.py +31 -0
  131. empathy_os/memory/security/audit_logger.py +930 -0
  132. empathy_os/memory/security/pii_scrubber.py +640 -0
  133. empathy_os/memory/security/secrets_detector.py +678 -0
  134. empathy_os/memory/short_term.py +2119 -0
  135. empathy_os/memory/storage/__init__.py +15 -0
  136. empathy_os/memory/summary_index.py +583 -0
  137. empathy_os/memory/unified.py +619 -0
  138. empathy_os/metrics/__init__.py +12 -0
  139. empathy_os/metrics/prompt_metrics.py +190 -0
  140. empathy_os/models/__init__.py +136 -0
  141. empathy_os/models/__main__.py +13 -0
  142. empathy_os/models/cli.py +655 -0
  143. empathy_os/models/empathy_executor.py +354 -0
  144. empathy_os/models/executor.py +252 -0
  145. empathy_os/models/fallback.py +671 -0
  146. empathy_os/models/provider_config.py +563 -0
  147. empathy_os/models/registry.py +382 -0
  148. empathy_os/models/tasks.py +302 -0
  149. empathy_os/models/telemetry.py +548 -0
  150. empathy_os/models/token_estimator.py +378 -0
  151. empathy_os/models/validation.py +274 -0
  152. empathy_os/monitoring/__init__.py +52 -0
  153. empathy_os/monitoring/alerts.py +23 -0
  154. empathy_os/monitoring/alerts_cli.py +268 -0
  155. empathy_os/monitoring/multi_backend.py +271 -0
  156. empathy_os/monitoring/otel_backend.py +363 -0
  157. empathy_os/optimization/__init__.py +19 -0
  158. empathy_os/optimization/context_optimizer.py +272 -0
  159. empathy_os/pattern_library.py +29 -28
  160. empathy_os/persistence.py +30 -34
  161. empathy_os/platform_utils.py +261 -0
  162. empathy_os/plugins/__init__.py +28 -0
  163. empathy_os/plugins/base.py +361 -0
  164. empathy_os/plugins/registry.py +268 -0
  165. empathy_os/project_index/__init__.py +30 -0
  166. empathy_os/project_index/cli.py +335 -0
  167. empathy_os/project_index/crew_integration.py +430 -0
  168. empathy_os/project_index/index.py +425 -0
  169. empathy_os/project_index/models.py +501 -0
  170. empathy_os/project_index/reports.py +473 -0
  171. empathy_os/project_index/scanner.py +538 -0
  172. empathy_os/prompts/__init__.py +61 -0
  173. empathy_os/prompts/config.py +77 -0
  174. empathy_os/prompts/context.py +177 -0
  175. empathy_os/prompts/parser.py +285 -0
  176. empathy_os/prompts/registry.py +313 -0
  177. empathy_os/prompts/templates.py +208 -0
  178. empathy_os/redis_config.py +144 -58
  179. empathy_os/redis_memory.py +53 -56
  180. empathy_os/resilience/__init__.py +56 -0
  181. empathy_os/resilience/circuit_breaker.py +256 -0
  182. empathy_os/resilience/fallback.py +179 -0
  183. empathy_os/resilience/health.py +300 -0
  184. empathy_os/resilience/retry.py +209 -0
  185. empathy_os/resilience/timeout.py +135 -0
  186. empathy_os/routing/__init__.py +43 -0
  187. empathy_os/routing/chain_executor.py +433 -0
  188. empathy_os/routing/classifier.py +217 -0
  189. empathy_os/routing/smart_router.py +234 -0
  190. empathy_os/routing/wizard_registry.py +307 -0
  191. empathy_os/templates.py +12 -11
  192. empathy_os/trust/__init__.py +28 -0
  193. empathy_os/trust/circuit_breaker.py +579 -0
  194. empathy_os/trust_building.py +44 -36
  195. empathy_os/validation/__init__.py +19 -0
  196. empathy_os/validation/xml_validator.py +281 -0
  197. empathy_os/wizard_factory_cli.py +170 -0
  198. empathy_os/{workflows.py → workflow_commands.py} +123 -31
  199. empathy_os/workflows/__init__.py +360 -0
  200. empathy_os/workflows/base.py +1660 -0
  201. empathy_os/workflows/bug_predict.py +962 -0
  202. empathy_os/workflows/code_review.py +960 -0
  203. empathy_os/workflows/code_review_adapters.py +310 -0
  204. empathy_os/workflows/code_review_pipeline.py +720 -0
  205. empathy_os/workflows/config.py +600 -0
  206. empathy_os/workflows/dependency_check.py +648 -0
  207. empathy_os/workflows/document_gen.py +1069 -0
  208. empathy_os/workflows/documentation_orchestrator.py +1205 -0
  209. empathy_os/workflows/health_check.py +679 -0
  210. empathy_os/workflows/keyboard_shortcuts/__init__.py +39 -0
  211. empathy_os/workflows/keyboard_shortcuts/generators.py +386 -0
  212. empathy_os/workflows/keyboard_shortcuts/parsers.py +414 -0
  213. empathy_os/workflows/keyboard_shortcuts/prompts.py +295 -0
  214. empathy_os/workflows/keyboard_shortcuts/schema.py +193 -0
  215. empathy_os/workflows/keyboard_shortcuts/workflow.py +505 -0
  216. empathy_os/workflows/manage_documentation.py +804 -0
  217. empathy_os/workflows/new_sample_workflow1.py +146 -0
  218. empathy_os/workflows/new_sample_workflow1_README.md +150 -0
  219. empathy_os/workflows/perf_audit.py +687 -0
  220. empathy_os/workflows/pr_review.py +748 -0
  221. empathy_os/workflows/progress.py +445 -0
  222. empathy_os/workflows/progress_server.py +322 -0
  223. empathy_os/workflows/refactor_plan.py +693 -0
  224. empathy_os/workflows/release_prep.py +808 -0
  225. empathy_os/workflows/research_synthesis.py +404 -0
  226. empathy_os/workflows/secure_release.py +585 -0
  227. empathy_os/workflows/security_adapters.py +297 -0
  228. empathy_os/workflows/security_audit.py +1046 -0
  229. empathy_os/workflows/step_config.py +234 -0
  230. empathy_os/workflows/test5.py +125 -0
  231. empathy_os/workflows/test5_README.md +158 -0
  232. empathy_os/workflows/test_gen.py +1855 -0
  233. empathy_os/workflows/test_lifecycle.py +526 -0
  234. empathy_os/workflows/test_maintenance.py +626 -0
  235. empathy_os/workflows/test_maintenance_cli.py +590 -0
  236. empathy_os/workflows/test_maintenance_crew.py +821 -0
  237. empathy_os/workflows/xml_enhanced_crew.py +285 -0
  238. empathy_software_plugin/__init__.py +1 -2
  239. empathy_software_plugin/cli/__init__.py +120 -0
  240. empathy_software_plugin/cli/inspect.py +362 -0
  241. empathy_software_plugin/cli.py +35 -26
  242. empathy_software_plugin/plugin.py +4 -8
  243. empathy_software_plugin/wizards/__init__.py +42 -0
  244. empathy_software_plugin/wizards/advanced_debugging_wizard.py +392 -0
  245. empathy_software_plugin/wizards/agent_orchestration_wizard.py +511 -0
  246. empathy_software_plugin/wizards/ai_collaboration_wizard.py +503 -0
  247. empathy_software_plugin/wizards/ai_context_wizard.py +441 -0
  248. empathy_software_plugin/wizards/ai_documentation_wizard.py +503 -0
  249. empathy_software_plugin/wizards/base_wizard.py +288 -0
  250. empathy_software_plugin/wizards/book_chapter_wizard.py +519 -0
  251. empathy_software_plugin/wizards/code_review_wizard.py +606 -0
  252. empathy_software_plugin/wizards/debugging/__init__.py +50 -0
  253. empathy_software_plugin/wizards/debugging/bug_risk_analyzer.py +414 -0
  254. empathy_software_plugin/wizards/debugging/config_loaders.py +442 -0
  255. empathy_software_plugin/wizards/debugging/fix_applier.py +469 -0
  256. empathy_software_plugin/wizards/debugging/language_patterns.py +383 -0
  257. empathy_software_plugin/wizards/debugging/linter_parsers.py +470 -0
  258. empathy_software_plugin/wizards/debugging/verification.py +369 -0
  259. empathy_software_plugin/wizards/enhanced_testing_wizard.py +537 -0
  260. empathy_software_plugin/wizards/memory_enhanced_debugging_wizard.py +816 -0
  261. empathy_software_plugin/wizards/multi_model_wizard.py +501 -0
  262. empathy_software_plugin/wizards/pattern_extraction_wizard.py +422 -0
  263. empathy_software_plugin/wizards/pattern_retriever_wizard.py +400 -0
  264. empathy_software_plugin/wizards/performance/__init__.py +9 -0
  265. empathy_software_plugin/wizards/performance/bottleneck_detector.py +221 -0
  266. empathy_software_plugin/wizards/performance/profiler_parsers.py +278 -0
  267. empathy_software_plugin/wizards/performance/trajectory_analyzer.py +429 -0
  268. empathy_software_plugin/wizards/performance_profiling_wizard.py +305 -0
  269. empathy_software_plugin/wizards/prompt_engineering_wizard.py +425 -0
  270. empathy_software_plugin/wizards/rag_pattern_wizard.py +461 -0
  271. empathy_software_plugin/wizards/security/__init__.py +32 -0
  272. empathy_software_plugin/wizards/security/exploit_analyzer.py +290 -0
  273. empathy_software_plugin/wizards/security/owasp_patterns.py +241 -0
  274. empathy_software_plugin/wizards/security/vulnerability_scanner.py +604 -0
  275. empathy_software_plugin/wizards/security_analysis_wizard.py +322 -0
  276. empathy_software_plugin/wizards/security_learning_wizard.py +740 -0
  277. empathy_software_plugin/wizards/tech_debt_wizard.py +726 -0
  278. empathy_software_plugin/wizards/testing/__init__.py +27 -0
  279. empathy_software_plugin/wizards/testing/coverage_analyzer.py +459 -0
  280. empathy_software_plugin/wizards/testing/quality_analyzer.py +531 -0
  281. empathy_software_plugin/wizards/testing/test_suggester.py +533 -0
  282. empathy_software_plugin/wizards/testing_wizard.py +274 -0
  283. hot_reload/README.md +473 -0
  284. hot_reload/__init__.py +62 -0
  285. hot_reload/config.py +84 -0
  286. hot_reload/integration.py +228 -0
  287. hot_reload/reloader.py +298 -0
  288. hot_reload/watcher.py +179 -0
  289. hot_reload/websocket.py +176 -0
  290. scaffolding/README.md +589 -0
  291. scaffolding/__init__.py +35 -0
  292. scaffolding/__main__.py +14 -0
  293. scaffolding/cli.py +240 -0
  294. test_generator/__init__.py +38 -0
  295. test_generator/__main__.py +14 -0
  296. test_generator/cli.py +226 -0
  297. test_generator/generator.py +325 -0
  298. test_generator/risk_analyzer.py +216 -0
  299. workflow_patterns/__init__.py +33 -0
  300. workflow_patterns/behavior.py +249 -0
  301. workflow_patterns/core.py +76 -0
  302. workflow_patterns/output.py +99 -0
  303. workflow_patterns/registry.py +255 -0
  304. workflow_patterns/structural.py +288 -0
  305. workflow_scaffolding/__init__.py +11 -0
  306. workflow_scaffolding/__main__.py +12 -0
  307. workflow_scaffolding/cli.py +206 -0
  308. workflow_scaffolding/generator.py +265 -0
  309. agents/code_inspection/patterns/inspection/recurring_B112.json +0 -18
  310. agents/code_inspection/patterns/inspection/recurring_F541.json +0 -16
  311. agents/code_inspection/patterns/inspection/recurring_FORMAT.json +0 -25
  312. agents/code_inspection/patterns/inspection/recurring_bug_20250822_def456.json +0 -16
  313. agents/code_inspection/patterns/inspection/recurring_bug_20250915_abc123.json +0 -16
  314. agents/code_inspection/patterns/inspection/recurring_bug_20251212_3c5b9951.json +0 -16
  315. agents/code_inspection/patterns/inspection/recurring_bug_20251212_97c0f72f.json +0 -16
  316. agents/code_inspection/patterns/inspection/recurring_bug_20251212_a0871d53.json +0 -16
  317. agents/code_inspection/patterns/inspection/recurring_bug_20251212_a9b6ec41.json +0 -16
  318. agents/code_inspection/patterns/inspection/recurring_bug_null_001.json +0 -16
  319. agents/code_inspection/patterns/inspection/recurring_builtin.json +0 -16
  320. agents/compliance_anticipation_agent.py +0 -1427
  321. agents/epic_integration_wizard.py +0 -541
  322. agents/trust_building_behaviors.py +0 -891
  323. empathy_framework-3.2.3.dist-info/RECORD +0 -104
  324. empathy_framework-3.2.3.dist-info/entry_points.txt +0 -7
  325. empathy_llm_toolkit/htmlcov/status.json +0 -1
  326. empathy_llm_toolkit/security/htmlcov/status.json +0 -1
  327. {empathy_framework-3.2.3.dist-info → empathy_framework-3.8.2.dist-info}/WHEEL +0 -0
  328. {empathy_framework-3.2.3.dist-info → empathy_framework-3.8.2.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,265 @@
1
+ """Workflow code generator.
2
+
3
+ Generates workflow code from patterns and templates.
4
+
5
+ Copyright 2025 Smart-AI-Memory
6
+ Licensed under Fair Source License 0.9
7
+ """
8
+
9
+ from datetime import datetime
10
+ from pathlib import Path
11
+ from typing import Any
12
+
13
+ from jinja2 import Environment, FileSystemLoader
14
+
15
+ from workflow_patterns import get_workflow_pattern_registry
16
+
17
+
18
+ class WorkflowGenerator:
19
+ """Generates workflow code from patterns."""
20
+
21
+ def __init__(self, templates_dir: Path | None = None):
22
+ """Initialize generator.
23
+
24
+ Args:
25
+ templates_dir: Path to templates directory
26
+
27
+ """
28
+ if templates_dir is None:
29
+ templates_dir = Path(__file__).parent / "templates"
30
+
31
+ self.templates_dir = templates_dir
32
+ self.env = Environment(
33
+ loader=FileSystemLoader(str(templates_dir)),
34
+ trim_blocks=True,
35
+ lstrip_blocks=True,
36
+ )
37
+ self.registry = get_workflow_pattern_registry()
38
+
39
+ def _workflow_name_to_class_name(self, workflow_name: str) -> str:
40
+ """Convert workflow-name to WorkflowName class name.
41
+
42
+ Args:
43
+ workflow_name: Workflow name (e.g., "bug-scanner")
44
+
45
+ Returns:
46
+ Class name (e.g., "BugScannerWorkflow")
47
+
48
+ """
49
+ parts = workflow_name.replace("-", "_").replace("_", " ").split()
50
+ return "".join(p.capitalize() for p in parts) + "Workflow"
51
+
52
+ def _workflow_name_to_file_name(self, workflow_name: str) -> str:
53
+ """Convert workflow-name to file_name.
54
+
55
+ Args:
56
+ workflow_name: Workflow name (e.g., "bug-scanner")
57
+
58
+ Returns:
59
+ File name (e.g., "bug_scanner")
60
+
61
+ """
62
+ return workflow_name.replace("-", "_")
63
+
64
+ def _merge_code_sections(self, sections_by_location: dict) -> dict[str, str]:
65
+ """Merge code sections into single strings per location.
66
+
67
+ Args:
68
+ sections_by_location: Dict mapping location to list of CodeSection
69
+
70
+ Returns:
71
+ Dict mapping location to merged code string
72
+
73
+ """
74
+ merged = {}
75
+
76
+ for location, sections in sections_by_location.items():
77
+ # Sort by priority (highest first)
78
+ sections = sorted(sections, key=lambda s: -s.priority)
79
+
80
+ # Merge code
81
+ code_parts = [s.code for s in sections]
82
+ merged[location] = "\n\n".join(code_parts)
83
+
84
+ return merged
85
+
86
+ def generate_workflow(
87
+ self,
88
+ workflow_name: str,
89
+ description: str,
90
+ patterns: list[str],
91
+ stages: list[str] | None = None,
92
+ tier_map: dict[str, str] | None = None,
93
+ **kwargs: Any,
94
+ ) -> dict[str, str]:
95
+ """Generate workflow code.
96
+
97
+ Args:
98
+ workflow_name: Workflow name (e.g., "bug-scanner")
99
+ description: Workflow description
100
+ patterns: List of pattern IDs to use
101
+ stages: List of stage names (auto-generated if None)
102
+ tier_map: Mapping of stage to tier (auto-generated if None)
103
+ **kwargs: Additional context for code generation
104
+
105
+ Returns:
106
+ Dict with generated files:
107
+ - "workflow": Main workflow file content
108
+ - "test": Test file content
109
+ - "readme": README content
110
+
111
+ """
112
+ # Validate patterns
113
+ valid, error = self.registry.validate_pattern_combination(patterns)
114
+ if not valid:
115
+ raise ValueError(f"Invalid pattern combination: {error}")
116
+
117
+ # Auto-generate stages if not provided
118
+ if stages is None:
119
+ if "single-stage" in patterns:
120
+ stages = ["process"]
121
+ elif "multi-stage" in patterns:
122
+ stages = ["analyze", "process", "report"]
123
+ elif "crew-based" in patterns:
124
+ stages = ["diagnose", "fix"]
125
+ else:
126
+ stages = ["execute"]
127
+
128
+ # Auto-generate tier map if not provided
129
+ if tier_map is None:
130
+ if len(stages) == 1:
131
+ tier_map = {stages[0]: "CAPABLE"}
132
+ elif len(stages) == 2:
133
+ tier_map = {stages[0]: "CHEAP", stages[1]: "CAPABLE"}
134
+ else:
135
+ tier_map = {
136
+ stages[0]: "CHEAP",
137
+ **dict.fromkeys(stages[1:-1], "CAPABLE"),
138
+ stages[-1]: "PREMIUM",
139
+ }
140
+
141
+ # Generate class and file names
142
+ class_name = self._workflow_name_to_class_name(workflow_name)
143
+ workflow_file = self._workflow_name_to_file_name(workflow_name)
144
+
145
+ # Build context
146
+ context = {
147
+ "workflow_name": workflow_name,
148
+ "class_name": class_name,
149
+ "workflow_file": workflow_file,
150
+ "description": description,
151
+ "stages": stages,
152
+ "tier_map": tier_map,
153
+ "generation_date": datetime.now().strftime("%Y-%m-%d"),
154
+ "complexity": self._determine_complexity(patterns),
155
+ "patterns": [self.registry.get(p) for p in patterns if self.registry.get(p)],
156
+ # Pattern flags
157
+ "has_conditional_tier": "conditional-tier" in patterns,
158
+ "has_config_driven": "config-driven" in patterns,
159
+ "has_crew_based": "crew-based" in patterns,
160
+ "has_result_dataclass": "result-dataclass" in patterns,
161
+ "has_code_scanner": "code-scanner" in patterns,
162
+ "has_imports": False,
163
+ "has_step_config": False,
164
+ **kwargs,
165
+ }
166
+
167
+ # Generate code sections from patterns
168
+ sections_by_location = self.registry.generate_code_sections(patterns, context)
169
+ merged_sections = self._merge_code_sections(sections_by_location)
170
+
171
+ # Update context with merged sections
172
+ context.update(
173
+ {
174
+ "imports": merged_sections.get("imports", ""),
175
+ "helper_functions": merged_sections.get("helper_functions", ""),
176
+ "dataclasses": merged_sections.get("dataclasses", ""),
177
+ "class_attributes": merged_sections.get("class_attributes", ""),
178
+ "init_method": merged_sections.get("init_method", ""),
179
+ "methods": merged_sections.get("methods", ""),
180
+ }
181
+ )
182
+
183
+ # Update flags
184
+ context["has_imports"] = bool(context["imports"])
185
+ context["has_step_config"] = "WorkflowStepConfig" in str(merged_sections)
186
+
187
+ # Generate files
188
+ workflow_template = self.env.get_template("workflow.py.j2")
189
+ test_template = self.env.get_template("test.py.j2")
190
+ readme_template = self.env.get_template("README.md.j2")
191
+
192
+ return {
193
+ "workflow": workflow_template.render(**context),
194
+ "test": test_template.render(**context),
195
+ "readme": readme_template.render(**context),
196
+ }
197
+
198
+ def _determine_complexity(self, patterns: list[str]) -> str:
199
+ """Determine overall workflow complexity.
200
+
201
+ Args:
202
+ patterns: List of pattern IDs
203
+
204
+ Returns:
205
+ Complexity level string
206
+
207
+ """
208
+ if "crew-based" in patterns or "multi-stage" in patterns:
209
+ return "COMPLEX"
210
+ if "conditional-tier" in patterns or "config-driven" in patterns:
211
+ return "MODERATE"
212
+ return "SIMPLE"
213
+
214
+ def write_workflow(
215
+ self,
216
+ output_dir: Path,
217
+ workflow_name: str,
218
+ description: str,
219
+ patterns: list[str],
220
+ **kwargs: Any,
221
+ ) -> dict[str, Path]:
222
+ """Generate and write workflow files.
223
+
224
+ Args:
225
+ output_dir: Base output directory
226
+ workflow_name: Workflow name
227
+ description: Workflow description
228
+ patterns: List of pattern IDs
229
+ **kwargs: Additional generation parameters
230
+
231
+ Returns:
232
+ Dict mapping file type to written path
233
+
234
+ """
235
+ # Generate code
236
+ generated = self.generate_workflow(
237
+ workflow_name,
238
+ description,
239
+ patterns,
240
+ **kwargs,
241
+ )
242
+
243
+ # Determine file paths
244
+ workflow_file = self._workflow_name_to_file_name(workflow_name)
245
+
246
+ workflow_dir = output_dir / "src" / "empathy_os" / "workflows"
247
+ test_dir = output_dir / "tests" / "unit" / "workflows"
248
+
249
+ workflow_dir.mkdir(parents=True, exist_ok=True)
250
+ test_dir.mkdir(parents=True, exist_ok=True)
251
+
252
+ workflow_path = workflow_dir / f"{workflow_file}.py"
253
+ test_path = test_dir / f"test_{workflow_file}.py"
254
+ readme_path = workflow_dir / f"{workflow_file}_README.md"
255
+
256
+ # Write files
257
+ workflow_path.write_text(generated["workflow"])
258
+ test_path.write_text(generated["test"])
259
+ readme_path.write_text(generated["readme"])
260
+
261
+ return {
262
+ "workflow": workflow_path,
263
+ "test": test_path,
264
+ "readme": readme_path,
265
+ }
@@ -1,18 +0,0 @@
1
- {
2
- "pattern_id": "recurring_B112",
3
- "pattern_type": "recurring_finding",
4
- "code": "B112",
5
- "occurrence_count": 3,
6
- "affected_files": [
7
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/security_adapter.py",
8
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/tech_debt_adapter.py",
9
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/test_quality_adapter.py"
10
- ],
11
- "severity": "medium",
12
- "description": "Try, Except, Continue detected.",
13
- "category": "security",
14
- "tool": "code_health",
15
- "confidence": 0.3,
16
- "stored_at": "2025-12-18T14:56:09.532796",
17
- "execution_id": "insp_20251218_145600_e1ab97e6"
18
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_F541",
3
- "pattern_type": "recurring_finding",
4
- "code": "F541",
5
- "occurrence_count": 5,
6
- "affected_files": [
7
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/nodes/reporting.py"
8
- ],
9
- "severity": "high",
10
- "description": "f-string without any placeholders",
11
- "category": "lint",
12
- "tool": "code_health",
13
- "confidence": 0.5,
14
- "stored_at": "2025-12-18T14:03:03.868558",
15
- "execution_id": "insp_20251218_140301_06c77b71"
16
- }
@@ -1,25 +0,0 @@
1
- {
2
- "pattern_id": "recurring_FORMAT",
3
- "pattern_type": "recurring_finding",
4
- "code": "FORMAT",
5
- "occurrence_count": 13,
6
- "affected_files": [
7
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/handoffs.py",
8
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/nodes/cross_analysis.py",
9
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/state.py",
10
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/nodes/dynamic_analysis.py",
11
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/debugging_adapter.py",
12
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/nodes/reporting.py",
13
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/routing.py",
14
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/test_quality_adapter.py",
15
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/tech_debt_adapter.py",
16
- "/Users/patrickroebuck/empathy_11_6_2025/Empathy-framework/agents/code_inspection/adapters/code_health_adapter.py"
17
- ],
18
- "severity": "medium",
19
- "description": "File needs reformatting",
20
- "category": "format",
21
- "tool": "code_health",
22
- "confidence": 1.0,
23
- "stored_at": "2025-12-18T14:16:42.830219",
24
- "execution_id": "insp_20251218_141640_218eb55d"
25
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_20250822_def456",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_20250822_def456",
5
- "occurrence_count": 114,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_20250822_def456)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235614",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_20250915_abc123",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_20250915_abc123",
5
- "occurrence_count": 114,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_20250915_abc123)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235364",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_20251212_3c5b9951",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_20251212_3c5b9951",
5
- "occurrence_count": 57,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_20251212_3c5b9951)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235448",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_20251212_97c0f72f",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_20251212_97c0f72f",
5
- "occurrence_count": 57,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_20251212_97c0f72f)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235526",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_20251212_a0871d53",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_20251212_a0871d53",
5
- "occurrence_count": 57,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_20251212_a0871d53)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235777",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_20251212_a9b6ec41",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_20251212_a9b6ec41",
5
- "occurrence_count": 57,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_20251212_a9b6ec41)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235694",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_bug_null_001",
3
- "pattern_type": "recurring_finding",
4
- "code": "bug_null_001",
5
- "occurrence_count": 57,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference (historical: bug_null_001)",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235863",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }
@@ -1,16 +0,0 @@
1
- {
2
- "pattern_id": "recurring_builtin",
3
- "pattern_type": "recurring_finding",
4
- "code": "builtin",
5
- "occurrence_count": 80,
6
- "affected_files": [
7
- ""
8
- ],
9
- "severity": "medium",
10
- "description": "Potential null/undefined reference",
11
- "category": "review",
12
- "tool": "code_review",
13
- "confidence": 1.0,
14
- "stored_at": "2025-12-18T14:09:01.235276",
15
- "execution_id": "insp_20251218_140852_9d09aaa9"
16
- }