self-media-james/articles/008/claude-code-source-code/vendor/url-handler-src/index.ts
邓文兵 11b0bd6b86 chore(008): 纳入 Claude Code / claw-code 源码素材并忽略缓存文件
- 收录 008 文章分析用的两份源码(claude-code-source-code、claw-code),
  已移除其内嵌 .git,作为普通素材文件入库
- .gitignore 增加 .DS_Store、__pycache__/、*.pyc,屏蔽系统与缓存噪音

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-13 13:13:22 +08:00

59 lines
1.5 KiB
TypeScript

import { createRequire } from 'module'
import { fileURLToPath } from 'url'
import { dirname, join } from 'path'
type UrlHandlerNapi = {
waitForUrlEvent(timeoutMs: number): string | null
}
let cachedModule: UrlHandlerNapi | null = null
function loadModule(): UrlHandlerNapi | null {
if (cachedModule) {
return cachedModule
}
// Only works on macOS
if (process.platform !== 'darwin') {
return null
}
try {
if (process.env.URL_HANDLER_NODE_PATH) {
// Bundled mode - use the env var path
// eslint-disable-next-line @typescript-eslint/no-require-imports
cachedModule = require(process.env.URL_HANDLER_NODE_PATH) as UrlHandlerNapi
} else {
// Dev mode - load from vendor directory
const modulePath = join(
dirname(fileURLToPath(import.meta.url)),
'..',
'url-handler',
`${process.arch}-darwin`,
'url-handler.node',
)
cachedModule = createRequire(import.meta.url)(modulePath) as UrlHandlerNapi
}
return cachedModule
} catch {
return null
}
}
/**
* Wait for a macOS URL event (Apple Event kAEGetURL).
*
* Initializes NSApplication, registers for the URL event, and pumps
* the event loop for up to `timeoutMs` milliseconds.
*
* Returns the URL string if one was received, or null.
* Only functional on macOS — returns null on other platforms.
*/
export function waitForUrlEvent(timeoutMs: number): string | null {
const mod = loadModule()
if (!mod) {
return null
}
return mod.waitForUrlEvent(timeoutMs)
}