Skip to main content
Glama
NealZhi
by NealZhi

Instrucciones de integración de Codex JetBrains HUD + Hooks

Antecedentes del proyecto: Esta solución de adaptación se basa en el análisis del código fuente filtrado de Claude Code v2.1.88. El objetivo es dotar a Codex de capacidades similares a las de Claude Code, permitiéndole detectar el archivo, el número de línea y el rango de código seleccionados actualmente en la serie de IDE de JetBrains.

Autor: nealzhi

Este documento solo conserva una ruta de integración: HUD + hooks.

Este repositorio ha eliminado la antigua solución de "servidor MCP local + prompts globales", y ya no se recomienda ni se proporciona dicha configuración.

Captura de pantalla exitosa

1. Requisitos previos

Cumple primero con las siguientes dos condiciones:

  1. Utilizas la serie de IDE de JetBrains Por ejemplo: IntelliJ IDEA, PyCharm, WebStorm, GoLand, Android Studio

  2. Tu IDE tiene instalado el plugin oficial de Claude Code para JetBrains Este es el requisito previo para la vinculación. Sin este plugin, no existirán los archivos ~/.claude/ide/*.lock locales ni las interfaces locales correspondientes, por lo que Codex no podrá leer el archivo seleccionado actualmente ni el rango de código.

2. Instalación de dependencias

Ejecuta en la raíz del repositorio:

cd codex-jetbrains-mcp
npm install
brew install tmux

Explicación:

  • npm install: Instala las dependencias de HUD y hooks

  • tmux: Dependencia del HUD

3. Integración del HUD

Ejecuta en la raíz del repositorio:

chmod +x codex-jetbrains-mcp/bin/codex-jetbrains-hud

Si deseas que al ejecutar codex se inicie automáticamente con el HUD, añade la siguiente línea a tu ~/.zshrc o ~/.bashrc:

alias codex='$(pwd)/codex-jetbrains-mcp/bin/codex-jetbrains-hud'

Recarga el shell:

source ~/.zshrc

Si usas bash, ejecuta:

source ~/.bashrc

Si descubres que la rueda del ratón no puede desplazar la ventana de Codex en la terminal integrada de macOS o en la terminal Warp, puedes ejecutar el siguiente comando para activar el soporte de ratón de tmux:

tmux set -g mouse on

Una vez iniciado el HUD, se mostrará una línea:

JetBrains PyCharm 已连接 | test_main.py:2140-2147 (8 lines)

4. Configuración de hooks

El núcleo de esta solución es:

  1. Iniciar el HUD al mismo tiempo que se inicia codex

  2. El HUD escribe automáticamente el archivo/número de línea actual de JetBrains en .codex/jetbrains-selection-state.json

  3. El hook UserPromptSubmit lee este estado cuando envías un mensaje

  4. Cuando hay contexto de JetBrains, solo se inyecta la "ruta del archivo" o "ruta del archivo + número de línea"

  5. No se inyecta el texto seleccionado, permitiendo que Codex lea el archivo según sea necesario

4.1 Método de inicio recomendado

Ejecuta en la raíz del repositorio:

chmod +x codex-jetbrains-mcp/bin/codex-jetbrains-hud
alias codex='$(pwd)/codex-jetbrains-mcp/bin/codex-jetbrains-hud'

Después, puedes ejecutar codex normalmente.

Ahora, codex-jetbrains-hud no solo muestra el HUD, sino que también sincroniza automáticamente el estado necesario para los hooks. Esta es la única ruta recomendada; no se proporciona ni se necesita un proceso de sincronización independiente.

El archivo de estado se escribirá en:

.codex/jetbrains-selection-state.json

4.2 Configuración de hooks

El repositorio ya incluye:

  • .codex/config.toml

  • .codex/hooks/selection-state.mjs

  • .codex/hooks.json

  • .codex/hooks/user-prompt-submit-jetbrains-selection.mjs

Existen dos formas de integración:

  1. Si inicias codex en este directorio del repositorio Codex leerá directamente el .codex/config.toml y .codex/hooks.json del repositorio, sin necesidad de especificar rutas adicionales.

  2. Si ya tienes tu propio ~/.codex/hooks.json global No lo sobrescribas, simplemente fusiona la configuración de UserPromptSubmit del repositorio. Si vas a copiarlo a ~/.codex/hooks/, copia todo el directorio .codex/hooks/, no solo el archivo de entrada.

La función de .codex/config.toml es activar la funcionalidad de hooks requerida oficialmente:

[features]
codex_hooks = true

Según la documentación oficial, los hooks están desactivados por defecto y deben habilitarse en config.toml, o pasando codex --enable codex_hooks al iniciar. Además, la capa de configuración de Codex leerá tanto ~/.codex/config.toml como el .codex/config.toml del repositorio; si el proyecto no está marcado como confiable, el .codex/config.toml a nivel de repositorio no tendrá efecto.

El contenido de la configuración incluida en el repositorio es:

{
  "hooks": {
    "UserPromptSubmit": [
      {
        "hooks": [
          {
            "type": "command",
            "command": "node \"$(git rev-parse --show-toplevel)/.codex/hooks/user-prompt-submit-jetbrains-selection.mjs\"",
            "statusMessage": "Loading JetBrains selection"
          }
        ]
      }
    ]
  }
}

Este hook leerá el archivo de estado local cada vez que se ejecute UserPromptSubmit:

  • Si solo se ha seleccionado un archivo, inyecta a Codex "cuál es el archivo actual"

  • Si se ha seleccionado un rango de código, inyecta a Codex "archivo actual + número de línea"

  • Si no hay contexto de JetBrains o el estado ha caducado, no se inyecta nada

No inyecta el texto del código, solo proporciona la referencia de ubicación.

4.3 Limpieza de configuraciones antiguas

Si anteriormente utilizaste la versión antigua, elimina lo siguiente:

  1. Elimina la configuración de MCP local

codex mcp remove jetbrains-selection
  1. Elimina este tipo de contenido de tus prompts globales

每次用户请求时,先调用 MCP 工具 jetbrains-selection.jetbrains_get_selection 获取 JetBrains 当前选区

Este paso es obligatorio, de lo contrario, el modelo podría intentar seguir llamando a una herramienta MCP que ya no existe.

4.4 Contenido inyectado por el hook

Cuando solo se selecciona un archivo, se inyecta algo como:

JetBrains 当前选中文件:/path/to/file.ts
这只是文件指引,没有附带文件内容。
如果本轮问题和这个文件相关,请先自行读取该文件;如果无关,请忽略这条上下文。

Cuando se selecciona un rango de código, se inyecta algo como:

JetBrains 当前选中位置:/path/to/file.ts:120-146
这只是位置指引,没有附带代码内容。
如果本轮问题和这个位置相关,请先自行读取对应文件和行号;如果无关,请忽略这条上下文。

El estado predeterminado es válido por 20s. Mientras el HUD esté en ejecución, actualizará el estado cada 5s; si el HUD se cierra, el hook dejará de inyectar el estado antiguo rápidamente. También puedes ajustar este tiempo mediante la variable de entorno CODEX_JB_HOOK_MAX_AGE_MS.

5. ¿Por qué no mantener la solución MCP local?

Los problemas de la solución antigua eran principalmente:

  • Requería ejecutar codex mcp add adicionalmente, aumentando el coste de instalación y mantenimiento.

  • El modelo solía depender de prompts globales para "llamar a una MCP en cada turno", incluso si la pregunta no tenía nada que ver con la selección de JetBrains, lo cual era un paso innecesario.

  • La relevancia de la selección debería decidirse según la pregunta actual; ponerlo en un prompt global hacía que el comportamiento fuera demasiado mecánico.

  • El servidor MCP local era solo una capa de tránsito; en realidad, seguía conectándose al plugin de Claude Code para JetBrains. Mantener esta capa por separado no aportaba mucho valor y aumentaba la complejidad.

  • La configuración antigua no era fácil de limpiar, y tras la migración era fácil que quedaran nombres de herramientas inválidos o prompts antiguos.

Tras cambiar a HUD + hooks, los beneficios son más directos:

  • Solo se lee el estado local al enviar un mensaje, sin necesidad de invocar una capa MCP adicional en cada turno.

  • El contenido inyectado solo contiene la ruta del archivo o el número de línea, lo que hace que la información sea más limpia y permite que el modelo decida por sí mismo si necesita leer el archivo.

  • El archivo de estado está aislado por directorio raíz del proyecto; cada proyecto escribe su propio .codex/jetbrains-selection-state.json.

  • El HUD actualiza el estado continuamente mientras está activo; si el HUD se detiene, el estado antiguo caducará automáticamente.

  • La ruta de integración es más sencilla; el usuario solo necesita mantener el HUD y los hooks, sin necesidad de mantener configuraciones de MCP.

6. ¿Cómo funciona esta solución?

El flujo de datos es el siguiente:

  1. El plugin oficial de Claude Code para JetBrains expone la información de conexión local y los eventos de selección.

  2. El HUD coincide con la ventana del proyecto de JetBrains correcta según el directorio de trabajo actual.

  3. Una vez que el HUD recibe un cambio en la selección, escribe la ruta del archivo, el número de línea y el tiempo de latido en el .codex/jetbrains-selection-state.json del proyecto actual.

  4. El hook UserPromptSubmit lee este estado cuando envías un mensaje.

  5. Si el estado es válido, inyecta un prompt ligero con el "archivo actual" o "archivo actual + número de línea" a Codex.

En este flujo no hay servidor MCP local ni se necesitan prompts globales adicionales.

7. Verificación

Una vez completados los pasos anteriores:

  1. Abre el IDE de JetBrains.

  2. Inicia codex.

  3. Si utilizaste el envoltorio del HUD para iniciar, el HUD sincronizará automáticamente el estado del hook.

  4. Vuelve al IDE de JetBrains con el plugin oficial de Claude Code instalado y selecciona un archivo o un fragmento de código.

  5. Confirma que el HUD muestra el archivo y el número de línea actuales.

  6. Haz preguntas normalmente en Codex.

Si el HUD no se actualiza, lo más seguro es:

  • Volver al IDE y hacer clic de nuevo en el archivo.

  • O volver a arrastrar la selección.

En condiciones normales:

  • Cuando solo se selecciona un archivo, Codex recibirá la guía de la ruta del archivo.

  • Cuando se selecciona un rango de código, Codex recibirá la guía de la ruta del archivo y el número de línea.

  • Cuando no hay contexto de JetBrains, no se inyectará ninguna sugerencia de JetBrains.

Install Server
A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

Maintainers
Response time
Release cycle
1Releases (12mo)

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/NealZhi/codex-jetbrains-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server