claude-code-orchestrator-kit 1.4.0 → 1.4.15
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.
- package/.claude/agents/business/workers/lead-research-assistant.md +199 -0
- package/.claude/agents/database/workers/database-architect.md +3 -3
- package/.claude/agents/database/workers/supabase-auditor.md +7 -7
- package/.claude/agents/development/workers/code-reviewer.md +17 -2
- package/.claude/agents/frontend/workers/nextjs-ui-designer.md +30 -0
- package/.claude/agents/health/workers/bug-fixer.md +31 -2
- package/.claude/agents/health/workers/bug-hunter.md +0 -1
- package/.claude/agents/health/workers/dead-code-hunter.md +167 -75
- package/.claude/agents/health/workers/dead-code-remover.md +217 -66
- package/.claude/agents/health/workers/dependency-auditor.md +83 -24
- package/.claude/agents/health/workers/dependency-updater.md +0 -1
- package/.claude/agents/health/workers/security-scanner.md +0 -1
- package/.claude/agents/infrastructure/workers/deployment-engineer.md +446 -0
- package/.claude/agents/infrastructure/workers/infrastructure-specialist.md +2 -2
- package/.claude/agents/meta/workers/meta-agent-v3.md +22 -0
- package/.claude/agents/testing/workers/integration-tester.md +1 -1
- package/.claude/agents/testing/workers/test-writer.md +16 -0
- package/.claude/commands/health-bugs.md +14 -281
- package/.claude/commands/health-cleanup.md +14 -281
- package/.claude/commands/health-deps.md +14 -281
- package/.claude/commands/health-metrics.md +51 -709
- package/.claude/commands/health-reuse.md +14 -311
- package/.claude/commands/health-security.md +14 -281
- package/.claude/commands/push.md +17 -3
- package/.claude/commands/speckit.implement.md +0 -11
- package/.claude/commands/speckit.taskstoissues.md +95 -5
- package/.claude/commands/worktree.md +150 -0
- package/.claude/scripts/gates/check-bundle-size.sh +0 -0
- package/.claude/scripts/gates/check-coverage.sh +0 -0
- package/.claude/scripts/gates/check-security.sh +0 -0
- package/.claude/scripts/release.sh +469 -94
- package/.claude/skills/algorithmic-art/LICENSE.txt +202 -0
- package/.claude/skills/algorithmic-art/SKILL.md +405 -0
- package/.claude/skills/algorithmic-art/templates/generator_template.js +223 -0
- package/.claude/skills/algorithmic-art/templates/viewer.html +599 -0
- package/.claude/skills/artifacts-builder/LICENSE.txt +202 -0
- package/.claude/skills/artifacts-builder/SKILL.md +74 -0
- package/.claude/skills/artifacts-builder/scripts/bundle-artifact.sh +54 -0
- package/.claude/skills/artifacts-builder/scripts/init-artifact.sh +322 -0
- package/.claude/skills/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
- package/.claude/skills/bug-health-inline/SKILL.md +221 -0
- package/.claude/skills/bug-health-inline/references/worker-prompts.md +182 -0
- package/.claude/skills/canvas-design/LICENSE.txt +202 -0
- package/.claude/skills/canvas-design/SKILL.md +130 -0
- package/.claude/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
- package/.claude/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
- package/.claude/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
- package/.claude/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
- package/.claude/skills/changelog-generator/SKILL.md +104 -0
- package/.claude/skills/cleanup-health-inline/SKILL.md +224 -0
- package/.claude/skills/code-reviewer/SKILL.md +209 -0
- package/.claude/skills/code-reviewer/references/code_review_checklist.md +103 -0
- package/.claude/skills/code-reviewer/references/coding_standards.md +103 -0
- package/.claude/skills/code-reviewer/references/common_antipatterns.md +103 -0
- package/.claude/skills/code-reviewer/scripts/code_quality_checker.py +114 -0
- package/.claude/skills/code-reviewer/scripts/pr_analyzer.py +114 -0
- package/.claude/skills/code-reviewer/scripts/review_report_generator.py +114 -0
- package/.claude/skills/content-research-writer/SKILL.md +538 -0
- package/.claude/skills/deps-health-inline/SKILL.md +227 -0
- package/.claude/skills/frontend-aesthetics/SKILL.md +51 -396
- package/.claude/skills/git-commit-helper/SKILL.md +203 -0
- package/.claude/skills/lead-research-assistant/SKILL.md +199 -0
- package/.claude/skills/reuse-health-inline/SKILL.md +248 -0
- package/.claude/skills/rollback-changes/SKILL.md +50 -524
- package/.claude/skills/run-quality-gate/SKILL.md +36 -346
- package/.claude/skills/security-health-inline/SKILL.md +224 -0
- package/.claude/skills/senior-devops/SKILL.md +209 -0
- package/.claude/skills/senior-devops/references/cicd_pipeline_guide.md +103 -0
- package/.claude/skills/senior-devops/references/deployment_strategies.md +103 -0
- package/.claude/skills/senior-devops/references/infrastructure_as_code.md +103 -0
- package/.claude/skills/senior-devops/scripts/deployment_manager.py +114 -0
- package/.claude/skills/senior-devops/scripts/pipeline_generator.py +114 -0
- package/.claude/skills/senior-devops/scripts/terraform_scaffolder.py +114 -0
- package/.claude/skills/senior-prompt-engineer/SKILL.md +226 -0
- package/.claude/skills/senior-prompt-engineer/references/agentic_system_design.md +80 -0
- package/.claude/skills/senior-prompt-engineer/references/llm_evaluation_frameworks.md +80 -0
- package/.claude/skills/senior-prompt-engineer/references/prompt_engineering_patterns.md +80 -0
- package/.claude/skills/senior-prompt-engineer/scripts/agent_orchestrator.py +100 -0
- package/.claude/skills/senior-prompt-engineer/scripts/prompt_optimizer.py +100 -0
- package/.claude/skills/senior-prompt-engineer/scripts/rag_evaluator.py +100 -0
- package/.claude/skills/setup-knip/SKILL.md +372 -0
- package/.claude/skills/systematic-debugging/CREATION-LOG.md +119 -0
- package/.claude/skills/systematic-debugging/SKILL.md +296 -0
- package/.claude/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
- package/.claude/skills/systematic-debugging/condition-based-waiting.md +115 -0
- package/.claude/skills/systematic-debugging/defense-in-depth.md +122 -0
- package/.claude/skills/systematic-debugging/find-polluter.sh +63 -0
- package/.claude/skills/systematic-debugging/root-cause-tracing.md +169 -0
- package/.claude/skills/systematic-debugging/test-academic.md +14 -0
- package/.claude/skills/systematic-debugging/test-pressure-1.md +58 -0
- package/.claude/skills/systematic-debugging/test-pressure-2.md +68 -0
- package/.claude/skills/systematic-debugging/test-pressure-3.md +69 -0
- package/.claude/skills/theme-factory/LICENSE.txt +202 -0
- package/.claude/skills/theme-factory/SKILL.md +59 -0
- package/.claude/skills/theme-factory/theme-showcase.pdf +0 -0
- package/.claude/skills/theme-factory/themes/arctic-frost.md +19 -0
- package/.claude/skills/theme-factory/themes/botanical-garden.md +19 -0
- package/.claude/skills/theme-factory/themes/desert-rose.md +19 -0
- package/.claude/skills/theme-factory/themes/forest-canopy.md +19 -0
- package/.claude/skills/theme-factory/themes/golden-hour.md +19 -0
- package/.claude/skills/theme-factory/themes/midnight-galaxy.md +19 -0
- package/.claude/skills/theme-factory/themes/modern-minimalist.md +19 -0
- package/.claude/skills/theme-factory/themes/ocean-depths.md +19 -0
- package/.claude/skills/theme-factory/themes/sunset-boulevard.md +19 -0
- package/.claude/skills/theme-factory/themes/tech-innovation.md +19 -0
- package/.claude/skills/ui-design-system/SKILL.md +32 -0
- package/.claude/skills/ui-design-system/scripts/design_token_generator.py +529 -0
- package/.claude/skills/ux-researcher-designer/SKILL.md +30 -0
- package/.claude/skills/ux-researcher-designer/scripts/persona_generator.py +508 -0
- package/.claude/skills/webapp-testing/LICENSE.txt +202 -0
- package/.claude/skills/webapp-testing/SKILL.md +96 -0
- package/.claude/skills/webapp-testing/examples/console_logging.py +35 -0
- package/.claude/skills/webapp-testing/examples/element_discovery.py +40 -0
- package/.claude/skills/webapp-testing/examples/static_html_automation.py +33 -0
- package/.claude/skills/webapp-testing/scripts/with_server.py +106 -0
- package/.gitignore +4 -0
- package/README.md +492 -1093
- package/README.ru.md +719 -0
- package/docs/Agents Ecosystem/AGENT-ORCHESTRATION.md +2 -2
- package/docs/{SPECKIT-GUIDE.md → COMMANDS-GUIDE.md} +252 -20
- package/docs/reports/skills/new-skills-analysis-2025-12.md +331 -0
- package/package.json +11 -3
- package/.claude/agents/health/orchestrators/bug-orchestrator.md +0 -1084
- package/.claude/agents/health/orchestrators/dead-code-orchestrator.md +0 -1064
- package/.claude/agents/health/orchestrators/dependency-orchestrator.md +0 -1064
- package/.claude/agents/health/orchestrators/reuse-orchestrator.md +0 -1112
- package/.claude/agents/health/orchestrators/security-orchestrator.md +0 -1064
- package/.claude/commands/worktree-cleanup.md +0 -382
- package/.claude/commands/worktree-create.md +0 -287
- package/.claude/commands/worktree-list.md +0 -239
- package/.claude/commands/worktree-remove.md +0 -339
- package/.claude/project-index.md +0 -75
- package/.claude/skills/load-project-context/SKILL.md +0 -89
- package/.claude/skills/resume-session/SKILL.md +0 -164
- package/.claude/skills/save-session-context/SKILL.md +0 -123
- package/.claude/templates/project-index.template.md +0 -67
- package/.claude/templates/session/context.template.md +0 -40
- package/.claude/templates/session/log.template.md +0 -72
- package/.github/BRANCH_PROTECTION.md +0 -137
- package/.github/workflows/build.yml +0 -70
- package/.github/workflows/deploy-staging.yml +0 -90
- package/.github/workflows/test.yml +0 -104
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""
|
|
3
|
+
Agent Orchestrator
|
|
4
|
+
Production-grade tool for senior prompt engineer
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import os
|
|
8
|
+
import sys
|
|
9
|
+
import json
|
|
10
|
+
import logging
|
|
11
|
+
import argparse
|
|
12
|
+
from pathlib import Path
|
|
13
|
+
from typing import Dict, List, Optional
|
|
14
|
+
from datetime import datetime
|
|
15
|
+
|
|
16
|
+
logging.basicConfig(
|
|
17
|
+
level=logging.INFO,
|
|
18
|
+
format='%(asctime)s - %(levelname)s - %(message)s'
|
|
19
|
+
)
|
|
20
|
+
logger = logging.getLogger(__name__)
|
|
21
|
+
|
|
22
|
+
class AgentOrchestrator:
|
|
23
|
+
"""Production-grade agent orchestrator"""
|
|
24
|
+
|
|
25
|
+
def __init__(self, config: Dict):
|
|
26
|
+
self.config = config
|
|
27
|
+
self.results = {
|
|
28
|
+
'status': 'initialized',
|
|
29
|
+
'start_time': datetime.now().isoformat(),
|
|
30
|
+
'processed_items': 0
|
|
31
|
+
}
|
|
32
|
+
logger.info(f"Initialized {self.__class__.__name__}")
|
|
33
|
+
|
|
34
|
+
def validate_config(self) -> bool:
|
|
35
|
+
"""Validate configuration"""
|
|
36
|
+
logger.info("Validating configuration...")
|
|
37
|
+
# Add validation logic
|
|
38
|
+
logger.info("Configuration validated")
|
|
39
|
+
return True
|
|
40
|
+
|
|
41
|
+
def process(self) -> Dict:
|
|
42
|
+
"""Main processing logic"""
|
|
43
|
+
logger.info("Starting processing...")
|
|
44
|
+
|
|
45
|
+
try:
|
|
46
|
+
self.validate_config()
|
|
47
|
+
|
|
48
|
+
# Main processing
|
|
49
|
+
result = self._execute()
|
|
50
|
+
|
|
51
|
+
self.results['status'] = 'completed'
|
|
52
|
+
self.results['end_time'] = datetime.now().isoformat()
|
|
53
|
+
|
|
54
|
+
logger.info("Processing completed successfully")
|
|
55
|
+
return self.results
|
|
56
|
+
|
|
57
|
+
except Exception as e:
|
|
58
|
+
self.results['status'] = 'failed'
|
|
59
|
+
self.results['error'] = str(e)
|
|
60
|
+
logger.error(f"Processing failed: {e}")
|
|
61
|
+
raise
|
|
62
|
+
|
|
63
|
+
def _execute(self) -> Dict:
|
|
64
|
+
"""Execute main logic"""
|
|
65
|
+
# Implementation here
|
|
66
|
+
return {'success': True}
|
|
67
|
+
|
|
68
|
+
def main():
|
|
69
|
+
"""Main entry point"""
|
|
70
|
+
parser = argparse.ArgumentParser(
|
|
71
|
+
description="Agent Orchestrator"
|
|
72
|
+
)
|
|
73
|
+
parser.add_argument('--input', '-i', required=True, help='Input path')
|
|
74
|
+
parser.add_argument('--output', '-o', required=True, help='Output path')
|
|
75
|
+
parser.add_argument('--config', '-c', help='Configuration file')
|
|
76
|
+
parser.add_argument('--verbose', '-v', action='store_true', help='Verbose output')
|
|
77
|
+
|
|
78
|
+
args = parser.parse_args()
|
|
79
|
+
|
|
80
|
+
if args.verbose:
|
|
81
|
+
logging.getLogger().setLevel(logging.DEBUG)
|
|
82
|
+
|
|
83
|
+
try:
|
|
84
|
+
config = {
|
|
85
|
+
'input': args.input,
|
|
86
|
+
'output': args.output
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
processor = AgentOrchestrator(config)
|
|
90
|
+
results = processor.process()
|
|
91
|
+
|
|
92
|
+
print(json.dumps(results, indent=2))
|
|
93
|
+
sys.exit(0)
|
|
94
|
+
|
|
95
|
+
except Exception as e:
|
|
96
|
+
logger.error(f"Fatal error: {e}")
|
|
97
|
+
sys.exit(1)
|
|
98
|
+
|
|
99
|
+
if __name__ == '__main__':
|
|
100
|
+
main()
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""
|
|
3
|
+
Prompt Optimizer
|
|
4
|
+
Production-grade tool for senior prompt engineer
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import os
|
|
8
|
+
import sys
|
|
9
|
+
import json
|
|
10
|
+
import logging
|
|
11
|
+
import argparse
|
|
12
|
+
from pathlib import Path
|
|
13
|
+
from typing import Dict, List, Optional
|
|
14
|
+
from datetime import datetime
|
|
15
|
+
|
|
16
|
+
logging.basicConfig(
|
|
17
|
+
level=logging.INFO,
|
|
18
|
+
format='%(asctime)s - %(levelname)s - %(message)s'
|
|
19
|
+
)
|
|
20
|
+
logger = logging.getLogger(__name__)
|
|
21
|
+
|
|
22
|
+
class PromptOptimizer:
|
|
23
|
+
"""Production-grade prompt optimizer"""
|
|
24
|
+
|
|
25
|
+
def __init__(self, config: Dict):
|
|
26
|
+
self.config = config
|
|
27
|
+
self.results = {
|
|
28
|
+
'status': 'initialized',
|
|
29
|
+
'start_time': datetime.now().isoformat(),
|
|
30
|
+
'processed_items': 0
|
|
31
|
+
}
|
|
32
|
+
logger.info(f"Initialized {self.__class__.__name__}")
|
|
33
|
+
|
|
34
|
+
def validate_config(self) -> bool:
|
|
35
|
+
"""Validate configuration"""
|
|
36
|
+
logger.info("Validating configuration...")
|
|
37
|
+
# Add validation logic
|
|
38
|
+
logger.info("Configuration validated")
|
|
39
|
+
return True
|
|
40
|
+
|
|
41
|
+
def process(self) -> Dict:
|
|
42
|
+
"""Main processing logic"""
|
|
43
|
+
logger.info("Starting processing...")
|
|
44
|
+
|
|
45
|
+
try:
|
|
46
|
+
self.validate_config()
|
|
47
|
+
|
|
48
|
+
# Main processing
|
|
49
|
+
result = self._execute()
|
|
50
|
+
|
|
51
|
+
self.results['status'] = 'completed'
|
|
52
|
+
self.results['end_time'] = datetime.now().isoformat()
|
|
53
|
+
|
|
54
|
+
logger.info("Processing completed successfully")
|
|
55
|
+
return self.results
|
|
56
|
+
|
|
57
|
+
except Exception as e:
|
|
58
|
+
self.results['status'] = 'failed'
|
|
59
|
+
self.results['error'] = str(e)
|
|
60
|
+
logger.error(f"Processing failed: {e}")
|
|
61
|
+
raise
|
|
62
|
+
|
|
63
|
+
def _execute(self) -> Dict:
|
|
64
|
+
"""Execute main logic"""
|
|
65
|
+
# Implementation here
|
|
66
|
+
return {'success': True}
|
|
67
|
+
|
|
68
|
+
def main():
|
|
69
|
+
"""Main entry point"""
|
|
70
|
+
parser = argparse.ArgumentParser(
|
|
71
|
+
description="Prompt Optimizer"
|
|
72
|
+
)
|
|
73
|
+
parser.add_argument('--input', '-i', required=True, help='Input path')
|
|
74
|
+
parser.add_argument('--output', '-o', required=True, help='Output path')
|
|
75
|
+
parser.add_argument('--config', '-c', help='Configuration file')
|
|
76
|
+
parser.add_argument('--verbose', '-v', action='store_true', help='Verbose output')
|
|
77
|
+
|
|
78
|
+
args = parser.parse_args()
|
|
79
|
+
|
|
80
|
+
if args.verbose:
|
|
81
|
+
logging.getLogger().setLevel(logging.DEBUG)
|
|
82
|
+
|
|
83
|
+
try:
|
|
84
|
+
config = {
|
|
85
|
+
'input': args.input,
|
|
86
|
+
'output': args.output
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
processor = PromptOptimizer(config)
|
|
90
|
+
results = processor.process()
|
|
91
|
+
|
|
92
|
+
print(json.dumps(results, indent=2))
|
|
93
|
+
sys.exit(0)
|
|
94
|
+
|
|
95
|
+
except Exception as e:
|
|
96
|
+
logger.error(f"Fatal error: {e}")
|
|
97
|
+
sys.exit(1)
|
|
98
|
+
|
|
99
|
+
if __name__ == '__main__':
|
|
100
|
+
main()
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""
|
|
3
|
+
Rag Evaluator
|
|
4
|
+
Production-grade tool for senior prompt engineer
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import os
|
|
8
|
+
import sys
|
|
9
|
+
import json
|
|
10
|
+
import logging
|
|
11
|
+
import argparse
|
|
12
|
+
from pathlib import Path
|
|
13
|
+
from typing import Dict, List, Optional
|
|
14
|
+
from datetime import datetime
|
|
15
|
+
|
|
16
|
+
logging.basicConfig(
|
|
17
|
+
level=logging.INFO,
|
|
18
|
+
format='%(asctime)s - %(levelname)s - %(message)s'
|
|
19
|
+
)
|
|
20
|
+
logger = logging.getLogger(__name__)
|
|
21
|
+
|
|
22
|
+
class RagEvaluator:
|
|
23
|
+
"""Production-grade rag evaluator"""
|
|
24
|
+
|
|
25
|
+
def __init__(self, config: Dict):
|
|
26
|
+
self.config = config
|
|
27
|
+
self.results = {
|
|
28
|
+
'status': 'initialized',
|
|
29
|
+
'start_time': datetime.now().isoformat(),
|
|
30
|
+
'processed_items': 0
|
|
31
|
+
}
|
|
32
|
+
logger.info(f"Initialized {self.__class__.__name__}")
|
|
33
|
+
|
|
34
|
+
def validate_config(self) -> bool:
|
|
35
|
+
"""Validate configuration"""
|
|
36
|
+
logger.info("Validating configuration...")
|
|
37
|
+
# Add validation logic
|
|
38
|
+
logger.info("Configuration validated")
|
|
39
|
+
return True
|
|
40
|
+
|
|
41
|
+
def process(self) -> Dict:
|
|
42
|
+
"""Main processing logic"""
|
|
43
|
+
logger.info("Starting processing...")
|
|
44
|
+
|
|
45
|
+
try:
|
|
46
|
+
self.validate_config()
|
|
47
|
+
|
|
48
|
+
# Main processing
|
|
49
|
+
result = self._execute()
|
|
50
|
+
|
|
51
|
+
self.results['status'] = 'completed'
|
|
52
|
+
self.results['end_time'] = datetime.now().isoformat()
|
|
53
|
+
|
|
54
|
+
logger.info("Processing completed successfully")
|
|
55
|
+
return self.results
|
|
56
|
+
|
|
57
|
+
except Exception as e:
|
|
58
|
+
self.results['status'] = 'failed'
|
|
59
|
+
self.results['error'] = str(e)
|
|
60
|
+
logger.error(f"Processing failed: {e}")
|
|
61
|
+
raise
|
|
62
|
+
|
|
63
|
+
def _execute(self) -> Dict:
|
|
64
|
+
"""Execute main logic"""
|
|
65
|
+
# Implementation here
|
|
66
|
+
return {'success': True}
|
|
67
|
+
|
|
68
|
+
def main():
|
|
69
|
+
"""Main entry point"""
|
|
70
|
+
parser = argparse.ArgumentParser(
|
|
71
|
+
description="Rag Evaluator"
|
|
72
|
+
)
|
|
73
|
+
parser.add_argument('--input', '-i', required=True, help='Input path')
|
|
74
|
+
parser.add_argument('--output', '-o', required=True, help='Output path')
|
|
75
|
+
parser.add_argument('--config', '-c', help='Configuration file')
|
|
76
|
+
parser.add_argument('--verbose', '-v', action='store_true', help='Verbose output')
|
|
77
|
+
|
|
78
|
+
args = parser.parse_args()
|
|
79
|
+
|
|
80
|
+
if args.verbose:
|
|
81
|
+
logging.getLogger().setLevel(logging.DEBUG)
|
|
82
|
+
|
|
83
|
+
try:
|
|
84
|
+
config = {
|
|
85
|
+
'input': args.input,
|
|
86
|
+
'output': args.output
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
processor = RagEvaluator(config)
|
|
90
|
+
results = processor.process()
|
|
91
|
+
|
|
92
|
+
print(json.dumps(results, indent=2))
|
|
93
|
+
sys.exit(0)
|
|
94
|
+
|
|
95
|
+
except Exception as e:
|
|
96
|
+
logger.error(f"Fatal error: {e}")
|
|
97
|
+
sys.exit(1)
|
|
98
|
+
|
|
99
|
+
if __name__ == '__main__':
|
|
100
|
+
main()
|
|
@@ -0,0 +1,372 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: setup-knip
|
|
3
|
+
description: Install and configure Knip for dead code detection. Use before running dead-code-hunter or dependency-auditor to ensure Knip is available. Handles installation, configuration creation, and validation.
|
|
4
|
+
allowed-tools: Bash, Read, Write, Glob
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Setup Knip
|
|
8
|
+
|
|
9
|
+
Install and configure Knip - the tool for finding unused files, dependencies, and exports in JavaScript/TypeScript projects.
|
|
10
|
+
|
|
11
|
+
## When to Use
|
|
12
|
+
|
|
13
|
+
- Before running dead-code-hunter agent
|
|
14
|
+
- Before running dependency-auditor agent
|
|
15
|
+
- When project doesn't have Knip configured
|
|
16
|
+
- When upgrading Knip configuration
|
|
17
|
+
- In pre-flight validation of health workflows
|
|
18
|
+
|
|
19
|
+
## Instructions
|
|
20
|
+
|
|
21
|
+
### Step 1: Check if Knip is Installed
|
|
22
|
+
|
|
23
|
+
Check package.json for knip in devDependencies.
|
|
24
|
+
|
|
25
|
+
**Tools Used**: Read
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
# Read package.json and check for knip
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
**Check Logic**:
|
|
32
|
+
- If `devDependencies.knip` exists → Knip is installed
|
|
33
|
+
- If not found → Need to install
|
|
34
|
+
|
|
35
|
+
### Step 2: Install Knip if Missing
|
|
36
|
+
|
|
37
|
+
If Knip is not installed, add it as devDependency.
|
|
38
|
+
|
|
39
|
+
**Tools Used**: Bash
|
|
40
|
+
|
|
41
|
+
```bash
|
|
42
|
+
# Detect package manager
|
|
43
|
+
if [ -f "pnpm-lock.yaml" ]; then
|
|
44
|
+
pnpm add -D knip
|
|
45
|
+
elif [ -f "yarn.lock" ]; then
|
|
46
|
+
yarn add -D knip
|
|
47
|
+
elif [ -f "bun.lockb" ]; then
|
|
48
|
+
bun add -D knip
|
|
49
|
+
else
|
|
50
|
+
npm install -D knip
|
|
51
|
+
fi
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
**Expected Output**:
|
|
55
|
+
```
|
|
56
|
+
+ knip@5.x.x
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
### Step 3: Check for Knip Configuration
|
|
60
|
+
|
|
61
|
+
Look for existing Knip configuration files.
|
|
62
|
+
|
|
63
|
+
**Tools Used**: Glob
|
|
64
|
+
|
|
65
|
+
**Configuration Files** (in priority order):
|
|
66
|
+
1. `knip.json`
|
|
67
|
+
2. `knip.jsonc`
|
|
68
|
+
3. `knip.ts`
|
|
69
|
+
4. `knip.config.ts`
|
|
70
|
+
5. `knip.config.js`
|
|
71
|
+
6. `package.json` (knip field)
|
|
72
|
+
|
|
73
|
+
### Step 4: Create Default Configuration if Missing
|
|
74
|
+
|
|
75
|
+
If no configuration found, create `knip.json` with sensible defaults.
|
|
76
|
+
|
|
77
|
+
**Tools Used**: Write
|
|
78
|
+
|
|
79
|
+
**Default Configuration for Standard Project**:
|
|
80
|
+
```json
|
|
81
|
+
{
|
|
82
|
+
"$schema": "https://unpkg.com/knip@5/schema.json",
|
|
83
|
+
"entry": ["src/index.{ts,tsx,js,jsx}", "src/main.{ts,tsx,js,jsx}"],
|
|
84
|
+
"project": ["src/**/*.{ts,tsx,js,jsx}"],
|
|
85
|
+
"ignore": [
|
|
86
|
+
"**/*.d.ts",
|
|
87
|
+
"**/*.test.{ts,tsx}",
|
|
88
|
+
"**/*.spec.{ts,tsx}",
|
|
89
|
+
"**/test/**",
|
|
90
|
+
"**/tests/**",
|
|
91
|
+
"**/__tests__/**",
|
|
92
|
+
"**/node_modules/**"
|
|
93
|
+
],
|
|
94
|
+
"ignoreDependencies": [
|
|
95
|
+
"@types/*"
|
|
96
|
+
]
|
|
97
|
+
}
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
**Default Configuration for Next.js Project** (detected by next in dependencies):
|
|
101
|
+
```json
|
|
102
|
+
{
|
|
103
|
+
"$schema": "https://unpkg.com/knip@5/schema.json",
|
|
104
|
+
"entry": [
|
|
105
|
+
"src/app/**/*.{ts,tsx}",
|
|
106
|
+
"src/pages/**/*.{ts,tsx}",
|
|
107
|
+
"app/**/*.{ts,tsx}",
|
|
108
|
+
"pages/**/*.{ts,tsx}"
|
|
109
|
+
],
|
|
110
|
+
"project": ["src/**/*.{ts,tsx}", "app/**/*.{ts,tsx}", "pages/**/*.{ts,tsx}"],
|
|
111
|
+
"ignore": [
|
|
112
|
+
"**/*.d.ts",
|
|
113
|
+
"**/*.test.{ts,tsx}",
|
|
114
|
+
"**/*.spec.{ts,tsx}",
|
|
115
|
+
"**/node_modules/**"
|
|
116
|
+
],
|
|
117
|
+
"next": {
|
|
118
|
+
"entry": [
|
|
119
|
+
"next.config.{js,ts,mjs}",
|
|
120
|
+
"middleware.{js,ts}"
|
|
121
|
+
]
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
**Default Configuration for Monorepo** (detected by workspaces in package.json):
|
|
127
|
+
```json
|
|
128
|
+
{
|
|
129
|
+
"$schema": "https://unpkg.com/knip@5/schema.json",
|
|
130
|
+
"workspaces": {
|
|
131
|
+
"packages/*": {
|
|
132
|
+
"entry": ["src/index.{ts,tsx,js,jsx}"],
|
|
133
|
+
"project": ["src/**/*.{ts,tsx,js,jsx}"]
|
|
134
|
+
},
|
|
135
|
+
"apps/*": {
|
|
136
|
+
"entry": ["src/index.{ts,tsx,js,jsx}", "src/main.{ts,tsx,js,jsx}"],
|
|
137
|
+
"project": ["src/**/*.{ts,tsx,js,jsx}"]
|
|
138
|
+
}
|
|
139
|
+
},
|
|
140
|
+
"ignore": [
|
|
141
|
+
"**/*.d.ts",
|
|
142
|
+
"**/*.test.{ts,tsx}",
|
|
143
|
+
"**/*.spec.{ts,tsx}",
|
|
144
|
+
"**/node_modules/**"
|
|
145
|
+
]
|
|
146
|
+
}
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
### Step 5: Add npm Scripts if Missing
|
|
150
|
+
|
|
151
|
+
Check if package.json has knip scripts, add if missing.
|
|
152
|
+
|
|
153
|
+
**Tools Used**: Read, Bash
|
|
154
|
+
|
|
155
|
+
**Scripts to Add**:
|
|
156
|
+
```json
|
|
157
|
+
{
|
|
158
|
+
"scripts": {
|
|
159
|
+
"knip": "knip",
|
|
160
|
+
"knip:fix": "knip --fix",
|
|
161
|
+
"knip:deps": "knip --dependencies",
|
|
162
|
+
"knip:exports": "knip --exports",
|
|
163
|
+
"knip:files": "knip --files"
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
**Add via npm pkg**:
|
|
169
|
+
```bash
|
|
170
|
+
npm pkg set scripts.knip="knip"
|
|
171
|
+
npm pkg set scripts.knip:fix="knip --fix"
|
|
172
|
+
npm pkg set scripts.knip:deps="knip --dependencies"
|
|
173
|
+
npm pkg set scripts.knip:exports="knip --exports"
|
|
174
|
+
npm pkg set scripts.knip:files="knip --files"
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
### Step 6: Validate Installation
|
|
178
|
+
|
|
179
|
+
Run Knip to verify installation works.
|
|
180
|
+
|
|
181
|
+
**Tools Used**: Bash
|
|
182
|
+
|
|
183
|
+
```bash
|
|
184
|
+
npx knip --help
|
|
185
|
+
```
|
|
186
|
+
|
|
187
|
+
**Expected**: Help output displayed without errors
|
|
188
|
+
|
|
189
|
+
### Step 7: Return Result
|
|
190
|
+
|
|
191
|
+
Return structured result indicating setup status.
|
|
192
|
+
|
|
193
|
+
**Expected Output**:
|
|
194
|
+
```json
|
|
195
|
+
{
|
|
196
|
+
"installed": true,
|
|
197
|
+
"version": "5.x.x",
|
|
198
|
+
"config_file": "knip.json",
|
|
199
|
+
"config_created": true,
|
|
200
|
+
"scripts_added": ["knip", "knip:fix", "knip:deps", "knip:exports", "knip:files"],
|
|
201
|
+
"project_type": "nextjs|monorepo|standard",
|
|
202
|
+
"ready": true
|
|
203
|
+
}
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
## Error Handling
|
|
207
|
+
|
|
208
|
+
- **Installation fails**: Return error with package manager output
|
|
209
|
+
- **Configuration invalid**: Return error with validation details
|
|
210
|
+
- **Permission denied**: Return error suggesting sudo or permission fix
|
|
211
|
+
- **Network error**: Return error suggesting offline installation
|
|
212
|
+
|
|
213
|
+
## Examples
|
|
214
|
+
|
|
215
|
+
### Example 1: Fresh Project (No Knip)
|
|
216
|
+
|
|
217
|
+
**Initial State**:
|
|
218
|
+
- package.json exists
|
|
219
|
+
- No knip in devDependencies
|
|
220
|
+
- No knip.json
|
|
221
|
+
|
|
222
|
+
**Actions**:
|
|
223
|
+
1. Install knip via detected package manager
|
|
224
|
+
2. Detect project type (standard)
|
|
225
|
+
3. Create knip.json with defaults
|
|
226
|
+
4. Add npm scripts
|
|
227
|
+
5. Validate installation
|
|
228
|
+
|
|
229
|
+
**Output**:
|
|
230
|
+
```json
|
|
231
|
+
{
|
|
232
|
+
"installed": true,
|
|
233
|
+
"version": "5.73.3",
|
|
234
|
+
"config_file": "knip.json",
|
|
235
|
+
"config_created": true,
|
|
236
|
+
"scripts_added": ["knip", "knip:fix", "knip:deps", "knip:exports", "knip:files"],
|
|
237
|
+
"project_type": "standard",
|
|
238
|
+
"ready": true
|
|
239
|
+
}
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
### Example 2: Next.js Project with Existing Knip
|
|
243
|
+
|
|
244
|
+
**Initial State**:
|
|
245
|
+
- package.json with next dependency
|
|
246
|
+
- knip already in devDependencies
|
|
247
|
+
- knip.json exists
|
|
248
|
+
|
|
249
|
+
**Actions**:
|
|
250
|
+
1. Detect knip installed (skip installation)
|
|
251
|
+
2. Detect existing config (skip creation)
|
|
252
|
+
3. Check scripts (add missing)
|
|
253
|
+
4. Validate installation
|
|
254
|
+
|
|
255
|
+
**Output**:
|
|
256
|
+
```json
|
|
257
|
+
{
|
|
258
|
+
"installed": true,
|
|
259
|
+
"version": "5.73.3",
|
|
260
|
+
"config_file": "knip.json",
|
|
261
|
+
"config_created": false,
|
|
262
|
+
"scripts_added": ["knip:deps"],
|
|
263
|
+
"project_type": "nextjs",
|
|
264
|
+
"ready": true
|
|
265
|
+
}
|
|
266
|
+
```
|
|
267
|
+
|
|
268
|
+
### Example 3: Monorepo Project
|
|
269
|
+
|
|
270
|
+
**Initial State**:
|
|
271
|
+
- package.json with workspaces field
|
|
272
|
+
- No knip
|
|
273
|
+
|
|
274
|
+
**Actions**:
|
|
275
|
+
1. Detect monorepo (workspaces in package.json)
|
|
276
|
+
2. Install knip
|
|
277
|
+
3. Create monorepo-specific knip.json
|
|
278
|
+
4. Add npm scripts
|
|
279
|
+
5. Validate installation
|
|
280
|
+
|
|
281
|
+
**Output**:
|
|
282
|
+
```json
|
|
283
|
+
{
|
|
284
|
+
"installed": true,
|
|
285
|
+
"version": "5.73.3",
|
|
286
|
+
"config_file": "knip.json",
|
|
287
|
+
"config_created": true,
|
|
288
|
+
"scripts_added": ["knip", "knip:fix", "knip:deps", "knip:exports", "knip:files"],
|
|
289
|
+
"project_type": "monorepo",
|
|
290
|
+
"ready": true
|
|
291
|
+
}
|
|
292
|
+
```
|
|
293
|
+
|
|
294
|
+
## Knip Command Reference
|
|
295
|
+
|
|
296
|
+
For agents using Knip after setup:
|
|
297
|
+
|
|
298
|
+
| Command | Purpose | Use Case |
|
|
299
|
+
|---------|---------|----------|
|
|
300
|
+
| `npx knip` | Full analysis | Complete dead code scan |
|
|
301
|
+
| `npx knip --dependencies` | Dependencies only | dependency-auditor |
|
|
302
|
+
| `npx knip --exports` | Exports only | Unused export detection |
|
|
303
|
+
| `npx knip --files` | Files only | Unused file detection |
|
|
304
|
+
| `npx knip --fix --fix-type exports,types` | Auto-fix exports/types | Safe automated cleanup |
|
|
305
|
+
| `npx knip --fix --fix-type dependencies` | Auto-fix deps | Remove from package.json |
|
|
306
|
+
| `npx knip --reporter json` | JSON output | Machine parsing |
|
|
307
|
+
| `npx knip --reporter compact` | Compact output | Quick review |
|
|
308
|
+
|
|
309
|
+
## CRITICAL SAFETY WARNING
|
|
310
|
+
|
|
311
|
+
### NEVER Use `--allow-remove-files`
|
|
312
|
+
|
|
313
|
+
**`npx knip --fix --allow-remove-files` is FORBIDDEN!**
|
|
314
|
+
|
|
315
|
+
Knip has a critical limitation: **it cannot detect dynamic imports**.
|
|
316
|
+
|
|
317
|
+
```typescript
|
|
318
|
+
// Knip CANNOT see these relationships:
|
|
319
|
+
const module = await import(`./plugins/${name}.ts`);
|
|
320
|
+
const Component = lazy(() => import('./components/Dashboard'));
|
|
321
|
+
require(`./locales/${lang}.json`);
|
|
322
|
+
```
|
|
323
|
+
|
|
324
|
+
Files loaded via dynamic imports will appear "unused" to Knip but are actually critical!
|
|
325
|
+
|
|
326
|
+
### Safe Knip Usage
|
|
327
|
+
|
|
328
|
+
**ALLOWED**:
|
|
329
|
+
- `npx knip --fix --fix-type exports` - Safe: removes unused exports from files
|
|
330
|
+
- `npx knip --fix --fix-type types` - Safe: removes unused type exports
|
|
331
|
+
- `npx knip --fix --fix-type dependencies` - Safe: removes from package.json only
|
|
332
|
+
|
|
333
|
+
**FORBIDDEN**:
|
|
334
|
+
- `npx knip --fix --allow-remove-files` - DANGEROUS: may delete files with dynamic imports
|
|
335
|
+
- `npx knip --fix` (without --fix-type) - May include file removal
|
|
336
|
+
|
|
337
|
+
### Manual Verification Required
|
|
338
|
+
|
|
339
|
+
Before removing ANY file flagged by Knip:
|
|
340
|
+
1. Search for dynamic imports: `import(`, `require(`, `lazy(`, `loadable(`
|
|
341
|
+
2. Check for string interpolation in imports
|
|
342
|
+
3. Verify no config files reference the file
|
|
343
|
+
4. Run build and tests after removal
|
|
344
|
+
|
|
345
|
+
## Integration with Agents
|
|
346
|
+
|
|
347
|
+
### dead-code-hunter Pre-Check
|
|
348
|
+
|
|
349
|
+
```markdown
|
|
350
|
+
## Phase 0: Pre-Flight
|
|
351
|
+
|
|
352
|
+
1. Use setup-knip Skill to ensure Knip is available
|
|
353
|
+
2. If result.ready === false, halt with setup instructions
|
|
354
|
+
3. If result.ready === true, proceed with detection
|
|
355
|
+
```
|
|
356
|
+
|
|
357
|
+
### dependency-auditor Pre-Check
|
|
358
|
+
|
|
359
|
+
```markdown
|
|
360
|
+
## Phase 1: Environment Analysis
|
|
361
|
+
|
|
362
|
+
1. Use setup-knip Skill before dependency analysis
|
|
363
|
+
2. Knip will detect unused dependencies more accurately than manual grep
|
|
364
|
+
```
|
|
365
|
+
|
|
366
|
+
## Notes
|
|
367
|
+
|
|
368
|
+
- Knip version 5.x is required (major improvements over v4)
|
|
369
|
+
- Configuration is auto-detected for 100+ frameworks
|
|
370
|
+
- Monorepo support is first-class
|
|
371
|
+
- Use `--reporter json` for machine-readable output
|
|
372
|
+
- The `--fix` flag can auto-remove unused exports and dependencies
|