Fundamentals

Motor de contexto

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

  • Comprueba qué motor está activo

    openclaw doctor
    # or inspect config directly:
    cat ~/.openclaw/openclaw.json | jq '.plugins.slots.contextEngine'
    
  • Instala un motor de Plugin

    Los Plugins de motor de contexto se instalan como cualquier otro Plugin de OpenClaw.

    Desde npm

    openclaw plugins install @martian-engineering/lossless-claw
    

    Desde una ruta local

    openclaw plugins install -l ./my-context-engine
    
  • 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.

  • 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:

    1. Ingesta

    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.

    2. Ensamblaje

    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.

    3. Compact

    Se llama cuando la ventana de contexto está llena o cuando el usuario ejecuta /compact. El motor resume el historial antiguo para liberar espacio.

    4. Después del turno

    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:

    prepareSubagentSpawnmethod

    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.

    onSubagentEndedmethod

    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:

    
    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:

    Miembro Tipo Propósito
    info Propiedad Id, nombre, versión del motor y si posee la Compaction
    ingest(params) Método Almacenar un único mensaje
    assemble(params) Método Construir contexto para una ejecución de modelo (devuelve AssembleResult)
    compact(params) Método Resumir/reducir contexto

    assemble devuelve un AssembleResult con:

    messagesMessage[]required

    Los mensajes ordenados que se envían al modelo.

    estimatedTokensnumberrequired

    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.

    systemPromptAdditionstring

    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:

    Miembro Tipo Propósito
    bootstrap(params) Método Inicializar 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étodo Ingerir 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étodo Trabajo de ciclo de vida posterior a la ejecución (persistir estado, activar Compaction en segundo plano).
    prepareSubagentSpawn(params) Método Configurar estado compartido para una sesión hija antes de que comience.
    onSubagentEnded(params) Método Limpiar después de que finaliza un subagente.
    dispose() Método Liberar 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:

    ownsCompaction: true

    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.

    ownsCompaction: false o sin definir

    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.

    Eso significa que hay dos patrones válidos de Plugin:

    Modo propietario

    Implementa tu propio algoritmo de Compaction y define ownsCompaction: true.

    Modo delegado

    Define ownsCompaction: false y haz que compact() llame a delegateCompactionToRuntime(...) desde openclaw/plugin-sdk/core para usar el comportamiento de Compaction integrado de OpenClaw.

    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",
        },
      },
    }
    

    Relación con Compaction y memoria

    Compaction

    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.).

    Plugins de memoria

    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(...).

    Poda de sesiones

    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