Files
Serendipity 1a1254f045
CI - 构建、测试和质量检查 / Rust 代码检查 (push) Has been cancelled
CI - 构建、测试和质量检查 / 单元测试 (push) Has been cancelled
CI - 构建、测试和质量检查 / 代码格式检查 (push) Has been cancelled
CI - 构建、测试和质量检查 / Clippy 代码质量检查 (push) Has been cancelled
CI - 构建、测试和质量检查 / 构建可执行文件 (claude_code_rs, macos-latest, x86_64-apple-darwin) (push) Has been cancelled
CI - 构建、测试和质量检查 / 构建可执行文件 (claude_code_rs, ubuntu-latest, x86_64-unknown-linux-gnu) (push) Has been cancelled
CI - 构建、测试和质量检查 / 构建可执行文件 (claude_code_rs.exe, windows-latest, x86_64-pc-windows-msvc) (push) Has been cancelled
feat: 添加初始项目结构和基础文件
- 添加 Rust GUI 桌面应用程序入口点
- 添加 TypeScript/JavaScript 项目基础结构文件
- 包含组件、工具、命令、服务和工具定义
- 添加配置文件如 .gitignore、.gitattributes 和 LICENSE
- 包含图片资源和演示文件
- 为各种功能模块添加占位符和类型定义
2026-04-20 16:58: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()
}