muon-ui 0.7.0 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/dist/cli.cjs +269 -120
- package/dist/cli.cjs.map +1 -1
- package/dist/index.cjs +2 -2
- package/dist/index.mjs +2 -2
- package/dist/native/linux-amd64/muon-bootstrap +0 -0
- package/dist/native/linux-amd64/muon-builder +0 -0
- package/dist/native/linux-arm64/muon-bootstrap +0 -0
- package/dist/native/linux-arm64/{muon-prepare → muon-builder} +0 -0
- package/dist/native/linux-armhf/muon-bootstrap +0 -0
- package/dist/native/linux-armhf/{muon-prepare → muon-builder} +0 -0
- package/dist/native/muon-bootstrap.png +0 -0
- package/dist/native/windows-amd64/muon-bootstrap.exe +0 -0
- package/dist/native/windows-amd64/muon-builder.exe +0 -0
- package/dist/native/windows-i686/muon-bootstrap.exe +0 -0
- package/dist/native/windows-i686/muon-builder.exe +0 -0
- package/dist/runtime/linux-amd64/CREDITS.md +24 -0
- package/dist/runtime/linux-amd64/muon-core +0 -0
- package/dist/runtime/linux-arm64/CREDITS.md +24 -0
- package/dist/runtime/linux-arm64/muon-core +0 -0
- package/dist/runtime/linux-armhf/CREDITS.md +24 -0
- package/dist/runtime/linux-armhf/muon-core +0 -0
- package/dist/runtime/windows-amd64/CREDITS.md +24 -0
- package/dist/runtime/windows-amd64/libcardio.dll +0 -0
- package/dist/runtime/windows-amd64/libmuon-ui.dll +0 -0
- package/dist/runtime/windows-amd64/muon-core.exe +0 -0
- package/dist/runtime/windows-i686/CREDITS.md +24 -0
- package/dist/runtime/windows-i686/libcardio.dll +0 -0
- package/dist/runtime/windows-i686/libmuon-ui.dll +0 -0
- package/dist/runtime/windows-i686/muon-core.exe +0 -0
- package/dist/{vite-options-FFh0NWUa.cjs → vite-internals-ChWiL2TL.cjs} +1225 -102
- package/dist/vite-internals-ChWiL2TL.cjs.map +1 -0
- package/dist/vite.cjs +10 -8
- package/dist/vite.cjs.map +1 -1
- package/dist/vite.mjs +876 -49
- package/dist/vite.mjs.map +1 -1
- package/muon.d.ts +129 -27
- package/package.json +14 -10
- package/vite.d.ts +165 -13
- package/dist/native/linux-amd64/muon-prepare +0 -0
- package/dist/native/windows-amd64/muon-prepare.exe +0 -0
- package/dist/native/windows-i686/muon-prepare.exe +0 -0
- package/dist/vite-options-FFh0NWUa.cjs.map +0 -1
package/dist/cli.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.cjs","names":[],"sources":["../src/dev.ts","../src/pack.ts","../src/generated/packageMetadata.ts","../src/cli.ts"],"sourcesContent":["// muon - Multi-platform GUI application framework that uses CEF as its backend\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/muon\n\nimport { spawn } from \"node:child_process\";\nimport { constants } from \"node:fs\";\nimport { access, mkdir, readFile, stat, writeFile } from \"node:fs/promises\";\nimport { dirname, isAbsolute, join, resolve } from \"node:path\";\n\nimport { parse } from \"json5\";\nimport type { UserConfig } from \"vite\";\n\nimport { ensureMuonGitignoreEntry } from \"./gitignore.js\";\nimport { getDefaultMuonPrepareTarget, runMuonPrepare } from \"./prepare.js\";\nimport {\n getMuonExecutablePath,\n resolveMuonRuntimePath,\n} from \"./vite-internals.js\";\nimport {\n flattenVitePluginOptions,\n getMuonVitePluginOptions,\n} from \"./vite-options.js\";\nimport type { MuonVitePluginOptions } from \"./vite.js\";\n\nconst muonRecycleExitCode = 88;\n\ntype JsonObject = Record<string, unknown>;\n\ninterface LoadedViteMuonOptions {\n root: string;\n pluginOptions: MuonVitePluginOptions | undefined;\n}\n\ninterface ProjectConfigResolution {\n configPath: string | undefined;\n config: JsonObject | undefined;\n}\n\ninterface MuonDevOverrideConfig {\n asset?: {\n sourcePath: string;\n };\n cdp?: {\n enable: true;\n };\n browser?: {\n keybind: {\n devtools: \"f12\";\n recycle: \"ctrl+f12\";\n };\n };\n}\n\n/**\n * Options for launching Muon directly against local development assets.\n */\nexport interface MuonDevOptions {\n /**\n * Directory used as the project root.\n */\n root?: string;\n\n /**\n * Directory containing muon-core runtime files such as muon-core and plugins.\n */\n muonPath?: string;\n\n /**\n * Directory containing CEF files, or a CEF archive root with Release/Resources.\n */\n cefPath?: string;\n\n /**\n * Runtime staging directory used for development startup.\n */\n stagePath?: string;\n\n /**\n * Muon config path passed before the generated development override.\n */\n configPath?: string;\n\n /**\n * Local development asset directory.\n */\n assetSourcePath?: string;\n\n /**\n * Enable the Muon debugger defaults during development startup.\n */\n enableDebugger?: boolean;\n\n /**\n * Platform used for runtime target resolution.\n *\n * @remarks This is injectable for tests. Production code uses process.platform.\n */\n platform?: NodeJS.Platform;\n\n /**\n * Architecture used for runtime target resolution.\n *\n * @remarks This is injectable for tests. Production code uses process.arch.\n */\n architecture?: NodeJS.Architecture;\n\n /**\n * Environment used for child processes.\n */\n environment?: NodeJS.ProcessEnv;\n\n /**\n * Suppress native prepare progress messages.\n */\n quietPrepare?: boolean;\n}\n\n/**\n * Result returned after the Muon development process exits.\n */\nexport interface MuonDevResult {\n /**\n * Absolute project root used for development startup.\n */\n root: string;\n\n /**\n * Muon runtime target used for prepare.\n */\n target: string;\n\n /**\n * Directory containing muon-core files used as the staging source.\n */\n muonPath: string;\n\n /**\n * Directory or cached archive containing CEF files used as the staging source.\n */\n cefPath: string;\n\n /**\n * Directory containing the prepared Muon runtime.\n */\n stagePath: string;\n\n /**\n * Prepared muon-core executable path.\n */\n muonExecutablePath: string;\n\n /**\n * Project config path passed before the generated development override.\n */\n projectConfigPath?: string;\n\n /**\n * Generated development override config path.\n */\n overrideConfigPath: string;\n\n /**\n * Effective local asset source path.\n */\n assetSourcePath: string;\n\n /**\n * Exit code returned by the Muon process.\n */\n exitCode: number;\n}\n\nconst defaultProjectConfigFileNames = [\"muon.json5\", \"muon.jsonc\", \"muon.json\"];\n\nconst resolveFromRoot = (root: string, path: string): string =>\n isAbsolute(path) ? path : resolve(root, path);\n\nconst isJsonObject = (value: unknown): value is JsonObject =>\n typeof value === \"object\" && value !== null && !Array.isArray(value);\n\nconst getErrorMessage = (error: unknown): string =>\n error instanceof Error ? error.message : String(error);\n\nconst fileExists = async (path: string): Promise<boolean> => {\n try {\n const stats = await stat(path);\n return stats.isFile();\n } catch {\n return false;\n }\n};\n\nconst directoryExists = async (path: string): Promise<boolean> => {\n try {\n const stats = await stat(path);\n return stats.isDirectory();\n } catch {\n return false;\n }\n};\n\nconst isMissingVitePackageError = (error: unknown): boolean => {\n const candidate = error as { code?: unknown; message?: unknown };\n return (\n candidate.code === \"ERR_MODULE_NOT_FOUND\" &&\n typeof candidate.message === \"string\" &&\n candidate.message.includes(\"vite\")\n );\n};\n\nconst loadViteMuonOptions = async (\n cwd: string,\n): Promise<LoadedViteMuonOptions> => {\n let vite: typeof import(\"vite\");\n try {\n vite = await import(\"vite\");\n } catch (error) {\n if (isMissingVitePackageError(error)) {\n return {\n root: resolve(cwd),\n pluginOptions: undefined,\n };\n }\n throw error;\n }\n\n const loaded = await vite.loadConfigFromFile(\n {\n command: \"serve\",\n mode: \"development\",\n isPreview: false,\n isSsrBuild: false,\n },\n undefined,\n cwd,\n \"silent\",\n );\n if (loaded === null) {\n return {\n root: resolve(cwd),\n pluginOptions: undefined,\n };\n }\n\n const config = loaded.config as UserConfig;\n const root =\n typeof config.root === \"string\" ? resolve(cwd, config.root) : resolve(cwd);\n const plugins = await flattenVitePluginOptions(config.plugins);\n const muonPlugins = plugins\n .map((plugin) => getMuonVitePluginOptions(plugin))\n .filter(\n (pluginOptions): pluginOptions is MuonVitePluginOptions =>\n pluginOptions !== undefined,\n );\n\n if (muonPlugins.length > 1) {\n throw new Error(\n \"Multiple muon() plugin definitions were found in vite.config.*.\",\n );\n }\n\n return {\n root,\n pluginOptions: muonPlugins[0],\n };\n};\n\nconst resolveProjectConfigPath = async (\n root: string,\n configPath: string | undefined,\n): Promise<string | undefined> => {\n if (configPath !== undefined) {\n const resolvedPath = resolveFromRoot(root, configPath);\n if (!(await fileExists(resolvedPath))) {\n throw new Error(`Muon config file does not exist: ${resolvedPath}`);\n }\n return resolvedPath;\n }\n\n for (const fileName of defaultProjectConfigFileNames) {\n const candidatePath = join(root, fileName);\n if (await fileExists(candidatePath)) {\n return candidatePath;\n }\n }\n\n return undefined;\n};\n\nconst readJsonObjectFile = async (\n filePath: string,\n label: string,\n): Promise<JsonObject> => {\n let content: string;\n try {\n content = await readFile(filePath, \"utf8\");\n } catch (error) {\n throw new Error(\n `${label} could not be read: ${filePath}: ${getErrorMessage(error)}`,\n );\n }\n\n let parsed: unknown;\n try {\n parsed = parse(content);\n } catch (error) {\n throw new Error(\n `${label} could not be parsed: ${filePath}: ${getErrorMessage(error)}`,\n );\n }\n\n if (!isJsonObject(parsed)) {\n throw new Error(`${label} must contain a JSON object: ${filePath}`);\n }\n\n return parsed;\n};\n\nconst resolveProjectConfig = async (\n root: string,\n configPath: string | undefined,\n): Promise<ProjectConfigResolution> => {\n const resolvedConfigPath = await resolveProjectConfigPath(root, configPath);\n if (resolvedConfigPath === undefined) {\n return {\n configPath: undefined,\n config: undefined,\n };\n }\n\n return {\n configPath: resolvedConfigPath,\n config: await readJsonObjectFile(resolvedConfigPath, \"muon config\"),\n };\n};\n\nconst readConfigAssetSourcePath = (\n config: JsonObject | undefined,\n): string | undefined => {\n if (config === undefined) {\n return undefined;\n }\n\n const asset = config.asset;\n if (asset === undefined) {\n return undefined;\n }\n if (!isJsonObject(asset)) {\n throw new Error(\"muon config asset must be an object when present.\");\n }\n\n const sourcePath = asset.sourcePath;\n if (sourcePath === undefined) {\n return undefined;\n }\n if (typeof sourcePath !== \"string\") {\n throw new Error(\"muon config asset.sourcePath must be a string.\");\n }\n if (sourcePath.trim().length === 0) {\n throw new Error(\"muon config asset.sourcePath must not be empty.\");\n }\n return sourcePath;\n};\n\nconst assertDevelopmentAssetDirectory = async (\n assetSourcePath: string,\n): Promise<void> => {\n if (await directoryExists(assetSourcePath)) {\n return;\n }\n\n try {\n await access(assetSourcePath, constants.F_OK);\n } catch {\n throw new Error(`Muon dev asset source does not exist: ${assetSourcePath}`);\n }\n\n throw new Error(\n `Muon dev asset source must be a directory: ${assetSourcePath}`,\n );\n};\n\nconst resolveAssetSource = async (\n root: string,\n assetSourcePath: string | undefined,\n projectConfig: ProjectConfigResolution,\n): Promise<{\n assetSourcePath: string;\n overrideAssetSourcePath: string | undefined;\n}> => {\n const configuredAssetSourcePath = readConfigAssetSourcePath(\n projectConfig.config,\n );\n if (assetSourcePath !== undefined) {\n const resolvedPath = resolveFromRoot(root, assetSourcePath);\n await assertDevelopmentAssetDirectory(resolvedPath);\n return {\n assetSourcePath: resolvedPath,\n overrideAssetSourcePath: resolvedPath,\n };\n }\n\n if (\n configuredAssetSourcePath !== undefined &&\n projectConfig.configPath !== undefined\n ) {\n return {\n assetSourcePath: resolve(\n dirname(projectConfig.configPath),\n configuredAssetSourcePath,\n ),\n overrideAssetSourcePath: undefined,\n };\n }\n\n const defaultAssetSourcePath = resolve(root, \"assets\");\n await assertDevelopmentAssetDirectory(defaultAssetSourcePath);\n return {\n assetSourcePath: defaultAssetSourcePath,\n overrideAssetSourcePath: defaultAssetSourcePath,\n };\n};\n\nconst createMuonDevOverrideConfig = (\n assetSourcePath: string | undefined,\n enableDebugger: boolean,\n): MuonDevOverrideConfig => ({\n ...(assetSourcePath === undefined\n ? {}\n : {\n asset: {\n sourcePath: assetSourcePath,\n },\n }),\n ...(enableDebugger\n ? {\n cdp: {\n enable: true,\n },\n browser: {\n keybind: {\n devtools: \"f12\",\n recycle: \"ctrl+f12\",\n },\n },\n }\n : {}),\n});\n\nconst writeMuonDevOverrideConfig = async (\n overrideConfigPath: string,\n overrideConfig: MuonDevOverrideConfig,\n): Promise<void> => {\n await mkdir(dirname(overrideConfigPath), { recursive: true });\n await writeFile(\n overrideConfigPath,\n `${JSON.stringify(overrideConfig, null, 2)}\\n`,\n );\n};\n\nconst runMuonExecutable = async (\n muonExecutablePath: string,\n configPaths: readonly string[],\n environment: NodeJS.ProcessEnv,\n): Promise<number> => {\n const args = configPaths.flatMap((configPath) => [\"-c\", configPath]);\n let exitCode = 0;\n do {\n const child = spawn(muonExecutablePath, args, {\n cwd: dirname(muonExecutablePath),\n env: environment,\n stdio: [\"ignore\", \"inherit\", \"inherit\"],\n });\n\n exitCode = await new Promise<number>((resolvePromise, reject) => {\n child.once(\"error\", reject);\n child.once(\"close\", (code) => {\n resolvePromise(code ?? 1);\n });\n });\n } while (exitCode === muonRecycleExitCode);\n return exitCode;\n};\n\n/**\n * Launches Muon directly against local development assets.\n *\n * @param options Development startup options.\n * @returns Development startup result after the Muon process exits.\n */\nexport const runMuonDev = async (\n options: MuonDevOptions = {},\n): Promise<MuonDevResult> => {\n const cwd = resolve(options.root ?? process.cwd());\n const loadedViteOptions = await loadViteMuonOptions(cwd);\n const root = loadedViteOptions.root;\n const pluginOptions = loadedViteOptions.pluginOptions;\n const platform = options.platform ?? process.platform;\n const architecture = options.architecture ?? process.arch;\n const environment = options.environment ?? process.env;\n const target = getDefaultMuonPrepareTarget(platform, architecture);\n const muonPath = resolveMuonRuntimePath({\n root,\n target,\n muonPath: options.muonPath ?? pluginOptions?.muonPath,\n });\n const cefPath =\n options.cefPath !== undefined\n ? resolveFromRoot(root, options.cefPath)\n : pluginOptions?.cefPath === undefined\n ? undefined\n : resolveFromRoot(root, pluginOptions.cefPath);\n const stagePath =\n options.stagePath !== undefined\n ? resolveFromRoot(root, options.stagePath)\n : pluginOptions?.stagePath === undefined\n ? resolve(root, \".muon\", target)\n : resolveFromRoot(root, pluginOptions.stagePath);\n const enableDebugger =\n options.enableDebugger ?? pluginOptions?.enableDebugger ?? true;\n const projectConfig = await resolveProjectConfig(root, options.configPath);\n const asset = await resolveAssetSource(\n root,\n options.assetSourcePath,\n projectConfig,\n );\n const overrideConfigPath = join(root, \".muon\", \"dev\", \"muon.dev.json\");\n\n await ensureMuonGitignoreEntry(root);\n\n const preparedRuntime = await runMuonPrepare({\n muonPath,\n cefPath,\n stageDir: stagePath,\n target,\n cacheDir: environment.MUON_CACHE_DIR,\n force: false,\n quiet: options.quietPrepare === true,\n prepareExecutablePath: undefined,\n environment,\n cwd: root,\n });\n if (preparedRuntime.stagePath === undefined) {\n throw new Error(\"muon-prepare did not return a staged runtime path.\");\n }\n\n await writeMuonDevOverrideConfig(\n overrideConfigPath,\n createMuonDevOverrideConfig(asset.overrideAssetSourcePath, enableDebugger),\n );\n const muonExecutablePath = getMuonExecutablePath(\n preparedRuntime.stagePath,\n platform,\n );\n const configPaths = [\n ...(projectConfig.configPath === undefined\n ? []\n : [projectConfig.configPath]),\n overrideConfigPath,\n ];\n const exitCode = await runMuonExecutable(\n muonExecutablePath,\n configPaths,\n environment,\n );\n\n return {\n root,\n target,\n muonPath: preparedRuntime.muonPath,\n cefPath: preparedRuntime.cefPath,\n stagePath: preparedRuntime.stagePath,\n muonExecutablePath,\n ...(projectConfig.configPath === undefined\n ? {}\n : { projectConfigPath: projectConfig.configPath }),\n overrideConfigPath,\n assetSourcePath: asset.assetSourcePath,\n exitCode,\n };\n};\n","// muon - Multi-platform GUI application framework that uses CEF as its backend\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/muon\n\nimport { spawn } from \"node:child_process\";\nimport { type Stats } from \"node:fs\";\nimport {\n chmod,\n cp,\n mkdir,\n readFile,\n readdir,\n rm,\n stat,\n writeFile,\n} from \"node:fs/promises\";\nimport {\n basename,\n dirname,\n isAbsolute,\n join,\n relative,\n resolve,\n sep,\n} from \"node:path\";\n\nimport AdmZip from \"adm-zip\";\nimport { parse } from \"json5\";\nimport type { InlineConfig, UserConfig } from \"vite\";\n\nimport {\n buildMuonApp,\n type MuonBuildOptions,\n type MuonBuildResult,\n type MuonBuildTarget,\n type MuonBuildTargetResult,\n} from \"./build.js\";\nimport {\n flattenVitePluginOptions,\n getMuonVitePluginOptions,\n} from \"./vite-options.js\";\nimport type { MuonViteBuildOptions, MuonVitePluginOptions } from \"./vite.js\";\nimport { getMuonTargetDescriptor } from \"./targets.js\";\n\nconst supportedPackTypes = [\"zip\", \"deb\", \"nsis\"] as const;\nconst defaultArtifactsDirectory = \"artifacts\";\nconst defaultPackageBuildDirectory = \".muon/pack\";\nconst suppressViteMuonBuildEnvironmentKey = \"MUON_SUPPRESS_VITE_MUON_BUILD\";\n\ntype JsonObject = Record<string, unknown>;\n\n/**\n * Muon package output type.\n */\nexport type MuonPackType = (typeof supportedPackTypes)[number];\n\n/**\n * Options for creating redistributable Muon package artifacts.\n */\nexport interface MuonPackOptions {\n /**\n * Project root.\n */\n root?: string;\n /**\n * Package artifact types to generate.\n */\n types: readonly string[];\n /**\n * Public target identifiers to build.\n */\n targets?: readonly string[];\n /**\n * Build every supported target.\n */\n allTargets?: boolean;\n /**\n * Muon config path to embed.\n */\n configPath?: string;\n /**\n * File name used for the app launcher.\n */\n appName?: string;\n /**\n * Stable application identifier used for portable runtime state.\n */\n appId?: string;\n /**\n * Directory containing package runtime/ and native/ folders.\n */\n packageDirectory?: string;\n /**\n * Directory that receives generated package artifacts.\n */\n artifactsDir?: string;\n /**\n * Package name override.\n */\n packageName?: string;\n /**\n * Package version override.\n */\n packageVersion?: string;\n /**\n * Package description override.\n */\n description?: string;\n /**\n * Package author/maintainer override.\n */\n author?: string;\n /**\n * Environment used for child processes.\n */\n environment?: NodeJS.ProcessEnv;\n}\n\n/**\n * Generated package artifact metadata.\n */\nexport interface MuonPackArtifact {\n /**\n * Package artifact type.\n */\n type: MuonPackType;\n /**\n * Muon target packaged in this artifact.\n */\n target: MuonBuildTarget;\n /**\n * Generated artifact path.\n */\n path: string;\n}\n\n/**\n * Result of a Muon package build.\n */\nexport interface MuonPackResult {\n /**\n * Absolute project root used for packaging.\n */\n root: string;\n /**\n * Debian/installer safe package name.\n */\n packageName: string;\n /**\n * Package version.\n */\n version: string;\n /**\n * Launcher file base name.\n */\n appName: string;\n /**\n * Stable app identifier embedded in launcher/runtime config.\n */\n appId: string;\n /**\n * Muon dist build result.\n */\n build: MuonBuildResult;\n /**\n * Target dist directories used as package inputs.\n */\n targets: MuonBuildTargetResult[];\n /**\n * Generated package artifacts.\n */\n artifacts: MuonPackArtifact[];\n}\n\ninterface LoadedViteMuonOptions {\n root: string;\n pluginOptions: MuonVitePluginOptions | undefined;\n}\n\ninterface PackageMetadata {\n packageName: string;\n version: string;\n description: string;\n author: string;\n}\n\nconst isJsonObject = (value: unknown): value is JsonObject =>\n typeof value === \"object\" && value !== null && !Array.isArray(value);\n\nconst isMissingVitePackageError = (error: unknown): boolean => {\n const candidate = error as { code?: unknown; message?: unknown };\n return (\n candidate.code === \"ERR_MODULE_NOT_FOUND\" &&\n typeof candidate.message === \"string\" &&\n candidate.message.includes(\"vite\")\n );\n};\n\nconst loadViteMuonOptions = async (\n cwd: string,\n): Promise<LoadedViteMuonOptions> => {\n let vite: typeof import(\"vite\");\n try {\n vite = await import(\"vite\");\n } catch (error) {\n if (isMissingVitePackageError(error)) {\n return {\n root: resolve(cwd),\n pluginOptions: undefined,\n };\n }\n throw error;\n }\n\n const loaded = await vite.loadConfigFromFile(\n {\n command: \"build\",\n mode: \"production\",\n isPreview: false,\n isSsrBuild: false,\n },\n undefined,\n cwd,\n \"silent\",\n );\n if (loaded === null) {\n return {\n root: resolve(cwd),\n pluginOptions: undefined,\n };\n }\n\n const config = loaded.config as UserConfig;\n const root =\n typeof config.root === \"string\" ? resolve(cwd, config.root) : resolve(cwd);\n const plugins = await flattenVitePluginOptions(config.plugins);\n const muonPlugins = plugins\n .map((plugin) => getMuonVitePluginOptions(plugin))\n .filter(\n (pluginOptions): pluginOptions is MuonVitePluginOptions =>\n pluginOptions !== undefined,\n );\n\n if (muonPlugins.length > 1) {\n throw new Error(\n \"Multiple muon() plugin definitions were found in vite.config.*.\",\n );\n }\n\n return {\n root,\n pluginOptions: muonPlugins[0],\n };\n};\n\nconst readJsonObjectFile = async (path: string): Promise<JsonObject> => {\n const parsed = parse(await readFile(path, \"utf8\"));\n if (!isJsonObject(parsed)) {\n throw new Error(`JSON file must contain an object: ${path}`);\n }\n return parsed;\n};\n\nconst readPackageJson = async (root: string): Promise<JsonObject> => {\n return await readJsonObjectFile(join(root, \"package.json\"));\n};\n\nconst sanitizePackageName = (value: string): string => {\n const unscoped = value.startsWith(\"@\")\n ? value.slice(value.indexOf(\"/\") + 1)\n : value;\n const sanitized = unscoped\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9+.-]+/g, \"-\")\n .replace(/^[.+-]+/g, \"\")\n .replace(/[.+-]+$/g, \"\");\n return sanitized.length > 0 ? sanitized : \"muon-app\";\n};\n\nconst stringifyAuthor = (value: unknown): string | undefined => {\n if (typeof value === \"string\") {\n return value;\n }\n if (!isJsonObject(value) || typeof value.name !== \"string\") {\n return undefined;\n }\n return value.email === undefined || typeof value.email !== \"string\"\n ? value.name\n : `${value.name} <${value.email}>`;\n};\n\nconst resolveMetadata = (\n packageJson: JsonObject,\n options: MuonPackOptions,\n): PackageMetadata => {\n const packageNameSource =\n options.packageName ??\n (typeof packageJson.name === \"string\" ? packageJson.name : undefined);\n if (packageNameSource === undefined || packageNameSource.trim() === \"\") {\n throw new Error(\"package.json name is required for muon pack.\");\n }\n const version =\n options.packageVersion ??\n (typeof packageJson.version === \"string\" ? packageJson.version : undefined);\n if (version === undefined || version.trim() === \"\") {\n throw new Error(\"package.json version is required for muon pack.\");\n }\n const description =\n options.description ??\n (typeof packageJson.description === \"string\"\n ? packageJson.description\n : \"Muon application\");\n const author =\n options.author ?? stringifyAuthor(packageJson.author) ?? \"Unknown\";\n return {\n packageName: sanitizePackageName(packageNameSource),\n version,\n description,\n author,\n };\n};\n\nconst normalizePackTypes = (types: readonly string[]): MuonPackType[] => {\n const normalized = types\n .flatMap((value) => value.split(\",\"))\n .map((value) => value.trim().toLowerCase())\n .filter((value) => value.length > 0);\n if (normalized.length === 0) {\n throw new Error(\"Specify at least one package type with --type.\");\n }\n for (const type of normalized) {\n if (!supportedPackTypes.includes(type as MuonPackType)) {\n throw new Error(`Unsupported muon pack type: ${type}`);\n }\n }\n return [...new Set(normalized)] as MuonPackType[];\n};\n\nconst getPluginBuildOptions = (\n pluginOptions: MuonVitePluginOptions | undefined,\n): MuonViteBuildOptions => {\n return typeof pluginOptions?.build === \"object\" ? pluginOptions.build : {};\n};\n\nconst resolveBuildOutputDirectory = async (root: string): Promise<string> => {\n const vite = await import(\"vite\");\n const resolved = await vite.resolveConfig(\n { root } satisfies InlineConfig,\n \"build\",\n \"production\",\n \"production\",\n );\n return isAbsolute(resolved.build.outDir)\n ? resolved.build.outDir\n : resolve(resolved.root, resolved.build.outDir);\n};\n\nconst runViteBuild = async (\n root: string,\n _environment: NodeJS.ProcessEnv,\n): Promise<void> => {\n const vite = await import(\"vite\");\n const previous = process.env[suppressViteMuonBuildEnvironmentKey];\n process.env[suppressViteMuonBuildEnvironmentKey] = \"1\";\n try {\n await vite.build({ root } satisfies InlineConfig);\n } finally {\n if (previous === undefined) {\n delete process.env[suppressViteMuonBuildEnvironmentKey];\n } else {\n process.env[suppressViteMuonBuildEnvironmentKey] = previous;\n }\n }\n};\n\nconst createBuildOptions = (\n root: string,\n assetSourcePath: string,\n pluginBuildOptions: MuonViteBuildOptions,\n options: MuonPackOptions,\n): MuonBuildOptions => {\n const buildOptions: MuonBuildOptions = {\n root,\n assetSourcePath,\n assetPrefix: \"main\",\n };\n Object.assign(buildOptions, pluginBuildOptions);\n if (options.targets !== undefined && options.targets.length > 0) {\n buildOptions.targets = options.targets;\n buildOptions.allTargets = false;\n } else if (options.allTargets !== undefined) {\n buildOptions.allTargets = options.allTargets;\n }\n if (options.configPath !== undefined) {\n buildOptions.configPath = options.configPath;\n }\n if (options.appName !== undefined) {\n buildOptions.appName = options.appName;\n }\n if (options.appId !== undefined) {\n buildOptions.appId = options.appId;\n }\n if (options.packageDirectory !== undefined) {\n buildOptions.packageDirectory = options.packageDirectory;\n }\n return buildOptions;\n};\n\nconst assertPackTypeSupportsTarget = (\n type: MuonPackType,\n target: MuonBuildTarget,\n): void => {\n const descriptor = getMuonTargetDescriptor(target);\n if (type === \"deb\" && descriptor.os !== \"linux\") {\n throw new Error(\"deb packaging supports only Linux targets.\");\n }\n if (type === \"nsis\" && descriptor.os !== \"windows\") {\n throw new Error(\"nsis packaging supports only Windows targets.\");\n }\n};\n\nconst runTool = async (\n executable: string,\n args: readonly string[],\n cwd: string,\n environment: NodeJS.ProcessEnv,\n): Promise<void> => {\n const child = spawn(executable, [...args], {\n cwd,\n env: environment,\n stdio: [\"ignore\", \"pipe\", \"pipe\"],\n });\n let stderr = \"\";\n child.stderr.setEncoding(\"utf8\");\n child.stderr.on(\"data\", (chunk: string) => {\n stderr += chunk;\n });\n const exitCode = await new Promise<number>((resolvePromise, reject) => {\n child.once(\"error\", reject);\n child.once(\"close\", (code) => {\n resolvePromise(code ?? 1);\n });\n });\n if (exitCode !== 0) {\n throw new Error(\n `${executable} failed with exit code ${exitCode}: ${stderr.trim()}`,\n );\n }\n};\n\nconst statOrUndefined = async (path: string): Promise<Stats | undefined> => {\n try {\n return await stat(path);\n } catch {\n return undefined;\n }\n};\n\nconst addDirectoryToZip = async (\n zip: AdmZip,\n directory: string,\n entryRoot: string,\n): Promise<void> => {\n const walk = async (currentDirectory: string): Promise<void> => {\n const entries = await readdir(currentDirectory, { withFileTypes: true });\n entries.sort((left, right) => left.name.localeCompare(right.name));\n for (const entry of entries) {\n const path = join(currentDirectory, entry.name);\n if (entry.isDirectory()) {\n await walk(path);\n } else if (entry.isFile()) {\n const stats = await stat(path);\n const relativePath = relative(directory, path).split(sep).join(\"/\");\n zip.addFile(\n `${entryRoot}/${relativePath}`,\n await readFile(path),\n undefined,\n stats.mode << 16,\n );\n }\n }\n };\n await walk(directory);\n};\n\nconst packageZip = async (\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n artifactsRoot: string,\n): Promise<MuonPackArtifact> => {\n const zip = new AdmZip();\n await addDirectoryToZip(\n zip,\n target.outputPath,\n target.distributionDirectoryName,\n );\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${target.target}.zip`,\n );\n await mkdir(dirname(outputPath), { recursive: true });\n await writeFile(outputPath, zip.toBuffer());\n return {\n type: \"zip\",\n target: target.target,\n path: outputPath,\n };\n};\n\nconst packageDeb = async (\n root: string,\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n artifactsRoot: string,\n packageBuildRoot: string,\n environment: NodeJS.ProcessEnv,\n): Promise<MuonPackArtifact> => {\n const descriptor = getMuonTargetDescriptor(target.target);\n if (descriptor.os !== \"linux\") {\n throw new Error(`Unsupported deb target: ${target.target}`);\n }\n const architecture = descriptor.arch;\n const packageRoot = join(\n packageBuildRoot,\n \"deb\",\n `${metadata.packageName}-${target.target}`,\n );\n await rm(packageRoot, { recursive: true, force: true });\n const installRoot = join(packageRoot, \"usr\", \"lib\", metadata.packageName);\n const installedDist = join(installRoot, target.distributionDirectoryName);\n await mkdir(installedDist, { recursive: true });\n await cp(target.outputPath, installedDist, { recursive: true });\n const binPath = join(packageRoot, \"usr\", \"bin\", metadata.packageName);\n const launcherName = basename(target.launcherPath);\n await mkdir(dirname(binPath), { recursive: true });\n await writeFile(\n binPath,\n [\n \"#!/usr/bin/env bash\",\n \"set -euo pipefail\",\n `exec ${JSON.stringify(`/usr/lib/${metadata.packageName}/${target.distributionDirectoryName}/${launcherName}`)} \"$@\"`,\n \"\",\n ].join(\"\\n\"),\n );\n await chmod(binPath, 0o755);\n const controlPath = join(packageRoot, \"DEBIAN\", \"control\");\n await mkdir(dirname(controlPath), { recursive: true });\n await writeFile(\n controlPath,\n [\n `Package: ${metadata.packageName}`,\n `Version: ${metadata.version}`,\n `Architecture: ${architecture}`,\n `Maintainer: ${metadata.author}`,\n `Description: ${metadata.description}`,\n \"\",\n ].join(\"\\n\"),\n );\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${architecture}.deb`,\n );\n await mkdir(dirname(outputPath), { recursive: true });\n await runTool(\n \"dpkg-deb\",\n [\"--build\", packageRoot, outputPath],\n root,\n environment,\n );\n return {\n type: \"deb\",\n target: target.target,\n path: outputPath,\n };\n};\n\nconst escapeNsis = (value: string): string =>\n value.replaceAll(\"\\\\\", \"\\\\\\\\\").replaceAll('\"', '$\\\\\"');\n\nconst packageNsis = async (\n root: string,\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n artifactsRoot: string,\n packageBuildRoot: string,\n environment: NodeJS.ProcessEnv,\n): Promise<MuonPackArtifact> => {\n const descriptor = getMuonTargetDescriptor(target.target);\n if (descriptor.os !== \"windows\") {\n throw new Error(`Unsupported nsis target: ${target.target}`);\n }\n const scriptPath = join(\n packageBuildRoot,\n \"nsis\",\n `${metadata.packageName}-${target.target}.nsi`,\n );\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${descriptor.arch}-setup.exe`,\n );\n await mkdir(dirname(scriptPath), { recursive: true });\n await mkdir(dirname(outputPath), { recursive: true });\n await writeFile(\n scriptPath,\n [\n \"Unicode true\",\n `Name \"${escapeNsis(metadata.packageName)}\"`,\n `OutFile \"${escapeNsis(outputPath)}\"`,\n `InstallDir \"$LOCALAPPDATA\\\\Programs\\\\${escapeNsis(metadata.packageName)}\"`,\n \"RequestExecutionLevel user\",\n \"Section\",\n ' SetOutPath \"$INSTDIR\"',\n ` File /r \"${escapeNsis(target.outputPath)}\\\\*\"`,\n ` CreateShortCut \"$SMPROGRAMS\\\\${escapeNsis(metadata.packageName)}.lnk\" \"$INSTDIR\\\\${escapeNsis(basename(target.launcherPath))}\"`,\n \"SectionEnd\",\n \"\",\n ].join(\"\\n\"),\n );\n await runTool(\"makensis\", [scriptPath], root, environment);\n if ((await statOrUndefined(outputPath)) === undefined) {\n throw new Error(`makensis did not create installer: ${outputPath}`);\n }\n return {\n type: \"nsis\",\n target: target.target,\n path: outputPath,\n };\n};\n\n/**\n * Builds a Vite app, creates Muon dist directories, and packages them.\n *\n * @param options Pack options.\n * @returns Generated package artifacts.\n */\nexport const packMuonApp = async (\n options: MuonPackOptions,\n): Promise<MuonPackResult> => {\n const cwd = resolve(options.root ?? process.cwd());\n const environment = options.environment ?? process.env;\n const loadedOptions = await loadViteMuonOptions(cwd);\n const root = loadedOptions.root;\n const metadata = resolveMetadata(await readPackageJson(root), options);\n const artifactsRoot = resolve(\n root,\n options.artifactsDir ?? defaultArtifactsDirectory,\n );\n const packageBuildRoot = resolve(root, defaultPackageBuildDirectory);\n const types = normalizePackTypes(options.types);\n const viteOutputDirectory = await resolveBuildOutputDirectory(root);\n await runViteBuild(root, environment);\n const build = await buildMuonApp(\n createBuildOptions(\n root,\n viteOutputDirectory,\n getPluginBuildOptions(loadedOptions.pluginOptions),\n options,\n ),\n );\n for (const type of types) {\n for (const target of build.targets) {\n assertPackTypeSupportsTarget(type, target.target);\n }\n }\n await rm(packageBuildRoot, { recursive: true, force: true });\n await rm(join(artifactsRoot, \"deb\"), { recursive: true, force: true });\n await rm(join(artifactsRoot, \"nsis\"), { recursive: true, force: true });\n await mkdir(artifactsRoot, { recursive: true });\n const artifacts: MuonPackArtifact[] = [];\n for (const target of build.targets) {\n for (const type of types) {\n if (type === \"zip\") {\n artifacts.push(await packageZip(target, metadata, artifactsRoot));\n } else if (type === \"deb\") {\n artifacts.push(\n await packageDeb(\n root,\n target,\n metadata,\n artifactsRoot,\n packageBuildRoot,\n environment,\n ),\n );\n } else {\n artifacts.push(\n await packageNsis(\n root,\n target,\n metadata,\n artifactsRoot,\n packageBuildRoot,\n environment,\n ),\n );\n }\n }\n }\n return {\n root,\n packageName: metadata.packageName,\n version: metadata.version,\n appName: build.appName,\n appId: build.appId,\n build,\n targets: build.targets,\n artifacts,\n };\n};\n\nexport const muonPackSuppressViteBuildEnvironmentKey =\n suppressViteMuonBuildEnvironmentKey;\n","// @ts-nocheck\n// This file is auto-generated by screw-up plugin\n// Do not edit manually\n\nexport const name = \"muon-ui\";\nexport const version = \"0.7.0\";\nexport const description = \"A multi-platform GUI application framework that uses CEF as its backend\";\nexport const author = \"Kouji Matsui (@kekyo@mi.kekyo.net)\";\nexport const license = \"MIT\";\nexport const repository_url = \"https://github.com/kekyo/muon-ui.git\";\nexport const git_commit_hash = \"fe80718aaa617c0c0ea5c816bbe38d22bf2e8402\";\n","#!/usr/bin/env node\n// muon - Multi-platform GUI application framework that uses CEF as its backend\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/muon\n\nimport { Command } from \"commander\";\n\nimport {\n getDefaultMuonPrepareTarget,\n runMuonPrepare,\n type MuonPrepareOptions,\n} from \"./prepare.js\";\nimport { ensureMuonGitignoreEntry } from \"./gitignore.js\";\nimport {\n embedMuonConfigInBootstrapFile,\n embedMuonConfigInCoreFile,\n embedMuonConfigInRuntime,\n type EmbedMuonConfigResult,\n} from \"./embed-config.js\";\nimport { buildMuonApp, type MuonBuildOptions } from \"./build.js\";\nimport { runMuonDev, type MuonDevOptions } from \"./dev.js\";\nimport { packMuonApp, type MuonPackOptions } from \"./pack.js\";\nimport { git_commit_hash, version } from \"./generated/packageMetadata.js\";\n\ninterface PrepareCommandOptions {\n muonPath: string | undefined;\n cefPath: string | undefined;\n stageDir: string | undefined;\n target: string | undefined;\n cacheDir: string | undefined;\n force: boolean | undefined;\n quiet: boolean | undefined;\n json: boolean | undefined;\n}\n\ninterface EmbedConfigCommandOptions {\n runtimePath: string | undefined;\n corePath: string | undefined;\n bootstrapPath: string | undefined;\n config: string | undefined;\n outputRuntimePath: string | undefined;\n output: string | undefined;\n outputBootstrap: string | undefined;\n json: boolean | undefined;\n}\n\ninterface BuildCommandOptions {\n target: string[];\n all: boolean | undefined;\n assets: string | undefined;\n config: string | undefined;\n outDir: string | undefined;\n name: string | undefined;\n appId: string | undefined;\n json: boolean | undefined;\n}\n\ninterface PackCommandOptions {\n type: string[];\n target: string[];\n all: boolean | undefined;\n config: string | undefined;\n name: string | undefined;\n appId: string | undefined;\n packageDirectory: string | undefined;\n artifactsDir: string | undefined;\n packageName: string | undefined;\n packageVersion: string | undefined;\n description: string | undefined;\n author: string | undefined;\n json: boolean | undefined;\n}\n\ninterface DevCommandOptions {\n muonPath: string | undefined;\n cefPath: string | undefined;\n stageDir: string | undefined;\n config: string | undefined;\n assets: string | undefined;\n debugger: boolean | undefined;\n json: boolean | undefined;\n}\n\nconst readTargetValues = (value: string): string[] => {\n return value\n .split(\",\")\n .map((value) => value.trim())\n .filter((value) => value.length > 0);\n};\n\nconst appendTargetValues = (value: string, previous: string[]): string[] => {\n return [...previous, ...readTargetValues(value)];\n};\n\nconst appendPackTypeValues = (value: string, previous: string[]): string[] => {\n return [...previous, ...readTargetValues(value)];\n};\n\nconst validateEmbedConfigOptions = (\n options: EmbedConfigCommandOptions,\n): void => {\n if (options.runtimePath !== undefined && options.corePath !== undefined) {\n throw new Error(\"Specify at most one of --runtime-path or --core-path.\");\n }\n if (\n options.runtimePath === undefined &&\n options.corePath === undefined &&\n options.bootstrapPath === undefined\n ) {\n throw new Error(\n \"Specify at least one of --runtime-path, --core-path, or --bootstrap-path.\",\n );\n }\n if (\n options.corePath !== undefined &&\n options.outputRuntimePath !== undefined\n ) {\n throw new Error(\"--output-runtime-path requires --runtime-path.\");\n }\n if (options.runtimePath !== undefined && options.output !== undefined) {\n throw new Error(\"--output requires --core-path.\");\n }\n if (\n options.bootstrapPath === undefined &&\n options.outputBootstrap !== undefined\n ) {\n throw new Error(\"--output-bootstrap requires --bootstrap-path.\");\n }\n};\n\nconst runBuildCommand = async (\n commandOptions: BuildCommandOptions,\n): Promise<void> => {\n const targets = commandOptions.target;\n if (commandOptions.all === true && targets.length > 0) {\n throw new Error(\"Specify either --all or --target, not both.\");\n }\n\n const buildOptions: MuonBuildOptions = {\n root: process.cwd(),\n allTargets: commandOptions.all === true,\n };\n\n if (targets.length > 0) {\n buildOptions.targets = targets;\n }\n if (commandOptions.assets !== undefined) {\n buildOptions.assetSourcePath = commandOptions.assets;\n }\n if (commandOptions.config !== undefined) {\n buildOptions.configPath = commandOptions.config;\n }\n if (commandOptions.outDir !== undefined) {\n buildOptions.outputRoot = commandOptions.outDir;\n }\n if (commandOptions.name !== undefined) {\n buildOptions.appName = commandOptions.name;\n }\n if (commandOptions.appId !== undefined) {\n buildOptions.appId = commandOptions.appId;\n }\n\n const result = await buildMuonApp(buildOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n for (const target of result.targets) {\n console.log(target.outputPath);\n }\n }\n};\n\nconst runPackCommand = async (\n commandOptions: PackCommandOptions,\n): Promise<void> => {\n const targets = commandOptions.target;\n if (commandOptions.all === true && targets.length > 0) {\n throw new Error(\"Specify either --all or --target, not both.\");\n }\n\n const packOptions: MuonPackOptions = {\n root: process.cwd(),\n types: commandOptions.type,\n environment: process.env,\n };\n if (targets.length > 0) {\n packOptions.targets = targets;\n }\n if (commandOptions.all !== undefined) {\n packOptions.allTargets = commandOptions.all;\n }\n if (commandOptions.config !== undefined) {\n packOptions.configPath = commandOptions.config;\n }\n if (commandOptions.name !== undefined) {\n packOptions.appName = commandOptions.name;\n }\n if (commandOptions.appId !== undefined) {\n packOptions.appId = commandOptions.appId;\n }\n if (commandOptions.packageDirectory !== undefined) {\n packOptions.packageDirectory = commandOptions.packageDirectory;\n }\n if (commandOptions.artifactsDir !== undefined) {\n packOptions.artifactsDir = commandOptions.artifactsDir;\n }\n if (commandOptions.packageName !== undefined) {\n packOptions.packageName = commandOptions.packageName;\n }\n if (commandOptions.packageVersion !== undefined) {\n packOptions.packageVersion = commandOptions.packageVersion;\n }\n if (commandOptions.description !== undefined) {\n packOptions.description = commandOptions.description;\n }\n if (commandOptions.author !== undefined) {\n packOptions.author = commandOptions.author;\n }\n\n const result = await packMuonApp(packOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n for (const artifact of result.artifacts) {\n console.log(artifact.path);\n }\n }\n};\n\nconst runPrepareCommand = async (\n commandOptions: PrepareCommandOptions,\n): Promise<void> => {\n const prepareOptions: MuonPrepareOptions = {\n muonPath: commandOptions.muonPath ?? \"\",\n cefPath: commandOptions.cefPath,\n stageDir: commandOptions.stageDir,\n target:\n commandOptions.target ??\n getDefaultMuonPrepareTarget(process.platform, process.arch),\n cacheDir: commandOptions.cacheDir,\n force: commandOptions.force === true,\n quiet: commandOptions.quiet === true,\n prepareExecutablePath: undefined,\n environment: process.env,\n cwd: process.cwd(),\n };\n const result = await runMuonPrepare(prepareOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n console.log(result.stagePath ?? result.cefPath);\n }\n};\n\nconst runDevCommand = async (\n commandOptions: DevCommandOptions,\n command: Command,\n): Promise<void> => {\n const devOptions: MuonDevOptions = {\n root: process.cwd(),\n environment: process.env,\n quietPrepare: commandOptions.json === true,\n };\n\n if (commandOptions.muonPath !== undefined) {\n devOptions.muonPath = commandOptions.muonPath;\n }\n if (commandOptions.cefPath !== undefined) {\n devOptions.cefPath = commandOptions.cefPath;\n }\n if (commandOptions.stageDir !== undefined) {\n devOptions.stagePath = commandOptions.stageDir;\n }\n if (commandOptions.config !== undefined) {\n devOptions.configPath = commandOptions.config;\n }\n if (commandOptions.assets !== undefined) {\n devOptions.assetSourcePath = commandOptions.assets;\n }\n if (command.getOptionValueSource(\"debugger\") === \"cli\") {\n devOptions.enableDebugger = commandOptions.debugger === true;\n }\n\n const result = await runMuonDev(devOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n }\n if (result.exitCode !== 0) {\n process.exitCode = result.exitCode;\n }\n};\n\nconst runInitCommand = async (): Promise<void> => {\n const result = await ensureMuonGitignoreEntry(process.cwd());\n console.log(\n result.changed ? `Updated ${result.gitignorePath}` : result.gitignorePath,\n );\n};\n\nconst printEmbedConfigResult = (\n result: EmbedMuonConfigResult,\n json: boolean | undefined,\n): void => {\n if (json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n console.log(result.outputPath);\n }\n};\n\nconst runEmbedConfigCommand = async (\n commandOptions: EmbedConfigCommandOptions,\n): Promise<void> => {\n validateEmbedConfigOptions(commandOptions);\n const configPath = commandOptions.config ?? \"\";\n const coreResult =\n commandOptions.corePath !== undefined\n ? await embedMuonConfigInCoreFile({\n corePath: commandOptions.corePath,\n configPath,\n outputPath: commandOptions.output,\n })\n : commandOptions.runtimePath !== undefined\n ? await embedMuonConfigInRuntime({\n runtimePath: commandOptions.runtimePath,\n configPath,\n outputRuntimePath: commandOptions.outputRuntimePath,\n })\n : undefined;\n const bootstrapResult =\n commandOptions.bootstrapPath === undefined\n ? undefined\n : await embedMuonConfigInBootstrapFile({\n bootstrapPath: commandOptions.bootstrapPath,\n configPath,\n outputPath: commandOptions.outputBootstrap,\n });\n if (coreResult !== undefined && bootstrapResult !== undefined) {\n if (commandOptions.json === true) {\n console.log(\n JSON.stringify(\n {\n core: coreResult,\n bootstrap: bootstrapResult,\n },\n null,\n 2,\n ),\n );\n } else {\n console.log(`${coreResult.outputPath}\\n${bootstrapResult.outputPath}`);\n }\n return;\n }\n const result = coreResult ?? bootstrapResult;\n if (result === undefined) {\n throw new Error(\"No embed-config target was specified.\");\n }\n printEmbedConfigResult(result, commandOptions.json);\n};\n\nconst createCliCommand = (): Command => {\n const program = new Command();\n\n program\n .name(\"muon\")\n .description(\n \"Multi-platform GUI application framework that uses CEF as its backend\",\n )\n .version(`${version}-${git_commit_hash}`)\n .showSuggestionAfterError()\n .action(() => {\n program.outputHelp({ error: true });\n process.exitCode = 1;\n });\n\n program\n .command(\"build\")\n .description(\"Build CEF-free Muon app distribution directories\")\n .option(\n \"--target <target>\",\n \"public target or comma-separated public targets\",\n appendTargetValues,\n [],\n )\n .option(\"--all\", \"build all supported targets\")\n .option(\"--assets <path>\", \"asset root path\")\n .option(\"--config <path>\", \"muon config path\")\n .option(\"--out-dir <path>\", \"output root directory\")\n .option(\"--name <name>\", \"launcher file name\")\n .option(\"--app-id <id>\", \"stable application identifier\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: BuildCommandOptions) => {\n await runBuildCommand(options);\n });\n\n program\n .command(\"pack\")\n .description(\"Build and package a Muon app\")\n .requiredOption(\n \"-t, --type <type>\",\n \"package type or comma-separated package types: zip, deb, nsis\",\n appendPackTypeValues,\n [],\n )\n .option(\n \"--target <target>\",\n \"public target or comma-separated public targets\",\n appendTargetValues,\n [],\n )\n .option(\"--all\", \"build all supported targets\")\n .option(\"--config <path>\", \"muon config path\")\n .option(\"--name <name>\", \"launcher file name\")\n .option(\"--app-id <id>\", \"stable application identifier\")\n .option(\"--package-directory <path>\", \"Muon package dist directory\")\n .option(\"--artifacts-dir <path>\", \"package artifact output directory\")\n .option(\"--package-name <name>\", \"package name override\")\n .option(\"--package-version <version>\", \"package version override\")\n .option(\"--description <text>\", \"package description override\")\n .option(\"--author <text>\", \"package author override\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: PackCommandOptions) => {\n await runPackCommand(options);\n });\n\n const devCommand = program\n .command(\"dev\")\n .description(\"Launch Muon directly with local development assets\")\n .option(\"--muon-path <path>\", \"Muon runtime file root\")\n .option(\"--cef-path <path>\", \"CEF file root\")\n .option(\"--stage-dir <path>\", \"prepared runtime output directory\")\n .option(\"--config <path>\", \"muon config path\")\n .option(\"--assets <path>\", \"development asset directory\")\n .option(\"--no-debugger\", \"disable Muon debugger defaults\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: DevCommandOptions) => {\n await runDevCommand(options, devCommand);\n });\n\n program\n .command(\"init\")\n .description(\"Initialize Muon project helper files\")\n .action(async () => {\n await runInitCommand();\n });\n\n program\n .command(\"prepare\")\n .description(\"Prepare a Muon runtime with CEF files\")\n .requiredOption(\"--muon-path <path>\", \"Muon runtime file root\")\n .option(\"--cef-path <path>\", \"CEF file root\")\n .option(\"--stage-dir <path>\", \"prepared runtime output directory\")\n .option(\"--target <target>\", \"prepare target\")\n .option(\"--cache-dir <path>\", \"CEF artifact cache directory\")\n .option(\"--force\", \"rebuild an existing prepared runtime\")\n .option(\"-q, --quiet\", \"suppress native prepare progress messages\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: PrepareCommandOptions) => {\n await runPrepareCommand(options);\n });\n\n program\n .command(\"embed-config\")\n .description(\"Embed muon.json into Muon runtime files\")\n .option(\"--runtime-path <path>\", \"prepared runtime directory\")\n .option(\"--core-path <path>\", \"muon-core executable path\")\n .option(\"--bootstrap-path <path>\", \"muon-bootstrap executable path\")\n .requiredOption(\"--config <path>\", \"muon config path\")\n .option(\"--output-runtime-path <path>\", \"patched runtime output directory\")\n .option(\"--output <path>\", \"patched muon-core output path\")\n .option(\"--output-bootstrap <path>\", \"patched bootstrap output path\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: EmbedConfigCommandOptions) => {\n await runEmbedConfigCommand(options);\n });\n\n return program;\n};\n\nconst main = async (): Promise<void> => {\n try {\n await createCliCommand().parseAsync(process.argv);\n } catch (error) {\n console.error(error instanceof Error ? error.message : String(error));\n process.exitCode = 1;\n }\n};\n\nvoid main();\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cli.cjs","names":[],"sources":["../src/dev.ts","../src/pack.ts","../src/generated/packageMetadata.ts","../src/cli.ts"],"sourcesContent":["// muon - Multi-platform GUI application framework that uses CEF as its backend\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/muon\n\nimport { spawn } from \"node:child_process\";\nimport { constants } from \"node:fs\";\nimport { access, mkdir, readFile, stat, writeFile } from \"node:fs/promises\";\nimport { dirname, isAbsolute, join, resolve } from \"node:path\";\n\nimport { parse } from \"json5\";\nimport type { UserConfig } from \"vite\";\n\nimport { ensureMuonGitignoreEntry } from \"./gitignore.js\";\nimport { getDefaultMuonPrepareTarget, runMuonPrepare } from \"./prepare.js\";\nimport {\n getMuonExecutablePath,\n resolveMuonRuntimePath,\n} from \"./vite-internals.js\";\nimport {\n flattenVitePluginOptions,\n getMuonVitePluginOptions,\n} from \"./vite-options.js\";\nimport type { MuonVitePluginOptions } from \"./vite.js\";\n\nconst muonRecycleExitCode = 88;\n\ntype JsonObject = Record<string, unknown>;\n\ninterface LoadedViteMuonOptions {\n root: string;\n pluginOptions: MuonVitePluginOptions | undefined;\n}\n\ninterface ProjectConfigResolution {\n configPath: string | undefined;\n config: JsonObject | undefined;\n}\n\ninterface MuonDevOverrideConfig {\n asset?: {\n sourcePath: string;\n };\n cdp?: {\n enable: true;\n };\n browser?: {\n keybind: {\n devtools: \"f12\";\n recycle: \"ctrl+f12\";\n };\n };\n}\n\n/**\n * Options for launching Muon directly against local development assets.\n */\nexport interface MuonDevOptions {\n /**\n * Directory used as the project root.\n */\n root?: string;\n\n /**\n * Directory containing muon-core runtime files such as muon-core and plugins.\n */\n muonPath?: string;\n\n /**\n * Directory containing CEF files, or a CEF archive root with Release/Resources.\n */\n cefPath?: string;\n\n /**\n * Runtime staging directory used for development startup.\n */\n stagePath?: string;\n\n /**\n * Muon config path passed before the generated development override.\n */\n configPath?: string;\n\n /**\n * Local development asset directory.\n */\n assetSourcePath?: string;\n\n /**\n * Enable the Muon debugger defaults during development startup.\n */\n enableDebugger?: boolean;\n\n /**\n * Platform used for runtime target resolution.\n *\n * @remarks This is injectable for tests. Production code uses process.platform.\n */\n platform?: NodeJS.Platform;\n\n /**\n * Architecture used for runtime target resolution.\n *\n * @remarks This is injectable for tests. Production code uses process.arch.\n */\n architecture?: NodeJS.Architecture;\n\n /**\n * Environment used for child processes.\n */\n environment?: NodeJS.ProcessEnv;\n\n /**\n * Suppress native builder progress messages.\n */\n quietPrepare?: boolean;\n}\n\n/**\n * Result returned after the Muon development process exits.\n */\nexport interface MuonDevResult {\n /**\n * Absolute project root used for development startup.\n */\n root: string;\n\n /**\n * Muon runtime target used for prepare.\n */\n target: string;\n\n /**\n * Directory containing muon-core files used as the staging source.\n */\n muonPath: string;\n\n /**\n * Directory or cached archive containing CEF files used as the staging source.\n */\n cefPath: string;\n\n /**\n * Directory containing the prepared Muon runtime.\n */\n stagePath: string;\n\n /**\n * Prepared muon-core executable path.\n */\n muonExecutablePath: string;\n\n /**\n * Project config path passed before the generated development override.\n */\n projectConfigPath?: string;\n\n /**\n * Generated development override config path.\n */\n overrideConfigPath: string;\n\n /**\n * Effective local asset source path.\n */\n assetSourcePath: string;\n\n /**\n * Exit code returned by the Muon process.\n */\n exitCode: number;\n}\n\nconst defaultProjectConfigFileNames = [\"muon.json5\", \"muon.jsonc\", \"muon.json\"];\n\nconst resolveFromRoot = (root: string, path: string): string =>\n isAbsolute(path) ? path : resolve(root, path);\n\nconst isJsonObject = (value: unknown): value is JsonObject =>\n typeof value === \"object\" && value !== null && !Array.isArray(value);\n\nconst getErrorMessage = (error: unknown): string =>\n error instanceof Error ? error.message : String(error);\n\nconst fileExists = async (path: string): Promise<boolean> => {\n try {\n const stats = await stat(path);\n return stats.isFile();\n } catch {\n return false;\n }\n};\n\nconst directoryExists = async (path: string): Promise<boolean> => {\n try {\n const stats = await stat(path);\n return stats.isDirectory();\n } catch {\n return false;\n }\n};\n\nconst isMissingVitePackageError = (error: unknown): boolean => {\n const candidate = error as { code?: unknown; message?: unknown };\n return (\n candidate.code === \"ERR_MODULE_NOT_FOUND\" &&\n typeof candidate.message === \"string\" &&\n candidate.message.includes(\"vite\")\n );\n};\n\nconst loadViteMuonOptions = async (\n cwd: string,\n): Promise<LoadedViteMuonOptions> => {\n let vite: typeof import(\"vite\");\n try {\n vite = await import(\"vite\");\n } catch (error) {\n if (isMissingVitePackageError(error)) {\n return {\n root: resolve(cwd),\n pluginOptions: undefined,\n };\n }\n throw error;\n }\n\n const loaded = await vite.loadConfigFromFile(\n {\n command: \"serve\",\n mode: \"development\",\n isPreview: false,\n isSsrBuild: false,\n },\n undefined,\n cwd,\n \"silent\",\n );\n if (loaded === null) {\n return {\n root: resolve(cwd),\n pluginOptions: undefined,\n };\n }\n\n const config = loaded.config as UserConfig;\n const root =\n typeof config.root === \"string\" ? resolve(cwd, config.root) : resolve(cwd);\n const plugins = await flattenVitePluginOptions(config.plugins);\n const muonPlugins = plugins\n .map((plugin) => getMuonVitePluginOptions(plugin))\n .filter(\n (pluginOptions): pluginOptions is MuonVitePluginOptions =>\n pluginOptions !== undefined,\n );\n\n if (muonPlugins.length > 1) {\n throw new Error(\n \"Multiple muon() plugin definitions were found in vite.config.*.\",\n );\n }\n\n return {\n root,\n pluginOptions: muonPlugins[0],\n };\n};\n\nconst resolveProjectConfigPath = async (\n root: string,\n configPath: string | undefined,\n): Promise<string | undefined> => {\n if (configPath !== undefined) {\n const resolvedPath = resolveFromRoot(root, configPath);\n if (!(await fileExists(resolvedPath))) {\n throw new Error(`Muon config file does not exist: ${resolvedPath}`);\n }\n return resolvedPath;\n }\n\n for (const fileName of defaultProjectConfigFileNames) {\n const candidatePath = join(root, fileName);\n if (await fileExists(candidatePath)) {\n return candidatePath;\n }\n }\n\n return undefined;\n};\n\nconst readJsonObjectFile = async (\n filePath: string,\n label: string,\n): Promise<JsonObject> => {\n let content: string;\n try {\n content = await readFile(filePath, \"utf8\");\n } catch (error) {\n throw new Error(\n `${label} could not be read: ${filePath}: ${getErrorMessage(error)}`,\n );\n }\n\n let parsed: unknown;\n try {\n parsed = parse(content);\n } catch (error) {\n throw new Error(\n `${label} could not be parsed: ${filePath}: ${getErrorMessage(error)}`,\n );\n }\n\n if (!isJsonObject(parsed)) {\n throw new Error(`${label} must contain a JSON object: ${filePath}`);\n }\n\n return parsed;\n};\n\nconst resolveProjectConfig = async (\n root: string,\n configPath: string | undefined,\n): Promise<ProjectConfigResolution> => {\n const resolvedConfigPath = await resolveProjectConfigPath(root, configPath);\n if (resolvedConfigPath === undefined) {\n return {\n configPath: undefined,\n config: undefined,\n };\n }\n\n return {\n configPath: resolvedConfigPath,\n config: await readJsonObjectFile(resolvedConfigPath, \"muon config\"),\n };\n};\n\nconst readConfigAssetSourcePath = (\n config: JsonObject | undefined,\n): string | undefined => {\n if (config === undefined) {\n return undefined;\n }\n\n const asset = config.asset;\n if (asset === undefined) {\n return undefined;\n }\n if (!isJsonObject(asset)) {\n throw new Error(\"muon config asset must be an object when present.\");\n }\n\n const sourcePath = asset.sourcePath;\n if (sourcePath === undefined) {\n return undefined;\n }\n if (typeof sourcePath !== \"string\") {\n throw new Error(\"muon config asset.sourcePath must be a string.\");\n }\n if (sourcePath.trim().length === 0) {\n throw new Error(\"muon config asset.sourcePath must not be empty.\");\n }\n return sourcePath;\n};\n\nconst assertDevelopmentAssetDirectory = async (\n assetSourcePath: string,\n): Promise<void> => {\n if (await directoryExists(assetSourcePath)) {\n return;\n }\n\n try {\n await access(assetSourcePath, constants.F_OK);\n } catch {\n throw new Error(`Muon dev asset source does not exist: ${assetSourcePath}`);\n }\n\n throw new Error(\n `Muon dev asset source must be a directory: ${assetSourcePath}`,\n );\n};\n\nconst resolveAssetSource = async (\n root: string,\n assetSourcePath: string | undefined,\n projectConfig: ProjectConfigResolution,\n): Promise<{\n assetSourcePath: string;\n overrideAssetSourcePath: string | undefined;\n}> => {\n const configuredAssetSourcePath = readConfigAssetSourcePath(\n projectConfig.config,\n );\n if (assetSourcePath !== undefined) {\n const resolvedPath = resolveFromRoot(root, assetSourcePath);\n await assertDevelopmentAssetDirectory(resolvedPath);\n return {\n assetSourcePath: resolvedPath,\n overrideAssetSourcePath: resolvedPath,\n };\n }\n\n if (\n configuredAssetSourcePath !== undefined &&\n projectConfig.configPath !== undefined\n ) {\n return {\n assetSourcePath: resolve(\n dirname(projectConfig.configPath),\n configuredAssetSourcePath,\n ),\n overrideAssetSourcePath: undefined,\n };\n }\n\n const defaultAssetSourcePath = resolve(root, \"assets\");\n await assertDevelopmentAssetDirectory(defaultAssetSourcePath);\n return {\n assetSourcePath: defaultAssetSourcePath,\n overrideAssetSourcePath: defaultAssetSourcePath,\n };\n};\n\nconst createMuonDevOverrideConfig = (\n assetSourcePath: string | undefined,\n enableDebugger: boolean,\n): MuonDevOverrideConfig => ({\n ...(assetSourcePath === undefined\n ? {}\n : {\n asset: {\n sourcePath: assetSourcePath,\n },\n }),\n ...(enableDebugger\n ? {\n cdp: {\n enable: true,\n },\n browser: {\n keybind: {\n devtools: \"f12\",\n recycle: \"ctrl+f12\",\n },\n },\n }\n : {}),\n});\n\nconst writeMuonDevOverrideConfig = async (\n overrideConfigPath: string,\n overrideConfig: MuonDevOverrideConfig,\n): Promise<void> => {\n await mkdir(dirname(overrideConfigPath), { recursive: true });\n await writeFile(\n overrideConfigPath,\n `${JSON.stringify(overrideConfig, null, 2)}\\n`,\n );\n};\n\nconst runMuonExecutable = async (\n muonExecutablePath: string,\n configPaths: readonly string[],\n environment: NodeJS.ProcessEnv,\n): Promise<number> => {\n const args = configPaths.flatMap((configPath) => [\"-c\", configPath]);\n let exitCode = 0;\n do {\n const child = spawn(muonExecutablePath, args, {\n cwd: dirname(muonExecutablePath),\n env: environment,\n stdio: [\"ignore\", \"inherit\", \"inherit\"],\n });\n\n exitCode = await new Promise<number>((resolvePromise, reject) => {\n child.once(\"error\", reject);\n child.once(\"close\", (code) => {\n resolvePromise(code ?? 1);\n });\n });\n } while (exitCode === muonRecycleExitCode);\n return exitCode;\n};\n\n/**\n * Launches Muon directly against local development assets.\n *\n * @param options Development startup options.\n * @returns Development startup result after the Muon process exits.\n */\nexport const runMuonDev = async (\n options: MuonDevOptions = {},\n): Promise<MuonDevResult> => {\n const cwd = resolve(options.root ?? process.cwd());\n const loadedViteOptions = await loadViteMuonOptions(cwd);\n const root = loadedViteOptions.root;\n const pluginOptions = loadedViteOptions.pluginOptions;\n const platform = options.platform ?? process.platform;\n const architecture = options.architecture ?? process.arch;\n const environment = options.environment ?? process.env;\n const target = getDefaultMuonPrepareTarget(platform, architecture);\n const muonPath = resolveMuonRuntimePath({\n root,\n target,\n muonPath: options.muonPath ?? pluginOptions?.muonPath,\n });\n const cefPath =\n options.cefPath !== undefined\n ? resolveFromRoot(root, options.cefPath)\n : pluginOptions?.cefPath === undefined\n ? undefined\n : resolveFromRoot(root, pluginOptions.cefPath);\n const stagePath =\n options.stagePath !== undefined\n ? resolveFromRoot(root, options.stagePath)\n : pluginOptions?.stagePath === undefined\n ? resolve(root, \".muon\", target)\n : resolveFromRoot(root, pluginOptions.stagePath);\n const enableDebugger =\n options.enableDebugger ?? pluginOptions?.enableDebugger ?? true;\n const projectConfig = await resolveProjectConfig(root, options.configPath);\n const asset = await resolveAssetSource(\n root,\n options.assetSourcePath,\n projectConfig,\n );\n const overrideConfigPath = join(root, \".muon\", \"dev\", \"muon.dev.json\");\n\n await ensureMuonGitignoreEntry(root);\n\n const preparedRuntime = await runMuonPrepare({\n muonPath,\n cefPath,\n stageDir: stagePath,\n target,\n cacheDir: environment.MUON_CACHE_DIR,\n force: false,\n quiet: options.quietPrepare === true,\n prepareExecutablePath: undefined,\n environment,\n cwd: root,\n });\n if (preparedRuntime.stagePath === undefined) {\n throw new Error(\"muon-builder did not return a staged runtime path.\");\n }\n\n await writeMuonDevOverrideConfig(\n overrideConfigPath,\n createMuonDevOverrideConfig(asset.overrideAssetSourcePath, enableDebugger),\n );\n const muonExecutablePath = getMuonExecutablePath(\n preparedRuntime.stagePath,\n platform,\n );\n const configPaths = [\n ...(projectConfig.configPath === undefined\n ? []\n : [projectConfig.configPath]),\n overrideConfigPath,\n ];\n const exitCode = await runMuonExecutable(\n muonExecutablePath,\n configPaths,\n environment,\n );\n\n return {\n root,\n target,\n muonPath: preparedRuntime.muonPath,\n cefPath: preparedRuntime.cefPath,\n stagePath: preparedRuntime.stagePath,\n muonExecutablePath,\n ...(projectConfig.configPath === undefined\n ? {}\n : { projectConfigPath: projectConfig.configPath }),\n overrideConfigPath,\n assetSourcePath: asset.assetSourcePath,\n exitCode,\n };\n};\n","// muon - Multi-platform GUI application framework that uses CEF as its backend\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/muon\n\nimport { spawn } from \"node:child_process\";\nimport { type Stats } from \"node:fs\";\nimport {\n chmod,\n cp,\n mkdir,\n readFile,\n readdir,\n rm,\n stat,\n writeFile,\n} from \"node:fs/promises\";\nimport { basename, dirname, join, relative, resolve, sep } from \"node:path\";\n\nimport AdmZip from \"adm-zip\";\nimport { parse } from \"json5\";\nimport {\n createDirectoryItem,\n createReadFileItem,\n createTarPacker,\n storeReaderToFile,\n type EntryItem,\n} from \"tar-vern\";\n\nimport {\n getDefaultMuonBuildTarget,\n type MuonBuildResult,\n type MuonBuildTarget,\n type MuonBuildTargetResult,\n} from \"./build.js\";\nimport {\n loadMuonBuildSequenceProject,\n muonBuildSequenceSuppressViteBuildEnvironmentKey,\n resolveMuonViteBuildOptions,\n runMuonBuildSequence,\n type MuonBuildSequenceOptions,\n} from \"./build-sequence.js\";\nimport type { MuonViteBuildOptions } from \"./vite.js\";\nimport {\n allMuonTargets,\n getMuonTargetDescriptor,\n normalizeMuonTarget,\n} from \"./targets.js\";\nimport {\n mergeMuonWindowsResourceOptions,\n readMuonConfigForWindowsResource,\n resolveMuonWindowsResource,\n updateWindowsPeResources,\n type MuonWindowsResourceOptions,\n type ResolvedMuonWindowsResource,\n} from \"./windows-resource.js\";\nimport { createWindowsIconFromPngFile } from \"./windows-icon.js\";\nimport {\n createLinuxDesktopEntry,\n mergeMuonLinuxDesktopOptions,\n quoteDesktopExecArgument,\n type MuonLinuxDesktopOptions,\n} from \"./linux-desktop.js\";\n\nconst supportedPackTypes = [\"zip\", \"tar.gz\", \"deb\", \"nsis\"] as const;\nconst defaultArtifactsDirectory = \"artifacts\";\nconst defaultPackageBuildDirectory = \".muon/pack\";\n\ntype JsonObject = Record<string, unknown>;\n\n/**\n * Muon package output type.\n */\nexport type MuonPackType = (typeof supportedPackTypes)[number];\n\n/**\n * Options for creating redistributable Muon package artifacts.\n */\nexport interface MuonPackOptions {\n /**\n * Project root.\n */\n root?: string;\n /**\n * Package artifact types to generate.\n *\n * @remarks Defaults to zip, tar.gz, deb, and nsis when omitted.\n */\n types?: readonly string[];\n /**\n * Public target identifiers to build.\n */\n targets?: readonly string[];\n /**\n * Build every supported target.\n */\n allTargets?: boolean;\n /**\n * Muon config path to embed.\n */\n configPath?: string;\n /**\n * File name used for the app launcher.\n */\n appName?: string;\n /**\n * Stable application identifier used for portable runtime state.\n */\n appId?: string;\n /**\n * Windows PE and NSIS resource metadata.\n *\n * @defaultValue Uses Vite build options, `muon.json` `windows.resource`,\n * `project.json`, `package.json`, then Muon defaults.\n */\n windowsResource?: MuonWindowsResourceOptions;\n /**\n * Linux desktop entry metadata.\n *\n * @defaultValue Uses Vite build options, `muon.json` `linux.desktop`,\n * package metadata, then Muon defaults.\n */\n linuxDesktop?: MuonLinuxDesktopOptions;\n /**\n * Directory containing package runtime/ and native/ folders.\n */\n packageDirectory?: string;\n /**\n * Directory that receives generated package artifacts.\n */\n artifactsDir?: string;\n /**\n * Package name override.\n */\n packageName?: string;\n /**\n * Package version override.\n */\n packageVersion?: string;\n /**\n * Package description override.\n */\n description?: string;\n /**\n * Package author/maintainer override.\n */\n author?: string;\n /**\n * Environment used for child processes.\n */\n environment?: NodeJS.ProcessEnv;\n}\n\n/**\n * Generated package artifact metadata.\n */\nexport interface MuonPackArtifact {\n /**\n * Package artifact type.\n */\n type: MuonPackType;\n /**\n * Muon target packaged in this artifact.\n */\n target: MuonBuildTarget;\n /**\n * Generated artifact path.\n */\n path: string;\n}\n\n/**\n * Result of a Muon package build.\n */\nexport interface MuonPackResult {\n /**\n * Absolute project root used for packaging.\n */\n root: string;\n /**\n * Debian/installer safe package name.\n */\n packageName: string;\n /**\n * Package version.\n */\n version: string;\n /**\n * Launcher file base name.\n */\n appName: string;\n /**\n * Stable app identifier embedded in launcher/runtime config.\n */\n appId: string;\n /**\n * Muon dist build result.\n */\n build: MuonBuildResult;\n /**\n * Target dist directories used as package inputs.\n */\n targets: MuonBuildTargetResult[];\n /**\n * Generated package artifacts.\n */\n artifacts: MuonPackArtifact[];\n}\n\ninterface PackageMetadata {\n packageName: string;\n version: string;\n description: string;\n author: string;\n}\n\ninterface MuonPackTargetPlan {\n target: MuonBuildTarget;\n types: MuonPackType[];\n}\n\nconst isJsonObject = (value: unknown): value is JsonObject =>\n typeof value === \"object\" && value !== null && !Array.isArray(value);\n\nconst readJsonObjectFile = async (path: string): Promise<JsonObject> => {\n const parsed = parse(await readFile(path, \"utf8\"));\n if (!isJsonObject(parsed)) {\n throw new Error(`JSON file must contain an object: ${path}`);\n }\n return parsed;\n};\n\nconst readPackageJson = async (root: string): Promise<JsonObject> => {\n return await readJsonObjectFile(join(root, \"package.json\"));\n};\n\nconst sanitizePackageName = (value: string): string => {\n const unscoped = value.startsWith(\"@\")\n ? value.slice(value.indexOf(\"/\") + 1)\n : value;\n const sanitized = unscoped\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9+.-]+/g, \"-\")\n .replace(/^[.+-]+/g, \"\")\n .replace(/[.+-]+$/g, \"\");\n return sanitized.length > 0 ? sanitized : \"muon-app\";\n};\n\nconst stringifyAuthor = (value: unknown): string | undefined => {\n if (typeof value === \"string\") {\n return value;\n }\n if (!isJsonObject(value) || typeof value.name !== \"string\") {\n return undefined;\n }\n return value.email === undefined || typeof value.email !== \"string\"\n ? value.name\n : `${value.name} <${value.email}>`;\n};\n\nconst resolveMetadata = (\n packageJson: JsonObject,\n options: MuonPackOptions,\n): PackageMetadata => {\n const packageNameSource =\n options.packageName ??\n (typeof packageJson.name === \"string\" ? packageJson.name : undefined);\n if (packageNameSource === undefined || packageNameSource.trim() === \"\") {\n throw new Error(\"package.json name is required for muon pack.\");\n }\n const version =\n options.packageVersion ??\n (typeof packageJson.version === \"string\" ? packageJson.version : undefined);\n if (version === undefined || version.trim() === \"\") {\n throw new Error(\"package.json version is required for muon pack.\");\n }\n const description =\n options.description ??\n (typeof packageJson.description === \"string\"\n ? packageJson.description\n : \"Muon application\");\n const author =\n options.author ?? stringifyAuthor(packageJson.author) ?? \"Unknown\";\n return {\n packageName: sanitizePackageName(packageNameSource),\n version,\n description,\n author,\n };\n};\n\nconst createPackMetadataPackageJson = (\n packageJson: JsonObject,\n metadata: PackageMetadata,\n): JsonObject => ({\n ...packageJson,\n version: metadata.version,\n});\n\nconst normalizePackTypes = (\n types: readonly string[] | undefined,\n): MuonPackType[] => {\n if (types === undefined) {\n return [...supportedPackTypes];\n }\n const normalized = types\n .flatMap((value) => value.split(\",\"))\n .map((value) => value.trim().toLowerCase())\n .map((value) => (value === \"tgz\" ? \"tar.gz\" : value))\n .filter((value) => value.length > 0);\n if (normalized.length === 0) {\n throw new Error(\"Specify at least one package type with --type.\");\n }\n for (const type of normalized) {\n if (!supportedPackTypes.includes(type as MuonPackType)) {\n throw new Error(`Unsupported muon pack type: ${type}`);\n }\n }\n return [...new Set(normalized)] as MuonPackType[];\n};\n\nconst packTargetSelectorTargets: Record<string, readonly MuonBuildTarget[]> = {\n linux: [\"linux-amd64\", \"linux-armhf\", \"linux-arm64\"],\n windows: [\"windows-i686\", \"windows-amd64\"],\n amd64: [\"linux-amd64\", \"windows-amd64\"],\n arm64: [\"linux-arm64\"],\n armhf: [\"linux-armhf\"],\n i686: [\"windows-i686\"],\n};\n\nconst normalizePackTargetSelector = (\n selector: string,\n): readonly MuonBuildTarget[] => {\n const normalized = selector.trim().toLowerCase();\n if (allMuonTargets.includes(normalized as MuonBuildTarget)) {\n return [normalized as MuonBuildTarget];\n }\n const targets = packTargetSelectorTargets[normalized];\n if (targets !== undefined) {\n return targets;\n }\n throw new Error(`Unsupported muon pack target selector: ${selector}`);\n};\n\nconst normalizePackTargetSelectors = (\n selectors: readonly string[],\n): MuonBuildTarget[] => {\n const targets = selectors\n .flatMap((selector) => selector.split(\",\"))\n .map((selector) => selector.trim())\n .filter((selector) => selector.length > 0)\n .flatMap((selector) => normalizePackTargetSelector(selector));\n return [...new Set(targets)];\n};\n\nconst normalizePluginBuildTargets = (\n targets: readonly string[],\n): MuonBuildTarget[] => {\n return [\n ...new Set(\n targets.map((target) => normalizeMuonTarget(target, \"muon pack target\")),\n ),\n ];\n};\n\nconst resolvePackTargetCandidates = (\n options: MuonPackOptions,\n pluginBuildOptions: MuonViteBuildOptions,\n): MuonBuildTarget[] => {\n if (options.allTargets === true) {\n return [...allMuonTargets];\n }\n if (options.targets !== undefined && options.targets.length > 0) {\n return normalizePackTargetSelectors(options.targets);\n }\n if (options.allTargets === false) {\n return [getDefaultMuonBuildTarget()];\n }\n if (pluginBuildOptions.allTargets === true) {\n return [...allMuonTargets];\n }\n if (\n pluginBuildOptions.targets !== undefined &&\n pluginBuildOptions.targets.length > 0\n ) {\n return normalizePluginBuildTargets(pluginBuildOptions.targets);\n }\n if (pluginBuildOptions.allTargets === false) {\n return [getDefaultMuonBuildTarget()];\n }\n return [...allMuonTargets];\n};\n\nconst packTypeSupportsTarget = (\n type: MuonPackType,\n target: MuonBuildTarget,\n): boolean => {\n const descriptor = getMuonTargetDescriptor(target);\n return (\n (type === \"zip\" && descriptor.os === \"windows\") ||\n (type === \"tar.gz\" && descriptor.os === \"linux\") ||\n (type === \"deb\" && descriptor.os === \"linux\") ||\n (type === \"nsis\" && descriptor.os === \"windows\")\n );\n};\n\nconst createPackTargetPlan = (\n types: readonly MuonPackType[],\n targets: readonly MuonBuildTarget[],\n): MuonPackTargetPlan[] => {\n const plan = targets\n .map((target) => ({\n target,\n types: types.filter((type) => packTypeSupportsTarget(type, target)),\n }))\n .filter((entry) => entry.types.length > 0);\n if (plan.length === 0) {\n throw new Error(\"No valid muon pack target and type combinations.\");\n }\n return plan;\n};\n\nconst runTool = async (\n executable: string,\n args: readonly string[],\n cwd: string,\n environment: NodeJS.ProcessEnv,\n): Promise<void> => {\n const child = spawn(executable, [...args], {\n cwd,\n env: environment,\n stdio: [\"ignore\", \"pipe\", \"pipe\"],\n });\n let stderr = \"\";\n child.stderr.setEncoding(\"utf8\");\n child.stderr.on(\"data\", (chunk: string) => {\n stderr += chunk;\n });\n const exitCode = await new Promise<number>((resolvePromise, reject) => {\n child.once(\"error\", reject);\n child.once(\"close\", (code) => {\n resolvePromise(code ?? 1);\n });\n });\n if (exitCode !== 0) {\n throw new Error(\n `${executable} failed with exit code ${exitCode}: ${stderr.trim()}`,\n );\n }\n};\n\nconst statOrUndefined = async (path: string): Promise<Stats | undefined> => {\n try {\n return await stat(path);\n } catch {\n return undefined;\n }\n};\n\nconst addDirectoryToZip = async (\n zip: AdmZip,\n directory: string,\n entryRoot: string,\n): Promise<void> => {\n const walk = async (currentDirectory: string): Promise<void> => {\n const entries = await readdir(currentDirectory, { withFileTypes: true });\n entries.sort((left, right) => left.name.localeCompare(right.name));\n for (const entry of entries) {\n const path = join(currentDirectory, entry.name);\n if (entry.isDirectory()) {\n await walk(path);\n } else if (entry.isFile()) {\n const stats = await stat(path);\n const relativePath = relative(directory, path).split(sep).join(\"/\");\n zip.addFile(\n `${entryRoot}/${relativePath}`,\n await readFile(path),\n undefined,\n stats.mode << 16,\n );\n }\n }\n };\n await walk(directory);\n};\n\nconst packageZip = async (\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n artifactsRoot: string,\n): Promise<MuonPackArtifact> => {\n const zip = new AdmZip();\n await addDirectoryToZip(\n zip,\n target.outputPath,\n target.distributionDirectoryName,\n );\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${target.target}.zip`,\n );\n await mkdir(dirname(outputPath), { recursive: true });\n await writeFile(outputPath, zip.toBuffer());\n return {\n type: \"zip\",\n target: target.target,\n path: outputPath,\n };\n};\n\nconst toArchivePath = (path: string): string => path.split(sep).join(\"/\");\n\nconst createTarGzEntryGenerator = async function* (\n directory: string,\n entryRoot: string,\n): AsyncGenerator<EntryItem, void, unknown> {\n yield await createDirectoryItem(entryRoot, \"exceptName\", {\n directoryPath: directory,\n });\n\n const walk = async function* (\n currentDirectory: string,\n ): AsyncGenerator<EntryItem, void, unknown> {\n const entries = await readdir(currentDirectory, { withFileTypes: true });\n entries.sort((left, right) => left.name.localeCompare(right.name));\n for (const entry of entries) {\n const path = join(currentDirectory, entry.name);\n const relativePath = toArchivePath(relative(directory, path));\n const entryName = `${entryRoot}/${relativePath}`;\n if (entry.isDirectory()) {\n yield await createDirectoryItem(entryName, \"exceptName\", {\n directoryPath: path,\n });\n yield* walk(path);\n } else if (entry.isFile()) {\n yield await createReadFileItem(entryName, path, \"exceptName\");\n }\n }\n };\n\n yield* walk(directory);\n};\n\nconst packageTarGz = async (\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n artifactsRoot: string,\n): Promise<MuonPackArtifact> => {\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${target.target}.tar.gz`,\n );\n await mkdir(dirname(outputPath), { recursive: true });\n const packer = createTarPacker(\n createTarGzEntryGenerator(\n target.outputPath,\n target.distributionDirectoryName,\n ),\n \"gzip\",\n );\n await storeReaderToFile(packer, outputPath);\n return {\n type: \"tar.gz\",\n target: target.target,\n path: outputPath,\n };\n};\n\nconst packageDeb = async (\n root: string,\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n artifactsRoot: string,\n packageBuildRoot: string,\n environment: NodeJS.ProcessEnv,\n): Promise<MuonPackArtifact> => {\n const descriptor = getMuonTargetDescriptor(target.target);\n if (descriptor.os !== \"linux\") {\n throw new Error(`Unsupported deb target: ${target.target}`);\n }\n const architecture = descriptor.arch;\n const packageRoot = join(\n packageBuildRoot,\n \"deb\",\n `${metadata.packageName}-${target.target}`,\n );\n await rm(packageRoot, { recursive: true, force: true });\n const installRoot = join(packageRoot, \"usr\", \"lib\", metadata.packageName);\n const installedDist = join(installRoot, target.distributionDirectoryName);\n await mkdir(installedDist, { recursive: true });\n await cp(target.outputPath, installedDist, { recursive: true });\n await writeFile(\n join(installedDist, \"muon-install.json\"),\n `${JSON.stringify(\n {\n type: \"deb\",\n packageName: metadata.packageName,\n launcherPath: `/usr/bin/${metadata.packageName}`,\n },\n undefined,\n 2,\n )}\\n`,\n );\n const binPath = join(packageRoot, \"usr\", \"bin\", metadata.packageName);\n const launcherName = basename(target.launcherPath);\n await mkdir(dirname(binPath), { recursive: true });\n await writeFile(\n binPath,\n [\n \"#!/usr/bin/env bash\",\n \"set -euo pipefail\",\n `exec ${JSON.stringify(`/usr/lib/${metadata.packageName}/${target.distributionDirectoryName}/${launcherName}`)} \"$@\"`,\n \"\",\n ].join(\"\\n\"),\n );\n await chmod(binPath, 0o755);\n if (target.linuxDesktop === undefined) {\n throw new Error(`Linux desktop metadata is unavailable: ${target.target}`);\n }\n const applicationsPath = join(\n packageRoot,\n \"usr\",\n \"share\",\n \"applications\",\n `${target.linuxDesktop.desktopId}.desktop`,\n );\n await mkdir(dirname(applicationsPath), { recursive: true });\n await writeFile(\n applicationsPath,\n createLinuxDesktopEntry({\n desktop: target.linuxDesktop,\n exec: `${quoteDesktopExecArgument(`/usr/bin/${metadata.packageName}`)} --muon-launch-from=normal`,\n tryExec: `/usr/bin/${metadata.packageName}`,\n icon: target.linuxDesktop.desktopId,\n }),\n );\n const iconPath = join(\n packageRoot,\n \"usr\",\n \"share\",\n \"icons\",\n \"hicolor\",\n \"256x256\",\n \"apps\",\n `${target.linuxDesktop.desktopId}.png`,\n );\n await mkdir(dirname(iconPath), { recursive: true });\n await cp(join(target.outputPath, target.linuxDesktop.iconFileName), iconPath);\n const controlPath = join(packageRoot, \"DEBIAN\", \"control\");\n await mkdir(dirname(controlPath), { recursive: true });\n await writeFile(\n controlPath,\n [\n `Package: ${metadata.packageName}`,\n `Version: ${metadata.version}`,\n `Architecture: ${architecture}`,\n `Maintainer: ${metadata.author}`,\n `Description: ${metadata.description}`,\n \"\",\n ].join(\"\\n\"),\n );\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${architecture}.deb`,\n );\n await mkdir(dirname(outputPath), { recursive: true });\n await runTool(\n \"dpkg-deb\",\n [\"--build\", packageRoot, outputPath],\n root,\n environment,\n );\n return {\n type: \"deb\",\n target: target.target,\n path: outputPath,\n };\n};\n\nconst escapeNsis = (value: string): string =>\n value.replaceAll(\"\\\\\", \"\\\\\\\\\").replaceAll('\"', '$\\\\\"');\n\nconst nsisUninstallRegistryRoot =\n \"Software\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\\Uninstall\";\n\nconst createNsisUninstallRegistryKey = (appId: string): string =>\n `${nsisUninstallRegistryRoot}\\\\${appId}`;\n\nconst packageNsis = async (\n root: string,\n target: MuonBuildTargetResult,\n metadata: PackageMetadata,\n appId: string,\n windowsResource: ResolvedMuonWindowsResource,\n artifactsRoot: string,\n packageBuildRoot: string,\n environment: NodeJS.ProcessEnv,\n): Promise<MuonPackArtifact> => {\n const descriptor = getMuonTargetDescriptor(target.target);\n if (descriptor.os !== \"windows\") {\n throw new Error(`Unsupported nsis target: ${target.target}`);\n }\n const scriptPath = join(\n packageBuildRoot,\n \"nsis\",\n `${metadata.packageName}-${target.target}.nsi`,\n );\n const outputPath = join(\n artifactsRoot,\n `${metadata.packageName}-${metadata.version}-${descriptor.arch}-setup.exe`,\n );\n const launcherFileName = basename(target.launcherPath);\n const uninstallRegistryKey = createNsisUninstallRegistryKey(appId);\n await mkdir(dirname(scriptPath), { recursive: true });\n await mkdir(dirname(outputPath), { recursive: true });\n const iconPath =\n windowsResource.iconPath === undefined\n ? undefined\n : join(\n dirname(scriptPath),\n `${metadata.packageName}-${target.target}.ico`,\n );\n if (windowsResource.iconPath !== undefined && iconPath !== undefined) {\n await createWindowsIconFromPngFile(windowsResource.iconPath, iconPath);\n }\n await writeFile(\n scriptPath,\n [\n \"Unicode true\",\n `Name \"${escapeNsis(metadata.packageName)}\"`,\n `OutFile \"${escapeNsis(outputPath)}\"`,\n `InstallDir \"$LOCALAPPDATA\\\\Programs\\\\${escapeNsis(metadata.packageName)}\"`,\n \"RequestExecutionLevel user\",\n \"ShowInstDetails nevershow\",\n \"AutoCloseWindow true\",\n ...createNsisResourceDirectives(windowsResource, iconPath),\n \"Page instfiles\",\n \"Section\",\n ' SetOutPath \"$INSTDIR\"',\n ` File /r \"${escapeNsis(target.outputPath)}\\\\*\"`,\n ` CreateShortCut \"$SMPROGRAMS\\\\${escapeNsis(metadata.packageName)}.lnk\" \"$INSTDIR\\\\${escapeNsis(launcherFileName)}\"`,\n ' WriteUninstaller \"$INSTDIR\\\\Uninstall.exe\"',\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"DisplayName\" \"${escapeNsis(metadata.packageName)}\"`,\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"DisplayVersion\" \"${escapeNsis(metadata.version)}\"`,\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"Publisher\" \"${escapeNsis(metadata.author)}\"`,\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"InstallLocation\" \"$INSTDIR\"`,\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"DisplayIcon\" \"$\\\\\"$INSTDIR\\\\${escapeNsis(launcherFileName)}$\\\\\"\"`,\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"UninstallString\" \"$\\\\\"$INSTDIR\\\\Uninstall.exe$\\\\\" /S\"`,\n ` WriteRegStr HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"QuietUninstallString\" \"$\\\\\"$INSTDIR\\\\Uninstall.exe$\\\\\" /S\"`,\n ` WriteRegDWORD HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"NoModify\" 1`,\n ` WriteRegDWORD HKCU \"${escapeNsis(uninstallRegistryKey)}\" \"NoRepair\" 1`,\n \"SectionEnd\",\n \"\",\n 'Section \"Uninstall\"',\n ` Delete \"$SMPROGRAMS\\\\${escapeNsis(metadata.packageName)}.lnk\"`,\n ` DeleteRegKey HKCU \"${escapeNsis(uninstallRegistryKey)}\"`,\n ' RMDir /r \"$INSTDIR\"',\n ` RMDir /r \"$LOCALAPPDATA\\\\${escapeNsis(appId)}\"`,\n \"SectionEnd\",\n \"\",\n \"Function .onInstSuccess\",\n \" IfSilent +3\",\n ' SetOutPath \"$INSTDIR\"',\n ` Exec \"$\\\\\"$INSTDIR\\\\${escapeNsis(launcherFileName)}$\\\\\"\"`,\n \"FunctionEnd\",\n \"\",\n ].join(\"\\n\"),\n );\n await runTool(\"makensis\", [scriptPath], root, environment);\n if ((await statOrUndefined(outputPath)) === undefined) {\n throw new Error(`makensis did not create installer: ${outputPath}`);\n }\n return {\n type: \"nsis\",\n target: target.target,\n path: outputPath,\n };\n};\n\nconst createNsisResourceDirectives = (\n resource: ResolvedMuonWindowsResource,\n iconPath: string | undefined,\n): string[] => {\n const lines: string[] = [];\n if (iconPath !== undefined) {\n lines.push(`Icon \"${escapeNsis(iconPath)}\"`);\n lines.push(`UninstallIcon \"${escapeNsis(iconPath)}\"`);\n }\n lines.push(`VIProductVersion \"${escapeNsis(resource.fixedVersion)}\"`);\n lines.push(`VIFileVersion \"${escapeNsis(resource.fixedVersion)}\"`);\n lines.push(\n `VIAddVersionKey /LANG=${resource.language} \"CompanyName\" \"${escapeNsis(resource.companyName)}\"`,\n );\n lines.push(\n `VIAddVersionKey /LANG=${resource.language} \"FileDescription\" \"${escapeNsis(resource.fileDescription)}\"`,\n );\n lines.push(\n `VIAddVersionKey /LANG=${resource.language} \"FileVersion\" \"${escapeNsis(resource.version)}\"`,\n );\n lines.push(\n `VIAddVersionKey /LANG=${resource.language} \"ProductName\" \"${escapeNsis(resource.productName)}\"`,\n );\n lines.push(\n `VIAddVersionKey /LANG=${resource.language} \"ProductVersion\" \"${escapeNsis(resource.version)}\"`,\n );\n if (resource.copyright !== undefined) {\n lines.push(\n `VIAddVersionKey /LANG=${resource.language} \"LegalCopyright\" \"${escapeNsis(resource.copyright)}\"`,\n );\n }\n return lines;\n};\n\nconst reapplyPackWindowsResources = async (\n targets: readonly MuonBuildTargetResult[],\n resource: ResolvedMuonWindowsResource,\n root: string,\n environment: NodeJS.ProcessEnv,\n): Promise<void> => {\n for (const target of targets) {\n if (getMuonTargetDescriptor(target.target).os === \"windows\") {\n await updateWindowsPeResources({\n executablePath: target.launcherPath,\n resource,\n environment,\n cwd: root,\n });\n }\n }\n};\n\n/**\n * Runs the Muon build sequence and creates redistributable packages.\n *\n * @param options Pack options.\n * @returns Generated package artifacts.\n */\nexport const packMuonApp = async (\n options: MuonPackOptions,\n): Promise<MuonPackResult> => {\n const cwd = resolve(options.root ?? process.cwd());\n const environment = options.environment ?? process.env;\n const project = await loadMuonBuildSequenceProject(cwd);\n const root = project.root;\n const packageJson = await readPackageJson(root);\n const metadata = resolveMetadata(packageJson, options);\n const artifactsRoot = resolve(\n root,\n options.artifactsDir ?? defaultArtifactsDirectory,\n );\n const packageBuildRoot = resolve(root, defaultPackageBuildDirectory);\n const types = normalizePackTypes(options.types);\n const pluginBuildOptions = resolveMuonViteBuildOptions(project.pluginOptions);\n const targetPlan = createPackTargetPlan(\n types,\n resolvePackTargetCandidates(options, pluginBuildOptions),\n );\n const buildOptions: MuonBuildSequenceOptions = {\n root: cwd,\n targets: targetPlan.map((entry) => entry.target),\n allTargets: false,\n };\n const windowsResourceOptions = mergeMuonWindowsResourceOptions(\n options.windowsResource,\n pluginBuildOptions.windowsResource,\n );\n const linuxDesktopOptions = mergeMuonLinuxDesktopOptions(\n options.linuxDesktop,\n pluginBuildOptions.linuxDesktop,\n );\n if (options.configPath !== undefined) {\n buildOptions.configPath = options.configPath;\n }\n if (options.appName !== undefined) {\n buildOptions.appName = options.appName;\n }\n if (options.appId !== undefined) {\n buildOptions.appId = options.appId;\n }\n if (options.packageDirectory !== undefined) {\n buildOptions.packageDirectory = options.packageDirectory;\n }\n if (windowsResourceOptions !== undefined) {\n buildOptions.windowsResource = windowsResourceOptions;\n }\n if (linuxDesktopOptions !== undefined) {\n buildOptions.linuxDesktop = linuxDesktopOptions;\n }\n const windowsResourceConfig = await readMuonConfigForWindowsResource(\n root,\n options.configPath,\n );\n const windowsResource = await resolveMuonWindowsResource({\n root,\n packageDirectory:\n options.packageDirectory ?? pluginBuildOptions.packageDirectory ?? \"\",\n packageJson: createPackMetadataPackageJson(packageJson, metadata),\n muonConfig: windowsResourceConfig.config,\n muonConfigDirectory: windowsResourceConfig.directory,\n options: windowsResourceOptions,\n defaults: {\n productName: metadata.packageName,\n fileDescription: metadata.description,\n companyName: metadata.author,\n version: metadata.version,\n copyright: undefined,\n },\n });\n const build = await runMuonBuildSequence(buildOptions, project);\n if (options.packageVersion !== undefined) {\n await reapplyPackWindowsResources(\n build.targets,\n windowsResource,\n root,\n environment,\n );\n }\n const typesByTarget = new Map(\n targetPlan.map((entry) => [entry.target, entry.types] as const),\n );\n await rm(packageBuildRoot, { recursive: true, force: true });\n await rm(join(artifactsRoot, \"deb\"), { recursive: true, force: true });\n await rm(join(artifactsRoot, \"nsis\"), { recursive: true, force: true });\n await mkdir(artifactsRoot, { recursive: true });\n const artifacts: MuonPackArtifact[] = [];\n for (const target of build.targets) {\n for (const type of typesByTarget.get(target.target) ?? []) {\n if (type === \"zip\") {\n artifacts.push(await packageZip(target, metadata, artifactsRoot));\n } else if (type === \"tar.gz\") {\n artifacts.push(await packageTarGz(target, metadata, artifactsRoot));\n } else if (type === \"deb\") {\n artifacts.push(\n await packageDeb(\n root,\n target,\n metadata,\n artifactsRoot,\n packageBuildRoot,\n environment,\n ),\n );\n } else {\n artifacts.push(\n await packageNsis(\n root,\n target,\n metadata,\n build.appId,\n windowsResource,\n artifactsRoot,\n packageBuildRoot,\n environment,\n ),\n );\n }\n }\n }\n return {\n root,\n packageName: metadata.packageName,\n version: metadata.version,\n appName: build.appName,\n appId: build.appId,\n build,\n targets: build.targets,\n artifacts,\n };\n};\n\nexport const muonPackSuppressViteBuildEnvironmentKey =\n muonBuildSequenceSuppressViteBuildEnvironmentKey;\n","// @ts-nocheck\n// This file is auto-generated by screw-up plugin\n// Do not edit manually\n\nexport const name = \"muon-ui\";\nexport const version = \"0.8.0\";\nexport const description = \"A multi-platform GUI application framework that uses CEF as its backend\";\nexport const author = \"Kouji Matsui (@kekyo@mi.kekyo.net)\";\nexport const license = \"MIT\";\nexport const repository_url = \"https://github.com/kekyo/muon-ui.git\";\nexport const git_commit_hash = \"9bb6148e155dab16c4ca441073b144e21981b038\";\n","#!/usr/bin/env node\n// muon - Multi-platform GUI application framework that uses CEF as its backend\n// Copyright (c) Kouji Matsui. (@kekyo@mi.kekyo.net)\n// Under MIT.\n// https://github.com/kekyo/muon\n\nimport { Command } from \"commander\";\n\nimport {\n getDefaultMuonPrepareTarget,\n runMuonPrepare,\n type MuonPrepareOptions,\n} from \"./prepare.js\";\nimport { ensureMuonGitignoreEntry } from \"./gitignore.js\";\nimport {\n embedMuonConfigInBootstrapFile,\n embedMuonConfigInCoreFile,\n embedMuonConfigInRuntime,\n type EmbedMuonConfigResult,\n} from \"./embed-config.js\";\nimport {\n runMuonBuildSequence,\n type MuonBuildSequenceOptions,\n} from \"./build-sequence.js\";\nimport { runMuonDev, type MuonDevOptions } from \"./dev.js\";\nimport { packMuonApp, type MuonPackOptions } from \"./pack.js\";\nimport type { MuonWindowsResourceOptions } from \"./windows-resource.js\";\nimport type { MuonLinuxDesktopOptions } from \"./linux-desktop.js\";\nimport { git_commit_hash, version } from \"./generated/packageMetadata.js\";\n\ninterface PrepareCommandOptions {\n muonPath: string | undefined;\n cefPath: string | undefined;\n stageDir: string | undefined;\n target: string | undefined;\n cacheDir: string | undefined;\n force: boolean | undefined;\n quiet: boolean | undefined;\n json: boolean | undefined;\n}\n\ninterface EmbedConfigCommandOptions {\n runtimePath: string | undefined;\n corePath: string | undefined;\n bootstrapPath: string | undefined;\n config: string | undefined;\n outputRuntimePath: string | undefined;\n output: string | undefined;\n outputBootstrap: string | undefined;\n json: boolean | undefined;\n}\n\ninterface BuildCommandOptions {\n target: string[];\n all: boolean | undefined;\n assets: string | undefined;\n config: string | undefined;\n windowsIcon: string | undefined;\n windowsProductName: string | undefined;\n windowsFileDescription: string | undefined;\n windowsCompanyName: string | undefined;\n windowsVersion: string | undefined;\n windowsCopyright: string | undefined;\n linuxDesktopId: string | undefined;\n linuxName: string | undefined;\n linuxComment: string | undefined;\n linuxIcon: string | undefined;\n linuxCategories: string | undefined;\n linuxStartupNotify: string | undefined;\n outDir: string | undefined;\n name: string | undefined;\n appId: string | undefined;\n packageDirectory: string | undefined;\n json: boolean | undefined;\n}\n\ninterface PackCommandOptions {\n type: string[] | undefined;\n target: string[];\n all: boolean | undefined;\n config: string | undefined;\n windowsIcon: string | undefined;\n windowsProductName: string | undefined;\n windowsFileDescription: string | undefined;\n windowsCompanyName: string | undefined;\n windowsVersion: string | undefined;\n windowsCopyright: string | undefined;\n linuxDesktopId: string | undefined;\n linuxName: string | undefined;\n linuxComment: string | undefined;\n linuxIcon: string | undefined;\n linuxCategories: string | undefined;\n linuxStartupNotify: string | undefined;\n name: string | undefined;\n appId: string | undefined;\n packageDirectory: string | undefined;\n artifactsDir: string | undefined;\n packageName: string | undefined;\n packageVersion: string | undefined;\n description: string | undefined;\n author: string | undefined;\n json: boolean | undefined;\n}\n\ninterface DevCommandOptions {\n muonPath: string | undefined;\n cefPath: string | undefined;\n stageDir: string | undefined;\n config: string | undefined;\n assets: string | undefined;\n debugger: boolean | undefined;\n json: boolean | undefined;\n}\n\nconst readTargetValues = (value: string): string[] => {\n return value\n .split(\",\")\n .map((value) => value.trim())\n .filter((value) => value.length > 0);\n};\n\nconst appendTargetValues = (value: string, previous: string[]): string[] => {\n return [...previous, ...readTargetValues(value)];\n};\n\nconst appendPackTypeValues = (\n value: string,\n previous: string[] | undefined,\n): string[] => {\n return [...(previous ?? []), ...readTargetValues(value)];\n};\n\nconst readCommaSeparatedValues = (value: string): string[] =>\n value\n .split(\",\")\n .map((entry) => entry.trim())\n .filter((entry) => entry.length > 0);\n\nconst readBooleanValue = (value: string, label: string): boolean => {\n const normalized = value.trim().toLowerCase();\n if (normalized === \"true\" || normalized === \"1\" || normalized === \"yes\") {\n return true;\n }\n if (normalized === \"false\" || normalized === \"0\" || normalized === \"no\") {\n return false;\n }\n throw new Error(`${label} must be true or false.`);\n};\n\nconst validateEmbedConfigOptions = (\n options: EmbedConfigCommandOptions,\n): void => {\n if (options.runtimePath !== undefined && options.corePath !== undefined) {\n throw new Error(\"Specify at most one of --runtime-path or --core-path.\");\n }\n if (\n options.runtimePath === undefined &&\n options.corePath === undefined &&\n options.bootstrapPath === undefined\n ) {\n throw new Error(\n \"Specify at least one of --runtime-path, --core-path, or --bootstrap-path.\",\n );\n }\n if (\n options.corePath !== undefined &&\n options.outputRuntimePath !== undefined\n ) {\n throw new Error(\"--output-runtime-path requires --runtime-path.\");\n }\n if (options.runtimePath !== undefined && options.output !== undefined) {\n throw new Error(\"--output requires --core-path.\");\n }\n if (\n options.bootstrapPath === undefined &&\n options.outputBootstrap !== undefined\n ) {\n throw new Error(\"--output-bootstrap requires --bootstrap-path.\");\n }\n};\n\nconst createWindowsResourceOptions = (commandOptions: {\n windowsIcon: string | undefined;\n windowsProductName: string | undefined;\n windowsFileDescription: string | undefined;\n windowsCompanyName: string | undefined;\n windowsVersion: string | undefined;\n windowsCopyright: string | undefined;\n}): MuonWindowsResourceOptions | undefined => {\n const options: MuonWindowsResourceOptions = {};\n if (commandOptions.windowsIcon !== undefined) {\n options.iconPath = commandOptions.windowsIcon;\n }\n if (commandOptions.windowsProductName !== undefined) {\n options.productName = commandOptions.windowsProductName;\n }\n if (commandOptions.windowsFileDescription !== undefined) {\n options.fileDescription = commandOptions.windowsFileDescription;\n }\n if (commandOptions.windowsCompanyName !== undefined) {\n options.companyName = commandOptions.windowsCompanyName;\n }\n if (commandOptions.windowsVersion !== undefined) {\n options.version = commandOptions.windowsVersion;\n }\n if (commandOptions.windowsCopyright !== undefined) {\n options.copyright = commandOptions.windowsCopyright;\n }\n return Object.keys(options).length === 0 ? undefined : options;\n};\n\nconst createLinuxDesktopOptions = (commandOptions: {\n linuxDesktopId: string | undefined;\n linuxName: string | undefined;\n linuxComment: string | undefined;\n linuxIcon: string | undefined;\n linuxCategories: string | undefined;\n linuxStartupNotify: string | undefined;\n}): MuonLinuxDesktopOptions | undefined => {\n const options: MuonLinuxDesktopOptions = {};\n if (commandOptions.linuxDesktopId !== undefined) {\n options.desktopId = commandOptions.linuxDesktopId;\n }\n if (commandOptions.linuxName !== undefined) {\n options.name = commandOptions.linuxName;\n }\n if (commandOptions.linuxComment !== undefined) {\n options.comment = commandOptions.linuxComment;\n }\n if (commandOptions.linuxIcon !== undefined) {\n options.iconPath = commandOptions.linuxIcon;\n }\n if (commandOptions.linuxCategories !== undefined) {\n options.categories = readCommaSeparatedValues(\n commandOptions.linuxCategories,\n );\n }\n if (commandOptions.linuxStartupNotify !== undefined) {\n options.startupNotify = readBooleanValue(\n commandOptions.linuxStartupNotify,\n \"--linux-startup-notify\",\n );\n }\n return Object.keys(options).length === 0 ? undefined : options;\n};\n\nconst runBuildCommand = async (\n commandOptions: BuildCommandOptions,\n): Promise<void> => {\n const targets = commandOptions.target;\n if (commandOptions.all === true && targets.length > 0) {\n throw new Error(\"Specify either --all or --target, not both.\");\n }\n\n const buildOptions: MuonBuildSequenceOptions = {\n root: process.cwd(),\n defaultAllTargets: false,\n };\n\n if (targets.length > 0) {\n buildOptions.targets = targets;\n }\n if (commandOptions.all === true) {\n buildOptions.allTargets = true;\n }\n if (commandOptions.assets !== undefined) {\n buildOptions.assetSourcePath = commandOptions.assets;\n }\n if (commandOptions.config !== undefined) {\n buildOptions.configPath = commandOptions.config;\n }\n const windowsResource = createWindowsResourceOptions(commandOptions);\n if (windowsResource !== undefined) {\n buildOptions.windowsResource = windowsResource;\n }\n const linuxDesktop = createLinuxDesktopOptions(commandOptions);\n if (linuxDesktop !== undefined) {\n buildOptions.linuxDesktop = linuxDesktop;\n }\n if (commandOptions.outDir !== undefined) {\n buildOptions.outputRoot = commandOptions.outDir;\n }\n if (commandOptions.name !== undefined) {\n buildOptions.appName = commandOptions.name;\n }\n if (commandOptions.appId !== undefined) {\n buildOptions.appId = commandOptions.appId;\n }\n if (commandOptions.packageDirectory !== undefined) {\n buildOptions.packageDirectory = commandOptions.packageDirectory;\n }\n\n const result = await runMuonBuildSequence(buildOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n for (const target of result.targets) {\n console.log(target.outputPath);\n }\n }\n};\n\nconst runPackCommand = async (\n commandOptions: PackCommandOptions,\n): Promise<void> => {\n const targets = commandOptions.target;\n if (commandOptions.all === true && targets.length > 0) {\n throw new Error(\"Specify either --all or --target, not both.\");\n }\n\n const packOptions: MuonPackOptions = {\n root: process.cwd(),\n environment: process.env,\n };\n if (commandOptions.type !== undefined) {\n packOptions.types = commandOptions.type;\n }\n if (targets.length > 0) {\n packOptions.targets = targets;\n }\n if (commandOptions.all !== undefined) {\n packOptions.allTargets = commandOptions.all;\n }\n if (commandOptions.config !== undefined) {\n packOptions.configPath = commandOptions.config;\n }\n const windowsResource = createWindowsResourceOptions(commandOptions);\n if (windowsResource !== undefined) {\n packOptions.windowsResource = windowsResource;\n }\n const linuxDesktop = createLinuxDesktopOptions(commandOptions);\n if (linuxDesktop !== undefined) {\n packOptions.linuxDesktop = linuxDesktop;\n }\n if (commandOptions.name !== undefined) {\n packOptions.appName = commandOptions.name;\n }\n if (commandOptions.appId !== undefined) {\n packOptions.appId = commandOptions.appId;\n }\n if (commandOptions.packageDirectory !== undefined) {\n packOptions.packageDirectory = commandOptions.packageDirectory;\n }\n if (commandOptions.artifactsDir !== undefined) {\n packOptions.artifactsDir = commandOptions.artifactsDir;\n }\n if (commandOptions.packageName !== undefined) {\n packOptions.packageName = commandOptions.packageName;\n }\n if (commandOptions.packageVersion !== undefined) {\n packOptions.packageVersion = commandOptions.packageVersion;\n }\n if (commandOptions.description !== undefined) {\n packOptions.description = commandOptions.description;\n }\n if (commandOptions.author !== undefined) {\n packOptions.author = commandOptions.author;\n }\n\n const result = await packMuonApp(packOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n for (const artifact of result.artifacts) {\n console.log(artifact.path);\n }\n }\n};\n\nconst runPrepareCommand = async (\n commandOptions: PrepareCommandOptions,\n): Promise<void> => {\n const prepareOptions: MuonPrepareOptions = {\n muonPath: commandOptions.muonPath ?? \"\",\n cefPath: commandOptions.cefPath,\n stageDir: commandOptions.stageDir,\n target:\n commandOptions.target ??\n getDefaultMuonPrepareTarget(process.platform, process.arch),\n cacheDir: commandOptions.cacheDir,\n force: commandOptions.force === true,\n quiet: commandOptions.quiet === true,\n prepareExecutablePath: undefined,\n environment: process.env,\n cwd: process.cwd(),\n };\n const result = await runMuonPrepare(prepareOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n console.log(result.stagePath ?? result.cefPath);\n }\n};\n\nconst runDevCommand = async (\n commandOptions: DevCommandOptions,\n command: Command,\n): Promise<void> => {\n const devOptions: MuonDevOptions = {\n root: process.cwd(),\n environment: process.env,\n quietPrepare: commandOptions.json === true,\n };\n\n if (commandOptions.muonPath !== undefined) {\n devOptions.muonPath = commandOptions.muonPath;\n }\n if (commandOptions.cefPath !== undefined) {\n devOptions.cefPath = commandOptions.cefPath;\n }\n if (commandOptions.stageDir !== undefined) {\n devOptions.stagePath = commandOptions.stageDir;\n }\n if (commandOptions.config !== undefined) {\n devOptions.configPath = commandOptions.config;\n }\n if (commandOptions.assets !== undefined) {\n devOptions.assetSourcePath = commandOptions.assets;\n }\n if (command.getOptionValueSource(\"debugger\") === \"cli\") {\n devOptions.enableDebugger = commandOptions.debugger === true;\n }\n\n const result = await runMuonDev(devOptions);\n if (commandOptions.json === true) {\n console.log(JSON.stringify(result, null, 2));\n }\n if (result.exitCode !== 0) {\n process.exitCode = result.exitCode;\n }\n};\n\nconst runInitCommand = async (): Promise<void> => {\n const result = await ensureMuonGitignoreEntry(process.cwd());\n console.log(\n result.changed ? `Updated ${result.gitignorePath}` : result.gitignorePath,\n );\n};\n\nconst printEmbedConfigResult = (\n result: EmbedMuonConfigResult,\n json: boolean | undefined,\n): void => {\n if (json === true) {\n console.log(JSON.stringify(result, null, 2));\n } else {\n console.log(result.outputPath);\n }\n};\n\nconst runEmbedConfigCommand = async (\n commandOptions: EmbedConfigCommandOptions,\n): Promise<void> => {\n validateEmbedConfigOptions(commandOptions);\n const configPath = commandOptions.config ?? \"\";\n const coreResult =\n commandOptions.corePath !== undefined\n ? await embedMuonConfigInCoreFile({\n corePath: commandOptions.corePath,\n configPath,\n outputPath: commandOptions.output,\n })\n : commandOptions.runtimePath !== undefined\n ? await embedMuonConfigInRuntime({\n runtimePath: commandOptions.runtimePath,\n configPath,\n outputRuntimePath: commandOptions.outputRuntimePath,\n })\n : undefined;\n const bootstrapResult =\n commandOptions.bootstrapPath === undefined\n ? undefined\n : await embedMuonConfigInBootstrapFile({\n bootstrapPath: commandOptions.bootstrapPath,\n configPath,\n outputPath: commandOptions.outputBootstrap,\n });\n if (coreResult !== undefined && bootstrapResult !== undefined) {\n if (commandOptions.json === true) {\n console.log(\n JSON.stringify(\n {\n core: coreResult,\n bootstrap: bootstrapResult,\n },\n null,\n 2,\n ),\n );\n } else {\n console.log(`${coreResult.outputPath}\\n${bootstrapResult.outputPath}`);\n }\n return;\n }\n const result = coreResult ?? bootstrapResult;\n if (result === undefined) {\n throw new Error(\"No embed-config target was specified.\");\n }\n printEmbedConfigResult(result, commandOptions.json);\n};\n\nconst createCliCommand = (): Command => {\n const program = new Command();\n\n program\n .name(\"muon\")\n .description(\n \"Multi-platform GUI application framework that uses CEF as its backend\",\n )\n .version(`${version}-${git_commit_hash}`)\n .showSuggestionAfterError()\n .action(() => {\n program.outputHelp({ error: true });\n process.exitCode = 1;\n });\n\n program\n .command(\"build\")\n .description(\"Build CEF-free Muon app distribution directories\")\n .option(\n \"--target <target>\",\n \"public target or comma-separated public targets\",\n appendTargetValues,\n [],\n )\n .option(\"--all\", \"build all supported targets\")\n .option(\"--assets <path>\", \"asset root path\")\n .option(\"--config <path>\", \"muon config path\")\n .option(\"--windows-icon <path>\", \"Windows PNG icon resource path\")\n .option(\"--windows-product-name <name>\", \"Windows product name\")\n .option(\"--windows-file-description <text>\", \"Windows file description\")\n .option(\"--windows-company-name <name>\", \"Windows company name\")\n .option(\"--windows-version <version>\", \"Windows resource version\")\n .option(\"--windows-copyright <text>\", \"Windows legal copyright\")\n .option(\"--linux-desktop-id <id>\", \"Linux desktop entry identifier\")\n .option(\"--linux-name <name>\", \"Linux desktop display name\")\n .option(\"--linux-comment <text>\", \"Linux desktop comment\")\n .option(\"--linux-icon <path>\", \"Linux desktop PNG icon path\")\n .option(\"--linux-categories <list>\", \"Linux desktop categories\")\n .option(\"--linux-startup-notify <boolean>\", \"Linux startup notification\")\n .option(\"--out-dir <path>\", \"output root directory\")\n .option(\"--name <name>\", \"launcher file name\")\n .option(\"--app-id <id>\", \"stable application identifier\")\n .option(\"--package-directory <path>\", \"Muon package dist directory\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: BuildCommandOptions) => {\n await runBuildCommand(options);\n });\n\n program\n .command(\"pack\")\n .description(\"Build and package a Muon app\")\n .option(\n \"--type <type>\",\n \"package type or comma-separated package types: zip, tar.gz, tgz, deb, nsis (default: all)\",\n appendPackTypeValues,\n )\n .option(\n \"--target <target>\",\n \"public target, platform, arch, or comma-separated selectors\",\n appendTargetValues,\n [],\n )\n .option(\"--all\", \"build all supported targets\")\n .option(\"--config <path>\", \"muon config path\")\n .option(\"--windows-icon <path>\", \"Windows PNG icon resource path\")\n .option(\"--windows-product-name <name>\", \"Windows product name\")\n .option(\"--windows-file-description <text>\", \"Windows file description\")\n .option(\"--windows-company-name <name>\", \"Windows company name\")\n .option(\"--windows-version <version>\", \"Windows resource version\")\n .option(\"--windows-copyright <text>\", \"Windows legal copyright\")\n .option(\"--linux-desktop-id <id>\", \"Linux desktop entry identifier\")\n .option(\"--linux-name <name>\", \"Linux desktop display name\")\n .option(\"--linux-comment <text>\", \"Linux desktop comment\")\n .option(\"--linux-icon <path>\", \"Linux desktop PNG icon path\")\n .option(\"--linux-categories <list>\", \"Linux desktop categories\")\n .option(\"--linux-startup-notify <boolean>\", \"Linux startup notification\")\n .option(\"--name <name>\", \"launcher file name\")\n .option(\"--app-id <id>\", \"stable application identifier\")\n .option(\"--package-directory <path>\", \"Muon package dist directory\")\n .option(\"--artifacts-dir <path>\", \"package artifact output directory\")\n .option(\"--package-name <name>\", \"package name override\")\n .option(\"--package-version <version>\", \"package version override\")\n .option(\"--description <text>\", \"package description override\")\n .option(\"--author <text>\", \"package author override\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: PackCommandOptions) => {\n await runPackCommand(options);\n });\n\n const devCommand = program\n .command(\"dev\")\n .description(\"Launch Muon directly with local development assets\")\n .option(\"--muon-path <path>\", \"Muon runtime file root\")\n .option(\"--cef-path <path>\", \"CEF file root\")\n .option(\"--stage-dir <path>\", \"prepared runtime output directory\")\n .option(\"--config <path>\", \"muon config path\")\n .option(\"--assets <path>\", \"development asset directory\")\n .option(\"--no-debugger\", \"disable Muon debugger defaults\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: DevCommandOptions) => {\n await runDevCommand(options, devCommand);\n });\n\n program\n .command(\"init\")\n .description(\"Initialize Muon project helper files\")\n .action(async () => {\n await runInitCommand();\n });\n\n program\n .command(\"prepare\")\n .description(\"Prepare a Muon runtime with CEF files\")\n .requiredOption(\"--muon-path <path>\", \"Muon runtime file root\")\n .option(\"--cef-path <path>\", \"CEF file root\")\n .option(\"--stage-dir <path>\", \"prepared runtime output directory\")\n .option(\"--target <target>\", \"prepare target\")\n .option(\"--cache-dir <path>\", \"CEF artifact cache directory\")\n .option(\"--force\", \"rebuild an existing prepared runtime\")\n .option(\"-q, --quiet\", \"suppress native builder progress messages\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: PrepareCommandOptions) => {\n await runPrepareCommand(options);\n });\n\n program\n .command(\"embed-config\")\n .description(\"Embed muon.json into Muon runtime files\")\n .option(\"--runtime-path <path>\", \"prepared runtime directory\")\n .option(\"--core-path <path>\", \"muon-core executable path\")\n .option(\"--bootstrap-path <path>\", \"muon-bootstrap executable path\")\n .requiredOption(\"--config <path>\", \"muon config path\")\n .option(\"--output-runtime-path <path>\", \"patched runtime output directory\")\n .option(\"--output <path>\", \"patched muon-core output path\")\n .option(\"--output-bootstrap <path>\", \"patched bootstrap output path\")\n .option(\"--json\", \"write result as JSON\")\n .action(async (options: EmbedConfigCommandOptions) => {\n await runEmbedConfigCommand(options);\n });\n\n return program;\n};\n\nconst main = async (): Promise<void> => {\n try {\n await createCliCommand().parseAsync(process.argv);\n } catch (error) {\n console.error(error instanceof Error ? error.message : String(error));\n process.exitCode = 1;\n }\n};\n\nvoid main();\n"],"mappings":"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"}
|
package/dist/index.cjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* name: muon-ui
|
|
3
|
-
* version: 0.
|
|
3
|
+
* version: 0.8.0
|
|
4
4
|
* description: A multi-platform GUI application framework that uses CEF as its backend
|
|
5
5
|
* author: Kouji Matsui (@kekyo@mi.kekyo.net)
|
|
6
6
|
* license: MIT
|
|
7
7
|
* repository.url: https://github.com/kekyo/muon-ui.git
|
|
8
|
-
* git.commit.hash:
|
|
8
|
+
* git.commit.hash: 9bb6148e155dab16c4ca441073b144e21981b038
|
|
9
9
|
*/
|
package/dist/index.mjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* name: muon-ui
|
|
3
|
-
* version: 0.
|
|
3
|
+
* version: 0.8.0
|
|
4
4
|
* description: A multi-platform GUI application framework that uses CEF as its backend
|
|
5
5
|
* author: Kouji Matsui (@kekyo@mi.kekyo.net)
|
|
6
6
|
* license: MIT
|
|
7
7
|
* repository.url: https://github.com/kekyo/muon-ui.git
|
|
8
|
-
* git.commit.hash:
|
|
8
|
+
* git.commit.hash: 9bb6148e155dab16c4ca441073b144e21981b038
|
|
9
9
|
*/
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -108,6 +108,30 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
108
108
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
109
109
|
SOFTWARE.
|
|
110
110
|
|
|
111
|
+
## engraver
|
|
112
|
+
|
|
113
|
+
Source: https://github.com/kekyo/engraver/
|
|
114
|
+
|
|
115
|
+
Copyright (c) Kouji Matsui (@kekyo@mi.kekyo.net)
|
|
116
|
+
|
|
117
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
118
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
119
|
+
in the Software without restriction, including without limitation the rights
|
|
120
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
121
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
122
|
+
furnished to do so, subject to the following conditions:
|
|
123
|
+
|
|
124
|
+
The above copyright notice and this permission notice shall be included in all
|
|
125
|
+
copies or substantial portions of the Software.
|
|
126
|
+
|
|
127
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
128
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
129
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
130
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
131
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
132
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
133
|
+
SOFTWARE.
|
|
134
|
+
|
|
111
135
|
## NetBSD SHA1
|
|
112
136
|
|
|
113
137
|
Source:
|
|
Binary file
|
|
@@ -108,6 +108,30 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
108
108
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
109
109
|
SOFTWARE.
|
|
110
110
|
|
|
111
|
+
## engraver
|
|
112
|
+
|
|
113
|
+
Source: https://github.com/kekyo/engraver/
|
|
114
|
+
|
|
115
|
+
Copyright (c) Kouji Matsui (@kekyo@mi.kekyo.net)
|
|
116
|
+
|
|
117
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
118
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
119
|
+
in the Software without restriction, including without limitation the rights
|
|
120
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
121
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
122
|
+
furnished to do so, subject to the following conditions:
|
|
123
|
+
|
|
124
|
+
The above copyright notice and this permission notice shall be included in all
|
|
125
|
+
copies or substantial portions of the Software.
|
|
126
|
+
|
|
127
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
128
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
129
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
130
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
131
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
132
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
133
|
+
SOFTWARE.
|
|
134
|
+
|
|
111
135
|
## NetBSD SHA1
|
|
112
136
|
|
|
113
137
|
Source:
|
|
Binary file
|
|
@@ -108,6 +108,30 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
108
108
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
109
109
|
SOFTWARE.
|
|
110
110
|
|
|
111
|
+
## engraver
|
|
112
|
+
|
|
113
|
+
Source: https://github.com/kekyo/engraver/
|
|
114
|
+
|
|
115
|
+
Copyright (c) Kouji Matsui (@kekyo@mi.kekyo.net)
|
|
116
|
+
|
|
117
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
118
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
119
|
+
in the Software without restriction, including without limitation the rights
|
|
120
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
121
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
122
|
+
furnished to do so, subject to the following conditions:
|
|
123
|
+
|
|
124
|
+
The above copyright notice and this permission notice shall be included in all
|
|
125
|
+
copies or substantial portions of the Software.
|
|
126
|
+
|
|
127
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
128
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
129
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
130
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
131
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
132
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
133
|
+
SOFTWARE.
|
|
134
|
+
|
|
111
135
|
## NetBSD SHA1
|
|
112
136
|
|
|
113
137
|
Source:
|
|
Binary file
|
|
@@ -108,6 +108,30 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
108
108
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
109
109
|
SOFTWARE.
|
|
110
110
|
|
|
111
|
+
## engraver
|
|
112
|
+
|
|
113
|
+
Source: https://github.com/kekyo/engraver/
|
|
114
|
+
|
|
115
|
+
Copyright (c) Kouji Matsui (@kekyo@mi.kekyo.net)
|
|
116
|
+
|
|
117
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
118
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
119
|
+
in the Software without restriction, including without limitation the rights
|
|
120
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
121
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
122
|
+
furnished to do so, subject to the following conditions:
|
|
123
|
+
|
|
124
|
+
The above copyright notice and this permission notice shall be included in all
|
|
125
|
+
copies or substantial portions of the Software.
|
|
126
|
+
|
|
127
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
128
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
129
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
130
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
131
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
132
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
133
|
+
SOFTWARE.
|
|
134
|
+
|
|
111
135
|
## NetBSD SHA1
|
|
112
136
|
|
|
113
137
|
Source:
|
|
Binary file
|
|
Binary file
|