.cursor/skills/framework-selection/SKILL.md
INVOKE THIS SKILL at the START of any LangChain/LangGraph/Deep Agents project, before writing any agent code. Determines which framework layer is right for the task: LangChain, LangGraph, Deep Agents, or a combination. Must be consulted before other agent skills.
npx skillsauth add jxtngx/dgx-lab framework-selectionInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
┌─────────────────────────────────────────┐
│ Deep Agents │ ← highest level: batteries included
│ (planning, memory, skills, files) │
├─────────────────────────────────────────┤
│ LangGraph │ ← orchestration: graphs, loops, state
│ (nodes, edges, state, persistence) │
├─────────────────────────────────────────┤
│ LangChain │ ← foundation: models, tools, chains
│ (models, tools, prompts, RAG) │
└─────────────────────────────────────────┘
Picking a higher layer does not cut you off from lower layers — you can use LangGraph graphs inside Deep Agents, and LangChain primitives inside both.
This skill should be loaded at the top of any project before selecting other skills or writing agent code. The framework you choose dictates which other skills to invoke next.
</overview>
Answer these questions in order:
| Question | Yes → | No → |
|----------|-------|-------|
| Does the task require breaking work into sub-tasks, managing files across a long session, persistent memory, or loading on-demand skills? | Deep Agents | ↓ |
| Does the task require complex control flow — loops, dynamic branching, parallel workers, human-in-the-loop, or custom state? | LangGraph | ↓ |
| Is this a single-purpose agent that takes input, runs tools, and returns a result? | LangChain (create_agent) | ↓ |
| Is this a pure model call, chain, or retrieval pipeline with no agent loop? | LangChain (LCEL / chain) | — |
Best for:
Not ideal when:
Skills to invoke next: langchain-models, langchain-rag, langchain-middleware
Best for:
Not ideal when:
Skills to invoke next: langgraph-fundamentals, langgraph-human-in-the-loop, langgraph-persistence
Best for:
Not ideal when:
Middleware — built-in and extensible:
Deep Agents ships with a built-in middleware layer out of the box — you configure it, you don't implement it. The following come pre-wired; you can also add your own on top:
| Middleware | What it provides | Always on? |
|------------|-----------------|------------|
| TodoListMiddleware | write_todos tool — agent plans and tracks multi-step tasks | ✓ |
| FilesystemMiddleware | ls, read_file, write_file, edit_file, glob, grep tools | ✓ |
| SubAgentMiddleware | task tool — delegate work to named subagents | ✓ |
| SkillsMiddleware | Load SKILL.md files on demand from a skills directory | Opt-in |
| MemoryMiddleware | Long-term memory across sessions via a Store instance | Opt-in |
| HumanInTheLoopMiddleware | Interrupt and request human approval before sensitive tool calls | Opt-in |
Skills to invoke next: deep-agents-core, deep-agents-memory, deep-agents-orchestration
| Scenario | Recommended pattern | |----------|---------------------| | Main agent needs planning + memory, but one subtask requires precise graph control | Deep Agents orchestrator → LangGraph subagent | | Specialized pipeline (e.g. RAG, reflection loop) is called by a broader agent | LangGraph graph wrapped as a tool or subagent | | High-level coordination but low-level graph for a specific domain | Deep Agents + LangGraph compiled graph as a subagent |
A LangGraph compiled graph can be registered as a subagent inside Deep Agents. This means you can build a tightly-controlled LangGraph workflow (e.g. a retrieval-and-verify loop) and hand it off to the Deep Agents task tool as a named subagent — the Deep Agents orchestrator delegates to it without caring about its internal graph structure.
LangChain tools, chains, and retrievers can be used freely inside both LangGraph nodes and Deep Agents tools — they are the shared building blocks at every level.
</mixing-layers>| | LangChain | LangGraph | Deep Agents | |---|-----------|-----------|-------------| | Control flow | Fixed (tool loop) | Custom (graph) | Managed (middleware) | | Middleware layer | Callbacks only | ✗ None | ✓ Explicit, configurable | | Planning | ✗ | Manual | ✓ TodoListMiddleware | | File management | ✗ | Manual | ✓ FilesystemMiddleware | | Persistent memory | ✗ | With checkpointer | ✓ MemoryMiddleware | | Subagent delegation | ✗ | Manual | ✓ SubAgentMiddleware | | On-demand skills | ✗ | ✗ | ✓ SkillsMiddleware | | Human-in-the-loop | ✗ | Manual interrupt | ✓ HumanInTheLoopMiddleware | | Custom graph edges | ✗ | ✓ Full control | Limited | | Setup complexity | Low | Medium | Low | | Flexibility | Medium | High | Medium |
</quick-reference>Middleware is a concept specific to LangChain (callbacks) and Deep Agents (explicit middleware layer). LangGraph has no middleware — you wire behavior directly into nodes and edges.
tools
INVOKE THIS SKILL when working with LangSmith tracing OR querying traces. Covers adding tracing to applications and querying/exporting trace data. Uses the langsmith CLI tool.
tools
INVOKE THIS SKILL when building evaluation pipelines for LangSmith. Covers three core components: (1) Creating Evaluators - LLM-as-Judge, custom code; (2) Defining Run Functions - how to capture outputs and trajectories from your agent; (3) Running Evaluations - locally with evaluate() or auto-run via LangSmith. Uses the langsmith CLI tool.
tools
INVOKE THIS SKILL when creating evaluation datasets, uploading datasets to LangSmith, or managing existing datasets. Covers dataset types (final_response, single_step, trajectory, RAG), CLI management commands, SDK-based creation, and example management. Uses the langsmith CLI tool.
testing
INVOKE THIS SKILL when your LangGraph needs to persist state, remember conversations, travel through history, or configure subgraph checkpointer scoping. Covers checkpointers, thread_id, time travel, Store, and subgraph persistence modes.