mirror of
https://github.com/sanbuphy/claude-code-source-code.git
synced 2026-04-04 03:54:56 +08:00
v2.1.88 反编译源码
从 npm 包 @anthropic-ai/claude-code 2.1.88 版本提取的反编译源码 包含 src/ 目录下的 TypeScript 源文件及 vendor/ 原生模块源码 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
67
vendor/modifiers-napi-src/index.ts
vendored
Normal file
67
vendor/modifiers-napi-src/index.ts
vendored
Normal file
@@ -0,0 +1,67 @@
|
||||
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()
|
||||
}
|
||||
Reference in New Issue
Block a user