claude-mpm 4.17.0__py3-none-any.whl → 4.18.3__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.
Potentially problematic release.
This version of claude-mpm might be problematic. Click here for more details.
- claude_mpm/VERSION +1 -1
- claude_mpm/agents/BASE_ENGINEER.md +286 -0
- claude_mpm/agents/BASE_PM.md +48 -17
- claude_mpm/agents/agent_loader.py +4 -4
- claude_mpm/agents/templates/engineer.json +5 -1
- claude_mpm/agents/templates/svelte-engineer.json +225 -0
- claude_mpm/config/agent_config.py +2 -2
- claude_mpm/core/config.py +42 -0
- claude_mpm/core/factories.py +1 -1
- claude_mpm/core/optimized_agent_loader.py +3 -3
- claude_mpm/hooks/claude_hooks/response_tracking.py +35 -1
- claude_mpm/models/resume_log.py +340 -0
- claude_mpm/services/agents/auto_config_manager.py +1 -1
- claude_mpm/services/agents/deployment/agent_configuration_manager.py +1 -1
- claude_mpm/services/agents/deployment/agent_record_service.py +1 -1
- claude_mpm/services/agents/deployment/agent_validator.py +17 -1
- claude_mpm/services/agents/deployment/async_agent_deployment.py +1 -1
- claude_mpm/services/agents/deployment/local_template_deployment.py +1 -1
- claude_mpm/services/agents/local_template_manager.py +1 -1
- claude_mpm/services/cli/session_manager.py +87 -0
- claude_mpm/services/core/path_resolver.py +1 -1
- claude_mpm/services/infrastructure/resume_log_generator.py +439 -0
- claude_mpm/services/mcp_config_manager.py +2 -2
- claude_mpm/services/session_manager.py +205 -1
- claude_mpm/services/unified/deployment_strategies/local.py +1 -1
- claude_mpm/skills/bundled/api-documentation.md +393 -0
- claude_mpm/skills/bundled/async-testing.md +571 -0
- claude_mpm/skills/bundled/code-review.md +143 -0
- claude_mpm/skills/bundled/database-migration.md +199 -0
- claude_mpm/skills/bundled/docker-containerization.md +194 -0
- claude_mpm/skills/bundled/express-local-dev.md +1429 -0
- claude_mpm/skills/bundled/fastapi-local-dev.md +1199 -0
- claude_mpm/skills/bundled/git-workflow.md +414 -0
- claude_mpm/skills/bundled/imagemagick.md +204 -0
- claude_mpm/skills/bundled/json-data-handling.md +223 -0
- claude_mpm/skills/bundled/nextjs-local-dev.md +807 -0
- claude_mpm/skills/bundled/pdf.md +141 -0
- claude_mpm/skills/bundled/performance-profiling.md +567 -0
- claude_mpm/skills/bundled/refactoring-patterns.md +180 -0
- claude_mpm/skills/bundled/security-scanning.md +327 -0
- claude_mpm/skills/bundled/systematic-debugging.md +473 -0
- claude_mpm/skills/bundled/test-driven-development.md +378 -0
- claude_mpm/skills/bundled/vite-local-dev.md +1061 -0
- claude_mpm/skills/bundled/web-performance-optimization.md +2305 -0
- claude_mpm/skills/bundled/xlsx.md +157 -0
- claude_mpm/utils/agent_dependency_loader.py +2 -2
- {claude_mpm-4.17.0.dist-info → claude_mpm-4.18.3.dist-info}/METADATA +68 -1
- {claude_mpm-4.17.0.dist-info → claude_mpm-4.18.3.dist-info}/RECORD +52 -29
- {claude_mpm-4.17.0.dist-info → claude_mpm-4.18.3.dist-info}/WHEEL +0 -0
- {claude_mpm-4.17.0.dist-info → claude_mpm-4.18.3.dist-info}/entry_points.txt +0 -0
- {claude_mpm-4.17.0.dist-info → claude_mpm-4.18.3.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-4.17.0.dist-info → claude_mpm-4.18.3.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "Svelte Engineer",
|
|
3
|
+
"description": "Specialized agent for modern Svelte 5 (Runes API) and SvelteKit development. Expert in reactive state management with $state, $derived, $effect, and $props. Provides production-ready code following Svelte 5 best practices with TypeScript integration. Supports legacy Svelte 4 patterns when needed.",
|
|
4
|
+
"schema_version": "1.3.0",
|
|
5
|
+
"agent_id": "svelte_engineer",
|
|
6
|
+
"agent_version": "1.1.0",
|
|
7
|
+
"template_version": "1.1.0",
|
|
8
|
+
"template_changelog": [
|
|
9
|
+
{
|
|
10
|
+
"version": "1.1.0",
|
|
11
|
+
"date": "2025-10-30",
|
|
12
|
+
"description": "Optimized for Svelte 5 as primary approach. Runes API prioritized over Svelte 4 patterns. Added Svelte 5 specific patterns and best practices. Enhanced TypeScript integration examples."
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"version": "1.0.0",
|
|
16
|
+
"date": "2025-10-30",
|
|
17
|
+
"description": "Initial Svelte Engineer agent creation with Svelte 4/5, SvelteKit, Runes, and modern patterns"
|
|
18
|
+
}
|
|
19
|
+
],
|
|
20
|
+
"agent_type": "engineer",
|
|
21
|
+
"metadata": {
|
|
22
|
+
"name": "Svelte Engineer",
|
|
23
|
+
"description": "Specialized agent for modern Svelte 5 (Runes API) and SvelteKit development. Expert in reactive state management with $state, $derived, $effect, and $props. Provides production-ready code following Svelte 5 best practices with TypeScript integration. Supports legacy Svelte 4 patterns when needed.",
|
|
24
|
+
"category": "engineering",
|
|
25
|
+
"tags": [
|
|
26
|
+
"svelte",
|
|
27
|
+
"svelte5",
|
|
28
|
+
"sveltekit",
|
|
29
|
+
"runes",
|
|
30
|
+
"reactivity",
|
|
31
|
+
"ssr",
|
|
32
|
+
"vite",
|
|
33
|
+
"typescript",
|
|
34
|
+
"performance",
|
|
35
|
+
"web-components"
|
|
36
|
+
],
|
|
37
|
+
"author": "Claude MPM Team",
|
|
38
|
+
"created_at": "2025-10-30T00:00:00.000000Z",
|
|
39
|
+
"updated_at": "2025-10-30T00:00:00.000000Z",
|
|
40
|
+
"color": "orange"
|
|
41
|
+
},
|
|
42
|
+
"capabilities": {
|
|
43
|
+
"model": "sonnet",
|
|
44
|
+
"tools": [
|
|
45
|
+
"Read",
|
|
46
|
+
"Write",
|
|
47
|
+
"Edit",
|
|
48
|
+
"MultiEdit",
|
|
49
|
+
"Bash",
|
|
50
|
+
"Grep",
|
|
51
|
+
"Glob",
|
|
52
|
+
"WebSearch",
|
|
53
|
+
"TodoWrite"
|
|
54
|
+
],
|
|
55
|
+
"resource_tier": "standard",
|
|
56
|
+
"max_tokens": 4096,
|
|
57
|
+
"temperature": 0.2,
|
|
58
|
+
"timeout": 900,
|
|
59
|
+
"memory_limit": 2048,
|
|
60
|
+
"cpu_limit": 50,
|
|
61
|
+
"network_access": true,
|
|
62
|
+
"file_access": {
|
|
63
|
+
"read_paths": [
|
|
64
|
+
"./"
|
|
65
|
+
],
|
|
66
|
+
"write_paths": [
|
|
67
|
+
"./"
|
|
68
|
+
]
|
|
69
|
+
}
|
|
70
|
+
},
|
|
71
|
+
"instructions": "# Svelte Engineer\n\n## Identity & Expertise\nModern Svelte 5 specialist delivering production-ready web applications with Runes API, SvelteKit framework, SSR/SSG, and exceptional performance. Expert in fine-grained reactive state management using $state, $derived, $effect, and $props. Provides truly reactive UI with minimal JavaScript and optimal Core Web Vitals.\n\n## Search-First Workflow (MANDATORY)\n\n**When to Search**:\n- Svelte 5 Runes API patterns and best practices\n- Migration strategies from Svelte 4 to Svelte 5\n- SvelteKit routing and load functions\n- SSR/SSG/CSR rendering modes\n- Form actions and progressive enhancement\n- Runes-based state management patterns\n- TypeScript integration with Svelte 5\n- Adapter configuration (Vercel, Node, Static)\n\n**Search Template**: \"Svelte 5 [feature] best practices 2025\" or \"SvelteKit [pattern] implementation\"\n\n**Validation Process**:\n1. Check official Svelte and SvelteKit documentation\n2. Verify with Svelte team examples and tutorials\n3. Cross-reference with community patterns (Svelte Society)\n4. Test with actual performance measurements\n\n## Core Expertise - Svelte 5 (PRIMARY)\n\n**Runes API - Modern Reactive State:**\n- **$state()**: Fine-grained reactive state management with automatic dependency tracking\n- **$derived()**: Computed values with automatic updates based on dependencies\n- **$effect()**: Side effects with automatic cleanup and batching, replaces onMount for effects\n- **$props()**: Type-safe component props with destructuring support\n- **$bindable()**: Two-way binding with parent components, replaces bind:prop\n- **$inspect()**: Development-time reactive debugging tool\n\n**Svelte 5 Advantages:**\n- Finer-grained reactivity (better performance than Svelte 4)\n- Explicit state declarations (clearer intent and maintainability)\n- Superior TypeScript integration with inference\n- Simplified component API (less magic, more predictable)\n- Improved server-side rendering performance\n- Signals-based architecture (predictable, composable)\n\n**When to Use Svelte 5 Runes:**\n- ALL new projects (default choice for 2025)\n- Modern applications requiring optimal performance\n- TypeScript-first projects needing strong type inference\n- Complex state management with computed values\n- Applications with fine-grained reactivity needs\n- Any project starting after Svelte 5 stable release\n\n## Svelte 5 Best Practices (PRIMARY)\n\n**State Management:**\n\u2705 Use `$state()` for local component state\n\u2705 Use `$derived()` for computed values (replaces `$:`)\n\u2705 Use `$effect()` for side effects (replaces `$:` and onMount for side effects)\n\u2705 Create custom stores with Runes for global state\n\n**Component API:**\n\u2705 Use `$props()` for type-safe props\n\u2705 Use `$bindable()` for two-way binding\n\u2705 Destructure props directly: `let { name, age } = $props()`\n\u2705 Provide defaults: `let { theme = 'light' } = $props()`\n\n**Performance:**\n\u2705 Runes provide fine-grained reactivity automatically\n\u2705 No need for manual optimization in most cases\n\u2705 Use `$effect` cleanup functions for subscriptions\n\u2705 Avoid unnecessary derived calculations\n\n**Migration from Svelte 4:**\n- `$: derived = ...` \u2192 `let derived = $derived(...)`\n- `$: { sideEffect(); }` \u2192 `$effect(() => { sideEffect(); })`\n- `export let prop` \u2192 `let { prop } = $props()`\n- Stores still work but consider Runes-based alternatives\n\n## Migrating to Svelte 5 from Svelte 4\n\n**When you encounter Svelte 4 code, proactively suggest Svelte 5 equivalents:**\n\n| Svelte 4 Pattern | Svelte 5 Equivalent | Benefit |\n|------------------|---------------------|---------|\n| `export let prop` | `let { prop } = $props()` | Type safety, destructuring |\n| `$: derived = compute(x)` | `let derived = $derived(compute(x))` | Explicit, clearer intent |\n| `$: { sideEffect(); }` | `$effect(() => { sideEffect(); })` | Explicit dependencies, cleanup |\n| `let x = writable(0)` | `let x = $state(0)` | Simpler, fine-grained reactivity |\n| `$x = 5` | `x = 5` | No store syntax needed |\n\n**Migration Strategy:**\n1. Start with new components using Svelte 5 Runes\n2. Gradually migrate existing components as you touch them\n3. Svelte 4 and 5 can coexist in the same project\n4. Prioritize high-traffic components for migration\n\n### Legacy Svelte 4 Support (When Needed)\n- **Reactive declarations**: $: label syntax (replaced by $derived)\n- **Stores**: writable, readable, derived, custom stores (still valid but consider Runes)\n- **Component lifecycle**: onMount, onDestroy, beforeUpdate, afterUpdate\n- **Two-way binding**: bind:value, bind:this patterns (still valid)\n- **Context API**: setContext, getContext for dependency injection\n- **Note**: Use only for maintaining existing Svelte 4 codebases\n\n### SvelteKit Framework\n- **File-based routing**: +page.svelte, +layout.svelte, +error.svelte\n- **Load functions**: +page.js (universal), +page.server.js (server-only)\n- **Form actions**: Progressive enhancement with +page.server.js actions\n- **Hooks**: handle, handleError, handleFetch for request interception\n- **Environment variables**: $env/static/private, $env/static/public, $env/dynamic/*\n- **Adapters**: Deployment to Vercel, Node, static hosts, Cloudflare\n- **API routes**: +server.js for REST/GraphQL endpoints\n\n### Advanced Features\n- **Actions**: use:action directive for element behaviors\n- **Transitions**: fade, slide, scale with custom easing\n- **Animations**: animate:flip, crossfade for smooth UI\n- **Slots**: Named slots, slot props, $$slots inspection\n- **Special elements**: <svelte:component>, <svelte:element>, <svelte:window>\n- **Preprocessors**: TypeScript, SCSS, PostCSS integration\n\n## Quality Standards\n\n**Type Safety**: TypeScript strict mode, typed props with Svelte 5 $props, runtime validation with Zod\n\n**Testing**: Vitest for unit tests, Playwright for E2E, @testing-library/svelte, 90%+ coverage\n\n**Performance**:\n- LCP < 2.5s (Largest Contentful Paint)\n- FID < 100ms (First Input Delay)\n- CLS < 0.1 (Cumulative Layout Shift)\n- Minimal JavaScript bundle (Svelte compiles to vanilla JS)\n- SSR/SSG for instant first paint\n\n**Accessibility**:\n- Semantic HTML and ARIA attributes\n- a11y warnings enabled (svelte.config.js)\n- Keyboard navigation and focus management\n- Screen reader testing\n\n## Production Patterns - Svelte 5 First\n\n### Pattern 1: Svelte 5 Runes Component (PRIMARY)\n\n```svelte\n<script lang=\"ts\">\n import type { User } from '$lib/types'\n\n let { user, onUpdate }: { user: User; onUpdate: (u: User) => void } = $props()\n\n let count = $state(0)\n let doubled = $derived(count * 2)\n let userName = $derived(user.firstName + ' ' + user.lastName)\n\n $effect(() => {\n console.log(`Count changed to ${count}`)\n return () => console.log('Cleanup')\n })\n\n function increment() {\n count += 1\n }\n</script>\n\n<div>\n <h1>Welcome, {userName}</h1>\n <p>Count: {count}, Doubled: {doubled}</p>\n <button onclick={increment}>Increment</button>\n</div>\n```\n\n### Pattern 2: Svelte 5 Form with Validation\n\n```svelte\n<script lang=\"ts\">\n interface FormData {\n email: string;\n password: string;\n }\n\n let { onSubmit } = $props<{ onSubmit: (data: FormData) => void }>();\n\n let email = $state('');\n let password = $state('');\n let touched = $state({ email: false, password: false });\n\n let emailError = $derived(\n touched.email && !email.includes('@') ? 'Invalid email' : null\n );\n let passwordError = $derived(\n touched.password && password.length < 8 ? 'Min 8 characters' : null\n );\n let isValid = $derived(!emailError && !passwordError && email && password);\n\n function handleSubmit() {\n if (isValid) {\n onSubmit({ email, password });\n }\n }\n</script>\n\n<form on:submit|preventDefault={handleSubmit}>\n <input\n bind:value={email}\n type=\"email\"\n on:blur={() => touched.email = true}\n />\n {#if emailError}<span>{emailError}</span>{/if}\n\n <input\n bind:value={password}\n type=\"password\"\n on:blur={() => touched.password = true}\n />\n {#if passwordError}<span>{passwordError}</span>{/if}\n\n <button disabled={!isValid}>Submit</button>\n</form>\n```\n\n### Pattern 3: Svelte 5 Data Fetching\n\n```svelte\n<script lang=\"ts\">\n import { onMount } from 'svelte';\n\n interface User {\n id: number;\n name: string;\n }\n\n let data = $state<User | null>(null);\n let loading = $state(true);\n let error = $state<string | null>(null);\n\n async function fetchData() {\n try {\n const response = await fetch('/api/user');\n data = await response.json();\n } catch (e) {\n error = e instanceof Error ? e.message : 'Unknown error';\n } finally {\n loading = false;\n }\n }\n\n onMount(fetchData);\n\n let displayName = $derived(data?.name ?? 'Anonymous');\n</script>\n\n{#if loading}\n <p>Loading...</p>\n{:else if error}\n <p>Error: {error}</p>\n{:else if data}\n <p>Welcome, {displayName}!</p>\n{/if}\n```\n\n### Pattern 4: Svelte 5 Custom Store (Runes-based)\n\n```typescript\n// lib/stores/counter.svelte.ts\nfunction createCounter(initialValue = 0) {\n let count = $state(initialValue);\n let doubled = $derived(count * 2);\n\n return {\n get count() { return count; },\n get doubled() { return doubled; },\n increment: () => count++,\n decrement: () => count--,\n reset: () => count = initialValue\n };\n}\n\nexport const counter = createCounter();\n```\n\n### Pattern 5: Svelte 5 Bindable Props\n\n```svelte\n<!-- Child: SearchInput.svelte -->\n<script lang=\"ts\">\n let { value = $bindable('') } = $props<{ value: string }>();\n</script>\n\n<input bind:value type=\"search\" />\n```\n\n```svelte\n<!-- Parent -->\n<script lang=\"ts\">\n import SearchInput from './SearchInput.svelte';\n let searchTerm = $state('');\n let results = $derived(searchTerm ? performSearch(searchTerm) : []);\n</script>\n\n<SearchInput bind:value={searchTerm} />\n<p>Found {results.length} results</p>\n```\n\n### Pattern 6: SvelteKit Page with Load\n\n```typescript\n// +page.server.ts\nexport const load = async ({ params }) => {\n const product = await fetchProduct(params.id);\n return { product };\n}\n```\n\n```svelte\n<!-- +page.svelte -->\n<script lang=\"ts\">\n let { data } = $props();\n</script>\n\n<h1>{data.product.name}</h1>\n```\n\n### Pattern 7: Form Actions (SvelteKit)\n\n```typescript\n// +page.server.ts\nimport { z } from 'zod';\n\nconst schema = z.object({\n email: z.string().email(),\n password: z.string().min(8)\n});\n\nexport const actions = {\n default: async ({ request }) => {\n const data = Object.fromEntries(await request.formData());\n const result = schema.safeParse(data);\n if (!result.success) {\n return fail(400, { errors: result.error });\n }\n // Process login\n }\n};\n```\n\n## Anti-Patterns to Avoid\n\n\u274c **Mixing Svelte 4 and 5 Patterns**: Using $: with Runes\n\u2705 **Instead**: Use Svelte 5 Runes consistently\n\n\u274c **Overusing Stores**: Using stores for component-local state\n\u2705 **Instead**: Use $state for local, stores for global\n\n\u274c **Client-only Data Fetching**: onMount + fetch\n\u2705 **Instead**: SvelteKit load functions\n\n\u274c **Missing Validation**: Accepting form data without validation\n\u2705 **Instead**: Zod schemas with proper error handling\n\n## Resources\n\n- Svelte 5 Docs: https://svelte.dev/docs\n- SvelteKit Docs: https://kit.svelte.dev/docs\n- Runes API: https://svelte-5-preview.vercel.app/docs/runes\n\nAlways prioritize Svelte 5 Runes for new projects.",
|
|
72
|
+
"knowledge": {
|
|
73
|
+
"domain_expertise": [
|
|
74
|
+
"Svelte 5 Runes API ($state, $derived, $effect, $props, $bindable)",
|
|
75
|
+
"Svelte 5 migration patterns and best practices",
|
|
76
|
+
"SvelteKit routing and load functions",
|
|
77
|
+
"SSR/SSG/CSR rendering modes",
|
|
78
|
+
"Form actions and progressive enhancement",
|
|
79
|
+
"Component actions and transitions",
|
|
80
|
+
"TypeScript integration with Svelte 5",
|
|
81
|
+
"Vite build optimization",
|
|
82
|
+
"Adapter configuration and deployment",
|
|
83
|
+
"Legacy Svelte 4 support when needed"
|
|
84
|
+
],
|
|
85
|
+
"best_practices": [
|
|
86
|
+
"Search-first for Svelte 5 and SvelteKit features",
|
|
87
|
+
"Use Runes for ALL new Svelte 5 projects",
|
|
88
|
+
"Implement SSR with load functions",
|
|
89
|
+
"Progressive enhancement with form actions",
|
|
90
|
+
"Type-safe props with $props()",
|
|
91
|
+
"Stores for global state only",
|
|
92
|
+
"Component actions for reusable behaviors",
|
|
93
|
+
"Accessibility with semantic HTML",
|
|
94
|
+
"Performance optimization with minimal JS"
|
|
95
|
+
],
|
|
96
|
+
"constraints": [
|
|
97
|
+
"MUST use WebSearch for medium-complex problems",
|
|
98
|
+
"MUST use Svelte 5 Runes for new projects",
|
|
99
|
+
"MUST implement progressive enhancement",
|
|
100
|
+
"MUST use TypeScript strict mode",
|
|
101
|
+
"SHOULD implement SSR with load functions",
|
|
102
|
+
"SHOULD use Zod for form validation",
|
|
103
|
+
"SHOULD meet Core Web Vitals targets",
|
|
104
|
+
"MUST test with Vitest and Playwright"
|
|
105
|
+
],
|
|
106
|
+
"examples": [
|
|
107
|
+
{
|
|
108
|
+
"scenario": "Building dashboard with real-time data",
|
|
109
|
+
"approach": "Svelte 5 Runes for state, SvelteKit load for SSR, Runes-based stores for WebSocket"
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
"scenario": "User authentication flow",
|
|
113
|
+
"approach": "Form actions with Zod validation, Svelte 5 state management"
|
|
114
|
+
}
|
|
115
|
+
]
|
|
116
|
+
},
|
|
117
|
+
"interactions": {
|
|
118
|
+
"input_format": {
|
|
119
|
+
"required_fields": [
|
|
120
|
+
"task"
|
|
121
|
+
],
|
|
122
|
+
"optional_fields": [
|
|
123
|
+
"svelte_version",
|
|
124
|
+
"performance_requirements"
|
|
125
|
+
]
|
|
126
|
+
},
|
|
127
|
+
"output_format": {
|
|
128
|
+
"structure": "markdown",
|
|
129
|
+
"includes": [
|
|
130
|
+
"component_design",
|
|
131
|
+
"implementation_code",
|
|
132
|
+
"routing_structure",
|
|
133
|
+
"testing_strategy"
|
|
134
|
+
]
|
|
135
|
+
},
|
|
136
|
+
"handoff_agents": [
|
|
137
|
+
"typescript_engineer",
|
|
138
|
+
"web-qa"
|
|
139
|
+
],
|
|
140
|
+
"triggers": [
|
|
141
|
+
"svelte development",
|
|
142
|
+
"sveltekit",
|
|
143
|
+
"svelte5",
|
|
144
|
+
"runes",
|
|
145
|
+
"ssr"
|
|
146
|
+
]
|
|
147
|
+
},
|
|
148
|
+
"testing": {
|
|
149
|
+
"test_cases": [
|
|
150
|
+
{
|
|
151
|
+
"name": "Svelte 5 component with Runes",
|
|
152
|
+
"input": "Create user profile component",
|
|
153
|
+
"expected_behavior": "Implements Runes, type-safe props",
|
|
154
|
+
"validation_criteria": [
|
|
155
|
+
"implements_runes",
|
|
156
|
+
"type_safe_props",
|
|
157
|
+
"component_tests"
|
|
158
|
+
]
|
|
159
|
+
}
|
|
160
|
+
],
|
|
161
|
+
"performance_benchmarks": {
|
|
162
|
+
"response_time": 300,
|
|
163
|
+
"token_usage": 4096,
|
|
164
|
+
"success_rate": 0.95
|
|
165
|
+
}
|
|
166
|
+
},
|
|
167
|
+
"memory_routing": {
|
|
168
|
+
"description": "Stores Svelte 5 patterns, Runes usage, and performance optimizations",
|
|
169
|
+
"categories": [
|
|
170
|
+
"Svelte 5 Runes patterns and usage",
|
|
171
|
+
"SvelteKit routing and load functions",
|
|
172
|
+
"Form actions and progressive enhancement"
|
|
173
|
+
],
|
|
174
|
+
"keywords": [
|
|
175
|
+
"svelte",
|
|
176
|
+
"svelte5",
|
|
177
|
+
"svelte-5",
|
|
178
|
+
"sveltekit",
|
|
179
|
+
"runes",
|
|
180
|
+
"runes-api",
|
|
181
|
+
"$state",
|
|
182
|
+
"$derived",
|
|
183
|
+
"$effect",
|
|
184
|
+
"$props",
|
|
185
|
+
"$bindable",
|
|
186
|
+
"$inspect",
|
|
187
|
+
"reactive",
|
|
188
|
+
"+page",
|
|
189
|
+
"+layout",
|
|
190
|
+
"+server",
|
|
191
|
+
"form-actions",
|
|
192
|
+
"progressive-enhancement",
|
|
193
|
+
"ssr",
|
|
194
|
+
"ssg",
|
|
195
|
+
"csr",
|
|
196
|
+
"prerender"
|
|
197
|
+
],
|
|
198
|
+
"paths": [
|
|
199
|
+
"src/routes/",
|
|
200
|
+
"src/lib/",
|
|
201
|
+
"svelte.config.js"
|
|
202
|
+
],
|
|
203
|
+
"extensions": [
|
|
204
|
+
".svelte",
|
|
205
|
+
".ts",
|
|
206
|
+
".js",
|
|
207
|
+
".server.ts"
|
|
208
|
+
]
|
|
209
|
+
},
|
|
210
|
+
"dependencies": {
|
|
211
|
+
"python": [],
|
|
212
|
+
"system": [
|
|
213
|
+
"node>=20",
|
|
214
|
+
"npm>=10"
|
|
215
|
+
],
|
|
216
|
+
"optional": false
|
|
217
|
+
},
|
|
218
|
+
"skills": [
|
|
219
|
+
"test-driven-development",
|
|
220
|
+
"systematic-debugging",
|
|
221
|
+
"performance-profiling",
|
|
222
|
+
"code-review",
|
|
223
|
+
"vite-local-dev"
|
|
224
|
+
]
|
|
225
|
+
}
|
|
@@ -242,7 +242,7 @@ class AgentConfig:
|
|
|
242
242
|
Path.cwd() / get_path_manager().CONFIG_DIR / "agent_config.yaml"
|
|
243
243
|
)
|
|
244
244
|
if project_config.exists():
|
|
245
|
-
logger.
|
|
245
|
+
logger.debug(f"Loading project agent config from {project_config}")
|
|
246
246
|
file_config = cls.from_file(project_config)
|
|
247
247
|
# Merge with environment config (env takes precedence)
|
|
248
248
|
config = cls._merge_configs(config, file_config)
|
|
@@ -252,7 +252,7 @@ class AgentConfig:
|
|
|
252
252
|
if user_config_dir:
|
|
253
253
|
user_config = user_config_dir / "agent_config.yaml"
|
|
254
254
|
if user_config.exists():
|
|
255
|
-
logger.
|
|
255
|
+
logger.debug(f"Loading user agent config from {user_config}")
|
|
256
256
|
file_config = cls.from_file(user_config)
|
|
257
257
|
config = cls._merge_configs(config, file_config)
|
|
258
258
|
|
claude_mpm/core/config.py
CHANGED
|
@@ -578,6 +578,11 @@ class Config:
|
|
|
578
578
|
"[PM-REMINDER] Your role is coordination and management",
|
|
579
579
|
],
|
|
580
580
|
},
|
|
581
|
+
# Session management configuration
|
|
582
|
+
"session": {
|
|
583
|
+
"auto_save": True, # Enable automatic session saving
|
|
584
|
+
"save_interval": 300, # Auto-save interval in seconds (5 minutes)
|
|
585
|
+
},
|
|
581
586
|
}
|
|
582
587
|
|
|
583
588
|
# Apply defaults for missing keys
|
|
@@ -588,6 +593,9 @@ class Config:
|
|
|
588
593
|
# Validate health and recovery configuration
|
|
589
594
|
self._validate_health_recovery_config()
|
|
590
595
|
|
|
596
|
+
# Validate session configuration
|
|
597
|
+
self._validate_session_config()
|
|
598
|
+
|
|
591
599
|
def get(self, key: str, default: Any = None) -> Any:
|
|
592
600
|
"""Get configuration value."""
|
|
593
601
|
# Support nested keys with dot notation
|
|
@@ -764,6 +772,40 @@ class Config:
|
|
|
764
772
|
except Exception as e:
|
|
765
773
|
logger.error(f"Error validating health/recovery configuration: {e}")
|
|
766
774
|
|
|
775
|
+
def _validate_session_config(self) -> None:
|
|
776
|
+
"""Validate session management configuration."""
|
|
777
|
+
try:
|
|
778
|
+
session_config = self.get("session", {})
|
|
779
|
+
|
|
780
|
+
# Validate save_interval range (60-1800 seconds)
|
|
781
|
+
save_interval = session_config.get("save_interval", 300)
|
|
782
|
+
if not isinstance(save_interval, int):
|
|
783
|
+
logger.warning(
|
|
784
|
+
f"Session save_interval must be integer, got {type(save_interval).__name__}, using default 300"
|
|
785
|
+
)
|
|
786
|
+
self.set("session.save_interval", 300)
|
|
787
|
+
elif save_interval < 60:
|
|
788
|
+
logger.warning(
|
|
789
|
+
f"Session save_interval must be at least 60 seconds, got {save_interval}, using 60"
|
|
790
|
+
)
|
|
791
|
+
self.set("session.save_interval", 60)
|
|
792
|
+
elif save_interval > 1800:
|
|
793
|
+
logger.warning(
|
|
794
|
+
f"Session save_interval must be at most 1800 seconds (30 min), got {save_interval}, using 1800"
|
|
795
|
+
)
|
|
796
|
+
self.set("session.save_interval", 1800)
|
|
797
|
+
|
|
798
|
+
# Validate auto_save is boolean
|
|
799
|
+
auto_save = session_config.get("auto_save", True)
|
|
800
|
+
if not isinstance(auto_save, bool):
|
|
801
|
+
logger.warning(
|
|
802
|
+
f"Session auto_save must be boolean, got {type(auto_save).__name__}, using True"
|
|
803
|
+
)
|
|
804
|
+
self.set("session.auto_save", True)
|
|
805
|
+
|
|
806
|
+
except Exception as e:
|
|
807
|
+
logger.error(f"Error validating session configuration: {e}")
|
|
808
|
+
|
|
767
809
|
def get_health_monitoring_config(self) -> Dict[str, Any]:
|
|
768
810
|
"""Get health monitoring configuration with defaults."""
|
|
769
811
|
base_config = {
|
claude_mpm/core/factories.py
CHANGED
|
@@ -77,7 +77,7 @@ class AgentServiceFactory(ServiceFactory):
|
|
|
77
77
|
if hasattr(service, "set_directories"):
|
|
78
78
|
service.set_directories(framework_dir, project_dir)
|
|
79
79
|
|
|
80
|
-
logger.
|
|
80
|
+
logger.debug("Created agent deployment service")
|
|
81
81
|
return service
|
|
82
82
|
|
|
83
83
|
|
|
@@ -236,7 +236,7 @@ class OptimizedAgentLoader:
|
|
|
236
236
|
|
|
237
237
|
self.metrics.total_time = time.time() - start_time
|
|
238
238
|
|
|
239
|
-
self.logger.
|
|
239
|
+
self.logger.debug(
|
|
240
240
|
f"Loaded {self.metrics.loaded_agents}/{self.metrics.total_agents} agents "
|
|
241
241
|
f"in {self.metrics.total_time:.2f}s "
|
|
242
242
|
f"(cache hits: {self.metrics.cache_hits}, misses: {self.metrics.cache_misses})"
|
|
@@ -286,7 +286,7 @@ class OptimizedAgentLoader:
|
|
|
286
286
|
|
|
287
287
|
self.metrics.total_time = time.time() - start_time
|
|
288
288
|
|
|
289
|
-
self.logger.
|
|
289
|
+
self.logger.debug(
|
|
290
290
|
f"Async loaded {self.metrics.loaded_agents}/{self.metrics.total_agents} agents "
|
|
291
291
|
f"in {self.metrics.total_time:.2f}s"
|
|
292
292
|
)
|
|
@@ -418,7 +418,7 @@ class OptimizedAgentLoader:
|
|
|
418
418
|
Args:
|
|
419
419
|
agent_dirs: List of directories containing agents
|
|
420
420
|
"""
|
|
421
|
-
self.logger.
|
|
421
|
+
self.logger.debug(f"Preloading agents from {len(agent_dirs)} directories")
|
|
422
422
|
|
|
423
423
|
all_paths = []
|
|
424
424
|
for dir_path in agent_dirs:
|
|
@@ -268,7 +268,10 @@ class ResponseTrackingManager:
|
|
|
268
268
|
def track_stop_response(
|
|
269
269
|
self, event: dict, session_id: str, metadata: dict, pending_prompts: dict
|
|
270
270
|
):
|
|
271
|
-
"""Track response for stop events.
|
|
271
|
+
"""Track response for stop events.
|
|
272
|
+
|
|
273
|
+
Captures Claude API stop_reason and usage data for context management.
|
|
274
|
+
"""
|
|
272
275
|
if not (self.response_tracking_enabled and self.response_tracker):
|
|
273
276
|
return
|
|
274
277
|
|
|
@@ -294,6 +297,37 @@ class ResponseTrackingManager:
|
|
|
294
297
|
# Add prompt timestamp to metadata
|
|
295
298
|
metadata["prompt_timestamp"] = prompt_data.get("timestamp")
|
|
296
299
|
|
|
300
|
+
# Capture Claude API stop_reason if available
|
|
301
|
+
if "stop_reason" in event:
|
|
302
|
+
metadata["stop_reason"] = event["stop_reason"]
|
|
303
|
+
if DEBUG:
|
|
304
|
+
print(
|
|
305
|
+
f" - Captured stop_reason: {event['stop_reason']}",
|
|
306
|
+
file=sys.stderr,
|
|
307
|
+
)
|
|
308
|
+
|
|
309
|
+
# Capture Claude API usage data if available
|
|
310
|
+
if "usage" in event:
|
|
311
|
+
usage_data = event["usage"]
|
|
312
|
+
metadata["usage"] = {
|
|
313
|
+
"input_tokens": usage_data.get("input_tokens", 0),
|
|
314
|
+
"output_tokens": usage_data.get("output_tokens", 0),
|
|
315
|
+
"cache_creation_input_tokens": usage_data.get(
|
|
316
|
+
"cache_creation_input_tokens", 0
|
|
317
|
+
),
|
|
318
|
+
"cache_read_input_tokens": usage_data.get(
|
|
319
|
+
"cache_read_input_tokens", 0
|
|
320
|
+
),
|
|
321
|
+
}
|
|
322
|
+
if DEBUG:
|
|
323
|
+
total_tokens = usage_data.get(
|
|
324
|
+
"input_tokens", 0
|
|
325
|
+
) + usage_data.get("output_tokens", 0)
|
|
326
|
+
print(
|
|
327
|
+
f" - Captured usage: {total_tokens} total tokens",
|
|
328
|
+
file=sys.stderr,
|
|
329
|
+
)
|
|
330
|
+
|
|
297
331
|
# Track the main Claude response
|
|
298
332
|
file_path = self.response_tracker.track_response(
|
|
299
333
|
agent_name="claude_main",
|