viba-cli 0.14.0 → 0.16.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/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +2 -2
- package/.next/fallback-build-manifest.json +2 -2
- package/.next/prerender-manifest.json +3 -3
- package/.next/server/app/_global-error.html +2 -2
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +2 -2
- package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/index.html +1 -1
- package/.next/server/app/index.rsc +3 -3
- package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/index.segments/_full.segment.rsc +3 -3
- package/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/server/app/index.segments/_index.segment.rsc +2 -2
- package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
- package/.next/server/app/new/page/server-reference-manifest.json +23 -23
- package/.next/server/app/new/page.js.nft.json +1 -1
- package/.next/server/app/new/page_client-reference-manifest.js +1 -1
- package/.next/server/app/page/server-reference-manifest.json +23 -23
- package/.next/server/app/page.js.nft.json +1 -1
- package/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/server/app/session/[sessionId]/page/server-reference-manifest.json +18 -18
- package/.next/server/app/session/[sessionId]/page.js.nft.json +1 -1
- package/.next/server/app/session/[sessionId]/page_client-reference-manifest.js +1 -1
- package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_14850b56.js +1 -1
- package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_14850b56.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__14040f84._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__14040f84._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__7cb77b2c._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__7cb77b2c._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__90433455._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__90433455._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__997d0abe._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__997d0abe._.js.map +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__fc21e97b._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__fc21e97b._.js.map +1 -1
- package/.next/server/chunks/ssr/{_fa433ecd._.js → _2d8b69eb._.js} +3 -3
- package/.next/server/chunks/ssr/{_fa433ecd._.js.map → _2d8b69eb._.js.map} +1 -1
- package/.next/server/chunks/ssr/{_d6c63e2d._.js → _89491450._.js} +2 -2
- package/.next/server/chunks/ssr/_89491450._.js.map +1 -0
- package/.next/server/chunks/ssr/{_dbe3619a._.js → _9aad5de4._.js} +2 -2
- package/.next/server/chunks/ssr/_9aad5de4._.js.map +1 -0
- package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js +2 -2
- package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js.map +1 -1
- package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js +1 -1
- package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js.map +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +2 -2
- package/.next/server/server-reference-manifest.js +1 -1
- package/.next/server/server-reference-manifest.json +37 -37
- package/.next/static/chunks/{1edc4934fe56d7a3.js → 1e68d6f867104d33.js} +3 -3
- package/.next/static/chunks/{16cc8c773ed878ee.js → 2ad6ea8cc15960f2.js} +2 -2
- package/.next/static/chunks/{1d50bee0b23f7f52.js → 660dde386765d6d2.js} +3 -3
- package/.next/static/chunks/74f04c1c1df58968.js +3 -0
- package/.next/static/chunks/7f97d710f0f65591.css +3 -0
- package/.next/static/chunks/{5897b6d22d32c16c.js → a95f626254af994c.js} +2 -2
- package/bin/viba.mjs +23 -4
- package/package.json +3 -1
- package/src/lib/cli-args.mjs +41 -0
- package/.next/server/chunks/ssr/_d6c63e2d._.js.map +0 -1
- package/.next/server/chunks/ssr/_dbe3619a._.js.map +0 -1
- package/.next/static/chunks/4912d72f34832326.js +0 -3
- package/.next/static/chunks/dc895d87368362da.css +0 -3
- /package/.next/static/{ocMpsYGXHH9jCRWP6zbfc → v6mncCHdB1IHE5fd7JPBO}/_buildManifest.js +0 -0
- /package/.next/static/{ocMpsYGXHH9jCRWP6zbfc → v6mncCHdB1IHE5fd7JPBO}/_clientMiddlewareManifest.json +0 -0
- /package/.next/static/{ocMpsYGXHH9jCRWP6zbfc → v6mncCHdB1IHE5fd7JPBO}/_ssgManifest.js +0 -0
package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_14850b56.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/app/api/component-source/resolve/route.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import fs from 'fs/promises';\nimport path from 'path';\nimport { execFile } from 'child_process';\nimport { promisify } from 'util';\nimport { NextRequest, NextResponse } from 'next/server';\n\nexport const runtime = 'nodejs';\n\nconst execFileAsync = promisify(execFile);\n\ntype ResolveComponentSourceRequestBody = {\n componentName?: string;\n componentNames?: string[];\n workspaceRoot?: string;\n};\n\nconst SEARCH_GLOBS = [\n '!**/node_modules/**',\n '!**/.git/**',\n '!**/.next/**',\n '!**/dist/**',\n '!**/build/**',\n '!**/coverage/**',\n '*.{ts,tsx,js,jsx,mjs,cjs}',\n];\nconst SOURCE_EXTENSIONS = ['.tsx', '.ts', '.jsx', '.js', '.mjs', '.cjs'] as const;\nconst IGNORED_DIR_NAMES = new Set([\n 'node_modules',\n '.git',\n '.next',\n 'dist',\n 'build',\n 'coverage',\n '.turbo',\n '.cache',\n]);\nconst MAX_WALKED_FILES = 10000;\nconst MAX_FILE_BYTES = 512 * 1024;\n\nconst escapeRegex = (value: string): string => value.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n\nconst toKebabCase = (value: string): string =>\n value\n .replace(/([a-z0-9])([A-Z])/g, '$1-$2')\n .replace(/[\\s_]+/g, '-')\n .toLowerCase();\n\nconst unique = (items: string[]): string[] => Array.from(new Set(items));\n\nconst normalizeComponentLookupName = (value: string): string => {\n const trimmed = value.trim();\n if (!trimmed) return '';\n\n const match = trimmed.match(/[A-Za-z_$][\\w$]*/);\n return match ? match[0] : '';\n};\n\nconst toPascalCase = (value: string): string =>\n value\n .split(/[-_\\s]+/)\n .filter(Boolean)\n .map((segment) => segment[0] ? segment[0].toUpperCase() + segment.slice(1) : '')\n .join('');\n\nconst buildSearchPatterns = (componentName: string): string[] => {\n const escaped = escapeRegex(componentName);\n\n return [\n `\\\\bexport\\\\s+(?:default\\\\s+)?(?:async\\\\s+)?function\\\\s+${escaped}\\\\b`,\n `\\\\b(?:async\\\\s+)?function\\\\s+${escaped}\\\\b`,\n `\\\\b(?:export\\\\s+)?(?:const|let|var)\\\\s+${escaped}\\\\s*=\\\\s*(?:async\\\\s*)?\\\\([^)]*\\\\)\\\\s*=>`,\n `\\\\b(?:export\\\\s+)?(?:const|let|var)\\\\s+${escaped}\\\\s*=\\\\s*(?:async\\\\s*)?[A-Za-z_$][\\\\w$]*\\\\s*=>`,\n `\\\\b(?:export\\\\s+)?(?:const|let|var)\\\\s+${escaped}\\\\s*=\\\\s*(?:memo|forwardRef)\\\\s*\\\\(`,\n `\\\\bexport\\\\s+default\\\\s+${escaped}\\\\b`,\n `\\\\bclass\\\\s+${escaped}\\\\b`,\n ];\n};\n\nconst buildRgArgs = (pattern: string): string[] => {\n const args = [\n '-l',\n '--no-messages',\n '--pcre2',\n ];\n\n for (const glob of SEARCH_GLOBS) {\n args.push('--glob', glob);\n }\n\n args.push(pattern, '.');\n return args;\n};\n\nconst buildDirectCandidates = (componentName: string): string[] => {\n const kebab = toKebabCase(componentName);\n const pascal = toPascalCase(componentName);\n const snake = componentName\n .replace(/([a-z0-9])([A-Z])/g, '$1_$2')\n .replace(/[\\s-]+/g, '_')\n .toLowerCase();\n\n const baseDirs = [\n 'src/components',\n 'components',\n 'src',\n ];\n const baseNames = unique([kebab, pascal, snake, componentName]);\n const candidates: string[] = [];\n\n for (const dir of baseDirs) {\n for (const base of baseNames) {\n for (const ext of SOURCE_EXTENSIONS) {\n candidates.push(`${dir}/${base}${ext}`);\n }\n }\n }\n\n return candidates;\n};\n\nconst fileExists = async (absolutePath: string): Promise<boolean> => {\n try {\n const stat = await fs.stat(absolutePath);\n return stat.isFile();\n } catch {\n return false;\n }\n};\n\nconst runPatternSearch = async (workspaceRoot: string, pattern: string): Promise<string[]> => {\n try {\n const { stdout } = await execFileAsync('rg', buildRgArgs(pattern), {\n cwd: workspaceRoot,\n maxBuffer: 2 * 1024 * 1024,\n timeout: 20000,\n });\n\n return stdout\n .split('\\n')\n .map((line) => line.trim())\n .filter(Boolean);\n } catch {\n try {\n const { stdout } = await execFileAsync('git', ['grep', '-l', '-P', pattern], {\n cwd: workspaceRoot,\n maxBuffer: 2 * 1024 * 1024,\n timeout: 20000,\n });\n\n return stdout\n .split('\\n')\n .map((line) => line.trim())\n .filter(Boolean);\n } catch {\n return [];\n }\n }\n};\n\nconst walkSourceFiles = async (workspaceRoot: string): Promise<string[]> => {\n try {\n const { stdout } = await execFileAsync('git', ['ls-files', '--cached', '--others', '--exclude-standard'], {\n cwd: workspaceRoot,\n maxBuffer: 10 * 1024 * 1024,\n timeout: 10000,\n });\n \n const gitFiles = stdout\n .split('\\n')\n .map((line) => line.trim())\n .filter((line) => line && SOURCE_EXTENSIONS.some((ext) => line.endsWith(ext)))\n .map((line) => path.join(workspaceRoot, line));\n \n if (gitFiles.length > 0) {\n return gitFiles;\n }\n } catch {\n // Ignore git error and fallback to manual walk\n }\n\n const files: string[] = [];\n const queue: string[] = [workspaceRoot];\n\n while (queue.length > 0 && files.length < MAX_WALKED_FILES) {\n const currentDir = queue.shift();\n if (!currentDir) continue;\n\n let entries: Array<{ isDirectory: () => boolean; isFile: () => boolean; name: string }>;\n try {\n entries = await fs.readdir(currentDir, { withFileTypes: true });\n } catch {\n continue;\n }\n\n for (const entry of entries) {\n const fullPath = path.join(currentDir, entry.name);\n if (entry.isDirectory()) {\n if (!IGNORED_DIR_NAMES.has(entry.name)) {\n queue.push(fullPath);\n }\n continue;\n }\n\n if (!entry.isFile()) continue;\n if (!SOURCE_EXTENSIONS.some((ext) => entry.name.endsWith(ext))) continue;\n\n files.push(fullPath);\n if (files.length >= MAX_WALKED_FILES) break;\n }\n }\n\n return files;\n};\n\nconst searchByScanningFilesForNames = async (workspaceRoot: string, componentNames: string[]): Promise<Map<string, string[]>> => {\n const files = await walkSourceFiles(workspaceRoot);\n if (files.length === 0) return new Map();\n\n const nameToRegexes = new Map<string, RegExp[]>();\n for (const name of componentNames) {\n const regexes = buildSearchPatterns(name).map((pattern) => {\n try {\n return new RegExp(pattern, 'm');\n } catch {\n return null;\n }\n }).filter((entry): entry is RegExp => entry instanceof RegExp);\n if (regexes.length > 0) {\n nameToRegexes.set(name, regexes);\n }\n }\n\n const results = new Map<string, string[]>();\n if (nameToRegexes.size === 0) return results;\n\n const BATCH_SIZE = 100;\n for (let i = 0; i < files.length; i += BATCH_SIZE) {\n const batch = files.slice(i, i + BATCH_SIZE);\n await Promise.all(\n batch.map(async (absolutePath) => {\n try {\n const stat = await fs.stat(absolutePath);\n if (!stat.isFile() || stat.size > MAX_FILE_BYTES) return;\n const content = await fs.readFile(absolutePath, 'utf-8');\n \n const relativePath = path.relative(workspaceRoot, absolutePath);\n \n for (const [name, regexes] of nameToRegexes.entries()) {\n if (regexes.some((regex) => regex.test(content))) {\n const currentMatches = results.get(name) || [];\n currentMatches.push(relativePath);\n results.set(name, currentMatches);\n }\n }\n } catch {\n // Ignore unreadable files\n }\n })\n );\n }\n\n return results;\n};\n\nconst scoreCandidate = (candidatePath: string, componentName: string): number => {\n const normalized = candidatePath.replace(/\\\\/g, '/').toLowerCase();\n const kebabName = toKebabCase(componentName);\n const fileName = path.basename(normalized);\n\n let score = 0;\n if (normalized.includes('/src/components/')) score += 100;\n if (normalized.includes('/components/')) score += 80;\n if (normalized.includes('/src/')) score += 60;\n if (/\\.(tsx|jsx)$/.test(normalized)) score += 20;\n if (fileName.includes(kebabName)) score += 15;\n if (fileName.includes(componentName.toLowerCase())) score += 10;\n if (normalized.includes('/node_modules/')) score -= 1000;\n\n return score;\n};\n\nconst pickBestCandidate = (workspaceRoot: string, componentName: string, relativePaths: string[]): string | null => {\n const absoluteCandidates = unique(relativePaths)\n .map((relativePath) => path.resolve(workspaceRoot, relativePath))\n .filter(Boolean);\n\n if (absoluteCandidates.length === 0) return null;\n\n const sorted = absoluteCandidates.sort((a, b) => {\n const scoreDiff = scoreCandidate(b, componentName) - scoreCandidate(a, componentName);\n if (scoreDiff !== 0) return scoreDiff;\n return a.length - b.length;\n });\n\n return sorted[0] || null;\n};\n\nconst resolveSourcePathByComponentNameFast = async (\n workspaceRoot: string,\n componentName: string\n): Promise<string | null> => {\n const directCandidates = buildDirectCandidates(componentName);\n for (const candidate of directCandidates) {\n const absolute = path.resolve(workspaceRoot, candidate);\n if (await fileExists(absolute)) {\n return absolute;\n }\n }\n\n const patterns = buildSearchPatterns(componentName);\n let candidates: string[] = [];\n\n for (const pattern of patterns) {\n const matches = await runPatternSearch(workspaceRoot, pattern);\n if (matches.length > 0) {\n candidates = matches;\n break;\n }\n }\n\n if (candidates.length > 0) {\n return pickBestCandidate(workspaceRoot, componentName, candidates);\n }\n\n return null;\n};\n\nexport async function POST(request: NextRequest) {\n let body: ResolveComponentSourceRequestBody;\n\n try {\n body = await request.json();\n } catch {\n return NextResponse.json({ error: 'Invalid request payload' }, { status: 400 });\n }\n\n const componentNames = Array.isArray(body.componentNames)\n ? body.componentNames.map((n) => typeof n === 'string' ? normalizeComponentLookupName(n) : '').filter(Boolean)\n : [];\n\n const componentName = typeof body.componentName === 'string'\n ? normalizeComponentLookupName(body.componentName)\n : '';\n\n const namesToResolve = componentNames.length > 0 ? componentNames : (componentName ? [componentName] : []);\n const workspaceRoot = typeof body.workspaceRoot === 'string' ? body.workspaceRoot.trim() : '';\n\n if (namesToResolve.length === 0) {\n return NextResponse.json({ error: 'componentName or componentNames is required' }, { status: 400 });\n }\n\n if (!workspaceRoot || !path.isAbsolute(workspaceRoot)) {\n return NextResponse.json({ error: 'workspaceRoot must be an absolute path' }, { status: 400 });\n }\n\n try {\n const stat = await fs.stat(workspaceRoot);\n if (!stat.isDirectory()) {\n return NextResponse.json({ error: 'workspaceRoot must be a directory' }, { status: 400 });\n }\n\n // Step 1: Try fast resolution (direct candidates + ripgrep) for all names sequentially\n const unresolvedNames: string[] = [];\n for (const name of namesToResolve) {\n const sourcePath = await resolveSourcePathByComponentNameFast(workspaceRoot, name);\n if (sourcePath) {\n return NextResponse.json({ sourcePath, resolvedName: name });\n }\n unresolvedNames.push(name);\n }\n\n // Step 2: If we reach here, neither direct matches nor ripgrep found anything for any of the names.\n // We do ONE filesystem scan for ALL unresolved names.\n if (unresolvedNames.length > 0) {\n const scanResults = await searchByScanningFilesForNames(workspaceRoot, unresolvedNames);\n \n // We process them in order of namesToResolve to keep the precedence\n for (const name of unresolvedNames) {\n const candidates = scanResults.get(name);\n if (candidates && candidates.length > 0) {\n const best = pickBestCandidate(workspaceRoot, name, candidates);\n if (best) {\n return NextResponse.json({ sourcePath: best, resolvedName: name });\n }\n }\n }\n }\n\n return NextResponse.json({ error: 'Source file not found' }, { status: 404 });\n } catch (error) {\n const message = error instanceof Error ? error.message : 'Failed to resolve component source';\n return NextResponse.json({ error: message }, { status: 500 });\n }\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setManifestsSingleton } from \"next/dist/esm/server/app-render/manifests-singleton\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/component-source/resolve/route\",\n pathname: \"/api/component-source/resolve\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/src/app/api/component-source/resolve/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/component-source/resolve/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest\n });\n }\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext, silenceLog)=>routeModule.onRequestError(req, error, errorContext, silenceLog, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil,\n isMinimalMode\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!isMinimalMode) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(isMinimalMode && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${srcPage}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n"],"names":[],"mappings":"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","ignoreList":[1]}
|
|
1
|
+
{"version":3,"sources":["../../../src/app/api/component-source/resolve/route.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js","../../../src/lib/string-utils.ts"],"sourcesContent":["import fs from 'fs/promises';\nimport path from 'path';\nimport { execFile } from 'child_process';\nimport { promisify } from 'util';\nimport { NextRequest, NextResponse } from 'next/server';\nimport { escapeRegex, toKebabCase, toPascalCase, uniqueStrings } from '@/lib/string-utils';\n\nexport const runtime = 'nodejs';\n\nconst execFileAsync = promisify(execFile);\n\ntype ResolveComponentSourceRequestBody = {\n componentName?: string;\n componentNames?: string[];\n workspaceRoot?: string;\n};\n\nconst SEARCH_GLOBS = [\n '!**/node_modules/**',\n '!**/.git/**',\n '!**/.next/**',\n '!**/dist/**',\n '!**/build/**',\n '!**/coverage/**',\n '*.{ts,tsx,js,jsx,mjs,cjs}',\n];\nconst SOURCE_EXTENSIONS = ['.tsx', '.ts', '.jsx', '.js', '.mjs', '.cjs'] as const;\nconst IGNORED_DIR_NAMES = new Set([\n 'node_modules',\n '.git',\n '.next',\n 'dist',\n 'build',\n 'coverage',\n '.turbo',\n '.cache',\n]);\nconst MAX_WALKED_FILES = 10000;\nconst MAX_FILE_BYTES = 512 * 1024;\n\nconst normalizeComponentLookupName = (value: string): string => {\n const trimmed = value.trim();\n if (!trimmed) return '';\n\n const match = trimmed.match(/[A-Za-z_$][\\w$]*/);\n return match ? match[0] : '';\n};\n\nconst buildSearchPatterns = (componentName: string): string[] => {\n const escaped = escapeRegex(componentName);\n\n return [\n `\\\\bexport\\\\s+(?:default\\\\s+)?(?:async\\\\s+)?function\\\\s+${escaped}\\\\b`,\n `\\\\b(?:async\\\\s+)?function\\\\s+${escaped}\\\\b`,\n `\\\\b(?:export\\\\s+)?(?:const|let|var)\\\\s+${escaped}\\\\s*=\\\\s*(?:async\\\\s*)?\\\\([^)]*\\\\)\\\\s*=>`,\n `\\\\b(?:export\\\\s+)?(?:const|let|var)\\\\s+${escaped}\\\\s*=\\\\s*(?:async\\\\s*)?[A-Za-z_$][\\\\w$]*\\\\s*=>`,\n `\\\\b(?:export\\\\s+)?(?:const|let|var)\\\\s+${escaped}\\\\s*=\\\\s*(?:memo|forwardRef)\\\\s*\\\\(`,\n `\\\\bexport\\\\s+default\\\\s+${escaped}\\\\b`,\n `\\\\bclass\\\\s+${escaped}\\\\b`,\n ];\n};\n\nconst buildRgArgs = (pattern: string): string[] => {\n const args = [\n '-l',\n '--no-messages',\n '--pcre2',\n ];\n\n for (const glob of SEARCH_GLOBS) {\n args.push('--glob', glob);\n }\n\n args.push(pattern, '.');\n return args;\n};\n\nconst buildDirectCandidates = (componentName: string): string[] => {\n const kebab = toKebabCase(componentName);\n const pascal = toPascalCase(componentName);\n const snake = componentName\n .replace(/([a-z0-9])([A-Z])/g, '$1_$2')\n .replace(/[\\s-]+/g, '_')\n .toLowerCase();\n\n const baseDirs = [\n 'src/components',\n 'components',\n 'src',\n ];\n const baseNames = uniqueStrings([kebab, pascal, snake, componentName]);\n const candidates: string[] = [];\n\n for (const dir of baseDirs) {\n for (const base of baseNames) {\n for (const ext of SOURCE_EXTENSIONS) {\n candidates.push(`${dir}/${base}${ext}`);\n }\n }\n }\n\n return candidates;\n};\n\nconst fileExists = async (absolutePath: string): Promise<boolean> => {\n try {\n const stat = await fs.stat(absolutePath);\n return stat.isFile();\n } catch {\n return false;\n }\n};\n\nconst runPatternSearch = async (workspaceRoot: string, pattern: string): Promise<string[]> => {\n try {\n const { stdout } = await execFileAsync('rg', buildRgArgs(pattern), {\n cwd: workspaceRoot,\n maxBuffer: 2 * 1024 * 1024,\n timeout: 20000,\n });\n\n return stdout\n .split('\\n')\n .map((line) => line.trim())\n .filter(Boolean);\n } catch {\n try {\n const { stdout } = await execFileAsync('git', ['grep', '-l', '-P', pattern], {\n cwd: workspaceRoot,\n maxBuffer: 2 * 1024 * 1024,\n timeout: 20000,\n });\n\n return stdout\n .split('\\n')\n .map((line) => line.trim())\n .filter(Boolean);\n } catch {\n return [];\n }\n }\n};\n\nconst walkSourceFiles = async (workspaceRoot: string): Promise<string[]> => {\n try {\n const { stdout } = await execFileAsync('git', ['ls-files', '--cached', '--others', '--exclude-standard'], {\n cwd: workspaceRoot,\n maxBuffer: 10 * 1024 * 1024,\n timeout: 10000,\n });\n \n const gitFiles = stdout\n .split('\\n')\n .map((line) => line.trim())\n .filter((line) => line && SOURCE_EXTENSIONS.some((ext) => line.endsWith(ext)))\n .map((line) => path.join(workspaceRoot, line));\n \n if (gitFiles.length > 0) {\n return gitFiles;\n }\n } catch {\n // Ignore git error and fallback to manual walk\n }\n\n const files: string[] = [];\n const queue: string[] = [workspaceRoot];\n\n while (queue.length > 0 && files.length < MAX_WALKED_FILES) {\n const currentDir = queue.shift();\n if (!currentDir) continue;\n\n let entries: Array<{ isDirectory: () => boolean; isFile: () => boolean; name: string }>;\n try {\n entries = await fs.readdir(currentDir, { withFileTypes: true });\n } catch {\n continue;\n }\n\n for (const entry of entries) {\n const fullPath = path.join(currentDir, entry.name);\n if (entry.isDirectory()) {\n if (!IGNORED_DIR_NAMES.has(entry.name)) {\n queue.push(fullPath);\n }\n continue;\n }\n\n if (!entry.isFile()) continue;\n if (!SOURCE_EXTENSIONS.some((ext) => entry.name.endsWith(ext))) continue;\n\n files.push(fullPath);\n if (files.length >= MAX_WALKED_FILES) break;\n }\n }\n\n return files;\n};\n\nconst runWithConcurrency = async <T>(\n items: T[],\n limit: number,\n fn: (item: T) => Promise<void>\n): Promise<void> => {\n const ret: Promise<void>[] = [];\n const executing: Promise<void>[] = [];\n\n for (const item of items) {\n const p = Promise.resolve().then(() => fn(item));\n ret.push(p);\n\n if (limit <= items.length) {\n const e: Promise<void> = p.then(() => {\n executing.splice(executing.indexOf(e), 1);\n });\n executing.push(e);\n if (executing.length >= limit) {\n await Promise.race(executing);\n }\n }\n }\n\n await Promise.all(ret);\n};\n\nconst searchByScanningFilesForNames = async (workspaceRoot: string, componentNames: string[]): Promise<Map<string, string[]>> => {\n const files = await walkSourceFiles(workspaceRoot);\n if (files.length === 0) return new Map();\n\n const nameToRegexes = new Map<string, RegExp[]>();\n for (const name of componentNames) {\n const regexes = buildSearchPatterns(name).map((pattern) => {\n try {\n return new RegExp(pattern, 'm');\n } catch {\n return null;\n }\n }).filter((entry): entry is RegExp => entry instanceof RegExp);\n if (regexes.length > 0) {\n nameToRegexes.set(name, regexes);\n }\n }\n\n const results = new Map<string, string[]>();\n if (nameToRegexes.size === 0) return results;\n\n const CONCURRENCY_LIMIT = 100;\n await runWithConcurrency(files, CONCURRENCY_LIMIT, async (absolutePath) => {\n try {\n const stat = await fs.stat(absolutePath);\n if (!stat.isFile() || stat.size > MAX_FILE_BYTES) return;\n const content = await fs.readFile(absolutePath, 'utf-8');\n\n const relativePath = path.relative(workspaceRoot, absolutePath);\n\n for (const [name, regexes] of nameToRegexes.entries()) {\n if (regexes.some((regex) => regex.test(content))) {\n const currentMatches = results.get(name) || [];\n currentMatches.push(relativePath);\n results.set(name, currentMatches);\n }\n }\n } catch {\n // Ignore unreadable files\n }\n });\n\n return results;\n};\n\nconst scoreCandidate = (candidatePath: string, componentName: string): number => {\n const normalized = candidatePath.replace(/\\\\/g, '/').toLowerCase();\n const kebabName = toKebabCase(componentName);\n const fileName = path.basename(normalized);\n\n let score = 0;\n if (normalized.includes('/src/components/')) score += 100;\n if (normalized.includes('/components/')) score += 80;\n if (normalized.includes('/src/')) score += 60;\n if (/\\.(tsx|jsx)$/.test(normalized)) score += 20;\n if (fileName.includes(kebabName)) score += 15;\n if (fileName.includes(componentName.toLowerCase())) score += 10;\n if (normalized.includes('/node_modules/')) score -= 1000;\n\n return score;\n};\n\nconst pickBestCandidate = (workspaceRoot: string, componentName: string, relativePaths: string[]): string | null => {\n const absoluteCandidates = uniqueStrings(relativePaths)\n .map((relativePath) => path.resolve(workspaceRoot, relativePath))\n .filter(Boolean);\n\n if (absoluteCandidates.length === 0) return null;\n\n const sorted = absoluteCandidates.sort((a, b) => {\n const scoreDiff = scoreCandidate(b, componentName) - scoreCandidate(a, componentName);\n if (scoreDiff !== 0) return scoreDiff;\n return a.length - b.length;\n });\n\n return sorted[0] || null;\n};\n\nconst resolveSourcePathByComponentNameFast = async (\n workspaceRoot: string,\n componentName: string\n): Promise<string | null> => {\n const directCandidates = buildDirectCandidates(componentName);\n\n const checks = directCandidates.map(async (candidate) => {\n const absolute = path.resolve(workspaceRoot, candidate);\n const exists = await fileExists(absolute);\n return exists ? absolute : null;\n });\n\n const results = await Promise.all(checks);\n const firstMatch = results.find((result) => result !== null);\n\n if (firstMatch) {\n return firstMatch;\n }\n\n const patterns = buildSearchPatterns(componentName);\n let candidates: string[] = [];\n\n for (const pattern of patterns) {\n const matches = await runPatternSearch(workspaceRoot, pattern);\n if (matches.length > 0) {\n candidates = matches;\n break;\n }\n }\n\n if (candidates.length > 0) {\n return pickBestCandidate(workspaceRoot, componentName, candidates);\n }\n\n return null;\n};\n\nexport async function POST(request: NextRequest) {\n let body: ResolveComponentSourceRequestBody;\n\n try {\n body = await request.json();\n } catch {\n return NextResponse.json({ error: 'Invalid request payload' }, { status: 400 });\n }\n\n const componentNames = Array.isArray(body.componentNames)\n ? body.componentNames.map((n) => typeof n === 'string' ? normalizeComponentLookupName(n) : '').filter(Boolean)\n : [];\n\n const componentName = typeof body.componentName === 'string'\n ? normalizeComponentLookupName(body.componentName)\n : '';\n\n const namesToResolve = componentNames.length > 0 ? componentNames : (componentName ? [componentName] : []);\n const workspaceRoot = typeof body.workspaceRoot === 'string' ? body.workspaceRoot.trim() : '';\n\n if (namesToResolve.length === 0) {\n return NextResponse.json({ error: 'componentName or componentNames is required' }, { status: 400 });\n }\n\n if (!workspaceRoot || !path.isAbsolute(workspaceRoot)) {\n return NextResponse.json({ error: 'workspaceRoot must be an absolute path' }, { status: 400 });\n }\n\n try {\n const stat = await fs.stat(workspaceRoot);\n if (!stat.isDirectory()) {\n return NextResponse.json({ error: 'workspaceRoot must be a directory' }, { status: 400 });\n }\n\n // Step 1: Try fast resolution (direct candidates + ripgrep) for all names sequentially\n const unresolvedNames: string[] = [];\n for (const name of namesToResolve) {\n const sourcePath = await resolveSourcePathByComponentNameFast(workspaceRoot, name);\n if (sourcePath) {\n return NextResponse.json({ sourcePath, resolvedName: name });\n }\n unresolvedNames.push(name);\n }\n\n // Step 2: If we reach here, neither direct matches nor ripgrep found anything for any of the names.\n // We do ONE filesystem scan for ALL unresolved names.\n if (unresolvedNames.length > 0) {\n const scanResults = await searchByScanningFilesForNames(workspaceRoot, unresolvedNames);\n \n // We process them in order of namesToResolve to keep the precedence\n for (const name of unresolvedNames) {\n const candidates = scanResults.get(name);\n if (candidates && candidates.length > 0) {\n const best = pickBestCandidate(workspaceRoot, name, candidates);\n if (best) {\n return NextResponse.json({ sourcePath: best, resolvedName: name });\n }\n }\n }\n }\n\n return NextResponse.json({ error: 'Source file not found' }, { status: 404 });\n } catch (error) {\n const message = error instanceof Error ? error.message : 'Failed to resolve component source';\n return NextResponse.json({ error: message }, { status: 500 });\n }\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setManifestsSingleton } from \"next/dist/esm/server/app-render/manifests-singleton\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/component-source/resolve/route\",\n pathname: \"/api/component-source/resolve\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/src/app/api/component-source/resolve/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/component-source/resolve/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest\n });\n }\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext, silenceLog)=>routeModule.onRequestError(req, error, errorContext, silenceLog, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil,\n isMinimalMode\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!isMinimalMode) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(isMinimalMode && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${srcPage}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n","export const escapeRegex = (value: string): string => value.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n\nexport const toKebabCase = (value: string): string =>\n value\n .replace(/([a-z0-9])([A-Z])/g, '$1-$2')\n .replace(/[\\s_]+/g, '-')\n .toLowerCase();\n\nexport const toPascalCase = (value: string): string =>\n value\n .split(/[-_\\s]+/)\n .filter(Boolean)\n .map((segment) => (segment[0] ? segment[0].toUpperCase() + segment.slice(1) : ''))\n .join('');\n\nexport const uniqueStrings = (items: string[]): string[] => Array.from(new Set(items));\n"],"names":[],"mappings":"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","ignoreList":[1]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
module.exports=[37936,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"registerServerReference",{enumerable:!0,get:function(){return d.registerServerReference}});let d=a.r(11857)},51615,(a,b,c)=>{b.exports=a.x("node:buffer",()=>require("node:buffer"))},22734,(a,b,c)=>{b.exports=a.x("fs",()=>require("fs"))},41202,(a,b,c)=>{function d(a,b,c,d){return Math.round(a/c)+" "+d+(b>=1.5*c?"s":"")}b.exports=function(a,b){b=b||{};var c,e,f,g,h=typeof a;if("string"===h&&a.length>0){var i=a;if(!((i=String(i)).length>100)){var j=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(j){var k=parseFloat(j[1]);switch((j[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return 315576e5*k;case"weeks":case"week":case"w":return 6048e5*k;case"days":case"day":case"d":return 864e5*k;case"hours":case"hour":case"hrs":case"hr":case"h":return 36e5*k;case"minutes":case"minute":case"mins":case"min":case"m":return 6e4*k;case"seconds":case"second":case"secs":case"sec":case"s":return 1e3*k;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return k;default:break}}}return}if("number"===h&&isFinite(a)){return b.long?(e=Math.abs(c=a))>=864e5?d(c,e,864e5,"day"):e>=36e5?d(c,e,36e5,"hour"):e>=6e4?d(c,e,6e4,"minute"):e>=1e3?d(c,e,1e3,"second"):c+" ms":(g=Math.abs(f=a))>=864e5?Math.round(f/864e5)+"d":g>=36e5?Math.round(f/36e5)+"h":g>=6e4?Math.round(f/6e4)+"m":g>=1e3?Math.round(f/1e3)+"s":f+"ms"}throw Error("val is not a non-empty string or a valid number. val="+JSON.stringify(a))}},93830,(a,b,c)=>{b.exports=function(b){function c(a){let b,e,f,g=null;function h(...a){if(!h.enabled)return;let d=Number(new Date);h.diff=d-(b||d),h.prev=b,h.curr=d,b=d,a[0]=c.coerce(a[0]),"string"!=typeof a[0]&&a.unshift("%O");let e=0;a[0]=a[0].replace(/%([a-zA-Z%])/g,(b,d)=>{if("%%"===b)return"%";e++;let f=c.formatters[d];if("function"==typeof f){let c=a[e];b=f.call(h,c),a.splice(e,1),e--}return b}),c.formatArgs.call(h,a),(h.log||c.log).apply(h,a)}return h.namespace=a,h.useColors=c.useColors(),h.color=c.selectColor(a),h.extend=d,h.destroy=c.destroy,Object.defineProperty(h,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==g?g:(e!==c.namespaces&&(e=c.namespaces,f=c.enabled(a)),f),set:a=>{g=a}}),"function"==typeof c.init&&c.init(h),h}function d(a,b){let d=c(this.namespace+(void 0===b?":":b)+a);return d.log=this.log,d}function e(a,b){let c=0,d=0,e=-1,f=0;for(;c<a.length;)if(d<b.length&&(b[d]===a[c]||"*"===b[d]))"*"===b[d]?(e=d,f=c):c++,d++;else{if(-1===e)return!1;d=e+1,c=++f}for(;d<b.length&&"*"===b[d];)d++;return d===b.length}return c.debug=c,c.default=c,c.coerce=function(a){return a instanceof Error?a.stack||a.message:a},c.disable=function(){let a=[...c.names,...c.skips.map(a=>"-"+a)].join(",");return c.enable(""),a},c.enable=function(a){for(let b of(c.save(a),c.namespaces=a,c.names=[],c.skips=[],("string"==typeof a?a:"").trim().replace(/\s+/g,",").split(",").filter(Boolean)))"-"===b[0]?c.skips.push(b.slice(1)):c.names.push(b)},c.enabled=function(a){for(let b of c.skips)if(e(a,b))return!1;for(let b of c.names)if(e(a,b))return!0;return!1},c.humanize=a.r(41202),c.destroy=function(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")},Object.keys(b).forEach(a=>{c[a]=b[a]}),c.names=[],c.skips=[],c.formatters={},c.selectColor=function(a){let b=0;for(let c=0;c<a.length;c++)b=(b<<5)-b+a.charCodeAt(c)|0;return c.colors[Math.abs(b)%c.colors.length]},c.enable(c.load()),c}},36354,(a,b,c)=>{"use strict";b.exports=(a,b=process.argv)=>{let c=a.startsWith("-")?"":1===a.length?"-":"--",d=b.indexOf(c+a),e=b.indexOf("--");return -1!==d&&(-1===e||d<e)}},45681,(a,b,c)=>{"use strict";let d;a.r(46786);let e=a.r(70722),f=a.r(36354),{env:g}=process;function h(a){return 0!==a&&{level:a,hasBasic:!0,has256:a>=2,has16m:a>=3}}function i(a,b){if(0===d)return 0;if(f("color=16m")||f("color=full")||f("color=truecolor"))return 3;if(f("color=256"))return 2;if(a&&!b&&void 0===d)return 0;let c=d||0;if("dumb"===g.TERM)return c;if("CI"in g)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some(a=>a in g)||"codeship"===g.CI_NAME?1:c;if("TEAMCITY_VERSION"in g)return+!!/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(g.TEAMCITY_VERSION);if("truecolor"===g.COLORTERM)return 3;if("TERM_PROGRAM"in g){let a=parseInt((g.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(g.TERM_PROGRAM){case"iTerm.app":return a>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(g.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(g.TERM)||"COLORTERM"in g?1:c}f("no-color")||f("no-colors")||f("color=false")||f("color=never")?d=0:(f("color")||f("colors")||f("color=true")||f("color=always"))&&(d=1),"FORCE_COLOR"in g&&(d="true"===g.FORCE_COLOR?1:"false"===g.FORCE_COLOR?0:0===g.FORCE_COLOR.length?1:Math.min(parseInt(g.FORCE_COLOR,10),3)),b.exports={supportsColor:function(a){return h(i(a,a&&a.isTTY))},stdout:h(i(!0,e.isatty(1))),stderr:h(i(!0,e.isatty(2)))}},16956,(a,b,c)=>{let d=a.r(70722),e=a.r(24361);c.init=function(a){a.inspectOpts={};let b=Object.keys(c.inspectOpts);for(let d=0;d<b.length;d++)a.inspectOpts[b[d]]=c.inspectOpts[b[d]]},c.log=function(...a){return process.stderr.write(e.formatWithOptions(c.inspectOpts,...a)+"\n")},c.formatArgs=function(a){let{namespace:d,useColors:e}=this;if(e){let c=this.color,e="\x1b[3"+(c<8?c:"8;5;"+c),f=` ${e};1m${d} \u001B[0m`;a[0]=f+a[0].split("\n").join("\n"+f),a.push(e+"m+"+b.exports.humanize(this.diff)+"\x1b[0m")}else a[0]=(c.inspectOpts.hideDate?"":new Date().toISOString()+" ")+d+" "+a[0]},c.save=function(a){a?process.env.DEBUG=a:delete process.env.DEBUG},c.load=function(){return process.env.DEBUG},c.useColors=function(){return"colors"in c.inspectOpts?!!c.inspectOpts.colors:d.isatty(process.stderr.fd)},c.destroy=e.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),c.colors=[6,2,3,4,5,1];try{let b=a.r(45681);b&&(b.stderr||b).level>=2&&(c.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch(a){}c.inspectOpts=Object.keys(process.env).filter(a=>/^debug_/i.test(a)).reduce((a,b)=>{let c=b.substring(6).toLowerCase().replace(/_([a-z])/g,(a,b)=>b.toUpperCase()),d=process.env[b];return d=!!/^(yes|on|true|enabled)$/i.test(d)||!/^(no|off|false|disabled)$/i.test(d)&&("null"===d?null:Number(d)),a[c]=d,a},{}),b.exports=a.r(93830)(c);let{formatters:f}=b.exports;f.o=function(a){return this.inspectOpts.colors=this.useColors,e.inspect(a,this.inspectOpts).split("\n").map(a=>a.trim()).join(" ")},f.O=function(a){return this.inspectOpts.colors=this.useColors,e.inspect(a,this.inspectOpts)}},58077,(a,b,c)=>{let d;c.formatArgs=function(a){if(a[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+a[0]+(this.useColors?"%c ":" ")+"+"+b.exports.humanize(this.diff),!this.useColors)return;let c="color: "+this.color;a.splice(1,0,c,"color: inherit");let d=0,e=0;a[0].replace(/%[a-zA-Z%]/g,a=>{"%%"!==a&&(d++,"%c"===a&&(e=d))}),a.splice(e,0,c)},c.save=function(a){try{a?c.storage.setItem("debug",a):c.storage.removeItem("debug")}catch(a){}},c.load=function(){let a;try{a=c.storage.getItem("debug")||c.storage.getItem("DEBUG")}catch(a){}return!a&&"u">typeof process&&"env"in process&&(a=process.env.DEBUG),a},c.useColors=function(){let a;return!("u">typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("u">typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"u">typeof navigator&&navigator.userAgent&&(a=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(a[1],10)>=31||"u">typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},c.storage=function(){try{return localStorage}catch(a){}}(),d=!1,c.destroy=()=>{d||(d=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))},c.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],c.log=console.debug||console.log||(()=>{}),b.exports=a.r(93830)(c);let{formatters:e}=b.exports;e.j=function(a){try{return JSON.stringify(a)}catch(a){return"[UnexpectedJSONParseError]: "+a.message}}},61998,(a,b,c)=>{"u"<typeof process||"renderer"===process.type||process.__nwjs?b.exports=a.r(58077):b.exports=a.r(16956)},50023,(a,b,c)=>{"use strict";var d=a.e&&a.e.__importDefault||function(a){return a&&a.__esModule?a:{default:a}};Object.defineProperty(c,"__esModule",{value:!0});let e=a.r(22734),f=d(a.r(61998)).default("@kwsites/file-exists");c.exists=function(a,b=c.READABLE){return function(a,b,c){f("checking %s",a);try{let d=e.statSync(a);if(d.isFile()&&b)return f("[OK] path represents a file"),!0;if(d.isDirectory()&&c)return f("[OK] path represents a directory"),!0;return f("[FAIL] path represents something other than a file or directory"),!1}catch(a){if("ENOENT"===a.code)return f("[FAIL] path is not accessible: %o",a),!1;throw f("[FATAL] %o",a),a}}(a,(b&c.FILE)>0,(b&c.FOLDER)>0)},c.FILE=1,c.FOLDER=2,c.READABLE=c.FILE+c.FOLDER},2355,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0});var d=a.r(50023);for(var e in d)c.hasOwnProperty(e)||(c[e]=d[e])},68076,(a,b,c)=>{"use strict";function d(){let a,b,c="pending";return{promise:new Promise((c,d)=>{a=c,b=d}),done(b){"pending"===c&&(c="resolved",a(b))},fail(a){"pending"===c&&(c="rejected",b(a))},get fulfilled(){return"pending"!==c},get status(){return c}}}Object.defineProperty(c,"__esModule",{value:!0}),c.createDeferred=c.deferred=void 0,c.deferred=d,c.createDeferred=d,c.default=d},50227,(a,b,c)=>{b.exports=a.x("node:path",()=>require("node:path"))},87769,(a,b,c)=>{b.exports=a.x("node:events",()=>require("node:events"))},4503,a=>{"use strict";let b,c;var d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,$,_,aa,ab,ac,ad,ae,af,ag,ah,ai,aj,ak,al,am,an,ao,ap,aq,ar,as,at,au,av,aw,ax,ay,az,aA,aB,aC,aD,aE,aF,aG,aH,aI,aJ,aK,aL,aM,aN,aO,aP,aQ,aR,aS,aT,aU,aV,aW,aX=a.i(51615),aY=a.i(2355),aZ=a.i(61998),a$=a.i(33405),a_=a.i(68076),a0=a.i(50227),a1=a.i(87769),a2=Object.defineProperty,a3=Object.getOwnPropertyDescriptor,a4=Object.getOwnPropertyNames,a5=Object.prototype.hasOwnProperty,a6=(a,b)=>function(){return a&&(b=(0,a[a4(a)[0]])(a=0)),b},a7=(a,b)=>{for(var c in b)a2(a,c,{get:b[c],enumerable:!0})},a8=a=>((a,b,c,d)=>{if(b&&"object"==typeof b||"function"==typeof b)for(let e of a4(b))a5.call(a,e)||e===c||a2(a,e,{get:()=>b[e],enumerable:!(d=a3(b,e))||d.enumerable});return a})(a2({},"__esModule",{value:!0}),a);function a9(a){return a instanceof String&&d.has(a)}function ba(a){return d.get(a)||[]}var bb=a6({"src/lib/args/pathspec.ts"(){d=new WeakMap}}),bc=a6({"src/lib/errors/git-error.ts"(){e=class extends Error{constructor(a,b){super(b),this.task=a,Object.setPrototypeOf(this,new.target.prototype)}}}}),bd=a6({"src/lib/errors/git-response-error.ts"(){bc(),f=class extends e{constructor(a,b){super(void 0,b||String(a)),this.git=a}}}}),be=a6({"src/lib/errors/task-configuration-error.ts"(){bc(),g=class extends e{constructor(a){super(void 0,a)}}}});function bf(a){return"function"!=typeof a?i:a}function bg(a){return"function"==typeof a&&a!==i}function bh(a,b){let c=a.indexOf(b);return c<=0?[a,""]:[a.substr(0,c),a.substr(c+1)]}function bi(a,b=0){return o(a)&&a.length>b?a[b]:void 0}function bj(a,b=0){if(o(a)&&a.length>b)return a[a.length-1-b]}function bk(a="",b=!0,c="\n"){return a.split(c).reduce((a,c)=>{let d=b?c.trim():c;return d&&a.push(d),a},[])}function bl(a,b){return bk(a,!0).map(a=>b(a))}function bm(a){return(0,aY.exists)(a,aY.FOLDER)}function bn(a,b){return Array.isArray(a)?a.includes(b)||a.push(b):a.add(b),b}function bo(a,b){return Array.isArray(a)&&!a.includes(b)&&a.push(b),a}function bp(a,b){if(Array.isArray(a)){let c=a.indexOf(b);c>=0&&a.splice(c,1)}else a.delete(b);return b}function bq(a){return Array.isArray(a)?a:[a]}function br(a){return a.replace(/[\s-]+(.)/g,(a,b)=>b.toUpperCase())}function bs(a){return bq(a).map(a=>a instanceof String?a:String(a))}function bt(a,b=0){if(null==a)return b;let c=parseInt(a,10);return Number.isNaN(c)?b:c}function bu(a,b){let c=[];for(let d=0,e=a.length;d<e;d++)c.push(b,a[d]);return c}function bv(a){return(Array.isArray(a)?aX.Buffer.concat(a):a).toString("utf-8")}function bw(a,b){let c={};return b.forEach(b=>{void 0!==a[b]&&(c[b]=a[b])}),c}function bx(a=0){return new Promise(b=>setTimeout(b,a))}function by(a){if(!1!==a)return a}var bz=a6({"src/lib/utils/util.ts"(){bE(),h="\0",i=()=>{},j=Object.prototype.toString.call.bind(Object.prototype.toString)}});function bA(a,b,c){return b(a)?a:arguments.length>2?c:void 0}function bB(a,b){let c=a9(a)?"string":typeof a;return/number|string|boolean/.test(c)&&(!b||!b.includes(c))}function bC(a){return!!a&&"[object Object]"===j(a)}function bD(a){return"function"==typeof a}var bE=a6({"src/lib/utils/argument-filters.ts"(){bb(),bz(),k=a=>Array.isArray(a),l=a=>"number"==typeof a,m=a=>"string"==typeof a,n=a=>m(a)||Array.isArray(a)&&a.every(m),o=a=>!(null==a||"number|boolean|function".includes(typeof a))&&"number"==typeof a.length}}),bF=a6({"src/lib/utils/exit-codes.ts"(){var a;(a=p||{})[a.SUCCESS=0]="SUCCESS",a[a.ERROR=1]="ERROR",a[a.NOT_FOUND=-2]="NOT_FOUND",a[a.UNCLEAN=128]="UNCLEAN",p=a}}),bG=a6({"src/lib/utils/git-output-streams.ts"(){q=class a{constructor(a,b){this.stdOut=a,this.stdErr=b}asStrings(){return new a(this.stdOut.toString("utf8"),this.stdErr.toString("utf8"))}}}});function bH(){throw Error("LineParser:useMatches not implemented")}var bI=a6({"src/lib/utils/line-parser.ts"(){r=class{constructor(a,b){this.matches=[],this.useMatches=bH,this.parse=(a,b)=>(this.resetMatches(),!!this._regExp.every((b,c)=>this.addMatch(b,c,a(c)))&&!1!==this.useMatches(b,this.prepareMatches())),this._regExp=Array.isArray(a)?a:[a],b&&(this.useMatches=b)}resetMatches(){this.matches.length=0}prepareMatches(){return this.matches}addMatch(a,b,c){let d=c&&a.exec(c);return d&&this.pushMatch(b,d),!!d}pushMatch(a,b){this.matches.push(...b.slice(1))}},s=class extends r{addMatch(a,b,c){return/^remote:\s/.test(String(c))&&super.addMatch(a,b,c)}pushMatch(a,b){(a>0||b.length>1)&&super.pushMatch(a,b)}}}});function bJ(...a){let b=process.cwd(),c=Object.assign({baseDir:b,...t},...a.filter(a=>"object"==typeof a&&a));return c.baseDir=c.baseDir||b,c.trimmed=!0===c.trimmed,c}var bK=a6({"src/lib/utils/simple-git-options.ts"(){t={binary:"git",maxConcurrentProcesses:5,config:[],trimmed:!1}}});function bL(a,b=[]){return bC(a)?Object.keys(a).reduce((b,c)=>{let d=a[c];if(a9(d))b.push(d);else if(bB(d,["boolean"]))b.push(c+"="+d);else if(Array.isArray(d))for(let a of d)bB(a,["string","number"])||b.push(c+"="+a);else b.push(c);return b},b):b}function bM(a,b=0,c=!1){var d;let e,f=[];for(let c=0,d=b<0?a.length:b;c<d;c++)"string|number".includes(typeof a[c])&&f.push(String(a[c]));return bL(bN(a),f),c||f.push(...(e="function"==typeof bj(d=a),bs(bA(bj(d,+!!e),k,[])))),f}function bN(a){let b=bD(bj(a));return bA(bj(a,+!!b),bC)}function bO(a,b=!0){let c=bf(bj(a));return b||bg(c)?c:void 0}var bP=a6({"src/lib/utils/task-options.ts"(){bE(),bz(),bb()}});function bQ(a,b){return a(b.stdOut,b.stdErr)}function bR(a,b,c,d=!0){return bq(c).forEach(c=>{for(let e=bk(c,d),f=0,g=e.length;f<g;f++){let c=(a=0)=>{if(!(f+a>=g))return e[f+a]};b.some(({parse:b})=>b(c,a))}}),a}var bS=a6({"src/lib/utils/task-parser.ts"(){bz()}}),bT={};a7(bT,{ExitCodes:()=>p,GitOutputStreams:()=>q,LineParser:()=>r,NOOP:()=>i,NULL:()=>h,RemoteLineParser:()=>s,append:()=>bn,appendTaskOptions:()=>bL,asArray:()=>bq,asCamelCase:()=>br,asFunction:()=>bf,asNumber:()=>bt,asStringArray:()=>bs,bufferToString:()=>bv,callTaskParser:()=>bQ,createInstanceConfig:()=>bJ,delay:()=>bx,filterArray:()=>k,filterFunction:()=>bD,filterHasLength:()=>o,filterNumber:()=>l,filterPlainObject:()=>bC,filterPrimitives:()=>bB,filterString:()=>m,filterStringOrStringArray:()=>n,filterType:()=>bA,first:()=>bi,folderExists:()=>bm,forEachLineWithContent:()=>bl,getTrailingOptions:()=>bM,including:()=>bo,isUserFunction:()=>bg,last:()=>bj,objectToString:()=>j,orVoid:()=>by,parseStringResponse:()=>bR,pick:()=>bw,prefixedArray:()=>bu,remove:()=>bp,splitOn:()=>bh,toLinesWithContent:()=>bk,trailingFunctionArgument:()=>bO,trailingOptionsArgument:()=>bN});var bU=a6({"src/lib/utils/index.ts"(){bE(),bF(),bG(),bI(),bK(),bP(),bS(),bz()}}),bV={};function bW(a){switch(a){case"bare":return bY();case"root":return bX()}return{commands:["rev-parse","--is-inside-work-tree"],format:"utf-8",onError:v,parser:w}}function bX(){return{commands:["rev-parse","--git-dir"],format:"utf-8",onError:v,parser:a=>/^\.(git)?$/.test(a.trim())}}function bY(){return{commands:["rev-parse","--is-bare-repository"],format:"utf-8",onError:v,parser:w}}a7(bV,{CheckRepoActions:()=>u,checkIsBareRepoTask:()=>bY,checkIsRepoRootTask:()=>bX,checkIsRepoTask:()=>bW});var bZ=a6({"src/lib/tasks/check-is-repo.ts"(){var a;bU(),(a=u||{}).BARE="bare",a.IN_TREE="tree",a.IS_REPO_ROOT="root",u=a,v=({exitCode:a},b,c,d)=>{if(128===a&&/(Not a git repository|Kein Git-Repository)/i.test(String(b)))return c(Buffer.from("false"));d(b)},w=a=>"true"===a.trim()}}),b$=a6({"src/lib/responses/CleanSummary.ts"(){bU(),x=class{constructor(a){this.dryRun=a,this.paths=[],this.files=[],this.folders=[]}},y=/^[a-z]+\s*/i,z=/^[a-z]+\s+[a-z]+\s*/i,A=/\/$/}}),b_={};function b0(a){return{commands:B,format:"empty",parser:a}}function b1(a){return{commands:B,format:"empty",parser(){throw"string"==typeof a?new g(a):a}}}function b2(a,b=!1){return{commands:a,format:"utf-8",parser:a=>b?String(a).trim():a}}function b3(a){return{commands:a,format:"buffer",parser:a=>a}}function b4(a){return"buffer"===a.format}function b5(a){return"empty"===a.format||!a.commands.length}a7(b_,{EMPTY_COMMANDS:()=>B,adhocExecTask:()=>b0,configurationErrorTask:()=>b1,isBufferTask:()=>b4,isEmptyTask:()=>b5,straightThroughBufferTask:()=>b3,straightThroughStringTask:()=>b2});var b6=a6({"src/lib/tasks/task.ts"(){be(),B=[]}}),b7={};function b8(a,b){let c,d,e,{cleanMode:f,options:g,valid:h}=(d=[],e={cleanMode:!1,options:!0},a.replace(/[^a-z]i/g,"").split("").forEach(a=>{var b,f;"f"===(b=a)||"n"===b?(c=a,e.cleanMode=!0):e.options=e.options&&(f=d[d.length]=`-${a}`,/^-[a-z]$/i.test(f)&&G.has(f.charAt(1)))}),{cleanMode:c,options:d,valid:e});return f?h.options?(g.push(...b),g.some(cb))?b1(C):b9(f,g):b1(E+JSON.stringify(a)):b1(D)}function b9(a,b){return{commands:["clean",`-${a}`,...b],format:"utf-8",parser:b=>{var c;let d,e;return d=new x(c="n"===a),e=c?z:y,bk(b).forEach(a=>{let b=a.replace(e,"");d.paths.push(b),(A.test(b)?d.folders:d.files).push(b)}),d}}}function ca(a){return Array.isArray(a)&&a.every(a=>G.has(a))}function cb(a){return/^-[^\-]/.test(a)?a.indexOf("i")>0:"--interactive"===a}a7(b7,{CONFIG_ERROR_INTERACTIVE_MODE:()=>C,CONFIG_ERROR_MODE_REQUIRED:()=>D,CONFIG_ERROR_UNKNOWN_OPTION:()=>E,CleanOptions:()=>F,cleanTask:()=>b9,cleanWithOptionsTask:()=>b8,isCleanOptionsArray:()=>ca});var cc=a6({"src/lib/tasks/clean.ts"(){var a;b$(),bU(),b6(),C="Git clean interactive mode is not supported",D='Git clean mode parameter ("n" or "f") is required',E="Git clean unknown option found in: ",(a=F||{}).DRY_RUN="n",a.FORCE="f",a.IGNORED_INCLUDED="x",a.IGNORED_ONLY="X",a.EXCLUDING="e",a.QUIET="q",a.RECURSIVE="d",G=new Set(["i",...bs(Object.values(F=a))])}});function*cd(a,b=null){let c=a.split("\0");for(let a=0,d=c.length-1;a<d;){let d=c[a++].replace(/^(file):/,""),e=c[a++],f=b;if(e.includes("\n")){let a=bh(e,"\n");f=a[0],e=a[1]}yield{file:d,key:f,value:e}}}var ce=a6({"src/lib/responses/ConfigList.ts"(){bU(),H=class{constructor(){this.files=[],this.values=Object.create(null)}get all(){return this._all||(this._all=this.files.reduce((a,b)=>Object.assign(a,this.values[b]),{})),this._all}addFile(a){if(!(a in this.values)){let b=bj(this.files);this.values[a]=b?Object.create(this.values[b]):{},this.files.push(a)}return this.values[a]}addValue(a,b,c){let d=this.addFile(a);Object.hasOwn(d,b)?Array.isArray(d[b])?d[b].push(c):d[b]=[d[b],c]:d[b]=c,this._all=void 0}}}});function cf(a,b){return"string"==typeof a&&Object.hasOwn(I,a)?a:b}var cg=a6({"src/lib/tasks/config.ts"(){var a;ce(),bU(),(a=I||{}).system="system",a.global="global",a.local="local",a.worktree="worktree",I=a}}),ch=a6({"src/lib/tasks/diff-name-status.ts"(){var a;(a=J||{}).ADDED="A",a.COPIED="C",a.DELETED="D",a.MODIFIED="M",a.RENAMED="R",a.CHANGED="T",a.UNMERGED="U",a.UNKNOWN="X",a.BROKEN="B",K=new Set(Object.values(J=a))}}),ci=a6({"src/lib/tasks/grep.ts"(){bU(),b6(),L=["-h"],M=Symbol("grepQuery"),O=class{constructor(){this[N]=[]}*[(N=M,Symbol.iterator)](){for(let a of this[M])yield a}and(...a){return a.length&&this[M].push("--and","(",...bu(a,"-e"),")"),this}param(...a){return this[M].push(...bu(a,"-e")),this}}}}),cj={};function ck(a,b){let c=["reset"];return cm(a)&&c.push(`--${a}`),c.push(...b),b2(c)}function cl(a){if(cm(a))return a;switch(typeof a){case"string":case"undefined":return"soft"}}function cm(a){return"string"==typeof a&&Q.includes(a)}a7(cj,{ResetMode:()=>P,getResetMode:()=>cl,resetTask:()=>ck});var cn=a6({"src/lib/tasks/reset.ts"(){var a;bU(),b6(),(a=P||{}).MIXED="mixed",a.SOFT="soft",a.HARD="hard",a.MERGE="merge",a.KEEP="keep",Q=bs(Object.values(P=a))}});function co(a,b,c){return b&&String(b).replace(/\s*/,"")?(d,...e)=>{a(`%s ${d}`,b,...e),c&&c(d,...e)}:c?(b,...d)=>{a(b,...d),c(b,...d)}:a}function cp(a,b,c,d=(0,aZ.default)("simple-git")){let e=a&&`[${a}]`||"",f=[],g="string"==typeof b?d.extend(b):b,h=function(a,b,{namespace:c}){if("string"==typeof a)return a;let d=b&&b.namespace||"";return d.startsWith(c)?d.substr(c.length+1):d||c}(bA(b,m),g,d);return function b(c){let f=c&&`[${c}]`||"",h=g&&co(g,f)||i,k=co(d,`${e} ${f}`,h);return Object.assign(g?h:k,{label:a,sibling:j,info:k,step:b})}(c);function j(b,c){return bn(f,cp(a,h.replace(/^[^:]+/,b),c,d))}}var cq=a6({"src/lib/git-logger.ts"(){bU(),aZ.default.formatters.L=a=>String(o(a)?a.length:"-"),aZ.default.formatters.B=a=>Buffer.isBuffer(a)?a.toString("utf8"):j(a)}}),cr=a6({"src/lib/runners/tasks-pending-queue.ts"(){bc(),cq(),R=class a{constructor(a="GitExecutor"){this.logLabel=a,this._queue=new Map}withProgress(a){return this._queue.get(a)}createProgress(b){let c=a.getName(b.commands[0]);return{task:b,logger:cp(this.logLabel,c),name:c}}push(a){let b=this.createProgress(a);return b.logger("Adding task to the queue, commands = %o",a.commands),this._queue.set(a,b),b}fatal(a){for(let[b,{logger:c}]of Array.from(this._queue.entries()))b===a.task?(c.info("Failed %o",a),c("Fatal exception, any as-yet un-started tasks run through this executor will not be attempted")):c.info("A fatal exception occurred in a previous task, the queue has been purged: %o",a.message),this.complete(b);if(0!==this._queue.size)throw Error(`Queue size should be zero after fatal: ${this._queue.size}`)}complete(a){this.withProgress(a)&&this._queue.delete(a)}attempt(a){let b=this.withProgress(a);if(!b)throw new e(void 0,"TasksPendingQueue: attempt called for an unknown task");return b.logger("Starting task"),b}static getName(b="empty"){return`task:${b}:${++a.counter}`}static{this.counter=0}}}});function cs(a,b){return{method:bi(a.commands)||"",commands:b}}function ct(a,b,c,d){return e=>{c("%s received %L bytes",b,e),d("%B",e),a.push(e)}}var cu=a6({"src/lib/runners/git-executor-chain.ts"(){bc(),b6(),bU(),cr(),S=class{constructor(a,b,c){this._executor=a,this._scheduler=b,this._plugins=c,this._chain=Promise.resolve(),this._queue=new R}get cwd(){return this._cwd||this._executor.cwd}set cwd(a){this._cwd=a}get env(){return this._executor.env}get outputHandler(){return this._executor.outputHandler}chain(){return this}push(a){return this._queue.push(a),this._chain=this._chain.then(()=>this.attemptTask(a))}async attemptTask(a){let b=await this._scheduler.next(),c=()=>this._queue.complete(a);try{let{logger:b}=this._queue.attempt(a);return await (b5(a)?this.attemptEmptyTask(a,b):this.attemptRemoteTask(a,b))}catch(b){throw this.onFatalException(a,b)}finally{c(),b()}}onFatalException(a,b){let c=b instanceof e?Object.assign(b,{task:a}):new e(a,b&&String(b));return this._chain=Promise.resolve(),this._queue.fatal(c),c}async attemptRemoteTask(a,b){let c=this._plugins.exec("spawn.binary","",cs(a,a.commands)),d=this._plugins.exec("spawn.args",[...a.commands],cs(a,a.commands)),e=await this.gitResponse(a,c,d,this.outputHandler,b.step("SPAWN")),f=await this.handleTaskData(a,d,e,b.step("HANDLE"));return(b("passing response to task's parser as a %s",a.format),b4(a))?bQ(a.parser,f):bQ(a.parser,f.asStrings())}async attemptEmptyTask(a,b){return b("empty task bypassing child process to call to task's parser"),a.parser(this)}handleTaskData(a,b,c,d){let{exitCode:e,rejection:f,stdOut:g,stdErr:h}=c;return new Promise((i,k)=>{d("Preparing to handle process response exitCode=%d stdOut=",e);let{error:l}=this._plugins.exec("task.error",{error:f},{...cs(a,b),...c});return l&&a.onError?(d.info("exitCode=%s handling with custom error handler"),a.onError(c,l,a=>{d.info("custom error handler treated as success"),d("custom error returned a %s",j(a)),i(new q(Array.isArray(a)?Buffer.concat(a):a,Buffer.concat(h)))},k)):l?(d.info("handling as error: exitCode=%s stdErr=%s rejection=%o",e,h.length,f),k(l)):void(d.info("retrieving task output complete"),i(new q(Buffer.concat(g),Buffer.concat(h))))})}async gitResponse(a,b,c,d,e){let f=e.sibling("output"),g=this._plugins.exec("spawn.options",{cwd:this.cwd,env:this.env,windowsHide:!0},cs(a,a.commands));return new Promise(h=>{let i=[],j=[];e.info("%s %o",b,c),e("%O",g);let k=this._beforeSpawn(a,c);if(k)return h({stdOut:i,stdErr:j,exitCode:9901,rejection:k});this._plugins.exec("spawn.before",void 0,{...cs(a,c),kill(a){k=a||k}});let l=(0,a$.spawn)(b,c,g);l.stdout.on("data",ct(i,"stdOut",e,f.step("stdOut"))),l.stderr.on("data",ct(j,"stdErr",e,f.step("stdErr"))),l.on("error",a=>{e("[ERROR] child process exception %o",a),j.push(Buffer.from(String(a.stack),"ascii"))}),d&&(e("Passing child process stdOut/stdErr to custom outputHandler"),d(b,l.stdout,l.stderr,[...c])),this._plugins.exec("spawn.after",void 0,{...cs(a,c),spawned:l,close(a,b){h({stdOut:i,stdErr:j,exitCode:a,rejection:k||b})},kill(a){l.killed||(k=a,l.kill("SIGINT"))}})})}_beforeSpawn(a,b){let c;return this._plugins.exec("spawn.before",void 0,{...cs(a,b),kill(a){c=a||c}}),c}}}}),cv={};a7(cv,{GitExecutor:()=>T});var cw=a6({"src/lib/runners/git-executor.ts"(){cu(),T=class{constructor(a,b,c){this.cwd=a,this._scheduler=b,this._plugins=c,this._chain=new S(this,this._scheduler,this._plugins)}chain(){return new S(this,this._scheduler,this._plugins)}push(a){return this._chain.push(a)}}}}),cx=a6({"src/lib/task-callback.ts"(){bd(),bU()}});function cy(a,b){return b0(c=>{if(!bm(a))throw Error(`Git.cwd: cannot change to non-directory "${a}"`);return(b||c).cwd=a})}var cz=a6({"src/lib/tasks/change-working-directory.ts"(){bU(),b6()}});function cA(a){let b=["checkout",...a];return"-b"===b[1]&&b.includes("-B")&&(b[1]=bp(b,"-B")),b2(b)}var cB=a6({"src/lib/tasks/checkout.ts"(){bU(),b6()}}),cC=a6({"src/lib/tasks/count-objects.ts"(){bU(),U=new r(/([a-z-]+): (\d+)$/,(a,[b,c])=>{let d=br(b);Object.hasOwn(a,d)&&(a[d]=bt(c))})}});function cD(a){return bR({author:null,branch:"",commit:"",root:!1,summary:{changes:0,insertions:0,deletions:0}},V,a)}var cE=a6({"src/lib/parsers/parse-commit.ts"(){bU(),V=[new r(/^\[([^\s]+)( \([^)]+\))? ([^\]]+)/,(a,[b,c,d])=>{a.branch=b,a.commit=d,a.root=!!c}),new r(/\s*Author:\s(.+)/i,(a,[b])=>{let c=b.split("<"),d=c.pop();d&&d.includes("@")&&(a.author={email:d.substr(0,d.length-1),name:c.join("<").trim()})}),new r(/(\d+)[^,]*(?:,\s*(\d+)[^,]*)(?:,\s*(\d+))/g,(a,[b,c,d])=>{a.summary.changes=parseInt(b,10)||0,a.summary.insertions=parseInt(c,10)||0,a.summary.deletions=parseInt(d,10)||0}),new r(/^(\d+)[^,]*(?:,\s*(\d+)[^(]+\(([+-]))?/,(a,[b,c,d])=>{a.summary.changes=parseInt(b,10)||0;let e=parseInt(c,10)||0;"-"===d?a.summary.deletions=e:"+"===d&&(a.summary.insertions=e)})]}}),cF=a6({"src/lib/tasks/commit.ts"(){cE(),bU(),b6()}}),cG=a6({"src/lib/tasks/first-commit.ts"(){bU(),b6()}}),cH=a6({"src/lib/tasks/hash-object.ts"(){b6()}}),cI=a6({"src/lib/responses/InitSummary.ts"(){W=class{constructor(a,b,c,d){this.bare=a,this.path=b,this.existing=c,this.gitDir=d}},X=/^Init.+ repository in (.+)$/,Y=/^Rein.+ in (.+)$/}}),cJ=a6({"src/lib/tasks/init.ts"(){cI(),Z="--bare"}});function cK(a){for(let b=0;b<a.length;b++){let c=$.exec(a[b]);if(c)return`--${c[1]}`}return""}function cL(a){return $.test(a)}var cM=a6({"src/lib/args/log-format.ts"(){$=/^--(stat|numstat|name-only|name-status)(=|$)/}}),cN=a6({"src/lib/responses/DiffSummary.ts"(){_=class{constructor(){this.changed=0,this.deletions=0,this.insertions=0,this.files=[]}}}});function cO(a=""){let b=ad[a];return a=>bR(new _,b,a,!1)}var cP=a6({"src/lib/parsers/parse-diff-summary.ts"(){cM(),cN(),ch(),bU(),aa=[new r(/^(.+)\s+\|\s+(\d+)(\s+[+\-]+)?$/,(a,[b,c,d=""])=>{a.files.push({file:b.trim(),changes:bt(c),insertions:d.replace(/[^+]/g,"").length,deletions:d.replace(/[^-]/g,"").length,binary:!1})}),new r(/^(.+) \|\s+Bin ([0-9.]+) -> ([0-9.]+) ([a-z]+)/,(a,[b,c,d])=>{a.files.push({file:b.trim(),before:bt(c),after:bt(d),binary:!0})}),new r(/(\d+) files? changed\s*((?:, \d+ [^,]+){0,2})/,(a,[b,c])=>{let d=/(\d+) i/.exec(c),e=/(\d+) d/.exec(c);a.changed=bt(b),a.insertions=bt(d?.[1]),a.deletions=bt(e?.[1])})],ab=[new r(/(\d+)\t(\d+)\t(.+)$/,(a,[b,c,d])=>{let e=bt(b),f=bt(c);a.changed++,a.insertions+=e,a.deletions+=f,a.files.push({file:d,changes:e+f,insertions:e,deletions:f,binary:!1})}),new r(/-\t-\t(.+)$/,(a,[b])=>{a.changed++,a.files.push({file:b,after:0,before:0,binary:!0})})],ac=[new r(/(.+)$/,(a,[b])=>{a.changed++,a.files.push({file:b,changes:0,insertions:0,deletions:0,binary:!1})})],ad={"":aa,"--stat":aa,"--numstat":ab,"--name-status":[new r(/([ACDMRTUXB])([0-9]{0,3})\t(.[^\t]*)(\t(.[^\t]*))?$/,(a,[b,c,d,e,f])=>{a.changed++,a.files.push({file:f??d,changes:0,insertions:0,deletions:0,binary:!1,status:by(K.has(b)&&b),from:by(!!f&&d!==f&&d),similarity:bt(c)})})],"--name-only":ac}}});function cQ(a=ag,b=ah,c=""){let d=cO(c);return function(c){let e=bk(c.trim(),!1,ae).map(function(c){var e;let f=c.split(af),g=(e=f[0].split(a),b.reduce((a,b,c)=>(a[b]=e[c]||"",a),Object.create({diff:null})));return f.length>1&&f[1].trim()&&(g.diff=d(f[1])),g});return{all:e,latest:e.length&&e[0]||null,total:e.length}}}var cR=a6({"src/lib/parsers/parse-list-log-summary.ts"(){bU(),cP(),cM(),ae="òòòòòò ",af=" òò",ag=" ò ",ah=["hash","date","message","refs","author_name","author_email"]}}),cS={};function cT(a){let b=cK(a),c=["diff"];return""===b&&(b="--stat",c.push("--stat=4096")),c.push(...a),cU(c)||{commands:c,format:"utf-8",parser:cO(b)}}function cU(a){let b=a.filter(cL);return b.length>1?b1(`Summary flags are mutually exclusive - pick one of ${b.join(",")}`):b.length&&a.includes("-z")?b1(`Summary flag ${b} parsing is not compatible with null termination option '-z'`):void 0}a7(cS,{diffSummaryTask:()=>cT,validateLogFormatConfig:()=>cU});var cV=a6({"src/lib/tasks/diff.ts"(){cM(),cP(),b6()}});function cW(a={},b=[]){var c;let e,f,g=bA(a.splitter,m,ag),[h,i]=(c=bC(a.format)?a.format:{hash:"%H",date:!1===a.strictDate?"%ai":"%aI",message:"%s",refs:"%D",body:a.multiLine?"%B":"%b",author_name:!1!==a.mailMap?"%aN":"%an",author_email:!1!==a.mailMap?"%aE":"%ae"},e=[],f=[],Object.keys(c).forEach(a=>{e.push(a),f.push(String(c[a]))}),[e,f.join(g)]),j=[],k=[`--pretty=format:${ae}${i}${af}`,...b],l=a.n||a["max-count"]||a.maxCount;if(l&&k.push(`--max-count=${l}`),a.from||a.to){let b=!1!==a.symmetric?"...":"..";j.push(`${a.from||""}${b}${a.to||""}`)}return m(a.file)&&k.push("--follow",function(...a){let b=new String(a);return d.set(b,a),b}(a.file)),bL(Object.keys(a).reduce((b,c)=>(c in ai||(b[c]=a[c]),b),{}),k),{fields:h,splitter:g,commands:[...k,...j]}}var cX=a6({"src/lib/tasks/log.ts"(){var a;cM(),bb(),cR(),bU(),b6(),cV(),(a=ai||{})[a["--pretty"]=0]="--pretty",a[a["max-count"]=1]="max-count",a[a.maxCount=2]="maxCount",a[a.n=3]="n",a[a.file=4]="file",a[a.format=5]="format",a[a.from=6]="from",a[a.to=7]="to",a[a.splitter=8]="splitter",a[a.symmetric=9]="symmetric",a[a.mailMap=10]="mailMap",a[a.multiLine=11]="multiLine",a[a.strictDate=12]="strictDate",ai=a}}),cY=a6({"src/lib/responses/MergeSummary.ts"(){aj=class{constructor(a,b=null,c){this.reason=a,this.file=b,this.meta=c}toString(){return`${this.file}:${this.reason}`}},ak=class{constructor(){this.conflicts=[],this.merges=[],this.result="success"}get failed(){return this.conflicts.length>0}get reason(){return this.result}toString(){return this.conflicts.length?`CONFLICTS: ${this.conflicts.join(", ")}`:"OK"}}}}),cZ=a6({"src/lib/responses/PullSummary.ts"(){al=class{constructor(){this.remoteMessages={all:[]},this.created=[],this.deleted=[],this.files=[],this.deletions={},this.insertions={},this.summary={changes:0,deletions:0,insertions:0}}},am=class{constructor(){this.remote="",this.hash={local:"",remote:""},this.branch={local:"",remote:""},this.message=""}toString(){return this.message}}}});function c$(a){return a.objects=a.objects||{compressing:0,counting:0,enumerating:0,packReused:0,reused:{count:0,delta:0},total:{count:0,delta:0}}}function c_(a){let b=/^\s*(\d+)/.exec(a),c=/delta (\d+)/i.exec(a);return{count:bt(b&&b[1]||"0"),delta:bt(c&&c[1]||"0")}}var c0=a6({"src/lib/parsers/parse-remote-objects.ts"(){bU(),an=[new s(/^remote:\s*(enumerating|counting|compressing) objects: (\d+),/i,(a,[b,c])=>{let d=b.toLowerCase();Object.assign(c$(a.remoteMessages),{[d]:bt(c)})}),new s(/^remote:\s*(enumerating|counting|compressing) objects: \d+% \(\d+\/(\d+)\),/i,(a,[b,c])=>{let d=b.toLowerCase();Object.assign(c$(a.remoteMessages),{[d]:bt(c)})}),new s(/total ([^,]+), reused ([^,]+), pack-reused (\d+)/i,(a,[b,c,d])=>{let e=c$(a.remoteMessages);e.total=c_(b),e.reused=c_(c),e.packReused=bt(d)})]}});function c1(a,b){return bR({remoteMessages:new ap},ao,b)}var c2=a6({"src/lib/parsers/parse-remote-messages.ts"(){bU(),c0(),ao=[new s(/^remote:\s*(.+)$/,(a,[b])=>(a.remoteMessages.all.push(b.trim()),!1)),...an,new s([/create a (?:pull|merge) request/i,/\s(https?:\/\/\S+)$/],(a,[b])=>{a.remoteMessages.pullRequestUrl=b}),new s([/found (\d+) vulnerabilities.+\(([^)]+)\)/i,/\s(https?:\/\/\S+)$/],(a,[b,c,d])=>{a.remoteMessages.vulnerabilities={count:bt(b),summary:c,url:d}})],ap=class{constructor(){this.all=[]}}}}),c3=a6({"src/lib/parsers/parse-pull.ts"(){cZ(),bU(),c2(),aq=/(\d+)\D+((\d+)\D+\(\+\))?(\D+(\d+)\D+\(-\))?/,ar=/^(create|delete) mode \d+ (.+)/,as=[new r(/^\s*(.+?)\s+\|\s+\d+\s*(\+*)(-*)/,(a,[b,c,d])=>{a.files.push(b),c&&(a.insertions[b]=c.length),d&&(a.deletions[b]=d.length)}),new r(aq,(a,[b,,c,,d])=>(void 0!==c||void 0!==d)&&(a.summary.changes=+b||0,a.summary.insertions=+c||0,a.summary.deletions=+d||0,!0)),new r(ar,(a,[b,c])=>{bn(a.files,c),bn("create"===b?a.created:a.deleted,c)})],at=[new r(/^from\s(.+)$/i,(a,[b])=>void(a.remote=b)),new r(/^fatal:\s(.+)$/,(a,[b])=>void(a.message=b)),new r(/([a-z0-9]+)\.\.([a-z0-9]+)\s+(\S+)\s+->\s+(\S+)$/,(a,[b,c,d,e])=>{a.branch.local=d,a.hash.local=b,a.branch.remote=e,a.hash.remote=c})],au=(a,b)=>Object.assign(new al,bR(new al,as,[a,b]),c1(a,b))}}),c4=a6({"src/lib/parsers/parse-merge.ts"(){cY(),bU(),c3(),av=[new r(/^Auto-merging\s+(.+)$/,(a,[b])=>{a.merges.push(b)}),new r(/^CONFLICT\s+\((.+)\): Merge conflict in (.+)$/,(a,[b,c])=>{a.conflicts.push(new aj(b,c))}),new r(/^CONFLICT\s+\((.+\/delete)\): (.+) deleted in (.+) and/,(a,[b,c,d])=>{a.conflicts.push(new aj(b,c,{deleteRef:d}))}),new r(/^CONFLICT\s+\((.+)\):/,(a,[b])=>{a.conflicts.push(new aj(b,null))}),new r(/^Automatic merge failed;\s+(.+)$/,(a,[b])=>{a.result=b})],aw=(a,b)=>Object.assign(ax(a,b),au(a,b)),ax=a=>bR(new ak,av,a)}});function c5(a){return a.length?{commands:["merge",...a],format:"utf-8",parser(a,b){let c=aw(a,b);if(c.failed)throw new f(c);return c}}:b1("Git.merge requires at least one option")}var c6=a6({"src/lib/tasks/merge.ts"(){bd(),c4(),b6()}}),c7=a6({"src/lib/parsers/parse-push.ts"(){bU(),c2(),ay=[new r(/^Pushing to (.+)$/,(a,[b])=>{a.repo=b}),new r(/^updating local tracking ref '(.+)'/,(a,[b])=>{a.ref={...a.ref||{},local:b}}),new r(/^[=*-]\s+([^:]+):(\S+)\s+\[(.+)]$/,(a,[b,c,d])=>{let e,f,g;a.pushed.push((e=d.includes("deleted"),f=d.includes("tag")||/^refs\/tags/.test(b),{deleted:e,tag:f,branch:!f,new:!(g=!d.includes("new")),alreadyUpdated:g,local:b,remote:c}))}),new r(/^Branch '([^']+)' set up to track remote branch '([^']+)' from '([^']+)'/,(a,[b,c,d])=>{a.branch={...a.branch||{},local:b,remote:c,remoteName:d}}),new r(/^([^:]+):(\S+)\s+([a-z0-9]+)\.\.([a-z0-9]+)$/,(a,[b,c,d,e])=>{a.update={head:{local:b,remote:c},hash:{from:d,to:e}}})],az=(a,b)=>{let c=aA(a,b),d=c1(a,b);return{...c,...d}},aA=(a,b)=>bR({pushed:[]},ay,[a,b])}}),c8={};function c9(a={},b){return bn(b,"--tags"),da(a,b)}function da(a={},b){let c=["push",...b];return a.branch&&c.splice(1,0,a.branch),a.remote&&c.splice(1,0,a.remote),bp(c,"-v"),bn(c,"--verbose"),bn(c,"--porcelain"),{commands:c,format:"utf-8",parser:az}}a7(c8,{pushTagsTask:()=>c9,pushTask:()=>da});var db=a6({"src/lib/tasks/push.ts"(){c7(),bU()}}),dc=a6({"src/lib/tasks/show.ts"(){bU(),b6()}}),dd=a6({"src/lib/responses/FileStatusSummary.ts"(){aB=/^(.+)\0(.+)$/,aC=class{constructor(a,b,c){if(this.path=a,this.index=b,this.working_dir=c,"R"===b||"R"===c){const b=aB.exec(a)||[null,a,a];this.from=b[2]||"",this.path=b[1]||""}}}}});function de(a){let[b,c]=a.split(h);return{from:c||b,to:b}}function df(a,b,c){return[`${a}${b}`,c]}function dg(a,...b){return b.map(b=>df(a,b,(a,b)=>bn(a.conflicted,b)))}var dh=a6({"src/lib/responses/StatusSummary.ts"(){bU(),dd(),aD=class{constructor(){this.not_added=[],this.conflicted=[],this.created=[],this.deleted=[],this.ignored=void 0,this.modified=[],this.renamed=[],this.files=[],this.staged=[],this.ahead=0,this.behind=0,this.current=null,this.tracking=null,this.detached=!1,this.isClean=()=>!this.files.length}},aE=new Map([df(" ","A",(a,b)=>bn(a.created,b)),df(" ","D",(a,b)=>bn(a.deleted,b)),df(" ","M",(a,b)=>bn(a.modified,b)),df("A"," ",(a,b)=>bn(a.created,b)&&bn(a.staged,b)),df("A","M",(a,b)=>bn(a.created,b)&&bn(a.staged,b)&&bn(a.modified,b)),df("D"," ",(a,b)=>bn(a.deleted,b)&&bn(a.staged,b)),df("M"," ",(a,b)=>bn(a.modified,b)&&bn(a.staged,b)),df("M","M",(a,b)=>bn(a.modified,b)&&bn(a.staged,b)),df("R"," ",(a,b)=>{bn(a.renamed,de(b))}),df("R","M",(a,b)=>{let c=de(b);bn(a.renamed,c),bn(a.modified,c.to)}),df("!","!",(a,b)=>{bn(a.ignored=a.ignored||[],b)}),df("?","?",(a,b)=>bn(a.not_added,b)),...dg("A","A","U"),...dg("D","D","U"),...dg("U","A","D","U"),["##",(a,b)=>{let c=/ahead (\d+)/.exec(b);a.ahead=c&&+c[1]||0,a.behind=(c=/behind (\d+)/.exec(b))&&+c[1]||0,c=/^(.+?(?=(?:\.{3}|\s|$)))/.exec(b),a.current=bA(c?.[1],m,null),c=/\.{3}(\S*)/.exec(b),a.tracking=bA(c?.[1],m,null),(c=/\son\s(\S+?)(?=\.{3}|$)/.exec(b))&&(a.current=bA(c?.[1],m,a.current)),a.detached=/\(no branch\)/.test(b)}]]),aF=function(a){let b=a.split(h),c=new aD;for(let a=0,d=b.length;a<d;){let d=b[a++].trim();d&&("R"===d.charAt(0)&&(d+=h+(b[a++]||"")),function(a,b){let c=b.trim();switch(" "){case c.charAt(2):return d(c.charAt(0),c.charAt(1),c.substr(3));case c.charAt(1):return d(" ",c.charAt(0),c.substr(2));default:return}function d(b,c,d){let e=`${b}${c}`,f=aE.get(e);f&&f(a,d),"##"!==e&&"!!"!==e&&a.files.push(new aC(d,b,c))}}(c,d))}return c}}}),di=a6({"src/lib/tasks/status.ts"(){dh(),aG=["--null","-z"]}});function dj(a=0,b=0,c=0,d="",e=!0){return Object.defineProperty({major:a,minor:b,patch:c,agent:d,installed:e},"toString",{value(){return`${this.major}.${this.minor}.${this.patch}`},configurable:!1,enumerable:!1})}function dk(a){return a===aH?dj(0,0,0,"",!1):bR(dj(0,0,0,a),aI,a)}var dl=a6({"src/lib/tasks/version.ts"(){bU(),aH="installed=false",aI=[new r(/version (\d+)\.(\d+)\.(\d+)(?:\s*\((.+)\))?/,(a,[b,c,d,e=""])=>{Object.assign(a,dj(bt(b),bt(c),bt(d),e))}),new r(/version (\d+)\.(\d+)\.(\D+)(.+)?$/,(a,[b,c,d,e=""])=>{Object.assign(a,dj(bt(b),bt(c),d,e))})]}}),dm={};a7(dm,{SimpleGitApi:()=>aJ});var dn=a6({"src/lib/simple-git-api.ts"(){cx(),cz(),cB(),cC(),cF(),cg(),cG(),ci(),cH(),cJ(),cX(),c6(),db(),dc(),di(),b6(),dl(),bU(),Object.assign((aJ=class{constructor(a){this._executor=a}_runTask(a,b){let c=this._executor.chain(),d=c.push(a);return b&&function(a,b,c=i){b.then(a=>{c(null,a)},b=>{var d;let e;b?.task===a&&c(b instanceof f?(d=b,e=a=>{console.warn(`simple-git deprecation notice: accessing GitResponseError.${a} should be GitResponseError.git.${a}, this will no longer be available in version 3`),e=i},Object.create(d,Object.getOwnPropertyNames(d.git).reduce(function(a,b){return b in d||(a[b]={enumerable:!1,configurable:!1,get:()=>(e(b),d.git[b])}),a},{}))):b,void 0)})}(a,d,b),Object.create(this,{then:{value:d.then.bind(d)},catch:{value:d.catch.bind(d)},_executor:{value:c}})}add(a){return this._runTask(b2(["add",...bq(a)]),bO(arguments))}cwd(a){let b=bO(arguments);return"string"==typeof a?this._runTask(cy(a,this._executor),b):"string"==typeof a?.path?this._runTask(cy(a.path,a.root&&this._executor||void 0),b):this._runTask(b1("Git.cwd: workingDirectory must be supplied as a string"),b)}hashObject(a,b){var c;let d;return this._runTask((c=!0===b,d=["hash-object",a],c&&d.push("-w"),b2(d,!0)),bO(arguments))}init(a){return this._runTask(function(a=!1,b,c){let d=["init",...c];return a&&!d.includes(Z)&&d.splice(1,0,Z),{commands:d,format:"utf-8",parser:a=>(function(a,b,c){let d,e=String(c).trim();if(d=X.exec(e))return new W(a,b,!1,d[1]);if(d=Y.exec(e))return new W(a,b,!0,d[1]);let f="",g=e.split(" ");for(;g.length;)if("in"===g.shift()){f=g.join(" ");break}return new W(a,b,/^re/i.test(e),f)})(d.includes("--bare"),b,a)}}(!0===a,this._executor.cwd,bM(arguments)),bO(arguments))}merge(){return this._runTask(c5(bM(arguments)),bO(arguments))}mergeFromTo(a,b){return m(a)&&m(b)?this._runTask(c5([a,b,...bM(arguments)]),bO(arguments,!1)):this._runTask(b1("Git.mergeFromTo requires that the 'remote' and 'branch' arguments are supplied as strings"))}outputHandler(a){return this._executor.outputHandler=a,this}push(){let a=da({remote:bA(arguments[0],m),branch:bA(arguments[1],m)},bM(arguments));return this._runTask(a,bO(arguments))}stash(){return this._runTask(b2(["stash",...bM(arguments)]),bO(arguments))}status(){var a;return this._runTask((a=bM(arguments),{format:"utf-8",commands:["status","--porcelain","-b","-u","--null",...a.filter(a=>!aG.includes(a))],parser:a=>aF(a)}),bO(arguments))}}).prototype,{checkout(){return this._runTask(cA(bM(arguments,1)),bO(arguments))},checkoutBranch(a,b){return this._runTask(cA(["-b",a,b,...bM(arguments)]),bO(arguments))},checkoutLocalBranch(a){return this._runTask(cA(["-b",a,...bM(arguments)]),bO(arguments))}},{commit(a,...b){var c,d,e;let f=bO(arguments),g=!n(a)&&b1("git.commit: requires the commit message to be supplied as a string/string[]")||(c=bq(a),d=bq(bA(b[0],n,[])),e=[...bs(bA(b[1],k,[])),...bM(arguments,0,!0)],{commands:["-c","core.abbrev=40","commit",...bu(c,"-m"),...d,...e],format:"utf-8",parser:cD});return this._runTask(g,f)}},{addConfig(a,b,...c){var d,e;let f;return this._runTask((d=!0===c[0],e=cf(c[1],"local"),f=["config",`--${e}`],d&&f.push("--add"),f.push(a,b),{commands:f,format:"utf-8",parser:a=>a}),bO(arguments))},getConfig(a,b){var c;let d;return this._runTask((c=cf(b,void 0),d=["config","--null","--show-origin","--get-all",a],c&&d.splice(1,0,`--${c}`),{commands:d,format:"utf-8",parser:b=>(function(a,b){let c=null,d=[],e=new Map;for(let f of cd(a,b))f.key===b&&(d.push(c=f.value),e.has(f.file)||e.set(f.file,[]),e.get(f.file).push(c));return{key:b,paths:Array.from(e.keys()),scopes:e,value:c,values:d}})(b,a)}),bO(arguments))},listConfig(...a){var b;let c;return this._runTask((b=cf(a[0],void 0),c=["config","--list","--show-origin","--null"],b&&c.push(`--${b}`),{commands:c,format:"utf-8",parser:a=>(function(a){let b=new H;for(let c of cd(a))b.addValue(c.file,String(c.key),c.value);return b})(a)}),bO(arguments))}},{countObjects(){return this._runTask({commands:["count-objects","--verbose"],format:"utf-8",parser:a=>bR({count:0,garbage:0,inPack:0,packs:0,prunePackable:0,size:0,sizeGarbage:0,sizePack:0},[U],a)})}},{firstCommit(){return this._runTask(b2(["rev-list","--max-parents=0","HEAD"],!0),bO(arguments))}},{grep(a){let b=bO(arguments),c=bM(arguments);for(let a of L)if(c.includes(a))return this._runTask(b1(`git.grep: use of "${a}" is not supported.`),b);"string"==typeof a&&(a=(function(...a){return new O().param(...a)})().param(a));let d=["grep","--null","-n","--full-name",...c,...a];return this._runTask({commands:d,format:"utf-8",parser:a=>{let b,c;return b=new Set,c={},bl(a,a=>{let[d,e,f]=a.split(h);b.add(d),(c[d]=c[d]||[]).push({line:bt(e),path:d,preview:f})}),{paths:b,results:c}}},b)}},{log(...a){var b,c;let d,e=bO(arguments),f=cW(bN(arguments),bs(bA(arguments[0],k,[]))),g=function(a,b){return m(a)&&m(b)&&b1("git.log(string, string) should be replaced with git.log({ from: string, to: string })")}(...a)||cU(f.commands)||(d=cQ((b=f).splitter,b.fields,cK(c=b.commands)),{commands:["log",...c],format:"utf-8",parser:d});return this._runTask(g,e)}},{showBuffer(){let a=["show",...bM(arguments,1)];return a.includes("--binary")||a.splice(1,0,"--binary"),this._runTask(b3(a),bO(arguments))},show(){let a=["show",...bM(arguments,1)];return this._runTask(b2(a),bO(arguments))}},{version(){return this._runTask({commands:["--version"],format:"utf-8",parser:dk,onError(a,b,c,d){if(-2===a.exitCode)return c(Buffer.from(aH));d(b)}})}})}}),dp={};a7(dp,{Scheduler:()=>aK});var dq=a6({"src/lib/runners/scheduler.ts"(){let a;bU(),cq(),a=0,aK=class{constructor(a=2){this.concurrency=a,this.logger=cp("","scheduler"),this.pending=[],this.running=[],this.logger("Constructed, concurrency=%s",a)}schedule(){if(!this.pending.length||this.running.length>=this.concurrency)return void this.logger("Schedule attempt ignored, pending=%s running=%s concurrency=%s",this.pending.length,this.running.length,this.concurrency);let a=bn(this.running,this.pending.shift());this.logger("Attempting id=%s",a.id),a.done(()=>{this.logger("Completing id=",a.id),bp(this.running,a),this.schedule()})}next(){let{promise:b,id:c}=bn(this.pending,(()=>{a++;let{promise:b,done:c}=(0,a_.createDeferred)();return{promise:b,done:c,id:a}})());return this.logger("Scheduling id=%s",c),this.schedule(),b}}}}),dr={};function ds(a,b){return b2(["apply",...b,...a])}a7(dr,{applyPatchTask:()=>ds});var dt=a6({"src/lib/tasks/apply-patch.ts"(){b6()}}),du=a6({"src/lib/responses/BranchDeleteSummary.ts"(){aL=class{constructor(){this.all=[],this.branches={},this.errors=[]}get success(){return!this.errors.length}}}});function dv(a,b){return 1===b&&aM.test(a)}var dw=a6({"src/lib/parsers/parse-branch-delete.ts"(){du(),bU(),aM=/^error[^']+'([^']+)'/m,aN=[new r(/(\S+)\s+\(\S+\s([^)]+)\)/,(a,[b,c])=>{let d={branch:b,hash:c,success:!0};a.all.push(d),a.branches[b]=d}),new r(aM,(a,[b])=>{let c={branch:b,hash:null,success:!1};a.errors.push(c),a.all.push(c),a.branches[b]=c})],aO=(a,b)=>bR(new aL,aN,[a,b])}}),dx=a6({"src/lib/responses/BranchSummary.ts"(){aP=class{constructor(){this.all=[],this.branches={},this.current="",this.detached=!1}push(a,b,c,d,e){"*"===a&&(this.detached=b,this.current=c),this.all.push(c),this.branches[c]={current:"*"===a,linkedWorkTree:"+"===a,name:c,commit:d,label:e}}}}});function dy(a){return a?a.charAt(0):""}function dz(a,b=!1){return bR(new aP,b?[aR]:aQ,a)}var dA=a6({"src/lib/parsers/parse-branch.ts"(){dx(),bU(),aQ=[new r(/^([*+]\s)?\((?:HEAD )?detached (?:from|at) (\S+)\)\s+([a-z0-9]+)\s(.*)$/,(a,[b,c,d,e])=>{a.push(dy(b),!0,c,d,e)}),new r(/^([*+]\s)?(\S+)\s+([a-z0-9]+)\s?(.*)$/s,(a,[b,c,d,e])=>{a.push(dy(b),!1,c,d,e)})],aR=new r(/^(\S+)$/s,(a,[b])=>{a.push("*",!1,b,"","")})}}),dB={};function dC(a){let b=["-d","-D","--delete"];return a.some(a=>b.includes(a))}function dD(a){let b=dC(a),c=a.includes("--show-current"),d=["branch",...a];return 1===d.length&&d.push("-a"),d.includes("-v")||d.splice(1,0,"-v"),{format:"utf-8",commands:d,parser:(a,d)=>b?aO(a,d).all[0]:dz(a,c)}}function dE(){return{format:"utf-8",commands:["branch","-v"],parser:a=>dz(a)}}function dF(a,b=!1){return{format:"utf-8",commands:["branch","-v",b?"-D":"-d",...a],parser:(a,b)=>aO(a,b),onError({exitCode:a,stdOut:b},c,d,e){if(!dv(String(c),a))return e(c);d(b)}}}function dG(a,b=!1){let c={format:"utf-8",commands:["branch","-v",b?"-D":"-d",a],parser:(b,c)=>aO(b,c).branches[a],onError({exitCode:a,stdErr:b,stdOut:d},e,g,h){if(!dv(String(e),a))return h(e);throw new f(c.parser(bv(d),bv(b)),String(e))}};return c}a7(dB,{branchLocalTask:()=>dE,branchTask:()=>dD,containsDeleteBranchCommand:()=>dC,deleteBranchTask:()=>dG,deleteBranchesTask:()=>dF});var dH=a6({"src/lib/tasks/branch.ts"(){bd(),dw(),dA(),bU()}});function dI(a){let b=a.trim().replace(/^["']|["']$/g,"");return b&&(0,a0.normalize)(b)}var dJ=a6({"src/lib/responses/CheckIgnore.ts"(){aS=a=>a.split(/\n/g).map(dI).filter(Boolean)}}),dK={};function dL(a){return{commands:["check-ignore",...a],format:"utf-8",parser:aS}}a7(dK,{checkIgnoreTask:()=>dL});var dM=a6({"src/lib/tasks/check-ignore.ts"(){dJ()}}),dN={};function dO(a){return/^--upload-pack(=|$)/.test(a)}function dP(a,b,c){let d=["clone",...c];return(m(a)&&d.push(a),m(b)&&d.push(b),d.find(dO))?b1("git.fetch: potential exploit argument blocked."):b2(d)}function dQ(a,b,c){return bn(c,"--mirror"),dP(a,b,c)}a7(dN,{cloneMirrorTask:()=>dQ,cloneTask:()=>dP});var dR=a6({"src/lib/tasks/clone.ts"(){b6(),bU()}});function dS(a,b){return bR({raw:a,remote:null,branches:[],tags:[],updated:[],deleted:[]},aT,[a,b])}var dT=a6({"src/lib/parsers/parse-fetch.ts"(){bU(),aT=[new r(/From (.+)$/,(a,[b])=>{a.remote=b}),new r(/\* \[new branch]\s+(\S+)\s*-> (.+)$/,(a,[b,c])=>{a.branches.push({name:b,tracking:c})}),new r(/\* \[new tag]\s+(\S+)\s*-> (.+)$/,(a,[b,c])=>{a.tags.push({name:b,tracking:c})}),new r(/- \[deleted]\s+\S+\s*-> (.+)$/,(a,[b])=>{a.deleted.push({tracking:b})}),new r(/\s*([^.]+)\.\.(\S+)\s+(\S+)\s*-> (.+)$/,(a,[b,c,d,e])=>{a.updated.push({name:d,tracking:e,to:c,from:b})})]}}),dU={};function dV(a){return/^--upload-pack(=|$)/.test(a)}function dW(a,b,c){let d=["fetch",...c];return(a&&b&&d.push(a,b),d.find(dV))?b1("git.fetch: potential exploit argument blocked."):{commands:d,format:"utf-8",parser:dS}}a7(dU,{fetchTask:()=>dW});var dX=a6({"src/lib/tasks/fetch.ts"(){dT(),b6()}});function dY(a){return bR({moves:[]},aU,a)}var dZ=a6({"src/lib/parsers/parse-move.ts"(){bU(),aU=[new r(/^Renaming (.+) to (.+)$/,(a,[b,c])=>{a.moves.push({from:b,to:c})})]}}),d$={};function d_(a,b){return{commands:["mv","-v",...bq(a),b],format:"utf-8",parser:dY}}a7(d$,{moveTask:()=>d_});var d0=a6({"src/lib/tasks/move.ts"(){dZ(),bU()}}),d1={};function d2(a,b,c){let d=["pull",...c];return a&&b&&d.splice(1,0,a,b),{commands:d,format:"utf-8",parser:(a,b)=>au(a,b),onError(a,b,c,d){var e,g;let h,i=(e=bv(a.stdOut),g=bv(a.stdErr),(h=bR(new am,at,[e,g])).message&&h);if(i)return d(new f(i));d(b)}}}a7(d1,{pullTask:()=>d2});var d3=a6({"src/lib/tasks/pull.ts"(){bd(),c3(),bU()}});function d4(a){let b={};return d6(a,([a])=>b[a]={name:a}),Object.values(b)}function d5(a){let b={};return d6(a,([a,c,d])=>{Object.hasOwn(b,a)||(b[a]={name:a,refs:{fetch:"",push:""}}),d&&c&&(b[a].refs[d.replace(/[^a-z]/g,"")]=c)}),Object.values(b)}function d6(a,b){bl(a,a=>b(a.split(/\s+/)))}var d7=a6({"src/lib/responses/GetRemoteSummary.ts"(){bU()}}),d8={};function d9(a,b,c){return b2(["remote","add",...c,a,b])}function ea(a){let b=["remote"];return a&&b.push("-v"),{commands:b,format:"utf-8",parser:a?d5:d4}}function eb(a){let b=[...a];return"ls-remote"!==b[0]&&b.unshift("ls-remote"),b2(b)}function ec(a){let b=[...a];return"remote"!==b[0]&&b.unshift("remote"),b2(b)}function ed(a){return b2(["remote","remove",a])}a7(d8,{addRemoteTask:()=>d9,getRemotesTask:()=>ea,listRemotesTask:()=>eb,remoteTask:()=>ec,removeRemoteTask:()=>ed});var ee=a6({"src/lib/tasks/remote.ts"(){d7(),b6()}}),ef={};function eg(a={},b){let c=cW(a),d=["stash","list",...c.commands,...b],e=cQ(c.splitter,c.fields,cK(d));return cU(d)||{commands:d,format:"utf-8",parser:e}}a7(ef,{stashListTask:()=>eg});var eh=a6({"src/lib/tasks/stash-list.ts"(){cM(),cR(),cV(),cX()}}),ei={};function ej(a,b){return el(["add",a,b])}function ek(a){return el(["init",...a])}function el(a){let b=[...a];return"submodule"!==b[0]&&b.unshift("submodule"),b2(b)}function em(a){return el(["update",...a])}a7(ei,{addSubModuleTask:()=>ej,initSubModuleTask:()=>ek,subModuleTask:()=>el,updateSubModuleTask:()=>em});var en=a6({"src/lib/tasks/sub-module.ts"(){b6()}});function eo(a,b){return a===b?0:a>b?1:-1}function ep(a){return a.trim()}function eq(a){return"string"==typeof a&&parseInt(a.replace(/^\D+/g,""),10)||0}var er=a6({"src/lib/responses/TagList.ts"(){aV=class{constructor(a,b){this.all=a,this.latest=b}},aW=function(a,b=!1){let c=a.split("\n").map(ep).filter(Boolean);b||c.sort(function(a,b){let c=a.split("."),d=b.split(".");if(1===c.length||1===d.length){var e,f;let a;return e=eq(c[0]),f=eq(d[0]),(a=Number.isNaN(e))!==Number.isNaN(f)?a?1:-1:a?eo(e,f):0}for(let a=0,b=Math.max(c.length,d.length);a<b;a++){let b=eo(eq(c[a]),eq(d[a]));if(b)return b}return 0});let d=b?c[0]:[...c].reverse().find(a=>a.indexOf(".")>=0);return new aV(c,d)}}}),es={};function et(a=[]){let b=a.some(a=>/^--sort=/.test(a));return{format:"utf-8",commands:["tag","-l",...a],parser:a=>aW(a,b)}}function eu(a){return{format:"utf-8",commands:["tag",a],parser:()=>({name:a})}}function ev(a,b){return{format:"utf-8",commands:["tag","-a","-m",b,a],parser:()=>({name:a})}}a7(es,{addAnnotatedTagTask:()=>ev,addTagTask:()=>eu,tagListTask:()=>et});var ew=a6({"src/lib/tasks/tag.ts"(){er()}}),ex=(b={"src/git.js"(a,b){var{GitExecutor:c}=(cw(),a8(cv)),{SimpleGitApi:d}=(dn(),a8(dm)),{Scheduler:e}=(dq(),a8(dp)),{configurationErrorTask:f}=(b6(),a8(b_)),{asArray:g,filterArray:h,filterPrimitives:i,filterString:j,filterStringOrStringArray:k,filterType:l,getTrailingOptions:m,trailingFunctionArgument:n,trailingOptionsArgument:o}=(bU(),a8(bT)),{applyPatchTask:p}=(dt(),a8(dr)),{branchTask:q,branchLocalTask:r,deleteBranchesTask:s,deleteBranchTask:t}=(dH(),a8(dB)),{checkIgnoreTask:u}=(dM(),a8(dK)),{checkIsRepoTask:v}=(bZ(),a8(bV)),{cloneTask:w,cloneMirrorTask:x}=(dR(),a8(dN)),{cleanWithOptionsTask:y,isCleanOptionsArray:z}=(cc(),a8(b7)),{diffSummaryTask:A}=(cV(),a8(cS)),{fetchTask:B}=(dX(),a8(dU)),{moveTask:C}=(d0(),a8(d$)),{pullTask:D}=(d3(),a8(d1)),{pushTagsTask:E}=(db(),a8(c8)),{addRemoteTask:F,getRemotesTask:G,listRemotesTask:H,remoteTask:I,removeRemoteTask:J}=(ee(),a8(d8)),{getResetMode:K,resetTask:L}=(cn(),a8(cj)),{stashListTask:M}=(eh(),a8(ef)),{addSubModuleTask:N,initSubModuleTask:O,subModuleTask:P,updateSubModuleTask:Q}=(en(),a8(ei)),{addAnnotatedTagTask:R,addTagTask:S,tagListTask:T}=(ew(),a8(es)),{straightThroughBufferTask:U,straightThroughStringTask:V}=(b6(),a8(b_));function W(a,b){this._plugins=b,this._executor=new c(a.baseDir,new e(a.maxConcurrentProcesses),b),this._trimmed=a.trimmed}function X(a,b,c,d){return"string"!=typeof c?f(`git.${a}() requires a string 'repoPath'`):b(c,l(d,j),m(arguments))}(W.prototype=Object.create(d.prototype)).constructor=W,W.prototype.customBinary=function(a){return this._plugins.reconfigure("binary",a),this},W.prototype.env=function(a,b){return 1==arguments.length&&"object"==typeof a?this._executor.env=a:(this._executor.env=this._executor.env||{})[a]=b,this},W.prototype.stashList=function(a){return this._runTask(M(o(arguments)||{},h(a)&&a||[]),n(arguments))},W.prototype.clone=function(){return this._runTask(X("clone",w,...arguments),n(arguments))},W.prototype.mirror=function(){return this._runTask(X("mirror",x,...arguments),n(arguments))},W.prototype.mv=function(a,b){return this._runTask(C(a,b),n(arguments))},W.prototype.checkoutLatestTag=function(a){var b=this;return this.pull(function(){b.tags(function(c,d){b.checkout(d.latest,a)})})},W.prototype.pull=function(a,b,c,d){return this._runTask(D(l(a,j),l(b,j),m(arguments)),n(arguments))},W.prototype.fetch=function(a,b){return this._runTask(B(l(a,j),l(b,j),m(arguments)),n(arguments))},W.prototype.silent=function(a){return console.warn("simple-git deprecation notice: git.silent: logging should be configured using the `debug` library / `DEBUG` environment variable, this will be an error in version 3"),this},W.prototype.tags=function(a,b){return this._runTask(T(m(arguments)),n(arguments))},W.prototype.rebase=function(){return this._runTask(V(["rebase",...m(arguments)]),n(arguments))},W.prototype.reset=function(a){return this._runTask(L(K(a),m(arguments)),n(arguments))},W.prototype.revert=function(a){let b=n(arguments);return"string"!=typeof a?this._runTask(f("Commit must be a string"),b):this._runTask(V(["revert",...m(arguments,0,!0),a]),b)},W.prototype.addTag=function(a){let b="string"==typeof a?S(a):f("Git.addTag requires a tag name");return this._runTask(b,n(arguments))},W.prototype.addAnnotatedTag=function(a,b){return this._runTask(R(a,b),n(arguments))},W.prototype.deleteLocalBranch=function(a,b,c){return this._runTask(t(a,"boolean"==typeof b&&b),n(arguments))},W.prototype.deleteLocalBranches=function(a,b,c){return this._runTask(s(a,"boolean"==typeof b&&b),n(arguments))},W.prototype.branch=function(a,b){return this._runTask(q(m(arguments)),n(arguments))},W.prototype.branchLocal=function(a){return this._runTask(r(),n(arguments))},W.prototype.raw=function(a){let b=!Array.isArray(a),c=[].slice.call(b?arguments:a,0);for(let a=0;a<c.length&&b;a++)if(!i(c[a])){c.splice(a,c.length-a);break}c.push(...m(arguments,0,!0));var d=n(arguments);return c.length?this._runTask(V(c,this._trimmed),d):this._runTask(f("Raw: must supply one or more command to execute"),d)},W.prototype.submoduleAdd=function(a,b,c){return this._runTask(N(a,b),n(arguments))},W.prototype.submoduleUpdate=function(a,b){return this._runTask(Q(m(arguments,!0)),n(arguments))},W.prototype.submoduleInit=function(a,b){return this._runTask(O(m(arguments,!0)),n(arguments))},W.prototype.subModule=function(a,b){return this._runTask(P(m(arguments)),n(arguments))},W.prototype.listRemote=function(){return this._runTask(H(m(arguments)),n(arguments))},W.prototype.addRemote=function(a,b,c){return this._runTask(F(a,b,m(arguments)),n(arguments))},W.prototype.removeRemote=function(a,b){return this._runTask(J(a),n(arguments))},W.prototype.getRemotes=function(a,b){return this._runTask(G(!0===a),n(arguments))},W.prototype.remote=function(a,b){return this._runTask(I(m(arguments)),n(arguments))},W.prototype.tag=function(a,b){let c=m(arguments);return"tag"!==c[0]&&c.unshift("tag"),this._runTask(V(c),n(arguments))},W.prototype.updateServerInfo=function(a){return this._runTask(V(["update-server-info"]),n(arguments))},W.prototype.pushTags=function(a,b){let c=E({remote:l(a,j)},m(arguments));return this._runTask(c,n(arguments))},W.prototype.rm=function(a){return this._runTask(V(["rm","-f",...g(a)]),n(arguments))},W.prototype.rmKeepLocal=function(a){return this._runTask(V(["rm","--cached",...g(a)]),n(arguments))},W.prototype.catFile=function(a,b){return this._catFile("utf-8",arguments)},W.prototype.binaryCatFile=function(){return this._catFile("buffer",arguments)},W.prototype._catFile=function(a,b){var c=n(b),d=["cat-file"],e=b[0];if("string"==typeof e)return this._runTask(f("Git.catFile: options must be supplied as an array of strings"),c);Array.isArray(e)&&d.push.apply(d,e);let g="buffer"===a?U(d):V(d);return this._runTask(g,c)},W.prototype.diff=function(a,b){let c=j(a)?f("git.diff: supplying options as a single string is no longer supported, switch to an array of strings"):V(["diff",...m(arguments)]);return this._runTask(c,n(arguments))},W.prototype.diffSummary=function(){return this._runTask(A(m(arguments,1)),n(arguments))},W.prototype.applyPatch=function(a){let b=k(a)?p(g(a),m([].slice.call(arguments,1))):f("git.applyPatch requires one or more string patches as the first argument");return this._runTask(b,n(arguments))},W.prototype.revparse=function(){let a=["rev-parse",...m(arguments,!0)];return this._runTask(V(a,!0),n(arguments))},W.prototype.clean=function(a,b,c){let d=z(a),e=d&&a.join("")||l(a,j)||"",f=m([].slice.call(arguments,+!!d));return this._runTask(y(e,f),n(arguments))},W.prototype.exec=function(a){return this._runTask({commands:[],format:"utf-8",parser(){"function"==typeof a&&a()}})},W.prototype.clearQueue=function(){return this},W.prototype.checkIgnore=function(a,b){return this._runTask(u(g(l(a,k,[]))),n(arguments))},W.prototype.checkIsRepo=function(a,b){return this._runTask(v(l(a,j)),n(arguments))},b.exports=W}},function(){return c||(0,b[a4(b)[0]])((c={exports:{}}).exports,c),c.exports});bb(),bc();var ey=class extends e{constructor(a,b){super(void 0,b),this.config=a}};bc(),bc();var ez=class extends e{constructor(a,b,c){super(a,c),this.task=a,this.plugin=b,Object.setPrototypeOf(this,new.target.prototype)}};bd(),be(),bZ(),cc(),cg(),ch(),ci(),cn(),bU(),bU();var eA=(0,a_.deferred)().promise;bU();var eB="Invalid value supplied for custom binary, restricted characters must be removed or supply the unsafe.allowUnsafeCustomBinary option";function eC(a){return!a||!/^([a-z]:)?([a-z0-9/.\\_-]+)$/i.test(a)}function eD(a,b){if(a.length<1||a.length>2)throw new ez(void 0,"binary","Invalid value supplied for custom binary, requires a single string or an array containing either one or two strings");if(a.some(eC))if(b)console.warn(eB);else throw new ez(void 0,"binary",eB);let[c,d]=a;return{binary:c,prefix:d}}function eE(a){return{type:"task.error",action(b,c){let d=a(b.error,{stdErr:c.stdErr,stdOut:c.stdOut,exitCode:c.exitCode});return Buffer.isBuffer(d)?{error:new e(void 0,d.toString("utf-8"))}:{error:d}}}}bc(),bU();var eF=class{constructor(){this.plugins=new Set,this.events=new a1.EventEmitter}on(a,b){this.events.on(a,b)}reconfigure(a,b){this.events.emit(a,b)}append(a,b){let c=bn(this.plugins,{type:a,action:b});return()=>this.plugins.delete(c)}add(a){let b=[];return bq(a).forEach(a=>a&&this.plugins.add(bn(b,a))),()=>{b.forEach(a=>this.plugins.delete(a))}}exec(a,b,c){let d=b,e=Object.freeze(Object.create(c));for(let b of this.plugins)b.type===a&&(d=b.action(d,e));return d}};bU(),bU(),bb(),bU();var eG=ex();bd();var eH=function(a,b){var c;let d,e,f,g,h=new eF,i=bJ(a&&("string"==typeof a?{baseDir:a}:a)||{},b);if(!bm(i.baseDir))throw new ey(i,"Cannot use simple-git on a directory that does not exist");return Array.isArray(i.config)&&h.add((d=bu(i.config,"-c"),{type:"spawn.args",action:a=>[...d,...a]})),h.add(function({allowUnsafeProtocolOverride:a=!1,allowUnsafePack:b=!1}={}){return{type:"spawn.args",action:(c,d)=>(c.forEach((e,f)=>{let g=f<c.length?c[f+1]:"";a||function(a,b){if("string"==typeof a&&"-c"===a.trim().toLowerCase()&&/^\s*protocol(.[a-z]+)?.allow/.test(b))throw new ez(void 0,"unsafe","Configuring protocol.allow is not permitted without enabling allowUnsafeExtProtocol")}(e,g),b||function(a,b){if(/^\s*--(upload|receive)-pack/.test(a))throw new ez(void 0,"unsafe","Use of --upload-pack or --receive-pack is not permitted without enabling allowUnsafePack");if("clone"===b&&/^\s*-u\b/.test(a))throw new ez(void 0,"unsafe","Use of clone with option -u is not permitted without enabling allowUnsafePack");if("push"===b&&/^\s*--exec\b/.test(a))throw new ez(void 0,"unsafe","Use of push with option --exec is not permitted without enabling allowUnsafePack")}(e,d.method)}),c)}}(i.unsafe)),h.add({type:"spawn.args",action(a){let b,c=[];function d(a){(b=b||[]).push(...a)}for(let b=0;b<a.length;b++){let e=a[b];if(a9(e)){d(ba(e));continue}if("--"===e){d(a.slice(b+1).flatMap(a=>a9(a)&&ba(a)||a));break}c.push(e)}return b?[...c,"--",...b.map(String)]:c}}),h.add(function({onClose:a=!0,onExit:b=50}={}){function c(a,b,c){!1!==a&&(!0===a?b.promise:b.promise.then(()=>bx(a))).then(c.done)}return{type:"spawn.after",async action(d,{spawned:e,close:f}){let g,h,i,j=(g=-1,h={close:(0,a_.deferred)(),closeTimeout:(0,a_.deferred)(),exit:(0,a_.deferred)(),exitTimeout:(0,a_.deferred)()},i=Promise.race([!1===a?eA:h.closeTimeout.promise,!1===b?eA:h.exitTimeout.promise]),c(a,h.close,h.closeTimeout),c(b,h.exit,h.exitTimeout),{close(a){g=a,h.close.done()},exit(a){g=a,h.exit.done()},get exitCode(){return g},result:i}),k=!0,l=()=>void(k=!1);e.stdout?.on("data",l),e.stderr?.on("data",l),e.on("error",l),e.on("close",a=>j.close(a)),e.on("exit",a=>j.exit(a));try{await j.result,k&&await bx(50),f(j.exitCode)}catch(a){f(j.exitCode,a)}}}}(i.completion)),i.abort&&h.add(function(a){if(a)return[{type:"spawn.before",action(b,c){a.aborted&&c.kill(new ez(void 0,"abort","Abort already signaled"))}},{type:"spawn.after",action(b,c){function d(){c.kill(new ez(void 0,"abort","Abort signal received"))}a.addEventListener("abort",d),c.spawned.on("close",()=>a.removeEventListener("abort",d))}}]}(i.abort)),i.progress&&h.add((c=i.progress,e="--progress",f=["checkout","clone","fetch","pull","push"],[{type:"spawn.args",action:(a,b)=>f.includes(b.method)?bo(a,e):a},{type:"spawn.after",action(a,b){b.commands.includes(e)&&b.spawned.stderr?.on("data",a=>{let d=/^([\s\S]+?):\s*(\d+)% \((\d+)\/(\d+)\)/.exec(a.toString("utf8"));d&&c({method:b.method,stage:String(d[1].toLowerCase().split(" ",1))||"unknown",progress:bt(d[2]),processed:bt(d[3]),total:bt(d[4])})})}}])),i.timeout&&h.add(function({block:a,stdErr:b=!0,stdOut:c=!0}){if(a>0)return{type:"spawn.after",action(d,e){let f;function g(){f&&clearTimeout(f),f=setTimeout(i,a)}function h(){e.spawned.stdout?.off("data",g),e.spawned.stderr?.off("data",g),e.spawned.off("exit",h),e.spawned.off("close",h),f&&clearTimeout(f)}function i(){h(),e.kill(new ez(void 0,"timeout","block timeout reached"))}c&&e.spawned.stdout?.on("data",g),b&&e.spawned.stderr?.on("data",g),e.spawned.on("exit",h),e.spawned.on("close",h),g()}}}(i.timeout)),i.spawnOptions&&h.add((g=bw(i.spawnOptions,["uid","gid"]),{type:"spawn.options",action:a=>({...g,...a})})),h.add(eE(function(a=!1,b=function(a){return!!(a.exitCode&&a.stdErr.length)},c=function(a){return Buffer.concat([...a.stdOut,...a.stdErr])}){return(d,e)=>(a||!d)&&b(e)?c(e):d}(!0))),i.errors&&h.add(eE(i.errors)),!function(a,b=["git"],c=!1){let d=eD(bq(b),c);a.on("binary",a=>{d=eD(bq(a),c)}),a.append("spawn.binary",()=>d.binary),a.append("spawn.args",a=>d.prefix?[d.prefix,...a]:a)}(h,i.binary,i.unsafe?.allowUnsafeCustomBinary),new eG(i,h)};a.s(["default",()=>eH])},46666,a=>{"use strict";function b(a){return a instanceof Error?a.message:String(a)}a.s(["getErrorMessage",()=>b])},13095,(a,b,c)=>{"use strict";function d(a){for(let b=0;b<a.length;b++){let c=a[b];if("function"!=typeof c)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof c}.
|
|
2
|
-
Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"ensureServerEntryExports",{enumerable:!0,get:function(){return d}})},15271,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(46786),f=a.i(4503);function g(a,b){return`viba-${(a.trim().replace(/[^a-zA-Z0-9_-]/g,"-")||"session").slice(0,40)}-${b}`}var h=a.i(13095);let i={gemini:{executable:"gemini",installCommand:"npm install -g google/gemini-cli"},codex:{executable:"codex",installCommand:"npm i -g openai/codex"},agent:{executable:"agent",installCommand:"curl https://cursor.com/install -fsS | bash"}};function j(a){return"gemini"===a||"codex"===a||"agent"===a?a:null}async function k(){return e.default.homedir()}async function l(a){try{let b=(await c.default.readdir(a,{withFileTypes:!0})).sort((a,b)=>a.isDirectory()&&!b.isDirectory()?-1:!a.isDirectory()&&b.isDirectory()?1:a.name.localeCompare(b.name)),e=[];for(let f of b){if(!f.isDirectory()&&!f.isFile())continue;let b=d.default.join(a,f.name),g=!1;if(f.isDirectory())try{let a=d.default.join(b,".git");await c.default.access(a),g=!0}catch{g=!1}e.push({name:f.name,path:b,isDirectory:f.isDirectory(),isGitRepo:g})}return e}catch(a){return console.error("Error listing directory entries:",a),[]}}async function m(a){return(await l(a)).filter(a=>a.isDirectory)}async function n(a){try{if(!(await c.default.stat(a)).isDirectory())return!1;return await c.default.readdir(a),!0}catch{return!1}}async function o(a){try{let b=(0,f.default)(a),c=await b.branchLocal();return c.all.map(a=>({name:a,current:c.current===a}))}catch(a){throw console.error("Error fetching branches:",a),Error("Failed to fetch branches. Make sure the path is a valid git repository.")}}async function p(a,b){try{let c=(0,f.default)(a);await c.checkout(b)}catch(a){throw console.error("Error checking out branch:",a),Error(`Failed to checkout branch ${b}`)}}async function q(a){try{let b=d.default.join(a,".git");return await c.default.access(b),!0}catch{return!1}}async function r(b){let c=j(b);if(!c)return{success:!1,installed:!1,error:`Unsupported coding agent CLI: ${b}`};try{let{spawn:b}=await a.A(44264),d=i[c];e.default.platform();let f=["-lc",`command -v ${d.executable}`],g=await new Promise(a=>{let c=b("bash",f,{stdio:"ignore"});c.on("close",b=>a(b??1)),c.on("error",()=>a(1))});return{success:!0,installed:0===g}}catch(a){return console.error("Failed to detect coding agent CLI:",a),{success:!1,installed:!1,error:"Failed to detect coding agent CLI installation status."}}}async function s(b){let c=j(b);if(!c)return{success:!1,error:`Unsupported coding agent CLI: ${b}`};try{let{spawn:b}=await a.A(44264),d=i[c];e.default.platform();let f=["-lc",d.installCommand],g=[],h=await new Promise(a=>{let c=b("bash",f,{cwd:e.default.homedir(),env:process.env,stdio:["ignore","pipe","pipe"]});c.stdout.on("data",a=>{g.push(a.toString())}),c.stderr.on("data",a=>{g.push(a.toString())}),c.on("close",b=>a(b??1)),c.on("error",()=>a(1))});if(0===h)return{success:!0};let j=g.join("").trim();return{success:!1,error:j||`Failed to install ${c} CLI.`}}catch(a){return console.error("Failed to install coding agent CLI:",a),{success:!1,error:"Failed to install coding agent CLI."}}}async function t(){if(global.ttydProcess){if("tmux"===global.ttydPersistenceMode&&"win32"!==e.default.platform())try{let{spawnSync:b}=await a.A(44264);b("tmux",["set-option","-g","mouse","on"],{stdio:"ignore",env:process.env})}catch(a){console.error("Failed to apply tmux mouse option:",a)}return{success:!0,persistenceMode:global.ttydPersistenceMode||"shell"}}try{let{spawn:b,spawnSync:c}=await a.A(44264),d={...process.env};delete d.TURBOPACK,delete d.PORT,delete d.NODE_ENV;let f=e.default.homedir(),g="win32"!==e.default.platform()&&0===c("which",["tmux"],{stdio:"ignore",env:process.env}).status,h=["-p","7681","-t",'theme={"background": "white", "foreground": "black", "cursor": "black", "selectionBackground": "rgba(59, 130, 246, 0.4)"}',"-t","disableResizeOverlay=true","-t","fontSize=12","-t","fontWeight=300","-t","fontWeightBold=500","-w",f,"-W"],i="shell";g?(c("tmux",["start-server"],{stdio:"ignore",env:process.env}),c("tmux",["set-option","-g","mouse","on"],{stdio:"ignore",env:process.env}),c("tmux",["set-option","-g","history-limit","200000"],{stdio:"ignore",env:process.env}),h.push("-a","tmux"),i="tmux"):(console.warn("tmux is unavailable; falling back to non-persistent ttyd shell mode."),h.push("bash"));let j=b("ttyd",h,{stdio:"ignore",detached:!1,cwd:f,env:{...d,TERM:"xterm-256color",COLORTERM:"truecolor"}});return j.on("error",a=>{console.error("Failed to start ttyd:",a),global.ttydProcess=void 0,global.ttydPersistenceMode=void 0}),j.on("exit",()=>{global.ttydProcess=void 0,global.ttydPersistenceMode=void 0}),global.ttydProcess=j,global.ttydPersistenceMode=i,await new Promise(a=>setTimeout(a,1e3)),{success:!0,persistenceMode:i}}catch(a){return console.error("Error starting ttyd:",a),{success:!1,error:"Failed to start ttyd. Make sure ttyd is installed and in your PATH."}}}async function u(b,c,d){e.default.platform();try{let{spawnSync:e}=await a.A(44264),f=g(b,c),h=e("tmux",["has-session","-t",f],{stdio:"ignore",env:process.env});if("number"==typeof h.status&&0!==h.status)return{success:!0};let i=e("tmux",["set-option","-t",f,"mouse",d?"on":"off"],{stdio:"ignore",env:process.env});if("number"==typeof i.status&&0!==i.status)return{success:!1,error:`tmux exited with status ${i.status}`};return{success:!0}}catch(a){return console.error("Failed to set tmux mouse mode:",a),{success:!1,error:"Failed to set tmux mouse mode."}}}async function v(b){e.default.platform();try{let{spawnSync:c}=await a.A(44264);if(0!==c("which",["tmux"],{stdio:"ignore",env:process.env}).status)return;for(let a of["agent","terminal"]){let d=g(b,a);c("tmux",["kill-session","-t",d],{stdio:"ignore",env:process.env})}}catch(a){console.error("Failed to terminate session terminal sessions:",a)}}async function w(b,e){try{let{v4:g}=await a.A(37706),h=g().split("-")[0],i=new Date,j=i.toISOString().replace(/[-:]/g,"").slice(0,8)+"-"+i.getHours().toString().padStart(2,"0")+i.getMinutes().toString().padStart(2,"0"),k=`${j}-${h}`,l=`viba/${k}`,m=d.default.basename(b),n=d.default.dirname(b),o=d.default.join(n,".viba",m),p=d.default.join(o,k);await c.default.mkdir(o,{recursive:!0});let q=(0,f.default)(b);return await q.raw(["worktree","add","-b",l,p,e]),{success:!0,sessionName:k,worktreePath:p,branchName:l}}catch(a){return console.error("Failed to create worktree:",a),{success:!1,error:a.message||String(a)}}}async function x(a,b,d){try{let e=(0,f.default)(a);try{await e.raw(["worktree","remove","--force",b])}catch(c){let a=c.message||String(c);a.includes("is not a working tree")||a.includes("not a valid path")?console.warn(`Path ${b} is not a valid working tree according to git, continuing cleanup...`):console.error(`Git worktree remove failed, but continuing with cleanup: ${a}`);try{await e.raw(["worktree","prune"])}catch{}}try{await e.deleteLocalBranch(d,!0)}catch(a){console.warn(`Failed to delete branch ${d}: ${a.message||a}`)}try{await c.default.rm(b,{recursive:!0,force:!0})}catch{}try{let a=`${b}-attachments`;await c.default.rm(a,{recursive:!0,force:!0})}catch{}return{success:!0}}catch(a){return console.error("Failed to cleanup worktree (critical error):",a),{success:!0}}}async function y(a){try{let b=await c.default.readdir(a);if(b.includes("package-lock.json"))return"npm install";if(b.includes("pnpm-lock.yaml"))return"pnpm install";if(b.includes("yarn.lock"))return"yarn install";return""}catch(a){return console.error("Error determining startup script:",a),""}}async function z(a){try{let b=d.default.join(a,"package.json"),e=await c.default.readFile(b,"utf-8"),f=JSON.parse(e).scripts;if(!f||"object"!=typeof f)return"";if("string"==typeof f.dev&&f.dev.trim())return"npm run dev";if("string"==typeof f.watch&&f.watch.trim())return"npm run watch";if("string"==typeof f.start&&f.start.trim())return"npm run start";return""}catch(a){return"ENOENT"!==("object"==typeof a&&null!==a&&"code"in a?a.code:void 0)&&console.error("Error determining default dev server script:",a),""}}async function A(a,b=""){try{let c=(0,f.default)(a),d=(await c.raw(["ls-files"])).split("\n").filter(Boolean);if(!b)return d.slice(0,50);let e=b.toLowerCase();return d.filter(a=>a.toLowerCase().includes(e)).slice(0,50)}catch(a){return console.error("Failed to list repo files:",a),[]}}async function B(a,b){try{let e=`${a}-attachments`;await c.default.mkdir(e,{recursive:!0});let f=[];for(let[,a]of Array.from(b.entries()))if(a instanceof File){let b=Buffer.from(await a.arrayBuffer()),g=a.name.replace(/[^a-zA-Z0-9._-]/g,"_"),h=d.default.join(e,g);await c.default.writeFile(h,b),f.push(g)}return f}catch(a){return console.error("Failed to save attachments:",a),[]}}(0,h.ensureServerEntryExports)([k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B]),(0,b.registerServerReference)(k,"001ebbf8d876e41274fa9cefcf0b696bb69eb13196",null),(0,b.registerServerReference)(l,"40aef8fb312b609cd21a6689c7bd65cad7e75807a8",null),(0,b.registerServerReference)(m,"404a4f221fb5c80ba52b290838390241e31098f46e",null),(0,b.registerServerReference)(n,"40937c2f600add194af15aa737b5c7292f2d62d6f9",null),(0,b.registerServerReference)(o,"4085f6871b7c3add7b60aa3d34406bd991a6d3e03d",null),(0,b.registerServerReference)(p,"60a28c6aabf7dbb33218e8891c9b93f8aa91e39367",null),(0,b.registerServerReference)(q,"40029a09c358c79fdf51943e159e8dd1d54b98c3cc",null),(0,b.registerServerReference)(r,"40f3369647d8949c5f8381bd411f6f17951a389a2d",null),(0,b.registerServerReference)(s,"40aeefe4f48e4427751387c9d133cafd13cd2ae1c6",null),(0,b.registerServerReference)(t,"7fe6bfb3e24eb965be2acca177e9b7cc8650414d98",null),(0,b.registerServerReference)(u,"7f6a62aa6d0ad3fa742aec5c79aca5f71d38eb4aa3",null),(0,b.registerServerReference)(v,"7f63b2b07df2041a5c3f19cac7bb82eef2fdc2ac8e",null),(0,b.registerServerReference)(w,"7f75e855d2acdc470c71635f2b9b5364f3b090d22d",null),(0,b.registerServerReference)(x,"7f69b3d0811d36cf93db7533330165bf6353c6968f",null),(0,b.registerServerReference)(y,"7fecacfc9f2c4707a216267649a48a62d39bed5c8d",null),(0,b.registerServerReference)(z,"7fdb95dbb835f22dc7e0ee075de9334a0ed24fab36",null),(0,b.registerServerReference)(A,"7f2111a2cbb2181bee547d36532a08c868e4356374",null),(0,b.registerServerReference)(B,"7f906f2105615778e8f0882db2c9272b9353851164",null),a.s(["checkAgentCliInstalled",()=>r,"checkDirectoryAccessible",()=>n,"checkIsGitRepo",()=>q,"checkoutBranch",()=>p,"getBranches",()=>o,"getDefaultDevServerScript",()=>z,"getHomeDirectory",()=>k,"getStartupScript",()=>y,"installAgentCli",()=>s,"listDirectories",()=>m,"listPathEntries",()=>l,"listRepoFiles",()=>A,"prepareSessionWorktree",()=>w,"removeWorktree",()=>x,"saveAttachments",()=>B,"setTmuxSessionMouseMode",()=>u,"startTtydProcess",()=>t,"terminateSessionTerminalSessions",()=>v],15271)},51817,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(46786),f=a.i(4503),g=a.i(46666),h=a.i(15271);async function i(){let a=e.default.homedir(),b=d.default.join(a,".viba","sessions");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function j(){let a=e.default.homedir(),b=d.default.join(a,".viba","session-contexts");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function k(a){let b=await j();return d.default.join(b,`${a}.json`)}async function l(){let a=e.default.homedir(),b=d.default.join(a,".viba","session-prompts");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function m(a){let b=await i(),e=d.default.join(b,`${a.sessionName}.json`);await c.default.writeFile(e,JSON.stringify(a,null,2),"utf-8")}async function n(a,b){try{let e=await l(),f=d.default.join(e,`${a}.txt`);return await c.default.writeFile(f,b,"utf-8"),{success:!0,filePath:f}}catch(a){return console.error("Failed to write session prompt file:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function o(a,b){try{let d=await k(a),e={sessionName:a,...b,timestamp:new Date().toISOString()};return await c.default.writeFile(d,JSON.stringify(e,null,2),"utf-8"),{success:!0}}catch(a){return console.error("Failed to save session launch context:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function p(a){try{let b=await k(a),d=await c.default.readFile(b,"utf-8"),e=JSON.parse(d);return{success:!0,context:e}}catch(a){if("ENOENT"===("object"==typeof a&&null!==a&&"code"in a?a.code:void 0))return{success:!0};return console.error("Failed to consume session launch context:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function q(a){try{let b=await k(a),d=await c.default.readFile(b,"utf-8"),e=JSON.parse(d);return{success:!0,context:e}}catch(a){if("ENOENT"===("object"==typeof a&&null!==a&&"code"in a?a.code:void 0))return{success:!0};return console.error("Failed to read session launch context:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function r(a){let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=await q(a);if(!c.success)return{success:!1,error:c.error||"Failed to load session launch context"};let d=c.context;return{success:!0,context:{sourceSessionName:a,repoPath:b.repoPath,title:d?.title||b.title,initialMessage:d?.rawInitialMessage||d?.initialMessage,attachmentNames:d?.attachmentNames||[],agentProvider:d?.agentProvider||b.agent,model:d?.model||b.model}}}async function s(a,b,e){try{let f=await t(a);if(!f)return{success:!1,copiedAttachmentNames:[],missingAttachmentNames:[],error:"Source session metadata not found"};let g=`${f.worktreePath}-attachments`,h=`${b}-attachments`;await c.default.mkdir(h,{recursive:!0});let i=[],j=[];for(let a of Array.from(new Set(e.map(a=>a.trim()).filter(Boolean)))){let b=a.replace(/[^a-zA-Z0-9._-]/g,"_"),e=d.default.join(g,b),f=d.default.join(h,b);try{await c.default.copyFile(e,f),i.push(b)}catch(c){let b="object"==typeof c&&null!==c&&"code"in c?c.code:void 0;if("ENOENT"===b){j.push(a);continue}throw c}}return{success:!0,copiedAttachmentNames:i,missingAttachmentNames:j}}catch(a){return console.error("Failed to copy session attachments:",a),{success:!1,copiedAttachmentNames:[],missingAttachmentNames:[],error:(0,g.getErrorMessage)(a)}}}async function t(a){try{let b=await i(),e=d.default.join(b,`${a}.json`),f=await c.default.readFile(e,"utf-8");return JSON.parse(f)}catch{return null}}async function u(a){try{let b=await i(),e=await c.default.readdir(b),f=[];for(let g of e)if(g.endsWith(".json"))try{let e=d.default.join(b,g),h=await c.default.readFile(e,"utf-8"),i=JSON.parse(h);if(a&&i.repoPath!==a)continue;f.push(i)}catch(a){console.error(`Failed to parse session file ${g}:`,a)}return f.sort((a,b)=>new Date(b.timestamp).getTime()-new Date(a.timestamp).getTime())}catch(a){return console.error("Failed to list sessions:",a),[]}}async function v(a,b,c){try{let d=await (0,h.prepareSessionWorktree)(a,b);if(!d.success||!d.sessionName||!d.worktreePath||!d.branchName)return d;let e={sessionName:d.sessionName,repoPath:a,worktreePath:d.worktreePath,branchName:d.branchName,baseBranch:b,agent:c.agent,model:c.model,title:c.title,devServerScript:c.devServerScript,initialized:!1,timestamp:new Date().toISOString()};return await m(e),d}catch(a){return console.error("Failed to create session:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function w(a){let b=await t(a);!b||b.initialized||(b.initialized=!0,await m(b))}async function x(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let e=await (0,h.removeWorktree)(b.repoPath,b.worktreePath,b.branchName);if(await (0,h.terminateSessionTerminalSessions)(a),!e.success)return e;let f=await i(),g=d.default.join(f,`${a}.json`);await c.default.rm(g,{force:!0});let j=await k(a);await c.default.rm(j,{force:!0});let m=await l(),n=d.default.join(m,`${a}.txt`);return await c.default.rm(n,{force:!0}),{success:!0}}catch(a){return console.error("Failed to delete session:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function y(a){try{if(!await t(a))return{success:!1,error:"Session metadata not found"};return x(a).catch(b=>{console.error(`Background cleanup of session ${a} failed:`,b)}),{success:!0}}catch(a){return console.error("Failed to schedule background session deletion:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function z(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=b.baseBranch?.trim();if(!c)return{success:!1,error:"Base branch is missing for this session. This session may be from an older version."};let d=(0,f.default)(b.worktreePath);if(!(await d.status()).isClean())return{success:!1,error:"Worktree has uncommitted changes. Commit your changes first."};let e=(0,f.default)(b.repoPath),g=await e.branchLocal();if(!g.all.includes(c))return{success:!1,error:`Base branch "${c}" not found in repository.`};if(!g.all.includes(b.branchName))return{success:!1,error:`Session branch "${b.branchName}" not found in repository.`};let h=g.current;return h!==c&&await e.checkout(c),await e.merge(["--no-ff",b.branchName]),h&&h!==c&&await e.checkout(h),{success:!0,branchName:b.branchName,baseBranch:c}}catch(a){return console.error("Failed to merge session branch:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function A(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=b.baseBranch?.trim();if(!c)return{success:!1,error:"Base branch is missing for this session. This session may be from an older version."};let d=(0,f.default)(b.worktreePath);if(!(await d.status()).isClean())return{success:!1,error:"Worktree has uncommitted changes. Commit your changes first."};let e=(0,f.default)(b.repoPath),g=await e.branchLocal();if(!g.all.includes(c))return{success:!1,error:`Base branch "${c}" not found in repository.`};if(!g.all.includes(b.branchName))return{success:!1,error:`Session branch "${b.branchName}" not found in repository.`};return(await d.branchLocal()).current!==b.branchName&&await d.checkout(b.branchName),await d.rebase([c]),{success:!0,branchName:b.branchName,baseBranch:c}}catch(a){return console.error("Failed to rebase session branch:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function B(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=(0,f.default)(b.worktreePath),d=await c.status();return{success:!0,count:d.files.length}}catch(a){return console.error("Failed to get uncommitted file count:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function C(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=b.baseBranch?.trim();if(!c)return{success:!1,error:"Base branch is unavailable for this session."};let d=(0,f.default)(b.repoPath),e=await d.branchLocal();if(!e.all.includes(c))return{success:!1,error:`Base branch "${c}" not found in repository.`};if(!e.all.includes(b.branchName))return{success:!1,error:`Session branch "${b.branchName}" not found in repository.`};let[g,h]=(await d.raw(["rev-list","--left-right","--count",`${c}...${b.branchName}`])).trim().split(/\s+/),i=Number.parseInt(g,10),j=Number.parseInt(h,10);if(Number.isNaN(i)||Number.isNaN(j))return{success:!1,error:"Failed to parse git divergence output."};return{success:!0,ahead:j,behind:i}}catch(a){return console.error("Failed to get session divergence:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function D(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=(0,f.default)(b.repoPath),d=[...(await c.branchLocal()).all].sort((a,b)=>a.localeCompare(b)),e=b.baseBranch?.trim();return{success:!0,baseBranch:e,branches:d}}catch(a){return console.error("Failed to list session base branches:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function E(a,b){try{let c=await t(a);if(!c)return{success:!1,error:"Session metadata not found"};let d=b.trim();if(!d)return{success:!1,error:"Base branch cannot be empty."};let e=(0,f.default)(c.repoPath);if(!(await e.branchLocal()).all.includes(d))return{success:!1,error:`Base branch "${d}" not found in repository.`};return c.baseBranch=d,await m(c),{success:!0,baseBranch:d}}catch(a){return console.error("Failed to update session base branch:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}(0,a.i(13095).ensureServerEntryExports)([m,n,o,p,r,s,t,u,v,w,x,y,z,A,B,C,D,E]),(0,b.registerServerReference)(m,"407ee58cadc6bcd7c945a6aea2d10abbeaa9990bc0",null),(0,b.registerServerReference)(n,"60a9ad33509eb1722c9ff3f72c7427536e5092996f",null),(0,b.registerServerReference)(o,"601e17dd1c692d4b98c11b0ed5fcac332078c98942",null),(0,b.registerServerReference)(p,"40122eda8b252b24bbe27b4b3d47440267aaae6443",null),(0,b.registerServerReference)(r,"407a7852d4feddce84bff9b9235786c67bf33094d7",null),(0,b.registerServerReference)(s,"7046beca3672ffd0b320e53035897d1f55adb7a8f6",null),(0,b.registerServerReference)(t,"40ebee9bfc9e13bd2be243d1057d3003e8368b1840",null),(0,b.registerServerReference)(u,"4074282e03de6ae455e16e2433ff333625e5c17cae",null),(0,b.registerServerReference)(v,"70a9577fd7ad11f696a8773e31641c3fa655ca9228",null),(0,b.registerServerReference)(w,"400b499580f2a72ea8e82626fea3a23366810e119c",null),(0,b.registerServerReference)(x,"40fa6fd8fff10eb70f10c65ec2fa63192f4f538e89",null),(0,b.registerServerReference)(y,"40c3aa3728b8ed7448d9a8ccb4ff7438f4ec3c7aff",null),(0,b.registerServerReference)(z,"4065ab261ed1faee7b684297cf90f071a062c0d74d",null),(0,b.registerServerReference)(A,"409970f9db44be38345fba51bdacf1780bd4e3779c",null),(0,b.registerServerReference)(B,"40f689b567c478d2b3f236edf7d1c7a2a9dbe88274",null),(0,b.registerServerReference)(C,"40588386adda2f29ee36315d2143f4a1ea351b52ee",null),(0,b.registerServerReference)(D,"4007eca1b2c7c83e938f6470653a471095282299e2",null),(0,b.registerServerReference)(E,"6037646aa61e7d586744d1b67b84958a62a3942f19",null),a.s(["consumeSessionLaunchContext",()=>p,"copySessionAttachments",()=>s,"createSession",()=>v,"deleteSession",()=>x,"deleteSessionInBackground",()=>y,"getSessionDivergence",()=>C,"getSessionMetadata",()=>t,"getSessionPrefillContext",()=>r,"getSessionUncommittedFileCount",()=>B,"listSessionBaseBranches",()=>D,"listSessions",()=>u,"markSessionInitialized",()=>w,"mergeSessionToBase",()=>z,"rebaseSessionOntoBase",()=>A,"saveSessionLaunchContext",()=>o,"updateSessionBaseBranch",()=>E,"writeSessionPromptFile",()=>n])},38642,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(46786),f=a.i(13095);let g={recentRepos:[],defaultRoot:"",selectedIde:"vscode",agentWidth:66.666,repoSettings:{},pinnedFolderShortcuts:[]};async function h(){let a=e.default.homedir(),b=d.default.join(a,".viba");try{await c.default.mkdir(b,{recursive:!0})}catch(a){}return d.default.join(b,"config.json")}async function i(){try{let a=await h(),b=await c.default.readFile(a,"utf-8"),d=JSON.parse(b);return{...g,...d}}catch(a){return g}}async function j(a){try{let b=await h();await c.default.writeFile(b,JSON.stringify(a,null,2),"utf-8")}catch(a){throw console.error("Failed to save config:",a),Error("Failed to save configuration.")}}async function k(a){let b={...await i(),...a};return await j(b),b}async function l(a,b){let c=await i(),d=c.repoSettings[a]||{},e={...c,repoSettings:{...c.repoSettings,[a]:{...d,...b}}};return await j(e),e}(0,f.ensureServerEntryExports)([i,j,k,l]),(0,b.registerServerReference)(i,"00fba2cbb3b06f7e6a11533d96ebeaa87290bed9d4",null),(0,b.registerServerReference)(j,"4002d3bc2e111c7e51489926ae8f25af4d5dab4520",null),(0,b.registerServerReference)(k,"4005769a25df134b3287a35a39162f5dc8c990d459",null),(0,b.registerServerReference)(l,"60321d3a3c16e9c73a08bb8012a8c3a5a2a6d5c9d7",null),a.s(["getConfig",()=>i,"updateConfig",()=>k,"updateRepoSettings",()=>l])}];
|
|
2
|
+
Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"ensureServerEntryExports",{enumerable:!0,get:function(){return d}})},15271,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(46786),f=a.i(4503);function g(a,b){return`viba-${(a.trim().replace(/[^a-zA-Z0-9_-]/g,"-")||"session").slice(0,40)}-${b}`}var h=a.i(13095);let i={gemini:{executable:"gemini",installCommand:"npm install -g google/gemini-cli"},codex:{executable:"codex",installCommand:"npm i -g openai/codex"},agent:{executable:"agent",installCommand:"curl https://cursor.com/install -fsS | bash"}};function j(a){return"gemini"===a||"codex"===a||"agent"===a?a:null}async function k(){return e.default.homedir()}async function l(a){try{let b=(await c.default.readdir(a,{withFileTypes:!0})).sort((a,b)=>a.isDirectory()&&!b.isDirectory()?-1:!a.isDirectory()&&b.isDirectory()?1:a.name.localeCompare(b.name));return(await Promise.all(b.map(async b=>{if(!b.isDirectory()&&!b.isFile())return null;let e=d.default.join(a,b.name),f=!1;if(b.isDirectory())try{let a=d.default.join(e,".git");await c.default.access(a),f=!0}catch{f=!1}return{name:b.name,path:e,isDirectory:b.isDirectory(),isGitRepo:f}}))).filter(a=>null!==a)}catch(a){return console.error("Error listing directory entries:",a),[]}}async function m(a){return(await l(a)).filter(a=>a.isDirectory)}async function n(a){try{if(!(await c.default.stat(a)).isDirectory())return!1;return await c.default.readdir(a),!0}catch{return!1}}async function o(a){try{let b=(0,f.default)(a),c=await b.branchLocal();return c.all.map(a=>({name:a,current:c.current===a}))}catch(a){throw console.error("Error fetching branches:",a),Error("Failed to fetch branches. Make sure the path is a valid git repository.")}}async function p(a,b){try{let c=(0,f.default)(a);await c.checkout(b)}catch(a){throw console.error("Error checking out branch:",a),Error(`Failed to checkout branch ${b}`)}}async function q(a){try{let b=d.default.join(a,".git");return await c.default.access(b),!0}catch{return!1}}async function r(b){let c=j(b);if(!c)return{success:!1,installed:!1,error:`Unsupported coding agent CLI: ${b}`};try{let{spawn:b}=await a.A(44264),d=i[c];e.default.platform();let f=["-lc",`command -v ${d.executable}`],g=await new Promise(a=>{let c=b("bash",f,{stdio:"ignore"});c.on("close",b=>a(b??1)),c.on("error",()=>a(1))});return{success:!0,installed:0===g}}catch(a){return console.error("Failed to detect coding agent CLI:",a),{success:!1,installed:!1,error:"Failed to detect coding agent CLI installation status."}}}async function s(b){let c=j(b);if(!c)return{success:!1,error:`Unsupported coding agent CLI: ${b}`};try{let{spawn:b}=await a.A(44264),d=i[c];e.default.platform();let f=["-lc",d.installCommand],g=[],h=await new Promise(a=>{let c=b("bash",f,{cwd:e.default.homedir(),env:process.env,stdio:["ignore","pipe","pipe"]});c.stdout.on("data",a=>{g.push(a.toString())}),c.stderr.on("data",a=>{g.push(a.toString())}),c.on("close",b=>a(b??1)),c.on("error",()=>a(1))});if(0===h)return{success:!0};let j=g.join("").trim();return{success:!1,error:j||`Failed to install ${c} CLI.`}}catch(a){return console.error("Failed to install coding agent CLI:",a),{success:!1,error:"Failed to install coding agent CLI."}}}async function t(){if(global.ttydProcess){if("tmux"===global.ttydPersistenceMode&&"win32"!==e.default.platform())try{let{spawnSync:b}=await a.A(44264);b("tmux",["set-option","-g","mouse","on"],{stdio:"ignore",env:process.env})}catch(a){console.error("Failed to apply tmux mouse option:",a)}return{success:!0,persistenceMode:global.ttydPersistenceMode||"shell"}}try{let{spawn:b,spawnSync:c}=await a.A(44264),d={...process.env};delete d.TURBOPACK,delete d.PORT,delete d.NODE_ENV;let f=e.default.homedir(),g="win32"!==e.default.platform()&&0===c("which",["tmux"],{stdio:"ignore",env:process.env}).status,h=["-p","7681","-t",'theme={"background": "white", "foreground": "black", "cursor": "black", "selectionBackground": "rgba(59, 130, 246, 0.4)"}',"-t","disableResizeOverlay=true","-t","fontSize=12","-t","fontWeight=300","-t","fontWeightBold=500","-w",f,"-W"],i="shell";g?(c("tmux",["start-server"],{stdio:"ignore",env:process.env}),c("tmux",["set-option","-g","mouse","on"],{stdio:"ignore",env:process.env}),c("tmux",["set-option","-g","history-limit","200000"],{stdio:"ignore",env:process.env}),h.push("-a","tmux"),i="tmux"):(console.warn("tmux is unavailable; falling back to non-persistent ttyd shell mode."),h.push("bash"));let j=b("ttyd",h,{stdio:"ignore",detached:!1,cwd:f,env:{...d,TERM:"xterm-256color",COLORTERM:"truecolor"}});return j.on("error",a=>{console.error("Failed to start ttyd:",a),global.ttydProcess=void 0,global.ttydPersistenceMode=void 0}),j.on("exit",()=>{global.ttydProcess=void 0,global.ttydPersistenceMode=void 0}),global.ttydProcess=j,global.ttydPersistenceMode=i,await new Promise(a=>setTimeout(a,1e3)),{success:!0,persistenceMode:i}}catch(a){return console.error("Error starting ttyd:",a),{success:!1,error:"Failed to start ttyd. Make sure ttyd is installed and in your PATH."}}}async function u(b,c,d){e.default.platform();try{let{spawnSync:e}=await a.A(44264),f=g(b,c),h=e("tmux",["has-session","-t",f],{stdio:"ignore",env:process.env});if("number"==typeof h.status&&0!==h.status)return{success:!0};let i=e("tmux",["set-option","-t",f,"mouse",d?"on":"off"],{stdio:"ignore",env:process.env});if("number"==typeof i.status&&0!==i.status)return{success:!1,error:`tmux exited with status ${i.status}`};return{success:!0}}catch(a){return console.error("Failed to set tmux mouse mode:",a),{success:!1,error:"Failed to set tmux mouse mode."}}}async function v(b){e.default.platform();try{let{spawnSync:c}=await a.A(44264);if(0!==c("which",["tmux"],{stdio:"ignore",env:process.env}).status)return;for(let a of["agent","terminal"]){let d=g(b,a);c("tmux",["kill-session","-t",d],{stdio:"ignore",env:process.env})}}catch(a){console.error("Failed to terminate session terminal sessions:",a)}}async function w(b,e){try{let{v4:g}=await a.A(37706),h=g().split("-")[0],i=new Date,j=i.toISOString().replace(/[-:]/g,"").slice(0,8)+"-"+i.getHours().toString().padStart(2,"0")+i.getMinutes().toString().padStart(2,"0"),k=`${j}-${h}`,l=`viba/${k}`,m=d.default.basename(b),n=d.default.dirname(b),o=d.default.join(n,".viba",m),p=d.default.join(o,k);await c.default.mkdir(o,{recursive:!0});let q=(0,f.default)(b);return await q.raw(["worktree","add","-b",l,p,e]),{success:!0,sessionName:k,worktreePath:p,branchName:l}}catch(a){return console.error("Failed to create worktree:",a),{success:!1,error:a.message||String(a)}}}async function x(a,b,d){try{let e=(0,f.default)(a);try{await e.raw(["worktree","remove","--force",b])}catch(c){let a=c.message||String(c);a.includes("is not a working tree")||a.includes("not a valid path")?console.warn(`Path ${b} is not a valid working tree according to git, continuing cleanup...`):console.error(`Git worktree remove failed, but continuing with cleanup: ${a}`);try{await e.raw(["worktree","prune"])}catch{}}try{await e.deleteLocalBranch(d,!0)}catch(a){console.warn(`Failed to delete branch ${d}: ${a.message||a}`)}try{await c.default.rm(b,{recursive:!0,force:!0})}catch{}try{let a=`${b}-attachments`;await c.default.rm(a,{recursive:!0,force:!0})}catch{}return{success:!0}}catch(a){return console.error("Failed to cleanup worktree (critical error):",a),{success:!0}}}async function y(a){try{let b=await c.default.readdir(a);if(b.includes("package-lock.json"))return"npm install";if(b.includes("pnpm-lock.yaml"))return"pnpm install";if(b.includes("yarn.lock"))return"yarn install";return""}catch(a){return console.error("Error determining startup script:",a),""}}async function z(a){try{let b=d.default.join(a,"package.json"),e=await c.default.readFile(b,"utf-8"),f=JSON.parse(e).scripts;if(!f||"object"!=typeof f)return"";if("string"==typeof f.dev&&f.dev.trim())return"npm run dev";if("string"==typeof f.watch&&f.watch.trim())return"npm run watch";if("string"==typeof f.start&&f.start.trim())return"npm run start";return""}catch(a){return"ENOENT"!==("object"==typeof a&&null!==a&&"code"in a?a.code:void 0)&&console.error("Error determining default dev server script:",a),""}}async function A(a,b=""){try{let c=(0,f.default)(a),d=(await c.raw(["ls-files"])).split("\n").filter(Boolean);if(!b)return d.slice(0,50);let e=b.toLowerCase();return d.filter(a=>a.toLowerCase().includes(e)).slice(0,50)}catch(a){return console.error("Failed to list repo files:",a),[]}}async function B(a,b){try{let e=`${a}-attachments`;await c.default.mkdir(e,{recursive:!0});let f=Array.from(b.entries()).map(async([,a])=>{if(a instanceof File){let b=Buffer.from(await a.arrayBuffer()),f=a.name.replace(/[^a-zA-Z0-9._-]/g,"_"),g=d.default.join(e,f);return await c.default.writeFile(g,b),f}return null});return(await Promise.all(f)).filter(a=>null!==a)}catch(a){return console.error("Failed to save attachments:",a),[]}}(0,h.ensureServerEntryExports)([k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B]),(0,b.registerServerReference)(k,"0064142194fc66ae46cbc78d74274227c2d805e14d",null),(0,b.registerServerReference)(l,"4027173d01b680db0b9a657161c844c9552c369464",null),(0,b.registerServerReference)(m,"40b1a38d05ed18fbd8ced3addc361eba254f1ce878",null),(0,b.registerServerReference)(n,"40beb8f54bd8073ce761ab747cac2ed074b2049da8",null),(0,b.registerServerReference)(o,"40eef6c0002e4f3835e734632e0c94b1ccb6daa5ab",null),(0,b.registerServerReference)(p,"60a523b3b5a1496e160f1e38563e6c035984a1f82c",null),(0,b.registerServerReference)(q,"4075f0c9468052bae5318ba359cd2ca6123a1a0df6",null),(0,b.registerServerReference)(r,"40852a0dc25a576247a0af933e48820d6f5455d378",null),(0,b.registerServerReference)(s,"4086363688e5e2f58164a93321fe93408875252d56",null),(0,b.registerServerReference)(t,"7f0e36b243667a60f3b66d62df4156e5898316c0ca",null),(0,b.registerServerReference)(u,"7fdf3165813fbc7e5880c44f20875dd2978996393b",null),(0,b.registerServerReference)(v,"7fe7caae660fe176a6b754555cf1ed99e61cbeb4b0",null),(0,b.registerServerReference)(w,"7f72f9cc3a151d2a8a09dad3138c0c56a810a73eb9",null),(0,b.registerServerReference)(x,"7f6adb5fae9a12ab4e88197be1bf96cefbb4ece0e6",null),(0,b.registerServerReference)(y,"7f122779b69249e2fa7399c26400a71f662d4ae089",null),(0,b.registerServerReference)(z,"7f9e83a1385122422ad799f6075779a3d690ab450c",null),(0,b.registerServerReference)(A,"7f3e1dc70dae5e89dcfadfcda5bb871d59bf05a58b",null),(0,b.registerServerReference)(B,"7fde2dea8e03e5505cf3c38d40cfa3fbd5f3b7d6bc",null),a.s(["checkAgentCliInstalled",()=>r,"checkDirectoryAccessible",()=>n,"checkIsGitRepo",()=>q,"checkoutBranch",()=>p,"getBranches",()=>o,"getDefaultDevServerScript",()=>z,"getHomeDirectory",()=>k,"getStartupScript",()=>y,"installAgentCli",()=>s,"listDirectories",()=>m,"listPathEntries",()=>l,"listRepoFiles",()=>A,"prepareSessionWorktree",()=>w,"removeWorktree",()=>x,"saveAttachments",()=>B,"setTmuxSessionMouseMode",()=>u,"startTtydProcess",()=>t,"terminateSessionTerminalSessions",()=>v],15271)},51817,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(46786),f=a.i(4503),g=a.i(46666),h=a.i(15271);async function i(){let a=e.default.homedir(),b=d.default.join(a,".viba","sessions");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function j(){let a=e.default.homedir(),b=d.default.join(a,".viba","session-contexts");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function k(a){let b=await j();return d.default.join(b,`${a}.json`)}async function l(){let a=e.default.homedir(),b=d.default.join(a,".viba","session-prompts");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function m(a){let b=await i(),e=d.default.join(b,`${a.sessionName}.json`);await c.default.writeFile(e,JSON.stringify(a,null,2),"utf-8")}async function n(a,b){try{let e=await l(),f=d.default.join(e,`${a}.txt`);return await c.default.writeFile(f,b,"utf-8"),{success:!0,filePath:f}}catch(a){return console.error("Failed to write session prompt file:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function o(a,b){try{let d=await k(a),e={sessionName:a,...b,timestamp:new Date().toISOString()};return await c.default.writeFile(d,JSON.stringify(e,null,2),"utf-8"),{success:!0}}catch(a){return console.error("Failed to save session launch context:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function p(a){try{let b=await k(a),d=await c.default.readFile(b,"utf-8"),e=JSON.parse(d);return{success:!0,context:e}}catch(a){if("ENOENT"===("object"==typeof a&&null!==a&&"code"in a?a.code:void 0))return{success:!0};return console.error("Failed to consume session launch context:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function q(a){try{let b=await k(a),d=await c.default.readFile(b,"utf-8"),e=JSON.parse(d);return{success:!0,context:e}}catch(a){if("ENOENT"===("object"==typeof a&&null!==a&&"code"in a?a.code:void 0))return{success:!0};return console.error("Failed to read session launch context:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function r(a){let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=await q(a);if(!c.success)return{success:!1,error:c.error||"Failed to load session launch context"};let d=c.context;return{success:!0,context:{sourceSessionName:a,repoPath:b.repoPath,title:d?.title||b.title,initialMessage:d?.rawInitialMessage||d?.initialMessage,attachmentNames:d?.attachmentNames||[],agentProvider:d?.agentProvider||b.agent,model:d?.model||b.model}}}async function s(a,b,e){try{let f=await t(a);if(!f)return{success:!1,copiedAttachmentNames:[],missingAttachmentNames:[],error:"Source session metadata not found"};let g=`${f.worktreePath}-attachments`,h=`${b}-attachments`;await c.default.mkdir(h,{recursive:!0});let i=[],j=[];for(let a of Array.from(new Set(e.map(a=>a.trim()).filter(Boolean)))){let b=a.replace(/[^a-zA-Z0-9._-]/g,"_"),e=d.default.join(g,b),f=d.default.join(h,b);try{await c.default.copyFile(e,f),i.push(b)}catch(c){let b="object"==typeof c&&null!==c&&"code"in c?c.code:void 0;if("ENOENT"===b){j.push(a);continue}throw c}}return{success:!0,copiedAttachmentNames:i,missingAttachmentNames:j}}catch(a){return console.error("Failed to copy session attachments:",a),{success:!1,copiedAttachmentNames:[],missingAttachmentNames:[],error:(0,g.getErrorMessage)(a)}}}async function t(a){try{let b=await i(),e=d.default.join(b,`${a}.json`),f=await c.default.readFile(e,"utf-8");return JSON.parse(f)}catch{return null}}async function u(a){try{let b=await i(),e=(await c.default.readdir(b)).filter(a=>a.endsWith(".json")).map(async a=>{try{let e=d.default.join(b,a),f=await c.default.readFile(e,"utf-8");return JSON.parse(f)}catch(b){return console.error(`Failed to parse session file ${a}:`,b),null}});return(await Promise.all(e)).filter(b=>!!b&&(!a||b.repoPath===a)).sort((a,b)=>new Date(b.timestamp).getTime()-new Date(a.timestamp).getTime())}catch(a){return console.error("Failed to list sessions:",a),[]}}async function v(a,b,c){try{let d=await (0,h.prepareSessionWorktree)(a,b);if(!d.success||!d.sessionName||!d.worktreePath||!d.branchName)return d;let e={sessionName:d.sessionName,repoPath:a,worktreePath:d.worktreePath,branchName:d.branchName,baseBranch:b,agent:c.agent,model:c.model,title:c.title,devServerScript:c.devServerScript,initialized:!1,timestamp:new Date().toISOString()};return await m(e),d}catch(a){return console.error("Failed to create session:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function w(a){let b=await t(a);!b||b.initialized||(b.initialized=!0,await m(b))}async function x(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let e=await (0,h.removeWorktree)(b.repoPath,b.worktreePath,b.branchName);if(await (0,h.terminateSessionTerminalSessions)(a),!e.success)return e;let f=await i(),g=d.default.join(f,`${a}.json`);await c.default.rm(g,{force:!0});let j=await k(a);await c.default.rm(j,{force:!0});let m=await l(),n=d.default.join(m,`${a}.txt`);return await c.default.rm(n,{force:!0}),{success:!0}}catch(a){return console.error("Failed to delete session:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function y(a){try{if(!await t(a))return{success:!1,error:"Session metadata not found"};return x(a).catch(b=>{console.error(`Background cleanup of session ${a} failed:`,b)}),{success:!0}}catch(a){return console.error("Failed to schedule background session deletion:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function z(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=b.baseBranch?.trim();if(!c)return{success:!1,error:"Base branch is missing for this session. This session may be from an older version."};let d=(0,f.default)(b.worktreePath);if(!(await d.status()).isClean())return{success:!1,error:"Worktree has uncommitted changes. Commit your changes first."};let e=(0,f.default)(b.repoPath),g=await e.branchLocal();if(!g.all.includes(c))return{success:!1,error:`Base branch "${c}" not found in repository.`};if(!g.all.includes(b.branchName))return{success:!1,error:`Session branch "${b.branchName}" not found in repository.`};let h=g.current;return h!==c&&await e.checkout(c),await e.merge(["--no-ff",b.branchName]),h&&h!==c&&await e.checkout(h),{success:!0,branchName:b.branchName,baseBranch:c}}catch(a){return console.error("Failed to merge session branch:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function A(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=b.baseBranch?.trim();if(!c)return{success:!1,error:"Base branch is missing for this session. This session may be from an older version."};let d=(0,f.default)(b.worktreePath);if(!(await d.status()).isClean())return{success:!1,error:"Worktree has uncommitted changes. Commit your changes first."};let e=(0,f.default)(b.repoPath),g=await e.branchLocal();if(!g.all.includes(c))return{success:!1,error:`Base branch "${c}" not found in repository.`};if(!g.all.includes(b.branchName))return{success:!1,error:`Session branch "${b.branchName}" not found in repository.`};return(await d.branchLocal()).current!==b.branchName&&await d.checkout(b.branchName),await d.rebase([c]),{success:!0,branchName:b.branchName,baseBranch:c}}catch(a){return console.error("Failed to rebase session branch:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function B(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=(0,f.default)(b.worktreePath),d=await c.status();return{success:!0,count:d.files.length}}catch(a){return console.error("Failed to get uncommitted file count:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function C(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=b.baseBranch?.trim();if(!c)return{success:!1,error:"Base branch is unavailable for this session."};let d=(0,f.default)(b.repoPath),e=await d.branchLocal();if(!e.all.includes(c))return{success:!1,error:`Base branch "${c}" not found in repository.`};if(!e.all.includes(b.branchName))return{success:!1,error:`Session branch "${b.branchName}" not found in repository.`};let[g,h]=(await d.raw(["rev-list","--left-right","--count",`${c}...${b.branchName}`])).trim().split(/\s+/),i=Number.parseInt(g,10),j=Number.parseInt(h,10);if(Number.isNaN(i)||Number.isNaN(j))return{success:!1,error:"Failed to parse git divergence output."};return{success:!0,ahead:j,behind:i}}catch(a){return console.error("Failed to get session divergence:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function D(a){try{let b=await t(a);if(!b)return{success:!1,error:"Session metadata not found"};let c=(0,f.default)(b.repoPath),d=[...(await c.branchLocal()).all].sort((a,b)=>a.localeCompare(b)),e=b.baseBranch?.trim();return{success:!0,baseBranch:e,branches:d}}catch(a){return console.error("Failed to list session base branches:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}async function E(a,b){try{let c=await t(a);if(!c)return{success:!1,error:"Session metadata not found"};let d=b.trim();if(!d)return{success:!1,error:"Base branch cannot be empty."};let e=(0,f.default)(c.repoPath);if(!(await e.branchLocal()).all.includes(d))return{success:!1,error:`Base branch "${d}" not found in repository.`};return c.baseBranch=d,await m(c),{success:!0,baseBranch:d}}catch(a){return console.error("Failed to update session base branch:",a),{success:!1,error:(0,g.getErrorMessage)(a)}}}(0,a.i(13095).ensureServerEntryExports)([m,n,o,p,r,s,t,u,v,w,x,y,z,A,B,C,D,E]),(0,b.registerServerReference)(m,"40af3a26a6aeb226a2e84ee1f59f8927863046b547",null),(0,b.registerServerReference)(n,"6000fac926fcd3a521a99ce43401585249d483cc31",null),(0,b.registerServerReference)(o,"606c773d58bab53bf09c078fe6c5393d1b40c682a3",null),(0,b.registerServerReference)(p,"409a0f685692c79de2e35f381ece4017fcb1e9a035",null),(0,b.registerServerReference)(r,"4026293fd5f94399044fb0f6eb31b7f379c15ffb5a",null),(0,b.registerServerReference)(s,"70b878937c2b6ca39e88beeda0386789511cab3fbd",null),(0,b.registerServerReference)(t,"40a7c24d992badfaac56874fa73fcdab2bde3e0273",null),(0,b.registerServerReference)(u,"40b595b9b7be7f17bf90da24d82266c8102f0ea8fa",null),(0,b.registerServerReference)(v,"7080ffae5cb3bcd3a4afecbd505fa70cf16e193c7b",null),(0,b.registerServerReference)(w,"401a4b1abb7fae5c47d79ae2a699ae71f6f3956478",null),(0,b.registerServerReference)(x,"409ff654b6aa3c349f942a24fe29aaf2b85aeeeb3d",null),(0,b.registerServerReference)(y,"40b21925298ec80c5191c2efe1dc9cdbdf31eaf258",null),(0,b.registerServerReference)(z,"40176b32cff1b1301cacf1bc54f1db115a0f83751f",null),(0,b.registerServerReference)(A,"40726a4605af6ef644e9b4974a43804fb94e9f0f27",null),(0,b.registerServerReference)(B,"400bab56e36dd7ea82fa43c4b42699123504f75ea5",null),(0,b.registerServerReference)(C,"4001a448833f93e23c66de2f5894a0d0d67fef62ea",null),(0,b.registerServerReference)(D,"40cd1b594ff0069ba46f29a9eebe6c813be8a830cb",null),(0,b.registerServerReference)(E,"6001fae4969c5dd841fc2265613082781904ec98e8",null),a.s(["consumeSessionLaunchContext",()=>p,"copySessionAttachments",()=>s,"createSession",()=>v,"deleteSession",()=>x,"deleteSessionInBackground",()=>y,"getSessionDivergence",()=>C,"getSessionMetadata",()=>t,"getSessionPrefillContext",()=>r,"getSessionUncommittedFileCount",()=>B,"listSessionBaseBranches",()=>D,"listSessions",()=>u,"markSessionInitialized",()=>w,"mergeSessionToBase",()=>z,"rebaseSessionOntoBase",()=>A,"saveSessionLaunchContext",()=>o,"updateSessionBaseBranch",()=>E,"writeSessionPromptFile",()=>n])},38642,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(46786),f=a.i(13095);let g={recentRepos:[],defaultRoot:"",selectedIde:"vscode",agentWidth:66.666,repoSettings:{},pinnedFolderShortcuts:[]};async function h(){let a=e.default.homedir(),b=d.default.join(a,".viba");try{await c.default.mkdir(b,{recursive:!0})}catch(a){}return d.default.join(b,"config.json")}async function i(){try{let a=await h(),b=await c.default.readFile(a,"utf-8"),d=JSON.parse(b);return{...g,...d}}catch(a){return g}}async function j(a){try{let b=await h();await c.default.writeFile(b,JSON.stringify(a,null,2),"utf-8")}catch(a){throw console.error("Failed to save config:",a),Error("Failed to save configuration.")}}async function k(a){let b={...await i(),...a};return await j(b),b}async function l(a,b){let c=await i(),d=c.repoSettings[a]||{},e={...c,repoSettings:{...c.repoSettings,[a]:{...d,...b}}};return await j(e),e}(0,f.ensureServerEntryExports)([i,j,k,l]),(0,b.registerServerReference)(i,"00b5dd8081729b8743f38707e3a6543b158c9caaa4",null),(0,b.registerServerReference)(j,"40e7693a00101c42dbae22e1d1d33179ef297fa472",null),(0,b.registerServerReference)(k,"40fa02d701215ac0b9f7984db782c0e978b6fdaabf",null),(0,b.registerServerReference)(l,"60e4ee6c27d896d6b335f02c3f3e9272db502d9f5f",null),a.s(["getConfig",()=>i,"updateConfig",()=>k,"updateRepoSettings",()=>l])}];
|
|
3
3
|
|
|
4
4
|
//# sourceMappingURL=%5Broot-of-the-server%5D__14040f84._.js.map
|