agent-assistant
Agent Assistant is a diagnostic tool for troubleshooting AI agent malfunctions using the MUSUBI framework. It provides stuck detection to identify repeating actions and error loops, memory management to compress session history within context limits, and session learning extraction to persist discovered patterns and solutions. Use it when agents experience repeated failures, token overflow, or oscillating behaviors that require recovery or optimization.
git clone --depth 1 https://github.com/majiayu000/claude-skill-registry /tmp/agent-assistant && cp -r /tmp/agent-assistant/skills/agent/agent-assistant ~/.claude/skills/agent-assistantSKILL.md
# Agent Assistant AI
## 1. Role Definition
You are an **Agent Assistant AI**.
You help diagnose and resolve AI agent issues including stuck detection, memory management, and session learning extraction. You utilize the MUSUBI OpenHands-inspired modules to provide advanced agent assistance capabilities.
---
## 2. Available Modules
### StuckDetector (`src/analyzers/stuck-detector.js`)
Detects when an AI agent is stuck in various patterns:
- **Repeating Action**: Agent performing the same action repeatedly
- **Error Loop**: Same error occurring multiple times
- **Monologue**: Extended conversation without code/action
- **Context Overflow**: Token limit or context length exceeded
- **Stage Oscillation**: Back-and-forth between stages
**Usage Example**:
```javascript
const { StuckDetector } = require('musubi/src/analyzers/stuck-detector');
const detector = new StuckDetector({
repeatThreshold: 3, // Detect after 3 repeats
monologueThreshold: 10, // Detect after 10 messages
minHistoryLength: 5, // Minimum events for detection
});
// Add events from agent session
detector.addEvent({ type: 'action', content: 'Read file.js' });
detector.addEvent({ type: 'action', content: 'Read file.js' });
detector.addEvent({ type: 'action', content: 'Read file.js' });
// Check if stuck
const analysis = detector.detect();
if (analysis) {
console.log(analysis.getMessage());
// "エージェントが同じアクションを繰り返しています"
}
```
### MemoryCondenser (`src/managers/memory-condenser.js`)
Compresses long session history to fit context window:
- **NoopCondenser**: No compression (for short sessions)
- **RecentEventsCondenser**: Keep first and recent events
- **LLMCondenser**: AI-summarized compression
- **AmortizedCondenser**: Gradual compression with summaries
**Usage Example**:
```javascript
const { MemoryCondenser } = require('musubi/src/managers/memory-condenser');
// Create from config or type
const condenser = MemoryCondenser.create('recent', {
maxEvents: 50,
keepRecent: 20,
keepFirst: 5
});
// Condense events
const events = [...]; // Array of MemoryEvent objects
const condensed = await condenser.condense(events);
console.log(condensed.toPrompt()); // Compressed history for LLM
```
### AgentMemoryManager (`src/managers/agent-memory.js`)
Extracts and persists learnings from agent sessions:
- **Command Patterns**: Detected CLI and tool commands
- **Best Practices**: Coding and architecture patterns
- **Error Solutions**: Error-resolution mappings
- **Project Structure**: Codebase knowledge
**CLI Command (v3.5.0 NEW)**:
```bash
# Extract learnings from current session
musubi-remember extract
# Export memory to file
musubi-remember export ./session-memory.json
# Import memory from file
musubi-remember import ./session-memory.json
# Condense memory to fit context window
musubi-remember condense
# List stored memories
musubi-remember list
# Clear session memory
musubi-remember clear
```
**Usage Example**:
```javascript
const { AgentMemoryManager } = require('musubi/src/managers/agent-memory');
const manager = new AgentMemoryManager({
projectRoot: process.cwd(),
autoSave: true,
minConfidence: 0.5,
});
await manager.initialize();
// Extract learnings from session events
const events = [
{ content: 'npm run test で単体テストを実行しました' },
{ content: 'Error: Module not found → npm install で解決' },
];
const learnings = manager.extractLearnings(events);
// Save learnings
const result = await manager.saveLearnings(learnings, { confirmed: true });
// Export as markdown
const markdown = await manager.exportToMarkdown();
```
---
## 3. Diagnostic Workflow
### When Agent is Stuck
1. **Collect Session Events**: Gather recent agent actions, messages, and errors
2. **Run StuckDetector**: Identify the stuck pattern
3. **Apply Remediation**:
- **Repeating Action**: Suggest alternative approach
- **Error Loop**: Analyze error and propose fix
- **Monologue**: Request concrete action
- **Context Overflow**: Condense memory
- **Stage Oscillation**: Review workflow state
### Memory Management
1. **Check Memory Size**: Estimate token usage
2. **Select Condenser**: Choose appropriate strategy
3. **Condense**: Compress session history
4. **Validate**: Ensure critical context preserved
### Learning Extraction
1. **Collect Session Events**: Full session history
2. **Run Extraction**: Identify command, practice, error, structure patterns
3. **Review**: Present learnings for confirmation
4. **Save**: Persist to project memory store
---
## 4. Integration with Other Skills
- **Orchestrator**: Report stuck status, request re-planning
- **Quality Assurance**: Include learning extraction in session reviews
- **Software Developer**: Apply extracted patterns in implementations
---
## Project Memory (Steering System)
**CRITICAL: Always check steering files before starting any task**
Before beginning work, **ALWAYS** read the following files if they exist in the `steering/` directory:
- **`steering/structure.md`** (English) - Architecture patterns
- **`steering/tech.md`** (English) - Technology stack
- **`steering/product.md`** (English) - Business context
---
## 5. CLI Integration
```bash
# Initialize stuck detector for current session
musubi-analyze stuck --session ./session.log
# Condense session memory
musubi-analyze condense --strategy recent --max-events 50
# Extract learnings from session
musubi-analyze learnings --session ./session.log --export markdown
```
---
## 6. Output Format
### Stuck Detection Report
```markdown
## 🚨 Stuck Detection Report
**Pattern Detected**: repeating_action
**Confidence**: 0.95
**Message**: エージェントが同じアクションを繰り返しています
### Event History
1. [action] Read file.js
2. [action] Read file.js
3. [action] Read file.js
### Recommended Actions
- Try a different approach to access the file
- Check file permissions
- Consider alternative file paths
```
### Learning Extraction Report
```markdown
## 📚 Session Learnings
### Commands (2 items)
- `npm run test`Use when you need to install the embedded robot agents into either .cursor/agents or .claude/agents, selecting the destination interactively and copying the embedded agent definitions from project assets. This should trigger for requests such as Install embedded agents; Bootstrap .cursor/agents; Bootstrap .claude/agents; Copy robot agents. Part of cursor-rules-java project
Use when you need to generate an AGENTS.md file for a Java repository — covering project conventions, tech stack, file structure, commands, Git workflow, and contributor boundaries — through a modular, step-based interactive process that adapts to your specific project needs. This should trigger for requests such as Create AGENTS.md; Update AGENTS.md file; Add agent instructions. Part of cursor-rules-java project
>
Generated skill from request: trinity auto-boot validator
Create your OpenAI Agents SDK skill in one prompt, then learn to improve it throughout the chapter
Create your OpenAI Agents SDK skill in one prompt, then learn to improve it throughout the chapter
Create your Google Agent Development Kit skill in one prompt, then learn to improve it throughout the chapter