Saltar al contenido principal

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

Un motor de contexto controla cómo OpenClaw construye el contexto del modelo para cada ejecución: qué mensajes incluir, cómo resumir el historial antiguo y cómo gestionar el contexto a través de los límites de subagentes. OpenClaw incluye un motor legacy integrado y lo usa de forma predeterminada; la mayoría de los usuarios nunca necesitan cambiarlo. Instala y selecciona un motor de Plugin solo cuando quieras un comportamiento distinto de ensamblaje, Compaction o recuperación entre sesiones.

Inicio rápido

1

Comprueba qué motor está activo

openclaw doctor
# or inspect config directly:
cat ~/.openclaw/openclaw.json | jq '.plugins.slots.contextEngine'
2

Instala un motor de Plugin

Los Plugins de motor de contexto se instalan como cualquier otro Plugin de OpenClaw.
openclaw plugins install @martian-engineering/lossless-claw
3

Activa y selecciona el motor

// openclaw.json
{
  plugins: {
    slots: {
      contextEngine: "lossless-claw", // must match the plugin's registered engine id
    },
    entries: {
      "lossless-claw": {
        enabled: true,
        // Plugin-specific config goes here (see the plugin's docs)
      },
    },
  },
}
Reinicia el Gateway después de instalar y configurar.
4

Vuelve a legacy (opcional)

Define contextEngine como "legacy" (o elimina la clave por completo; "legacy" es el valor predeterminado).

Cómo funciona

Cada vez que OpenClaw ejecuta un prompt de modelo, el motor de contexto participa en cuatro puntos del ciclo de vida:
Se llama cuando se agrega un nuevo mensaje a la sesión. El motor puede almacenar o indexar el mensaje en su propio almacén de datos.
Se llama antes de cada ejecución del modelo. El motor devuelve un conjunto ordenado de mensajes (y un systemPromptAddition opcional) que cabe dentro del presupuesto de tokens.
Se llama cuando la ventana de contexto está llena o cuando el usuario ejecuta /compact. El motor resume el historial antiguo para liberar espacio.
Se llama después de que finaliza una ejecución. El motor puede persistir estado, activar Compaction en segundo plano o actualizar índices.
Para el arnés Codex no ACP incluido, OpenClaw aplica el mismo ciclo de vida proyectando el contexto ensamblado en las instrucciones de desarrollador de Codex y en el prompt del turno actual. Codex sigue siendo propietario de su historial de hilos nativo y de su compactador nativo.

Ciclo de vida de subagentes (opcional)

OpenClaw llama a dos hooks opcionales del ciclo de vida de subagentes:
prepareSubagentSpawn
method
Prepara el estado de contexto compartido antes de que comience una ejecución hija. El hook recibe claves de sesión padre/hija, contextMode (isolated o fork), ids/archivos de transcripción disponibles y TTL opcional. Si devuelve un identificador de reversión, OpenClaw lo llama cuando la generación falla después de que la preparación se completa correctamente.
onSubagentEnded
method
Limpia cuando una sesión de subagente se completa o se barre.

Adición al prompt del sistema

El método assemble puede devolver una cadena systemPromptAddition. OpenClaw la antepone al prompt del sistema para la ejecución. Esto permite que los motores inyecten orientación dinámica de recuperación, instrucciones de recuperación o sugerencias sensibles al contexto sin requerir archivos estáticos del espacio de trabajo.

El motor legacy

El motor legacy integrado conserva el comportamiento original de OpenClaw:
  • Ingesta: sin operación (el gestor de sesiones maneja directamente la persistencia de mensajes).
  • Ensamblaje: paso directo (la canalización existente sanitize → validate → limit en el runtime maneja el ensamblaje de contexto).
  • Compact: delega en la Compaction de resumen integrada, que crea un único resumen de los mensajes antiguos y mantiene intactos los mensajes recientes.
  • Después del turno: sin operación.
El motor legacy no registra herramientas ni proporciona un systemPromptAddition. Cuando no se define plugins.slots.contextEngine (o se define como "legacy"), este motor se usa automáticamente.

Motores de Plugin

Un Plugin puede registrar un motor de contexto mediante la API de Plugin:
import { buildMemorySystemPromptAddition } from "openclaw/plugin-sdk/core";

export default function register(api) {
  api.registerContextEngine("my-engine", (ctx) => ({
    info: {
      id: "my-engine",
      name: "My Context Engine",
      ownsCompaction: true,
    },

    async ingest({ sessionId, message, isHeartbeat }) {
      // Store the message in your data store
      return { ingested: true };
    },

    async assemble({ sessionId, messages, tokenBudget, availableTools, citationsMode }) {
      // Return messages that fit the budget
      return {
        messages: buildContext(messages, tokenBudget),
        estimatedTokens: countTokens(messages),
        systemPromptAddition: buildMemorySystemPromptAddition({
          availableTools: availableTools ?? new Set(),
          citationsMode,
        }),
      };
    },

    async compact({ sessionId, force }) {
      // Summarize older context
      return { ok: true, compacted: true };
    },
  }));
}
La fábrica ctx incluye valores opcionales config, agentDir y workspaceDir para que los Plugins puedan inicializar estado por agente o por espacio de trabajo antes de que se ejecute el primer hook de ciclo de vida. Luego actívalo en la configuración:
{
  plugins: {
    slots: {
      contextEngine: "my-engine",
    },
    entries: {
      "my-engine": {
        enabled: true,
      },
    },
  },
}

La interfaz ContextEngine

Miembros obligatorios:
MiembroTipoPropósito
infoPropiedadId, nombre, versión del motor y si posee la Compaction
ingest(params)MétodoAlmacenar un único mensaje
assemble(params)MétodoConstruir contexto para una ejecución de modelo (devuelve AssembleResult)
compact(params)MétodoResumir/reducir contexto
assemble devuelve un AssembleResult con:
messages
Message[]
requerido
Los mensajes ordenados que se envían al modelo.
estimatedTokens
number
requerido
La estimación del motor del total de tokens en el contexto ensamblado. OpenClaw usa esto para decisiones de umbral de Compaction e informes de diagnóstico.
systemPromptAddition
string
Se antepone al prompt del sistema.
promptAuthority
"assembled" | "preassembly_may_overflow"
Controla qué estimación de tokens usa el ejecutor para las comprobaciones previas preventivas de desbordamiento. El valor predeterminado es "assembled", lo que significa que solo se comprueba la estimación del prompt ensamblado; es apropiado para motores que devuelven un contexto con ventana y autónomo. Defínelo como "preassembly_may_overflow" solo cuando tu vista ensamblada pueda ocultar el riesgo de desbordamiento en la transcripción subyacente; entonces el ejecutor toma el máximo entre la estimación ensamblada y la estimación del historial de sesión previo al ensamblaje (sin ventana) al decidir si debe hacer Compaction preventivamente. En cualquier caso, los mensajes que devuelves siguen siendo lo que ve el modelo; promptAuthority solo afecta la comprobación previa.
compact devuelve un CompactResult. Cuando la Compaction rota la transcripción activa, result.sessionId y result.sessionFile identifican la sesión sucesora que debe usar el siguiente reintento o turno. Miembros opcionales:
MiembroTipoPropósito
bootstrap(params)MétodoInicializar el estado del motor para una sesión. Se llama una vez cuando el motor ve una sesión por primera vez (por ejemplo, importar historial).
ingestBatch(params)MétodoIngerir un turno completado como lote. Se llama después de que finaliza una ejecución, con todos los mensajes de ese turno a la vez.
afterTurn(params)MétodoTrabajo de ciclo de vida posterior a la ejecución (persistir estado, activar Compaction en segundo plano).
prepareSubagentSpawn(params)MétodoConfigurar estado compartido para una sesión hija antes de que comience.
onSubagentEnded(params)MétodoLimpiar después de que finaliza un subagente.
dispose()MétodoLiberar recursos. Se llama durante el apagado del Gateway o la recarga del Plugin, no por sesión.

ownsCompaction

ownsCompaction controla si la Compaction automática en intento integrada de Pi permanece activada para la ejecución:
El motor posee el comportamiento de Compaction. OpenClaw desactiva la Compaction automática integrada de Pi para esa ejecución, y la implementación compact() del motor es responsable de /compact, la Compaction de recuperación de desbordamiento y cualquier Compaction proactiva que quiera hacer en afterTurn(). OpenClaw aún puede ejecutar la protección contra desbordamiento previa al prompt; cuando predice que la transcripción completa se desbordará, la ruta de recuperación llama a compact() del motor activo antes de enviar otro prompt.
La Compaction automática integrada de Pi aún puede ejecutarse durante la ejecución del prompt, pero el método compact() del motor activo se sigue llamando para /compact y la recuperación de desbordamiento.
ownsCompaction: false no significa que OpenClaw recurra automáticamente a la ruta de Compaction del motor legacy.
Eso significa que hay dos patrones válidos de Plugin:
Implementa tu propio algoritmo de Compaction y define ownsCompaction: true.
Un compact() sin operación no es seguro para un motor activo que no posee Compaction porque desactiva la ruta normal de Compaction de /compact y recuperación de desbordamiento para ese slot de motor.

Referencia de configuración

{
  plugins: {
    slots: {
      // Select the active context engine. Default: "legacy".
      // Set to a plugin id to use a plugin engine.
      contextEngine: "legacy",
    },
  },
}
El slot es exclusivo en tiempo de ejecución: solo se resuelve un motor de contexto registrado para una ejecución u operación de Compaction determinada. Otros Plugins kind: "context-engine" activados aún pueden cargarse y ejecutar su código de registro; plugins.slots.contextEngine solo selecciona qué id de motor registrado resuelve OpenClaw cuando necesita un motor de contexto.
Desinstalación de Plugin: cuando desinstalas el Plugin seleccionado actualmente como plugins.slots.contextEngine, OpenClaw restablece el slot al valor predeterminado (legacy). El mismo comportamiento de restablecimiento se aplica a plugins.slots.memory. No se requiere ninguna edición manual de la configuración.

Relación con Compaction y memoria

Compaction es una responsabilidad del motor de contexto. El motor heredado delega en la resumición integrada de OpenClaw. Los motores de Plugin pueden implementar cualquier estrategia de compaction (resúmenes DAG, recuperación vectorial, etc.).
Los plugins de memoria (plugins.slots.memory) están separados de los motores de contexto. Los plugins de memoria proporcionan búsqueda/recuperación; los motores de contexto controlan lo que ve el modelo. Pueden trabajar juntos: un motor de contexto podría usar datos de plugins de memoria durante el ensamblaje. Los motores de Plugin que quieran la ruta de prompt de active memory deberían preferir buildMemorySystemPromptAddition(...) de openclaw/plugin-sdk/core, que convierte las secciones del prompt de active memory en un systemPromptAddition listo para anteponer. Si un motor necesita control de menor nivel, aún puede extraer líneas sin procesar de openclaw/plugin-sdk/memory-host-core mediante buildActiveMemoryPromptSection(...).
El recorte de resultados antiguos de herramientas en memoria sigue ejecutándose independientemente de qué motor de contexto esté activo.

Consejos

  • Usa openclaw doctor para verificar que tu motor se esté cargando correctamente.
  • Si cambias de motor, las sesiones existentes continúan con su historial actual. El nuevo motor toma el control para ejecuciones futuras.
  • Los errores del motor se registran y se muestran en diagnósticos. Si un motor de plugin no logra registrarse o el id del motor seleccionado no se puede resolver, OpenClaw no vuelve atrás automáticamente; las ejecuciones fallan hasta que corrijas el plugin o cambies plugins.slots.contextEngine de nuevo a "legacy".
  • Para desarrollo, usa openclaw plugins install -l ./my-engine para enlazar un directorio local de plugin sin copiarlo.

Relacionado