Copilot Local Models — Zero Cost AIPotencia GitHub Copilot con modelos de IA locales de coste cero usando LM Studio como motor principal. Conecta cualquier modelo GGUF directamente a VS Code — sin API keys, sin facturación, sin enviar código a servidores externos. ¿Qué hace este plugin?
Agentes Especialistas (.NET 10 Ready)El plugin incluye 27 agentes especializados. Se activan automáticamente según el contexto del workspace o mediante menciones explícas (
Unit Testing — 60% Coverage EnforcementEl agente
Stack recomendado: xUnit v3 + NSubstitute (evita licensing de Moq v5+) + FluentAssertions + bUnit (componentes Blazor). Requisitos PreviosInstalar LM Studio (motor principal)Descarga desde lmstudio.ai — disponible para Windows, macOS y Linux. Pasos de configuración:
LM Studio expone una API 100% compatible con OpenAI — el plugin la usa directamente sin ninguna configuración extra. Uso1. Chat Participant
|
| Comando | Descripción |
|---|---|
/models |
Lista los modelos cargados en LM Studio |
/switch <modelo> |
Cambia el modelo activo para la sesión |
/status |
Verifica el estado del servidor LM Studio |
/sdd |
Inicia el flujo Spec-Driven Development (9 pasos) |
/agent <id> |
Fuerza un especialista concreto (/agent csharp, /agent azure, etc.) |
/next |
Avanza al siguiente paso del flujo SDD activo |
/reset |
Cancela el flujo SDD activo |
2. Selector de Modelos de Copilot
Los modelos cargados en LM Studio aparecen automáticamente en el selector desplegable del chat de Copilot (junto a GPT-4o, Claude, etc.). Solo selecciona uno y úsalo normalmente — sin ningún comando adicional.
3. Comandos de la Paleta (Ctrl+Shift+P)
| Comando | Descripción |
|---|---|
Copilot Local: Listar Modelos Disponibles |
Ver modelos cargados en LM Studio |
Copilot Local: Cambiar Modelo Activo |
Quick pick para cambiar de modelo |
Copilot Local: Verificar Estado de Backends |
Estado del servidor LM Studio |
Copilot Local: Abrir Panel de Agentes |
Panel visual de especialistas disponibles |
Copilot Local: Configurar MCP |
Abrir/editar la configuración de MCP servers |
Copilot Local: Resetear Estadísticas |
Borra el historial de requests/tokens acumulados |
Configuración
{
// URL del servidor LM Studio (solo localhost por seguridad)
"copilotLocal.lmStudioUrl": "http://localhost:1234",
// Modelo por defecto (debe coincidir con uno cargado en LM Studio)
"copilotLocal.defaultModel": "qwen2.5-coder-7b-instruct",
// System prompt base enviado a todos los modelos
"copilotLocal.systemPrompt": "Eres un asistente de programación experto en .NET, C# y desarrollo web.",
// Tokens máximos de respuesta
"copilotLocal.maxTokens": 4096,
// Temperatura (0 = determinista, 1 = creativo)
"copilotLocal.temperature": 0.7,
// Mostrar indicador en la barra de estado
"copilotLocal.showStatusBar": true,
// Especialista forzado (sobrescribe la detección automática)
// "copilotLocal.activeSpecialist": "csharp",
// Ruta a un archivo .md de agente personalizado
// "copilotLocal.agentFilePath": "C:/mis-agentes/mi-agente.md",
// Auto-review de respuestas antes de mostrarlas
"copilotLocal.selfReview": false
}
Modelos Recomendados para LM Studio
Descarga desde la pestaña Discover de LM Studio:
| Modelo | Tamaño VRAM | Uso recomendado |
|---|---|---|
Qwen2.5-Coder-7B-Instruct |
~5GB | Código — el mejor relación calidad/tamaño |
Qwen2.5-Coder-14B-Instruct |
~9GB | Código avanzado con más contexto |
DeepSeek-Coder-V2-Lite-Instruct |
~9GB | Código + razonamiento técnico |
Llama-3.2-3B-Instruct |
~2GB | Ultraligero — consultas rápidas |
Mistral-7B-Instruct-v0.3 |
~5GB | General — razonamiento y chat |
Phi-3.5-mini-instruct |
~2.5GB | Ultraligero — bueno para C# y .NET |
Recomendación:
Qwen2.5-Coder-7B-Instructes el punto de entrada ideal para la mayoría de los casos de uso de este plugin.
Arquitectura
VS Code Copilot Chat
│
├── LanguageModelChatProvider (lmstudio-local)
│ └── src/localModelProvider.ts
│ └── src/lmStudioClient.ts → LM Studio API :1234/v1
│
├── ChatParticipant (@localai)
│ └── src/chatParticipant.ts
│ ├── src/agentRouter.ts ← detecta especialista
│ ├── src/sddWorkflow.ts ← flujo SDD (9 pasos)
│ ├── src/toolEngine.ts ← herramientas del agente
│ ├── src/mcpDetector.ts ← estado MCP
│ ├── src/statsTracker.ts ← tracking de uso (tokens, requests)
│ └── assets/agents/*.md ← 27 definiciones de agentes
│
├── Sidebar Webview (AgentPanelProvider)
│ └── src/agentPanel.ts
│ ├── Avatar AI animado (SVG)
│ ├── Status chip LM Studio
│ ├── SDD Stepper (9 dots conectados)
│ ├── Config en grid 2×3
│ └── Stats en grid 3×2 (JetBrains Mono)
│
└── LM Tools (Copilot Agent Mode)
└── src/extension.ts
├── localai_startSdd ← inicia flujo SDD desde agentes externos
├── localai_setSpecialist ← fija el especialista activo
└── localai_getStatus ← devuelve estado + estadísticas
Instalar VSIX
# 1. Clonar e instalar dependencias
git clone https://github.com/mdesantis1984/copilot-lmstudio
cd copilot-lmstudio
npm install
# 2. Compilar y empaquetar
npm run package
# 3. Instalar en VS Code
code --install-extension copilot-lmstudio-*.vsix
Sidebar — Panel de Control
El panel lateral (Local AI) provee control visual completo sobre la extensión:
- Avatar AI — SVG animado con anillos giratorios (purple/cyan) y ojos parpadeantes
- Status chip — estado de LM Studio en tiempo real (online/offline/verificando) con dot pulsante
- Especialista — selector del agente activo (Auto ó forzado)
- SDD Stepper — 9 dots (IN→EX→DE→SP→PR→TA→AP→VE→AR) con líneas de progreso; botones
▶ Iniciar/⏹ Cancelaren el header de la card (igual que Agent.md / Skills.md) - Config — grid 2×3 de tiles: temperatura, maxTokens, maxIteraciones, toolsMode, logLevel
- Estadísticas — grid 3×2: requests, tokens ↑, tokens ↓, errores, avg dur, % éxito
- Agent.md / Skills.md — gestión de archivos personalizados con chips + botones icon-only
LM Tools (Copilot Agent Mode)
La extensión registra 3 herramientas en el namespace de LM Tools de VS Code (vscode.lm.registerTool), disponibles en modo Agent de Copilot:
| Tool | Descripción |
|---|---|
localai_startSdd |
Inicia el flujo SDD invocando @localai /sdd en el chat |
localai_setSpecialist |
Fija el agente especialista activo (p.ej. csharp, azure, auto) |
localai_getStatus |
Retorna el estado de LM Studio + estadísticas de uso acumuladas |
Seguridad
- ✅ Solo se permiten conexiones a
localhost(previene SSRF) - ✅ Sin telemetría, sin datos enviados a terceros
- ✅ Todo el código y los modelos permanecen en tu máquina
- ✅ Sin API keys almacenadas ni requeridas
Licencia
MIT © ThisCloud Services
Changelog
v1.1.53 (2026-04-15)
- UI/UX sidebar: eliminado el panel TreeView separado "SDD Workflow" — el stepper SDD ya está integrado en la card del webview "Agente & Skills"
- SDD card: botones
▶ Iniciar/⏹ Cancelarmovidos al header de la card como icon-buttons (consistente con Agent.md y Skills.md); eliminado el botónxl primaryde ancho completo - Padding ajustado:
.sdd-stepperconmargin: 4px 0 6pxy hint conmargin-top: 8pxpara mejor separación visual
v1.1.52 (2026-04-15)
- StatsTracker: nuevo módulo de tracking persistente (tokens in/out, requests, errores, duración media, tasa de éxito) — sobrevive recargas via
globalState - Sidebar futurista: agentPanel rediseñado con avatar SVG animado (purple/cyan), stepper SDD de 9 dots, config en grid 2×3, stats en grid 3×2 (JetBrains Mono)
- Fix race condition:
_cachedStatusen AgentPanelProvider evita que_refreshPanel()resetee el chip de estado antes de recibir el resultado async de LM Studio - LM Tools: 3 herramientas registradas en Copilot Agent Mode (
localai_startSdd,localai_setSpecialist,localai_getStatus) y sidebar SddPanelProvider como TreeView - SDD Panel mejorado: iconos actualizados (
play-circle,pass-filled), labels sin prefijo numérico, descripción compacta por paso - lmStudioClient:
ModelInfointerface,getFullModelInfo(),reloadModel(),estimateTokens(),CHARS_PER_TOKEN=2.0(fixn_keep >= n_ctx) - modelManager: timeout de 4s en status check para no bloquear el panel
- mcpDetector: detección de ia-orquestador + ia-recuerdo,
saveDroppedHistoryToMemory()para persistir historial recortado - MCP commands:
copilotLocal.openMcpConfigycopilotLocal.checkMcpStatusen paleta
v1.1.46
- Commit inicial público — LM Studio + Copilot Chat integration baseline