empathy-framework 3.7.0__py3-none-any.whl → 3.7.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.
Files changed (267) hide show
  1. coach_wizards/code_reviewer_README.md +60 -0
  2. coach_wizards/code_reviewer_wizard.py +180 -0
  3. {empathy_framework-3.7.0.dist-info → empathy_framework-3.7.1.dist-info}/METADATA +20 -2
  4. empathy_framework-3.7.1.dist-info/RECORD +327 -0
  5. {empathy_framework-3.7.0.dist-info → empathy_framework-3.7.1.dist-info}/top_level.txt +5 -1
  6. empathy_healthcare_plugin/monitors/__init__.py +9 -0
  7. empathy_healthcare_plugin/monitors/clinical_protocol_monitor.py +315 -0
  8. empathy_healthcare_plugin/monitors/monitoring/__init__.py +44 -0
  9. empathy_healthcare_plugin/monitors/monitoring/protocol_checker.py +300 -0
  10. empathy_healthcare_plugin/monitors/monitoring/protocol_loader.py +214 -0
  11. empathy_healthcare_plugin/monitors/monitoring/sensor_parsers.py +306 -0
  12. empathy_healthcare_plugin/monitors/monitoring/trajectory_analyzer.py +389 -0
  13. empathy_llm_toolkit/agent_factory/__init__.py +53 -0
  14. empathy_llm_toolkit/agent_factory/adapters/__init__.py +85 -0
  15. empathy_llm_toolkit/agent_factory/adapters/autogen_adapter.py +312 -0
  16. empathy_llm_toolkit/agent_factory/adapters/crewai_adapter.py +454 -0
  17. empathy_llm_toolkit/agent_factory/adapters/haystack_adapter.py +298 -0
  18. empathy_llm_toolkit/agent_factory/adapters/langchain_adapter.py +362 -0
  19. empathy_llm_toolkit/agent_factory/adapters/langgraph_adapter.py +333 -0
  20. empathy_llm_toolkit/agent_factory/adapters/native.py +228 -0
  21. empathy_llm_toolkit/agent_factory/adapters/wizard_adapter.py +426 -0
  22. empathy_llm_toolkit/agent_factory/base.py +305 -0
  23. empathy_llm_toolkit/agent_factory/crews/__init__.py +67 -0
  24. empathy_llm_toolkit/agent_factory/crews/code_review.py +1113 -0
  25. empathy_llm_toolkit/agent_factory/crews/health_check.py +1246 -0
  26. empathy_llm_toolkit/agent_factory/crews/refactoring.py +1128 -0
  27. empathy_llm_toolkit/agent_factory/crews/security_audit.py +1018 -0
  28. empathy_llm_toolkit/agent_factory/decorators.py +286 -0
  29. empathy_llm_toolkit/agent_factory/factory.py +558 -0
  30. empathy_llm_toolkit/agent_factory/framework.py +192 -0
  31. empathy_llm_toolkit/agent_factory/memory_integration.py +324 -0
  32. empathy_llm_toolkit/agent_factory/resilient.py +320 -0
  33. empathy_llm_toolkit/cli/__init__.py +8 -0
  34. empathy_llm_toolkit/cli/sync_claude.py +487 -0
  35. empathy_llm_toolkit/code_health.py +150 -3
  36. empathy_llm_toolkit/config/__init__.py +29 -0
  37. empathy_llm_toolkit/config/unified.py +295 -0
  38. empathy_llm_toolkit/routing/__init__.py +32 -0
  39. empathy_llm_toolkit/routing/model_router.py +362 -0
  40. empathy_llm_toolkit/security/IMPLEMENTATION_SUMMARY.md +413 -0
  41. empathy_llm_toolkit/security/PHASE2_COMPLETE.md +384 -0
  42. empathy_llm_toolkit/security/PHASE2_SECRETS_DETECTOR_COMPLETE.md +271 -0
  43. empathy_llm_toolkit/security/QUICK_REFERENCE.md +316 -0
  44. empathy_llm_toolkit/security/README.md +262 -0
  45. empathy_llm_toolkit/security/__init__.py +62 -0
  46. empathy_llm_toolkit/security/audit_logger.py +929 -0
  47. empathy_llm_toolkit/security/audit_logger_example.py +152 -0
  48. empathy_llm_toolkit/security/pii_scrubber.py +640 -0
  49. empathy_llm_toolkit/security/secrets_detector.py +678 -0
  50. empathy_llm_toolkit/security/secrets_detector_example.py +304 -0
  51. empathy_llm_toolkit/security/secure_memdocs.py +1192 -0
  52. empathy_llm_toolkit/security/secure_memdocs_example.py +278 -0
  53. empathy_llm_toolkit/wizards/__init__.py +38 -0
  54. empathy_llm_toolkit/wizards/base_wizard.py +364 -0
  55. empathy_llm_toolkit/wizards/customer_support_wizard.py +190 -0
  56. empathy_llm_toolkit/wizards/healthcare_wizard.py +362 -0
  57. empathy_llm_toolkit/wizards/patient_assessment_README.md +64 -0
  58. empathy_llm_toolkit/wizards/patient_assessment_wizard.py +193 -0
  59. empathy_llm_toolkit/wizards/technology_wizard.py +194 -0
  60. empathy_os/__init__.py +52 -52
  61. empathy_os/adaptive/__init__.py +13 -0
  62. empathy_os/adaptive/task_complexity.py +127 -0
  63. empathy_os/cli.py +118 -8
  64. empathy_os/cli_unified.py +121 -1
  65. empathy_os/config/__init__.py +63 -0
  66. empathy_os/config/xml_config.py +239 -0
  67. empathy_os/dashboard/__init__.py +15 -0
  68. empathy_os/dashboard/server.py +743 -0
  69. empathy_os/memory/__init__.py +195 -0
  70. empathy_os/memory/claude_memory.py +466 -0
  71. empathy_os/memory/config.py +224 -0
  72. empathy_os/memory/control_panel.py +1298 -0
  73. empathy_os/memory/edges.py +179 -0
  74. empathy_os/memory/graph.py +567 -0
  75. empathy_os/memory/long_term.py +1193 -0
  76. empathy_os/memory/nodes.py +179 -0
  77. empathy_os/memory/redis_bootstrap.py +540 -0
  78. empathy_os/memory/security/__init__.py +31 -0
  79. empathy_os/memory/security/audit_logger.py +930 -0
  80. empathy_os/memory/security/pii_scrubber.py +640 -0
  81. empathy_os/memory/security/secrets_detector.py +678 -0
  82. empathy_os/memory/short_term.py +2119 -0
  83. empathy_os/memory/storage/__init__.py +15 -0
  84. empathy_os/memory/summary_index.py +583 -0
  85. empathy_os/memory/unified.py +619 -0
  86. empathy_os/metrics/__init__.py +12 -0
  87. empathy_os/metrics/prompt_metrics.py +190 -0
  88. empathy_os/models/__init__.py +136 -0
  89. empathy_os/models/__main__.py +13 -0
  90. empathy_os/models/cli.py +655 -0
  91. empathy_os/models/empathy_executor.py +354 -0
  92. empathy_os/models/executor.py +252 -0
  93. empathy_os/models/fallback.py +671 -0
  94. empathy_os/models/provider_config.py +563 -0
  95. empathy_os/models/registry.py +382 -0
  96. empathy_os/models/tasks.py +302 -0
  97. empathy_os/models/telemetry.py +548 -0
  98. empathy_os/models/token_estimator.py +378 -0
  99. empathy_os/models/validation.py +274 -0
  100. empathy_os/monitoring/__init__.py +52 -0
  101. empathy_os/monitoring/alerts.py +23 -0
  102. empathy_os/monitoring/alerts_cli.py +268 -0
  103. empathy_os/monitoring/multi_backend.py +271 -0
  104. empathy_os/monitoring/otel_backend.py +363 -0
  105. empathy_os/optimization/__init__.py +19 -0
  106. empathy_os/optimization/context_optimizer.py +272 -0
  107. empathy_os/plugins/__init__.py +28 -0
  108. empathy_os/plugins/base.py +361 -0
  109. empathy_os/plugins/registry.py +268 -0
  110. empathy_os/project_index/__init__.py +30 -0
  111. empathy_os/project_index/cli.py +335 -0
  112. empathy_os/project_index/crew_integration.py +430 -0
  113. empathy_os/project_index/index.py +425 -0
  114. empathy_os/project_index/models.py +501 -0
  115. empathy_os/project_index/reports.py +473 -0
  116. empathy_os/project_index/scanner.py +538 -0
  117. empathy_os/prompts/__init__.py +61 -0
  118. empathy_os/prompts/config.py +77 -0
  119. empathy_os/prompts/context.py +177 -0
  120. empathy_os/prompts/parser.py +285 -0
  121. empathy_os/prompts/registry.py +313 -0
  122. empathy_os/prompts/templates.py +208 -0
  123. empathy_os/resilience/__init__.py +56 -0
  124. empathy_os/resilience/circuit_breaker.py +256 -0
  125. empathy_os/resilience/fallback.py +179 -0
  126. empathy_os/resilience/health.py +300 -0
  127. empathy_os/resilience/retry.py +209 -0
  128. empathy_os/resilience/timeout.py +135 -0
  129. empathy_os/routing/__init__.py +43 -0
  130. empathy_os/routing/chain_executor.py +433 -0
  131. empathy_os/routing/classifier.py +217 -0
  132. empathy_os/routing/smart_router.py +234 -0
  133. empathy_os/routing/wizard_registry.py +307 -0
  134. empathy_os/trust/__init__.py +28 -0
  135. empathy_os/trust/circuit_breaker.py +579 -0
  136. empathy_os/validation/__init__.py +19 -0
  137. empathy_os/validation/xml_validator.py +281 -0
  138. empathy_os/wizard_factory_cli.py +170 -0
  139. empathy_os/workflows/__init__.py +360 -0
  140. empathy_os/workflows/base.py +1530 -0
  141. empathy_os/workflows/bug_predict.py +962 -0
  142. empathy_os/workflows/code_review.py +960 -0
  143. empathy_os/workflows/code_review_adapters.py +310 -0
  144. empathy_os/workflows/code_review_pipeline.py +720 -0
  145. empathy_os/workflows/config.py +600 -0
  146. empathy_os/workflows/dependency_check.py +648 -0
  147. empathy_os/workflows/document_gen.py +1069 -0
  148. empathy_os/workflows/documentation_orchestrator.py +1205 -0
  149. empathy_os/workflows/health_check.py +679 -0
  150. empathy_os/workflows/keyboard_shortcuts/__init__.py +39 -0
  151. empathy_os/workflows/keyboard_shortcuts/generators.py +386 -0
  152. empathy_os/workflows/keyboard_shortcuts/parsers.py +414 -0
  153. empathy_os/workflows/keyboard_shortcuts/prompts.py +295 -0
  154. empathy_os/workflows/keyboard_shortcuts/schema.py +193 -0
  155. empathy_os/workflows/keyboard_shortcuts/workflow.py +505 -0
  156. empathy_os/workflows/manage_documentation.py +804 -0
  157. empathy_os/workflows/new_sample_workflow1.py +146 -0
  158. empathy_os/workflows/new_sample_workflow1_README.md +150 -0
  159. empathy_os/workflows/perf_audit.py +687 -0
  160. empathy_os/workflows/pr_review.py +748 -0
  161. empathy_os/workflows/progress.py +445 -0
  162. empathy_os/workflows/progress_server.py +322 -0
  163. empathy_os/workflows/refactor_plan.py +691 -0
  164. empathy_os/workflows/release_prep.py +808 -0
  165. empathy_os/workflows/research_synthesis.py +404 -0
  166. empathy_os/workflows/secure_release.py +585 -0
  167. empathy_os/workflows/security_adapters.py +297 -0
  168. empathy_os/workflows/security_audit.py +1050 -0
  169. empathy_os/workflows/step_config.py +234 -0
  170. empathy_os/workflows/test5.py +125 -0
  171. empathy_os/workflows/test5_README.md +158 -0
  172. empathy_os/workflows/test_gen.py +1855 -0
  173. empathy_os/workflows/test_lifecycle.py +526 -0
  174. empathy_os/workflows/test_maintenance.py +626 -0
  175. empathy_os/workflows/test_maintenance_cli.py +590 -0
  176. empathy_os/workflows/test_maintenance_crew.py +821 -0
  177. empathy_os/workflows/xml_enhanced_crew.py +285 -0
  178. empathy_software_plugin/cli/__init__.py +120 -0
  179. empathy_software_plugin/cli/inspect.py +362 -0
  180. empathy_software_plugin/cli.py +3 -1
  181. empathy_software_plugin/wizards/__init__.py +42 -0
  182. empathy_software_plugin/wizards/advanced_debugging_wizard.py +392 -0
  183. empathy_software_plugin/wizards/agent_orchestration_wizard.py +511 -0
  184. empathy_software_plugin/wizards/ai_collaboration_wizard.py +503 -0
  185. empathy_software_plugin/wizards/ai_context_wizard.py +441 -0
  186. empathy_software_plugin/wizards/ai_documentation_wizard.py +503 -0
  187. empathy_software_plugin/wizards/base_wizard.py +288 -0
  188. empathy_software_plugin/wizards/book_chapter_wizard.py +519 -0
  189. empathy_software_plugin/wizards/code_review_wizard.py +606 -0
  190. empathy_software_plugin/wizards/debugging/__init__.py +50 -0
  191. empathy_software_plugin/wizards/debugging/bug_risk_analyzer.py +414 -0
  192. empathy_software_plugin/wizards/debugging/config_loaders.py +442 -0
  193. empathy_software_plugin/wizards/debugging/fix_applier.py +469 -0
  194. empathy_software_plugin/wizards/debugging/language_patterns.py +383 -0
  195. empathy_software_plugin/wizards/debugging/linter_parsers.py +470 -0
  196. empathy_software_plugin/wizards/debugging/verification.py +369 -0
  197. empathy_software_plugin/wizards/enhanced_testing_wizard.py +537 -0
  198. empathy_software_plugin/wizards/memory_enhanced_debugging_wizard.py +816 -0
  199. empathy_software_plugin/wizards/multi_model_wizard.py +501 -0
  200. empathy_software_plugin/wizards/pattern_extraction_wizard.py +422 -0
  201. empathy_software_plugin/wizards/pattern_retriever_wizard.py +400 -0
  202. empathy_software_plugin/wizards/performance/__init__.py +9 -0
  203. empathy_software_plugin/wizards/performance/bottleneck_detector.py +221 -0
  204. empathy_software_plugin/wizards/performance/profiler_parsers.py +278 -0
  205. empathy_software_plugin/wizards/performance/trajectory_analyzer.py +429 -0
  206. empathy_software_plugin/wizards/performance_profiling_wizard.py +305 -0
  207. empathy_software_plugin/wizards/prompt_engineering_wizard.py +425 -0
  208. empathy_software_plugin/wizards/rag_pattern_wizard.py +461 -0
  209. empathy_software_plugin/wizards/security/__init__.py +32 -0
  210. empathy_software_plugin/wizards/security/exploit_analyzer.py +290 -0
  211. empathy_software_plugin/wizards/security/owasp_patterns.py +241 -0
  212. empathy_software_plugin/wizards/security/vulnerability_scanner.py +604 -0
  213. empathy_software_plugin/wizards/security_analysis_wizard.py +322 -0
  214. empathy_software_plugin/wizards/security_learning_wizard.py +740 -0
  215. empathy_software_plugin/wizards/tech_debt_wizard.py +726 -0
  216. empathy_software_plugin/wizards/testing/__init__.py +27 -0
  217. empathy_software_plugin/wizards/testing/coverage_analyzer.py +459 -0
  218. empathy_software_plugin/wizards/testing/quality_analyzer.py +531 -0
  219. empathy_software_plugin/wizards/testing/test_suggester.py +533 -0
  220. empathy_software_plugin/wizards/testing_wizard.py +274 -0
  221. hot_reload/README.md +473 -0
  222. hot_reload/__init__.py +62 -0
  223. hot_reload/config.py +84 -0
  224. hot_reload/integration.py +228 -0
  225. hot_reload/reloader.py +298 -0
  226. hot_reload/watcher.py +179 -0
  227. hot_reload/websocket.py +176 -0
  228. scaffolding/README.md +589 -0
  229. scaffolding/__init__.py +35 -0
  230. scaffolding/__main__.py +14 -0
  231. scaffolding/cli.py +240 -0
  232. test_generator/__init__.py +38 -0
  233. test_generator/__main__.py +14 -0
  234. test_generator/cli.py +226 -0
  235. test_generator/generator.py +325 -0
  236. test_generator/risk_analyzer.py +216 -0
  237. workflow_patterns/__init__.py +33 -0
  238. workflow_patterns/behavior.py +249 -0
  239. workflow_patterns/core.py +76 -0
  240. workflow_patterns/output.py +99 -0
  241. workflow_patterns/registry.py +255 -0
  242. workflow_patterns/structural.py +288 -0
  243. workflow_scaffolding/__init__.py +11 -0
  244. workflow_scaffolding/__main__.py +12 -0
  245. workflow_scaffolding/cli.py +206 -0
  246. workflow_scaffolding/generator.py +265 -0
  247. agents/code_inspection/patterns/inspection/recurring_B112.json +0 -18
  248. agents/code_inspection/patterns/inspection/recurring_F541.json +0 -16
  249. agents/code_inspection/patterns/inspection/recurring_FORMAT.json +0 -25
  250. agents/code_inspection/patterns/inspection/recurring_bug_20250822_def456.json +0 -16
  251. agents/code_inspection/patterns/inspection/recurring_bug_20250915_abc123.json +0 -16
  252. agents/code_inspection/patterns/inspection/recurring_bug_20251212_3c5b9951.json +0 -16
  253. agents/code_inspection/patterns/inspection/recurring_bug_20251212_97c0f72f.json +0 -16
  254. agents/code_inspection/patterns/inspection/recurring_bug_20251212_a0871d53.json +0 -16
  255. agents/code_inspection/patterns/inspection/recurring_bug_20251212_a9b6ec41.json +0 -16
  256. agents/code_inspection/patterns/inspection/recurring_bug_null_001.json +0 -16
  257. agents/code_inspection/patterns/inspection/recurring_builtin.json +0 -16
  258. agents/compliance_anticipation_agent.py +0 -1422
  259. agents/compliance_db.py +0 -339
  260. agents/epic_integration_wizard.py +0 -530
  261. agents/notifications.py +0 -291
  262. agents/trust_building_behaviors.py +0 -872
  263. empathy_framework-3.7.0.dist-info/RECORD +0 -105
  264. {empathy_framework-3.7.0.dist-info → empathy_framework-3.7.1.dist-info}/WHEEL +0 -0
  265. {empathy_framework-3.7.0.dist-info → empathy_framework-3.7.1.dist-info}/entry_points.txt +0 -0
  266. {empathy_framework-3.7.0.dist-info → empathy_framework-3.7.1.dist-info}/licenses/LICENSE +0 -0
  267. /empathy_os/{monitoring.py → agent_monitoring.py} +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
- }