self-media-james/articles/008/claude-code-source-code/vendor/modifiers-napi-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

68 lines
1.6 KiB
TypeScript

import { createRequire } from 'module'
import { fileURLToPath } from 'url'
import { dirname, join } from 'path'
type ModifiersNapi = {
getModifiers(): string[]
isModifierPressed(modifier: string): boolean
}
let cachedModule: ModifiersNapi | null = null
function loadModule(): ModifiersNapi | null {
if (cachedModule) {
return cachedModule
}
// Only works on macOS
if (process.platform !== 'darwin') {
return null
}
try {
if (process.env.MODIFIERS_NODE_PATH) {
// Bundled mode - use the env var path
// eslint-disable-next-line @typescript-eslint/no-require-imports
cachedModule = require(process.env.MODIFIERS_NODE_PATH) as ModifiersNapi
} else {
// Dev mode - load from vendor directory
const modulePath = join(
dirname(fileURLToPath(import.meta.url)),
'..',
'modifiers-napi',
`${process.arch}-darwin`,
'modifiers.node',
)
cachedModule = createRequire(import.meta.url)(modulePath) as ModifiersNapi
}
return cachedModule
} catch {
return null
}
}
export function getModifiers(): string[] {
const mod = loadModule()
if (!mod) {
return []
}
return mod.getModifiers()
}
export function isModifierPressed(modifier: string): boolean {
const mod = loadModule()
if (!mod) {
return false
}
return mod.isModifierPressed(modifier)
}
/**
* Pre-warm the native module by loading it in advance.
* Call this early (e.g., at startup) to avoid delay on first use.
*/
export function prewarm(): void {
// Just call loadModule to cache it
loadModule()
}