@eldrforge/kodrdriv 1.2.131 → 1.2.132
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/agentic-reflection-commit-2025-12-27T22-56-06-143Z.md +50 -0
- package/agentic-reflection-commit-2025-12-27T23-01-57-294Z.md +50 -0
- package/agentic-reflection-commit-2025-12-27T23-11-57-811Z.md +50 -0
- package/agentic-reflection-commit-2025-12-27T23-12-50-645Z.md +50 -0
- package/agentic-reflection-commit-2025-12-27T23-13-59-347Z.md +52 -0
- package/agentic-reflection-commit-2025-12-27T23-14-36-001Z.md +50 -0
- package/agentic-reflection-commit-2025-12-27T23-18-59-832Z.md +50 -0
- package/agentic-reflection-commit-2025-12-27T23-25-20-667Z.md +62 -0
- package/dist/application.js +3 -0
- package/dist/application.js.map +1 -1
- package/dist/arguments.js +1 -1
- package/dist/arguments.js.map +1 -1
- package/dist/commands/commit.js +26 -163
- package/dist/commands/commit.js.map +1 -1
- package/dist/commands/publish.js +45 -0
- package/dist/commands/publish.js.map +1 -1
- package/dist/commands/release.js +25 -161
- package/dist/commands/release.js.map +1 -1
- package/dist/constants.js +1 -1
- package/dist/util/loggerAdapter.js +17 -0
- package/dist/util/loggerAdapter.js.map +1 -1
- package/package.json +9 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"publish.js","sources":["../../src/commands/publish.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nimport path from 'path';\nimport * as Commit from './commit';\nimport * as Diff from '../content/diff';\nimport * as Release from './release';\n\nimport { getLogger, getDryRunLogger } from '../logging';\nimport { Config, PullRequest } from '../types';\nimport { run, runWithDryRunSupport, runSecure, validateGitRef, safeJsonParse, validatePackageJson, isBranchInSyncWithRemote, safeSyncBranchWithRemote, localBranchExists, remoteBranchExists } from '@eldrforge/git-tools';\nimport * as GitHub from '@eldrforge/github-tools';\nimport { createStorage, incrementPatchVersion, calculateTargetVersion } from '@eldrforge/shared';\nimport { getOutputPath, checkIfTagExists, confirmVersionInteractively, calculateBranchDependentVersion } from '../util/general';\nimport { DEFAULT_OUTPUT_DIRECTORY, KODRDRIV_DEFAULTS } from '../constants';\nimport fs from 'fs/promises';\nimport { runGitWithLock } from '../util/gitMutex';\nimport { filterContent } from '../util/stopContext';\n\nconst scanNpmrcForEnvVars = async (storage: any): Promise<string[]> => {\n const logger = getLogger();\n const npmrcPath = path.join(process.cwd(), '.npmrc');\n const envVars: string[] = [];\n\n if (await storage.exists(npmrcPath)) {\n try {\n const npmrcContent = await storage.readFile(npmrcPath, 'utf-8');\n // Match environment variable patterns like ${VAR_NAME} or $VAR_NAME\n const envVarMatches = npmrcContent.match(/\\$\\{([^}]+)\\}|\\$([A-Z_][A-Z0-9_]*)/g);\n\n if (envVarMatches) {\n for (const match of envVarMatches) {\n // Extract variable name from ${VAR_NAME} or $VAR_NAME format\n const varName = match.replace(/\\$\\{|\\}|\\$/g, '');\n if (varName && !envVars.includes(varName)) {\n envVars.push(varName);\n }\n }\n }\n\n } catch (error: any) {\n logger.warn(`NPMRC_READ_FAILED: Unable to read .npmrc configuration file | Path: ${npmrcPath} | Error: ${error.message}`);\n logger.verbose('NPMRC_READ_IMPACT: Environment variable detection for publishing may be affected due to failed .npmrc read');\n }\n } else {\n logger.debug('NPMRC_NOT_FOUND: No .npmrc file present in current directory | Action: Skipping environment variable scan | Path: ' + npmrcPath);\n }\n\n return envVars;\n};\n\n/**\n * Checks if package-lock.json contains file: dependencies (from npm link)\n * and cleans them up if found by removing package-lock.json and regenerating it.\n */\nconst cleanupNpmLinkReferences = async (isDryRun: boolean): Promise<void> => {\n const logger = getDryRunLogger(isDryRun);\n const packageLockPath = path.join(process.cwd(), 'package-lock.json');\n\n try {\n // Check if package-lock.json exists\n try {\n await fs.access(packageLockPath);\n } catch {\n // No package-lock.json, nothing to clean\n logger.verbose('PACKAGE_LOCK_NOT_FOUND: No package-lock.json file exists | Action: Skipping npm link cleanup | Path: ' + packageLockPath);\n return;\n }\n\n // Read and parse package-lock.json\n const packageLockContent = await fs.readFile(packageLockPath, 'utf-8');\n const packageLock = safeJsonParse(packageLockContent, packageLockPath);\n\n // Check for file: dependencies in the lockfile\n let hasFileReferences = false;\n\n // Check in packages (npm v7+)\n if (packageLock.packages) {\n for (const [pkgPath, pkgInfo] of Object.entries(packageLock.packages as Record<string, any>)) {\n if (pkgInfo.resolved && typeof pkgInfo.resolved === 'string' && pkgInfo.resolved.startsWith('file:')) {\n // Check if it's a relative path (from npm link) rather than a workspace path\n const resolvedPath = pkgInfo.resolved.replace('file:', '');\n if (resolvedPath.startsWith('../') || resolvedPath.startsWith('./')) {\n hasFileReferences = true;\n logger.verbose(`NPM_LINK_DETECTED: Found npm link reference in packages section | Package: ${pkgPath} | Resolved: ${pkgInfo.resolved} | Type: relative_file_dependency`);\n break;\n }\n }\n }\n }\n\n // Check in dependencies (npm v6)\n if (!hasFileReferences && packageLock.dependencies) {\n for (const [pkgName, pkgInfo] of Object.entries(packageLock.dependencies as Record<string, any>)) {\n if (pkgInfo.version && typeof pkgInfo.version === 'string' && pkgInfo.version.startsWith('file:')) {\n const versionPath = pkgInfo.version.replace('file:', '');\n if (versionPath.startsWith('../') || versionPath.startsWith('./')) {\n hasFileReferences = true;\n logger.verbose(`NPM_LINK_DETECTED: Found npm link reference in dependencies section | Package: ${pkgName} | Version: ${pkgInfo.version} | Type: relative_file_dependency`);\n break;\n }\n }\n }\n }\n\n if (hasFileReferences) {\n logger.info('NPM_LINK_CLEANUP_REQUIRED: Detected npm link references in package-lock.json | File: package-lock.json | Impact: Must be cleaned before publish');\n logger.info('NPM_LINK_CLEANUP_STARTING: Removing package-lock.json and regenerating clean version | Action: Remove file with relative dependencies');\n\n if (isDryRun) {\n logger.info('DRY_RUN_OPERATION: Would remove package-lock.json and regenerate it | Mode: dry-run | File: package-lock.json');\n } else {\n // Remove package-lock.json\n await fs.unlink(packageLockPath);\n logger.verbose('NPM_LINK_CLEANUP_FILE_REMOVED: Deleted package-lock.json containing npm link references | Path: ' + packageLockPath);\n\n // Regenerate clean package-lock.json\n logger.verbose('NPM_LOCK_REGENERATING: Executing npm install to regenerate package-lock.json from package.json | Command: npm install --package-lock-only --no-audit --no-fund');\n await runWithDryRunSupport('npm install --package-lock-only --no-audit --no-fund', isDryRun);\n logger.info('NPM_LOCK_REGENERATED: Successfully regenerated clean package-lock.json without link references | Path: ' + packageLockPath);\n }\n } else {\n logger.verbose('NPM_LINK_CHECK_CLEAN: No npm link references found in package-lock.json | Status: Ready for publish | File: ' + packageLockPath);\n }\n } catch (error: any) {\n // Log warning but don't fail - let npm update handle any issues\n logger.warn(`NPM_LINK_CHECK_FAILED: Unable to check or clean npm link references | Error: ${error.message} | Impact: Continuing with publish, npm will handle issues`);\n logger.verbose('PUBLISH_PROCESS_CONTINUING: Proceeding with publish workflow despite npm link check failure | Next: Standard npm publish validation');\n }\n};\n\nconst validateEnvironmentVariables = (requiredEnvVars: string[], isDryRun: boolean): void => {\n const logger = getDryRunLogger(isDryRun);\n const missingEnvVars: string[] = [];\n\n for (const envVar of requiredEnvVars) {\n if (!process.env[envVar]) {\n missingEnvVars.push(envVar);\n }\n }\n\n if (missingEnvVars.length > 0) {\n if (isDryRun) {\n logger.warn(`ENV_VARS_MISSING: Required environment variables not set | Variables: ${missingEnvVars.join(', ')} | Mode: dry-run | Impact: Would fail in real publish`);\n } else {\n logger.error(`ENV_VARS_MISSING: Required environment variables not set | Variables: ${missingEnvVars.join(', ')} | Action: Must set before publish | Source: .npmrc configuration`);\n throw new Error(`Missing required environment variables: ${missingEnvVars.join(', ')}. Please set these environment variables before running publish.`);\n }\n }\n};\n\nconst runPrechecks = async (runConfig: Config, targetBranch?: string): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage();\n\n logger.info('PRECHECK_STARTING: Executing publish prechecks | Phase: validation | Target: ' + (targetBranch || 'default'));\n\n // Check if we're in a git repository\n try {\n if (isDryRun) {\n logger.info('PRECHECK_GIT_REPO: Would verify git repository | Mode: dry-run | Command: git rev-parse --git-dir');\n } else {\n await run('git rev-parse --git-dir');\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Not in a git repository or git command failed: ${originalMessage}. Please run this command from within a git repository.`);\n }\n }\n\n // Check for uncommitted changes\n logger.info('PRECHECK_GIT_STATUS: Checking for uncommitted changes | Command: git status --porcelain | Requirement: Clean working directory');\n try {\n if (isDryRun) {\n logger.info('PRECHECK_GIT_STATUS: Would verify clean working directory | Mode: dry-run | Command: git status --porcelain');\n } else {\n const { stdout } = await run('git status --porcelain');\n if (stdout.trim()) {\n throw new Error('Working directory has uncommitted changes. Please commit or stash your changes before running publish.');\n }\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Failed to check git status: ${originalMessage}. Please ensure you are in a valid git repository and try again.`);\n }\n }\n\n // Use the passed target branch or fallback to config/default\n const effectiveTargetBranch = targetBranch || runConfig.publish?.targetBranch || 'main';\n\n // Check that we're not running from the target branch\n logger.info('PRECHECK_BRANCH: Verifying current branch is not target branch | Target: ' + effectiveTargetBranch + ' | Requirement: Must run from feature branch');\n if (isDryRun) {\n logger.info(`PRECHECK_BRANCH: Would verify current branch is not target branch | Mode: dry-run | Target: ${effectiveTargetBranch}`);\n } else {\n const currentBranch = await GitHub.getCurrentBranchName();\n if (currentBranch === effectiveTargetBranch) {\n throw new Error(`Cannot run publish from the target branch '${effectiveTargetBranch}'. Please switch to a different branch before running publish.`);\n }\n }\n\n // Check target branch sync with remote\n logger.info(`PRECHECK_BRANCH_SYNC: Checking target branch sync with remote | Branch: ${effectiveTargetBranch} | Remote: origin | Requirement: Branches must be synchronized`);\n if (isDryRun) {\n logger.info(`PRECHECK_BRANCH_SYNC: Would verify target branch is in sync with remote | Mode: dry-run | Branch: ${effectiveTargetBranch} | Remote: origin`);\n } else {\n // Only check if local target branch exists (it's okay if it doesn't exist locally)\n const targetBranchExists = await localBranchExists(effectiveTargetBranch);\n if (targetBranchExists) {\n const syncStatus = await isBranchInSyncWithRemote(effectiveTargetBranch);\n\n if (!syncStatus.inSync) {\n logger.error(`BRANCH_SYNC_FAILED: Target branch not synchronized with remote | Branch: ${effectiveTargetBranch} | Status: out-of-sync | Impact: Cannot proceed with publish`);\n logger.error('');\n\n if (syncStatus.error) {\n logger.error(`BRANCH_SYNC_ERROR: ${syncStatus.error}`);\n } else if (syncStatus.localSha && syncStatus.remoteSha) {\n logger.error(`BRANCH_SYNC_DIVERGENCE: Local and remote commits differ | Local SHA: ${syncStatus.localSha.substring(0, 8)} | Remote SHA: ${syncStatus.remoteSha.substring(0, 8)}`);\n }\n\n logger.error('');\n logger.error('RESOLUTION_STEPS: Manual intervention required to sync branches:');\n logger.error(` Step 1: Switch to target branch | Command: git checkout ${effectiveTargetBranch}`);\n logger.error(` Step 2: Pull latest changes | Command: git pull origin ${effectiveTargetBranch}`);\n logger.error(' Step 3: Resolve merge conflicts if present');\n logger.error(' Step 4: Return to feature branch and retry publish');\n logger.error('');\n logger.error(`ALTERNATIVE_OPTION: Automatic sync available | Command: kodrdriv publish --sync-target | Branch: ${effectiveTargetBranch}`);\n\n throw new Error(`Target branch '${effectiveTargetBranch}' is not in sync with remote. Please sync the branch before running publish.`);\n } else {\n logger.info(`BRANCH_SYNC_VERIFIED: Target branch is synchronized with remote | Branch: ${effectiveTargetBranch} | Status: in-sync`);\n }\n } else {\n logger.info(`BRANCH_NOT_LOCAL: Target branch does not exist locally | Branch: ${effectiveTargetBranch} | Action: Will be created during publish process`);\n }\n }\n\n // Check GitHub Actions workflow configuration\n logger.info('PRECHECK_WORKFLOW: Checking GitHub Actions workflow configuration | Target: PR automation | Requirement: Workflows should trigger on pull requests');\n if (isDryRun) {\n logger.info('PRECHECK_WORKFLOW: Would check if GitHub Actions workflows are configured for pull requests | Mode: dry-run');\n } else {\n try {\n // TODO: Re-enable when checkWorkflowConfiguration is exported from github-tools\n // const workflowConfig = await GitHub.checkWorkflowConfiguration(effectiveTargetBranch);\n const workflowConfig = {\n hasWorkflows: true,\n hasPullRequestTriggers: true,\n workflowCount: 0,\n triggeredWorkflowNames: [] as string[]\n };\n\n if (!workflowConfig.hasWorkflows) {\n logger.warn('WORKFLOW_NOT_CONFIGURED: No GitHub Actions workflows found in repository | Impact: PR will be created but no automated checks will run | Recommendation: Add workflow file at .github/workflows/ci.yml');\n logger.warn('WORKFLOW_BEHAVIOR: Publish process will proceed without waiting for checks | PR State: Will be created | Check Status: None');\n logger.warn('WORKFLOW_RECOMMENDATION: Consider adding CI workflow to validate PRs automatically | Example: .github/workflows/ci.yml with PR triggers');\n } else if (!workflowConfig.hasPullRequestTriggers) {\n logger.warn(`WORKFLOW_NO_PR_TRIGGER: Found workflows but none trigger on pull requests | Workflow Count: ${workflowConfig.workflowCount} | Target Branch: ${effectiveTargetBranch} | Impact: No checks will run on PR`);\n logger.warn('WORKFLOW_BEHAVIOR: Publish process will create PR without automated checks | PR State: Will be created | Check Status: None');\n logger.warn(`WORKFLOW_RECOMMENDATION: Update workflow triggers to include PR events | Configuration: on.pull_request.branches: [${effectiveTargetBranch}]`);\n } else {\n logger.info(`WORKFLOW_CONFIGURED: Found workflows that will trigger on pull requests | Target Branch: ${effectiveTargetBranch} | Workflow Count: ${workflowConfig.triggeredWorkflowNames.length}`);\n for (const workflowName of workflowConfig.triggeredWorkflowNames) {\n logger.info(`WORKFLOW_ACTIVE: ${workflowName} | Trigger: pull_request | Target: ${effectiveTargetBranch}`);\n }\n }\n } catch (error: any) {\n // Don't fail the precheck if we can't verify workflows\n // The wait logic will handle it later\n logger.debug(`WORKFLOW_CHECK_FAILED: Unable to verify workflow configuration | Error: ${error.message} | Impact: Will proceed with publish | Note: Wait logic will handle checks later`);\n }\n }\n\n // Check if prepublishOnly script exists in package.json\n logger.info('PRECHECK_PREPUBLISH: Checking for prepublishOnly script in package.json | Requirement: Must exist to run pre-flight checks | Expected: clean, lint, build, test');\n const packageJsonPath = path.join(process.cwd(), 'package.json');\n\n if (!await storage.exists(packageJsonPath)) {\n if (!isDryRun) {\n throw new Error('package.json not found in current directory.');\n } else {\n logger.warn('PACKAGE_JSON_NOT_FOUND: No package.json in current directory | Mode: dry-run | Impact: Cannot verify prepublishOnly script | Path: ' + packageJsonPath);\n }\n } else {\n let packageJson;\n try {\n const packageJsonContents = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, packageJsonPath);\n packageJson = validatePackageJson(parsed, packageJsonPath);\n\n } catch (error) {\n if (!isDryRun) {\n throw new Error('Failed to parse package.json. Please ensure it contains valid JSON.');\n } else {\n logger.warn('PACKAGE_JSON_PARSE_FAILED: Unable to parse package.json | Mode: dry-run | Impact: Cannot verify prepublishOnly script | Path: ' + packageJsonPath + ' | Requirement: Valid JSON format');\n }\n }\n\n if (packageJson && !packageJson.scripts?.prepublishOnly) {\n if (!isDryRun) {\n throw new Error('prepublishOnly script is required in package.json but was not found. Please add a prepublishOnly script that runs your pre-flight checks (e.g., clean, lint, build, test).');\n } else {\n logger.warn('PREPUBLISH_SCRIPT_MISSING: No prepublishOnly script found in package.json | Mode: dry-run | Requirement: Script must exist | Expected Tasks: clean, lint, build, test | Path: ' + packageJsonPath);\n }\n }\n }\n\n // Check required environment variables\n logger.verbose('PRECHECK_ENV_VARS: Checking required environment variables | Source: Configuration and .npmrc | Requirement: All required vars must be set');\n const coreRequiredEnvVars = runConfig.publish?.requiredEnvVars || [];\n const npmrcEnvVars = isDryRun ? [] : await scanNpmrcForEnvVars(storage); // Skip .npmrc scan in dry run\n const allRequiredEnvVars = [...new Set([...coreRequiredEnvVars, ...npmrcEnvVars])];\n\n if (allRequiredEnvVars.length > 0) {\n logger.verbose(`ENV_VARS_REQUIRED: Environment variables needed for publish | Variables: ${allRequiredEnvVars.join(', ')} | Count: ${allRequiredEnvVars.length} | Source: config + .npmrc`);\n validateEnvironmentVariables(allRequiredEnvVars, isDryRun);\n } else {\n logger.verbose('ENV_VARS_NONE: No required environment variables specified | Status: No validation needed | Source: config + .npmrc');\n }\n\n logger.info('PRECHECK_COMPLETE: All publish prechecks passed successfully | Status: Ready to proceed | Next: Execute publish workflow');\n};\n\n// Helper: deep-sort object keys for stable comparison\nconst sortObjectKeys = (value: any): any => {\n if (Array.isArray(value)) {\n return value.map(sortObjectKeys);\n }\n if (value && typeof value === 'object') {\n const sorted: any = {};\n Object.keys(value).sort().forEach((key) => {\n sorted[key] = sortObjectKeys(value[key]);\n });\n return sorted;\n }\n return value;\n};\n\n// Determine if there are substantive changes compared to the target branch (beyond just version bump)\nconst isReleaseNecessaryComparedToTarget = async (targetBranch: string, isDryRun: boolean): Promise<{ necessary: boolean; reason: string }> => {\n const logger = getDryRunLogger(isDryRun);\n\n // We compare current HEAD branch to the provided target branch\n const currentBranch = await GitHub.getCurrentBranchName();\n\n // Check if target branch exists before trying to compare\n try {\n // Validate target branch exists and is accessible\n await runSecure('git', ['rev-parse', '--verify', targetBranch]);\n } catch (error: any) {\n // Target branch doesn't exist or isn't accessible\n logger.verbose(`RELEASE_CHECK_NO_TARGET: Target branch does not exist or is not accessible | Branch: ${targetBranch} | Action: Proceeding with publish | Reason: First release to this branch`);\n return { necessary: true, reason: `Target branch '${targetBranch}' does not exist; first release to this branch` };\n }\n\n // If branches are identical, nothing to release\n const { stdout: namesStdout } = await runSecure('git', ['diff', '--name-only', `${targetBranch}..${currentBranch}`]);\n const changedFiles = namesStdout.split('\\n').map(s => s.trim()).filter(Boolean);\n\n if (changedFiles.length === 0) {\n // No definitive signal; proceed with publish rather than skipping\n return { necessary: true, reason: 'No detectable changes via diff; proceeding conservatively' };\n }\n\n // If any files changed other than package.json or package-lock.json, a release is necessary\n const nonVersionFiles = changedFiles.filter(f => f !== 'package.json' && f !== 'package-lock.json');\n if (nonVersionFiles.length > 0) {\n return { necessary: true, reason: `Changed files beyond version bump: ${nonVersionFiles.join(', ')}` };\n }\n\n // Only package.json and/or package-lock.json changed. Verify package.json change is only the version field\n try {\n // Read package.json content from both branches\n const { stdout: basePkgStdout } = await runSecure('git', ['show', `${targetBranch}:package.json`]);\n const { stdout: headPkgStdout } = await runSecure('git', ['show', `${currentBranch}:package.json`]);\n\n const basePkg = validatePackageJson(safeJsonParse(basePkgStdout, `${targetBranch}:package.json`), `${targetBranch}:package.json`);\n const headPkg = validatePackageJson(safeJsonParse(headPkgStdout, `${currentBranch}:package.json`), `${currentBranch}:package.json`);\n\n const { version: _baseVersion, ...baseWithoutVersion } = basePkg;\n const { version: _headVersion, ...headWithoutVersion } = headPkg;\n\n const baseSorted = sortObjectKeys(baseWithoutVersion);\n const headSorted = sortObjectKeys(headWithoutVersion);\n\n const equalExceptVersion = JSON.stringify(baseSorted) === JSON.stringify(headSorted);\n if (equalExceptVersion) {\n const currentVersion = headPkg.version;\n const targetVersion = basePkg.version;\n return {\n necessary: false,\n reason: `No meaningful changes detected:\\n • Current version: ${currentVersion}\\n • Target branch version: ${targetVersion}\\n • Only package.json version field differs\\n\\n To force republish: Add meaningful code changes or use --force (not yet implemented)`\n };\n }\n\n // Other fields changed inside package.json\n return { necessary: true, reason: 'package.json changes beyond version field' };\n } catch (error: any) {\n // Conservative: if we cannot prove it is only a version change, proceed with release\n logger.verbose(`RELEASE_CHECK_COMPARISON_FAILED: Unable to conclusively compare package.json changes | Error: ${error.message} | Action: Proceeding conservatively with publish | Reason: Cannot verify version-only change`);\n return { necessary: true, reason: 'Could not compare package.json safely' };\n }\n};\n\nconst handleTargetBranchSyncRecovery = async (runConfig: Config, targetBranch: string): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n\n logger.info(`BRANCH_SYNC_ATTEMPTING: Initiating sync of target branch with remote | Branch: ${targetBranch} | Remote: origin | Operation: fetch + merge`);\n\n if (isDryRun) {\n logger.info(`BRANCH_SYNC_DRY_RUN: Would attempt to sync branch with remote | Mode: dry-run | Branch: ${targetBranch} | Remote: origin`);\n return;\n }\n\n const syncResult = await safeSyncBranchWithRemote(targetBranch);\n\n if (syncResult.success) {\n logger.info(`BRANCH_SYNC_SUCCESS: Successfully synchronized branch with remote | Branch: ${targetBranch} | Remote: origin | Status: in-sync`);\n logger.info('BRANCH_SYNC_NEXT_STEP: Ready to proceed with publish | Action: Re-run publish command | Branch: ' + targetBranch);\n } else if (syncResult.conflictResolutionRequired) {\n logger.error(`BRANCH_SYNC_CONFLICTS: Sync failed due to merge conflicts | Branch: ${targetBranch} | Status: conflicts-detected | Resolution: Manual intervention required`);\n logger.error('');\n logger.error('CONFLICT_RESOLUTION_STEPS: Manual conflict resolution required:');\n logger.error(` Step 1: Switch to target branch | Command: git checkout ${targetBranch}`);\n logger.error(` Step 2: Pull and resolve conflicts | Command: git pull origin ${targetBranch}`);\n logger.error(' Step 3: Commit resolved changes | Command: git commit');\n logger.error(' Step 4: Return to feature branch and retry | Command: kodrdriv publish');\n logger.error('');\n throw new Error(`Target branch '${targetBranch}' has conflicts that require manual resolution.`);\n } else {\n logger.error(`BRANCH_SYNC_FAILED: Sync operation failed | Branch: ${targetBranch} | Error: ${syncResult.error} | Remote: origin`);\n throw new Error(`Failed to sync target branch: ${syncResult.error}`);\n }\n};\n\nexport const execute = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage();\n\n // Get current branch for branch-dependent targeting\n let currentBranch: string;\n if (isDryRun) {\n currentBranch = 'mock-branch';\n } else {\n currentBranch = await GitHub.getCurrentBranchName();\n\n // Fetch latest remote information to avoid conflicts\n logger.info('GIT_FETCH_STARTING: Fetching latest remote information | Remote: origin | Purpose: Avoid conflicts during publish | Command: git fetch origin');\n try {\n await run('git fetch origin');\n logger.info('GIT_FETCH_SUCCESS: Successfully fetched latest remote information | Remote: origin | Status: up-to-date');\n } catch (error: any) {\n logger.warn(`GIT_FETCH_FAILED: Unable to fetch from remote | Remote: origin | Error: ${error.message} | Impact: May cause conflicts if remote has changes`);\n }\n\n // Sync current branch with remote to avoid conflicts\n logger.info(`CURRENT_BRANCH_SYNC: Synchronizing current branch with remote | Branch: ${currentBranch} | Remote: origin | Purpose: Avoid conflicts during publish`);\n try {\n const remoteExists = await run(`git ls-remote --exit-code --heads origin ${currentBranch}`).then(() => true).catch(() => false);\n\n if (remoteExists) {\n // Use explicit fetch+merge instead of pull to avoid git config conflicts\n await runGitWithLock(process.cwd(), async () => {\n await run(`git fetch origin ${currentBranch}`);\n await run(`git merge origin/${currentBranch} --no-edit`);\n }, `sync ${currentBranch}`);\n logger.info(`CURRENT_BRANCH_SYNCED: Successfully synchronized current branch with remote | Branch: ${currentBranch} | Remote: origin/${currentBranch} | Status: in-sync`);\n } else {\n logger.info(`REMOTE_BRANCH_NOT_FOUND: No remote branch exists | Branch: ${currentBranch} | Remote: origin | Action: Will be created on first push`);\n }\n } catch (error: any) {\n if (error.message && error.message.includes('CONFLICT')) {\n logger.error(`MERGE_CONFLICTS_DETECTED: Conflicts found when syncing current branch with remote | Branch: ${currentBranch} | Remote: origin/${currentBranch} | Status: conflicts-require-resolution`);\n logger.error(`CONFLICT_RESOLUTION_REQUIRED: Manual intervention needed to resolve conflicts and continue:`);\n logger.error(` Step 1: Resolve conflicts in affected files`);\n logger.error(` Step 2: Stage resolved files | Command: git add <resolved-files>`);\n logger.error(` Step 3: Commit resolution | Command: git commit`);\n logger.error(` Step 4: Retry publish | Command: kodrdriv publish`);\n throw new Error(`Merge conflicts detected when syncing ${currentBranch} with remote. Please resolve conflicts manually.`);\n } else {\n logger.warn(`CURRENT_BRANCH_SYNC_FAILED: Unable to sync current branch with remote | Branch: ${currentBranch} | Remote: origin/${currentBranch} | Error: ${error.message} | Impact: May cause issues during publish`);\n }\n }\n }\n\n // Determine target branch and version strategy based on branch configuration\n let targetBranch = runConfig.publish?.targetBranch || 'main';\n let branchDependentVersioning = false;\n\n // Check for branches configuration\n if (runConfig.branches && runConfig.branches[currentBranch]) {\n branchDependentVersioning = true;\n\n const branchConfig = runConfig.branches[currentBranch];\n\n if (branchConfig.targetBranch) {\n targetBranch = branchConfig.targetBranch;\n }\n\n logger.info(`BRANCH_DEPENDENT_TARGETING: Branch-specific configuration active | Source: ${currentBranch} | Target: ${targetBranch} | Feature: Branch-dependent versioning and targeting`);\n logger.info(`BRANCH_CONFIGURATION_SOURCE: Current branch | Branch: ${currentBranch} | Type: source`);\n logger.info(`BRANCH_CONFIGURATION_TARGET: Target branch for publish | Branch: ${targetBranch} | Type: destination`);\n\n // Look at target branch config to show version strategy\n const targetBranchConfig = runConfig.branches[targetBranch];\n if (targetBranchConfig?.version) {\n const versionType = targetBranchConfig.version.type;\n const versionTag = targetBranchConfig.version.tag;\n const versionIncrement = targetBranchConfig.version.increment;\n\n logger.info(`VERSION_STRATEGY: Target branch version configuration | Branch: ${targetBranch} | Type: ${versionType} | Tag: ${versionTag || 'none'} | Increment: ${versionIncrement ? 'enabled' : 'disabled'}`);\n }\n } else {\n logger.debug(`BRANCH_TARGETING_DEFAULT: No branch-specific configuration found | Branch: ${currentBranch} | Action: Using default target | Target: ${targetBranch}`);\n }\n\n // Handle --sync-target flag\n if (runConfig.publish?.syncTarget) {\n await handleTargetBranchSyncRecovery(runConfig, targetBranch);\n return; // Exit after sync operation\n }\n\n // Check if target branch exists and create it if needed\n logger.info(`TARGET_BRANCH_CHECK: Verifying target branch existence | Branch: ${targetBranch} | Action: Create if missing | Source: Current HEAD`);\n if (isDryRun) {\n logger.info(`TARGET_BRANCH_CHECK: Would verify target branch exists and create if needed | Mode: dry-run | Branch: ${targetBranch}`);\n } else {\n const targetBranchExists = await localBranchExists(targetBranch);\n if (!targetBranchExists) {\n // Check if it exists on remote\n const remoteExists = await remoteBranchExists(targetBranch);\n\n if (remoteExists) {\n logger.info(`TARGET_BRANCH_TRACKING: Target branch exists on remote but not locally, tracking origin/${targetBranch} | Branch: ${targetBranch}`);\n try {\n await runGitWithLock(process.cwd(), async () => {\n // Create local branch tracking remote\n await runSecure('git', ['branch', targetBranch, `origin/${targetBranch}`]);\n logger.info(`TARGET_BRANCH_CREATED: Successfully created local tracking branch | Branch: ${targetBranch} | Source: origin/${targetBranch}`);\n }, `track target branch ${targetBranch}`);\n } catch (error: any) {\n throw new Error(`Failed to track target branch '${targetBranch}': ${error.message}`);\n }\n } else {\n logger.info(`TARGET_BRANCH_CREATING: Target branch does not exist locally or on remote, creating from current branch | Branch: ${targetBranch} | Source: HEAD | Remote: origin`);\n try {\n // Wrap git branch and push operations with lock\n await runGitWithLock(process.cwd(), async () => {\n // Create the target branch from the current HEAD\n await runSecure('git', ['branch', targetBranch, 'HEAD']);\n logger.info(`TARGET_BRANCH_CREATED: Successfully created target branch locally | Branch: ${targetBranch} | Source: HEAD`);\n\n // Push the new branch to origin\n await runSecure('git', ['push', 'origin', targetBranch]);\n logger.info(`TARGET_BRANCH_PUSHED: Successfully pushed new target branch to remote | Branch: ${targetBranch} | Remote: origin/${targetBranch}`);\n }, `create and push target branch ${targetBranch}`);\n } catch (error: any) {\n throw new Error(`Failed to create target branch '${targetBranch}': ${error.message}`);\n }\n }\n } else {\n logger.info(`TARGET_BRANCH_EXISTS: Target branch already exists locally | Branch: ${targetBranch} | Status: ready`);\n }\n }\n\n // Run prechecks before starting any work\n await runPrechecks(runConfig, targetBranch);\n\n // Early check: determine if a release is necessary compared to target branch\n logger.info('RELEASE_NECESSITY_CHECK: Evaluating if release is required | Comparison: current branch vs target | Target: ' + targetBranch + ' | Purpose: Avoid unnecessary publishes');\n try {\n const necessity = await isReleaseNecessaryComparedToTarget(targetBranch, isDryRun);\n if (!necessity.necessary) {\n logger.info(`\\nRELEASE_SKIPPED: No meaningful changes detected, skipping publish | Reason: ${necessity.reason} | Target: ${targetBranch}`);\n // Emit a machine-readable marker so tree mode can detect skip and avoid propagating versions\n // CRITICAL: Use console.log to write to stdout (logger.info goes to stderr via winston)\n // eslint-disable-next-line no-console\n console.log('KODRDRIV_PUBLISH_SKIPPED');\n return;\n } else {\n logger.verbose(`RELEASE_PROCEEDING: Meaningful changes detected, continuing with publish | Reason: ${necessity.reason} | Target: ${targetBranch}`);\n }\n } catch (error: any) {\n // On unexpected errors, proceed with publish to avoid false negatives blocking releases\n logger.verbose(`RELEASE_NECESSITY_CHECK_ERROR: Unable to determine release necessity | Error: ${error.message} | Action: Proceeding conservatively with publish | Rationale: Avoid blocking valid releases`);\n }\n\n logger.info('RELEASE_PROCESS_STARTING: Initiating release workflow | Target: ' + targetBranch + ' | Phase: dependency updates and version management');\n\n\n let pr: PullRequest | null = null;\n\n if (isDryRun) {\n logger.info('PR_CHECK: Would check for existing pull request | Mode: dry-run | Action: Skip PR lookup');\n logger.info('PR_ASSUMPTION: Assuming no existing PR found | Mode: dry-run | Purpose: Demo workflow');\n } else {\n const branchName = await GitHub.getCurrentBranchName();\n pr = await GitHub.findOpenPullRequestByHeadRef(branchName);\n }\n\n if (pr) {\n logger.info(`PR_FOUND: Existing pull request detected for current branch | URL: ${pr.html_url} | Status: open`);\n } else {\n logger.info('PR_NOT_FOUND: No open pull request exists for current branch | Action: Starting new release publishing process | Next: Prepare dependencies and version');\n\n // STEP 1: Prepare for release (update dependencies and run prepublish checks) with NO version bump yet\n logger.verbose('RELEASE_PREP_STARTING: Preparing for release | Phase: dependency management | Action: Switch from workspace to remote dependencies | Version Bump: Not yet applied');\n\n // Clean up any npm link references before updating dependencies\n logger.verbose('NPM_LINK_CHECK: Scanning package-lock.json for npm link references | File: package-lock.json | Purpose: Remove development symlinks before publish');\n await cleanupNpmLinkReferences(isDryRun);\n\n // Update inter-project dependencies if --update-deps flag is present\n const updateDepsScope = runConfig.publish?.updateDeps;\n if (updateDepsScope) {\n logger.info(`INTER_PROJECT_DEPS_UPDATE: Updating inter-project dependencies | Scope: ${updateDepsScope} | Type: inter-project | Command: kodrdriv updates`);\n const Updates = await import('./updates');\n const updatesConfig: Config = {\n ...runConfig,\n dryRun: isDryRun,\n updates: {\n scope: updateDepsScope,\n interProject: true\n }\n };\n await Updates.execute(updatesConfig);\n }\n\n logger.verbose('DEPS_UPDATE_REGISTRY: Updating dependencies to latest versions from npm registry | Source: registry | Target: package.json');\n const updatePatterns = runConfig.publish?.dependencyUpdatePatterns;\n if (updatePatterns && updatePatterns.length > 0) {\n logger.verbose(`DEPS_UPDATE_PATTERNS: Updating dependencies matching specified patterns | Patterns: ${updatePatterns.join(', ')} | Count: ${updatePatterns.length} | Command: npm update`);\n const patternsArg = updatePatterns.join(' ');\n await runWithDryRunSupport(`npm update ${patternsArg}`, isDryRun);\n } else {\n logger.verbose('DEPS_UPDATE_ALL: No dependency patterns specified, updating all dependencies | Scope: all | Command: npm update');\n await runWithDryRunSupport('npm update', isDryRun);\n }\n\n logger.info('PREPUBLISH_SCRIPT_RUNNING: Executing prepublishOnly script | Script: prepublishOnly | Purpose: Run pre-flight checks (clean, lint, build, test)');\n await runWithDryRunSupport('npm run prepublishOnly', isDryRun, {}, true); // Use inherited stdio\n\n // STEP 2: Commit dependency updates if any (still no version bump)\n logger.verbose('DEPS_STAGING: Staging dependency updates for commit | Files: package.json + package-lock.json | Command: git add | Note: Version bump not yet applied');\n // Check if package-lock.json exists before trying to stage it\n const packageLockExists = await storage.exists('package-lock.json');\n const filesToStage = packageLockExists ? 'package.json package-lock.json' : 'package.json';\n\n // Wrap git operations with repository lock to prevent .git/index.lock conflicts\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git add ${filesToStage}`, isDryRun);\n }, 'stage dependency updates');\n\n logger.verbose('DEPS_COMMIT_CHECK: Checking for staged dependency updates | Command: git status | Purpose: Determine if commit needed');\n if (isDryRun) {\n logger.verbose('DEPS_COMMIT_DRY_RUN: Would create dependency update commit if changes are staged | Mode: dry-run');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('DEPS_COMMIT_CREATING: Staged dependency changes detected, creating commit | Files: ' + filesToStage + ' | Action: Execute commit command');\n // Commit also needs git lock\n await runGitWithLock(process.cwd(), async () => {\n await Commit.execute(runConfig);\n }, 'commit dependency updates');\n } else {\n logger.verbose('DEPS_COMMIT_SKIPPED: No dependency changes to commit | Files: ' + filesToStage + ' | Action: Skipping commit step');\n }\n }\n\n // STEP 3: Merge target branch into working branch (optional - now skipped by default since post-publish sync keeps branches in sync)\n const skipPreMerge = runConfig.publish?.skipPrePublishMerge !== false; // Default to true (skip)\n\n if (skipPreMerge) {\n logger.verbose(`PRE_MERGE_SKIPPED: Skipping pre-publish merge of target branch | Reason: Post-publish sync handles branch synchronization | Target: ${targetBranch} | Config: skipPrePublishMerge=true`);\n } else {\n logger.info(`PRE_MERGE_STARTING: Merging target branch into current branch | Target: ${targetBranch} | Purpose: Avoid version conflicts | Phase: pre-publish`);\n if (isDryRun) {\n logger.info(`Would merge ${targetBranch} into current branch`);\n } else {\n // Wrap entire merge process with git lock (involves fetch, merge, checkout, add, commit)\n await runGitWithLock(process.cwd(), async () => {\n // Fetch the latest target branch\n try {\n await run(`git fetch origin ${targetBranch}:${targetBranch}`);\n logger.info(`TARGET_BRANCH_FETCHED: Successfully fetched latest target branch | Branch: ${targetBranch} | Remote: origin/${targetBranch} | Purpose: Pre-merge sync`);\n } catch (fetchError: any) {\n logger.warn(`TARGET_BRANCH_FETCH_FAILED: Unable to fetch target branch | Branch: ${targetBranch} | Error: ${fetchError.message} | Impact: Proceeding without merge, PR may have conflicts`);\n logger.warn('MERGE_SKIPPED_NO_FETCH: Continuing without pre-merge | Reason: Target branch fetch failed | Impact: PR may require manual conflict resolution');\n }\n\n // Check if merge is needed (avoid unnecessary merge commits)\n try {\n const { stdout: mergeBase } = await run(`git merge-base HEAD ${targetBranch}`);\n const { stdout: targetCommit } = await run(`git rev-parse ${targetBranch}`);\n\n if (mergeBase.trim() === targetCommit.trim()) {\n logger.info(`MERGE_NOT_NEEDED: Current branch already up-to-date with target | Branch: ${targetBranch} | Status: in-sync | Action: Skipping merge`);\n } else {\n // Try to merge target branch into current branch\n let mergeSucceeded = false;\n try {\n await run(`git merge ${targetBranch} --no-edit -m \"Merge ${targetBranch} to sync before version bump\"`);\n logger.info(`MERGE_SUCCESS: Successfully merged target branch into current branch | Target: ${targetBranch} | Purpose: Sync before version bump`);\n mergeSucceeded = true;\n } catch (mergeError: any) {\n // If merge conflicts occur, check if they're only in version-related files\n const errorText = [mergeError.message || '', mergeError.stdout || '', mergeError.stderr || ''].join(' ');\n if (errorText.includes('CONFLICT')) {\n logger.warn(`MERGE_CONFLICTS_DETECTED: Merge conflicts found, attempting automatic resolution | Target: ${targetBranch} | Strategy: Auto-resolve version files`);\n\n // Get list of conflicted files\n const { stdout: conflictedFiles } = await run('git diff --name-only --diff-filter=U');\n const conflicts = conflictedFiles.trim().split('\\n').filter(Boolean);\n\n logger.verbose(`MERGE_CONFLICTS_LIST: Conflicted files detected | Files: ${conflicts.join(', ')} | Count: ${conflicts.length}`);\n\n // Check if conflicts are only in package.json and package-lock.json\n const versionFiles = ['package.json', 'package-lock.json'];\n const nonVersionConflicts = conflicts.filter(f => !versionFiles.includes(f));\n\n if (nonVersionConflicts.length > 0) {\n logger.error(`MERGE_AUTO_RESOLVE_FAILED: Cannot auto-resolve conflicts in non-version files | Files: ${nonVersionConflicts.join(', ')} | Count: ${nonVersionConflicts.length} | Resolution: Manual intervention required`);\n logger.error('');\n logger.error('CONFLICT_RESOLUTION_REQUIRED: Manual steps to resolve conflicts:');\n logger.error(' Step 1: Resolve conflicts in the files listed above');\n logger.error(' Step 2: Stage resolved files | Command: git add <resolved-files>');\n logger.error(' Step 3: Complete merge commit | Command: git commit');\n logger.error(' Step 4: Resume publish process | Command: kodrdriv publish');\n logger.error('');\n throw new Error(`Merge conflicts in non-version files. Please resolve manually.`);\n }\n\n // Auto-resolve version conflicts by accepting current branch versions\n // (keep our working branch's version, which is likely already updated)\n logger.info(`MERGE_AUTO_RESOLVING: Automatically resolving version conflicts | Strategy: Keep current branch versions | Files: ${versionFiles.join(', ')}`);\n for (const file of conflicts) {\n if (versionFiles.includes(file)) {\n await run(`git checkout --ours ${file}`);\n await run(`git add ${file}`);\n logger.verbose(`MERGE_FILE_RESOLVED: Resolved file using current branch version | File: ${file} | Strategy: checkout --ours`);\n }\n }\n\n // Complete the merge\n await run(`git commit --no-edit -m \"Merge ${targetBranch} to sync before version bump (auto-resolved version conflicts)\"`);\n logger.info(`MERGE_AUTO_RESOLVE_SUCCESS: Successfully auto-resolved version conflicts and completed merge | Target: ${targetBranch} | Files: ${versionFiles.join(', ')}`);\n mergeSucceeded = true;\n } else {\n // Not a conflict error, re-throw\n throw mergeError;\n }\n }\n\n // Only run npm install if merge actually happened\n if (mergeSucceeded) {\n // Run npm install to update package-lock.json based on merged package.json\n logger.info('POST_MERGE_NPM_INSTALL: Running npm install after merge | Purpose: Update package-lock.json based on merged package.json | Command: npm install');\n await run('npm install');\n logger.info('POST_MERGE_NPM_COMPLETE: npm install completed successfully | Status: Dependencies synchronized');\n\n // Commit any changes from npm install (e.g., package-lock.json updates)\n const { stdout: mergeChangesStatus } = await run('git status --porcelain');\n if (mergeChangesStatus.trim()) {\n logger.verbose('POST_MERGE_CHANGES_DETECTED: Changes detected after npm install | Action: Staging for commit | Command: git add');\n // Check if package-lock.json exists before trying to stage it\n const packageLockExistsPostMerge = await storage.exists('package-lock.json');\n const filesToStagePostMerge = packageLockExistsPostMerge ? 'package.json package-lock.json' : 'package.json';\n await run(`git add ${filesToStagePostMerge}`);\n\n if (await Diff.hasStagedChanges()) {\n logger.verbose('POST_MERGE_COMMIT: Committing post-merge changes | Files: ' + filesToStagePostMerge + ' | Purpose: Finalize merge');\n await Commit.execute(runConfig);\n }\n }\n }\n }\n } catch (error: any) {\n // Only catch truly unexpected errors here\n logger.error(`MERGE_UNEXPECTED_ERROR: Unexpected error during merge process | Error: ${error.message} | Target: ${targetBranch} | Action: Aborting publish`);\n throw error;\n }\n }, `merge ${targetBranch} into current branch`);\n }\n }\n\n // STEP 4: Determine and set target version AFTER checks, dependency commit, and target branch merge\n logger.info('Determining target version...');\n let newVersion: string;\n\n if (isDryRun) {\n logger.info('Would determine target version and update package.json');\n newVersion = '1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, 'package.json');\n const packageJson = validatePackageJson(parsed, 'package.json');\n const currentVersion = packageJson.version;\n\n let proposedVersion: string;\n let finalTargetBranch = targetBranch;\n\n if (branchDependentVersioning && runConfig.branches) {\n // Use branch-dependent versioning logic\n const branchDependentResult = await calculateBranchDependentVersion(\n currentVersion,\n currentBranch,\n runConfig.branches,\n targetBranch\n );\n proposedVersion = branchDependentResult.version;\n finalTargetBranch = branchDependentResult.targetBranch;\n\n logger.info(`VERSION_BRANCH_DEPENDENT_CALCULATED: Branch-dependent version calculated | Current: ${currentVersion} | Proposed: ${proposedVersion} | Strategy: branch-dependent`);\n logger.info(`TARGET_BRANCH_FINAL: Final target branch determined | Branch: ${finalTargetBranch} | Source: branch-dependent config`);\n\n // Update targetBranch for the rest of the function\n targetBranch = finalTargetBranch;\n } else {\n // Use existing logic for backward compatibility\n const targetVersionInput = runConfig.publish?.targetVersion || 'patch';\n proposedVersion = calculateTargetVersion(currentVersion, targetVersionInput);\n }\n\n const targetTagName = `v${proposedVersion}`;\n const tagExists = await checkIfTagExists(targetTagName);\n\n // Smart tag conflict handling\n if (tagExists) {\n const { getNpmPublishedVersion, getTagInfo } = await import('../util/general');\n\n logger.warn(`TAG_ALREADY_EXISTS: Tag already exists in repository | Tag: ${targetTagName} | Status: conflict | Action: Check npm registry`);\n\n // Check if this version is published on npm\n const npmVersion = await getNpmPublishedVersion(packageJson.name);\n const tagInfo = await getTagInfo(targetTagName);\n\n if (npmVersion === proposedVersion) {\n // Version is already published on npm\n logger.info(`VERSION_ALREADY_PUBLISHED: Version already published on npm registry | Version: ${proposedVersion} | Status: published | Action: Skipping`);\n logger.info(`PUBLISH_SKIPPED_DUPLICATE: Skipping publish operation | Reason: Package already at target version | Version: ${proposedVersion}`);\n logger.info('');\n logger.info('REPUBLISH_OPTIONS: Options if you need to republish:');\n logger.info(` Option 1: Bump version | Command: npm version patch (or minor/major)`);\n logger.info(` Option 2: Re-run publish | Command: kodrdriv publish`);\n logger.info('');\n\n if (runConfig.publish?.skipAlreadyPublished) {\n logger.info('PUBLISH_SKIPPED_FLAG: Skipping package due to flag | Flag: --skip-already-published | Version: ' + proposedVersion + ' | Status: skipped');\n // Emit skip marker for tree mode detection\n // eslint-disable-next-line no-console\n console.log('KODRDRIV_PUBLISH_SKIPPED');\n return; // Exit without error\n } else {\n throw new Error(`Version ${proposedVersion} already published. Use --skip-already-published to continue.`);\n }\n } else {\n // Tag exists but version not on npm - likely failed previous publish\n logger.warn('');\n logger.warn('PUBLISH_SITUATION_ANALYSIS: Analyzing publish conflict situation | Tag: ' + targetTagName + ' | npm: ' + (npmVersion || 'not published'));\n logger.warn(`PUBLISH_ANALYSIS_TAG_EXISTS: Tag exists locally | Tag: ${targetTagName} | Commit: ${tagInfo?.commit?.substring(0, 8)}`);\n logger.warn(`PUBLISH_ANALYSIS_NPM_STATUS: npm registry status | Version: ${npmVersion || 'not published'} | Status: ${npmVersion ? 'published' : 'missing'}`);\n logger.warn(`PUBLISH_ANALYSIS_CONCLUSION: Previous publish likely failed after tag creation | Reason: Tag exists but not on npm | Resolution: Recovery needed`);\n logger.warn('');\n logger.warn('PUBLISH_RECOVERY_OPTIONS: Recovery options available:');\n logger.warn(' OPTION_1_FORCE: Force republish by deleting tag | Command: kodrdriv publish --force-republish');\n logger.warn(' OPTION_2_BUMP: Skip version and bump | Command: npm version patch && kodrdriv publish');\n logger.warn(' OPTION_3_MANUAL: Manually delete tag:');\n logger.warn(` Command: git tag -d ${targetTagName}`);\n logger.warn(` Command: git push origin :refs/tags/${targetTagName}`);\n logger.warn('');\n\n if (runConfig.publish?.forceRepublish) {\n logger.info('PUBLISH_FORCE_REPUBLISH: Force republish mode enabled | Action: Deleting existing tag | Tag: ' + targetTagName + ' | Purpose: Allow republish');\n\n if (!isDryRun) {\n const { runSecure } = await import('@eldrforge/git-tools');\n\n // Delete local tag\n try {\n await runSecure('git', ['tag', '-d', targetTagName]);\n logger.info(`TAG_DELETED_LOCAL: Deleted local tag | Tag: ${targetTagName} | Status: removed-local`);\n } catch (error: any) {\n logger.debug(`Could not delete local tag: ${error.message}`);\n }\n\n // Delete remote tag\n try {\n await runSecure('git', ['push', 'origin', `:refs/tags/${targetTagName}`]);\n logger.info(`TAG_DELETED_REMOTE: Deleted remote tag | Tag: ${targetTagName} | Remote: origin | Status: removed-remote`);\n } catch (error: any) {\n logger.debug(`Could not delete remote tag: ${error.message}`);\n }\n\n logger.info('PUBLISH_TAG_CLEANUP_COMPLETE: Tag deleted successfully | Status: ready-for-publish | Next: Continue with publish workflow');\n } else {\n logger.info('Would delete tags and continue with publish');\n }\n } else {\n throw new Error(`Tag ${targetTagName} already exists. Use --force-republish to override.`);\n }\n }\n }\n\n if (runConfig.publish?.interactive) {\n newVersion = await confirmVersionInteractively(currentVersion, proposedVersion, runConfig.publish?.targetVersion);\n const confirmedTagName = `v${newVersion}`;\n const confirmedTagExists = await checkIfTagExists(confirmedTagName);\n\n if (confirmedTagExists) {\n const { getNpmPublishedVersion } = await import('../util/general');\n const npmVersion = await getNpmPublishedVersion(packageJson.name);\n\n if (npmVersion === newVersion) {\n throw new Error(`Tag ${confirmedTagName} already exists and version is published on npm. Please choose a different version.`);\n } else if (!runConfig.publish?.forceRepublish) {\n throw new Error(`Tag ${confirmedTagName} already exists. Use --force-republish to override.`);\n }\n // If forceRepublish is set, we'll continue (tag will be deleted later)\n }\n } else {\n newVersion = proposedVersion;\n }\n\n logger.info(`Bumping version from ${currentVersion} to ${newVersion}`);\n packageJson.version = newVersion;\n await storage.writeFile('package.json', JSON.stringify(packageJson, null, 2) + '\\n', 'utf-8');\n logger.info(`Version updated in package.json: ${newVersion}`);\n }\n\n // STEP 5: Commit version bump as a separate commit\n logger.verbose('Staging version bump for commit');\n // Check if package-lock.json exists before trying to stage it\n const packageLockExistsVersionBump = await storage.exists('package-lock.json');\n const filesToStageVersionBump = packageLockExistsVersionBump ? 'package.json package-lock.json' : 'package.json';\n\n // Wrap git operations with lock\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git add ${filesToStageVersionBump}`, isDryRun);\n }, 'stage version bump');\n\n if (isDryRun) {\n logger.verbose('Would create version bump commit');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('Creating version bump commit...');\n await runGitWithLock(process.cwd(), async () => {\n await Commit.execute(runConfig);\n }, 'commit version bump');\n } else {\n logger.verbose('No version changes to commit.');\n }\n }\n\n logger.info('Generating release notes...');\n\n // Use the existing currentBranch variable for tag detection\n logger.debug(`Current branch for release notes: ${currentBranch}`);\n\n // Create a modified config for release notes generation that includes the publish --from, --interactive, and --from-main options\n const releaseConfig = { ...runConfig };\n releaseConfig.release = {\n ...runConfig.release,\n currentBranch: currentBranch, // Pass current branch\n ...(runConfig.publish?.from && { from: runConfig.publish.from }),\n ...(runConfig.publish?.interactive && { interactive: runConfig.publish.interactive }),\n ...(runConfig.publish?.fromMain && { fromMain: runConfig.publish.fromMain })\n };\n if (runConfig.publish?.from) {\n logger.verbose(`Using custom 'from' reference for release notes: ${runConfig.publish.from}`);\n }\n if (runConfig.publish?.interactive) {\n logger.verbose('Interactive mode enabled for release notes generation');\n }\n if (runConfig.publish?.fromMain) {\n logger.verbose('Forcing comparison against main branch for release notes');\n }\n // Log agentic mode settings for debugging\n if (releaseConfig.release?.agentic) {\n logger.verbose('Agentic mode enabled for release notes generation');\n }\n if (releaseConfig.release?.selfReflection) {\n logger.verbose('Self-reflection enabled for release notes generation');\n }\n\n const releaseSummary = await Release.execute(releaseConfig);\n\n if (isDryRun) {\n logger.info('Would write release notes to RELEASE_NOTES.md and RELEASE_TITLE.md in output directory');\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n await storage.ensureDirectory(outputDirectory);\n\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n await storage.writeFile(releaseNotesPath, releaseSummary.body, 'utf-8');\n await storage.writeFile(releaseTitlePath, releaseSummary.title, 'utf-8');\n logger.info(`Release notes and title generated and saved to ${releaseNotesPath} and ${releaseTitlePath}.`);\n }\n\n logger.info('Pushing to origin...');\n // Get current branch name and push explicitly to avoid pushing to wrong remote/branch\n const branchName = await GitHub.getCurrentBranchName();\n\n // Wrap git push with lock\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git push origin ${branchName}`, isDryRun);\n }, `push ${branchName}`);\n\n logger.info('Creating pull request...');\n if (isDryRun) {\n logger.info('Would get commit title and create PR with GitHub API');\n pr = { number: 123, html_url: 'https://github.com/mock/repo/pull/123', labels: [] } as PullRequest;\n } else {\n const { stdout: rawCommitTitle } = await run('git log -1 --pretty=%B');\n\n // Apply stop-context filtering to PR title and body\n const commitTitle = filterContent(rawCommitTitle, runConfig.stopContext).filtered;\n const prBody = filterContent('Automated release PR.', runConfig.stopContext).filtered;\n\n pr = await GitHub.createPullRequest(commitTitle, prBody, branchName, targetBranch);\n if (!pr) {\n throw new Error('Failed to create pull request.');\n }\n logger.info(`Pull request created: ${pr.html_url} (${branchName} → ${targetBranch})`);\n }\n }\n\n logger.info(`Waiting for PR #${pr!.number} checks to complete...`);\n if (!isDryRun) {\n // Check if we already know from prechecks that no workflows will trigger\n let shouldSkipWait = false;\n try {\n // TODO: Re-enable when checkWorkflowConfiguration is exported from github-tools\n // const workflowConfig = await GitHub.checkWorkflowConfiguration(targetBranch);\n const workflowConfig = {\n hasWorkflows: true,\n hasPullRequestTriggers: true,\n workflowCount: 0,\n triggeredWorkflowNames: [] as string[]\n };\n if (!workflowConfig.hasWorkflows || !workflowConfig.hasPullRequestTriggers) {\n logger.info('PUBLISH_CHECK_WAIT_SKIPPED: Skipping check wait | Reason: No workflows configured for PR | Status: no-workflows | Next: Proceed with merge');\n shouldSkipWait = true;\n }\n } catch (error: any) {\n // If we can't verify, proceed with waiting to be safe\n logger.debug(`Could not verify workflow configuration for wait skip: ${error.message}`);\n }\n\n if (!shouldSkipWait) {\n // Configure timeout and user confirmation behavior\n const timeout = runConfig.publish?.checksTimeout || KODRDRIV_DEFAULTS.publish.checksTimeout;\n const senditMode = runConfig.publish?.sendit || false;\n // sendit flag overrides skipUserConfirmation - if sendit is true, skip confirmation\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n await GitHub.waitForPullRequestChecks(pr!.number, {\n timeout,\n skipUserConfirmation\n });\n }\n }\n\n const mergeMethod = runConfig.publish?.mergeMethod || 'squash';\n if (isDryRun) {\n logger.info(`Would merge PR #${pr!.number} using ${mergeMethod} method`);\n } else {\n try {\n await GitHub.mergePullRequest(pr!.number, mergeMethod, false); // Don't delete branch\n } catch (error: any) {\n // Check if this is a merge conflict error\n if (error.message && (\n error.message.includes('not mergeable') ||\n error.message.includes('Pull Request is not mergeable') ||\n error.message.includes('merge conflict')\n )) {\n logger.error(`PR_MERGE_CONFLICTS: Pull request has merge conflicts | PR Number: ${pr!.number} | Status: conflicts | Resolution: Manual intervention required`);\n logger.error('');\n logger.error('PR_CONFLICT_RESOLUTION: Steps to resolve conflicts:');\n logger.error(` Step 1: Visit pull request | URL: ${pr!.html_url}`);\n logger.error(' Step 2: Resolve merge conflicts | Method: GitHub UI or local');\n logger.error(' Step 3: Re-run publish command | Command: kodrdriv publish');\n logger.error('');\n logger.error('PR_AUTO_CONTINUE: Command will auto-detect existing PR | Behavior: Continues from where it left off | No re-creation needed');\n throw new Error(`Merge conflicts detected in PR #${pr!.number}. Please resolve conflicts and re-run the command.`);\n } else {\n // Re-throw other merge errors\n throw error;\n }\n }\n }\n\n // Switch to target branch and pull latest changes\n logger.info(`Checking out target branch: ${targetBranch}...`);\n\n // Check for uncommitted changes and stash them if necessary\n let hasStashedChanges = false;\n if (!isDryRun) {\n const { stdout: statusOutput } = await runSecure('git', ['status', '--porcelain']);\n if (statusOutput.trim()) {\n logger.info('PUBLISH_STASH_SAVING: Stashing uncommitted changes before checkout | Command: git stash push | Purpose: Protect changes during branch switch');\n await runSecure('git', ['stash', 'push', '-m', 'kodrdriv: stash before checkout target branch']);\n hasStashedChanges = true;\n logger.info('PUBLISH_STASH_SUCCESS: Successfully stashed uncommitted changes | Status: saved | Name: kodrdriv stash');\n }\n }\n\n try {\n // Wrap git checkout and pull with lock\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);\n }, `checkout ${targetBranch}`);\n\n // Sync target branch with remote to avoid conflicts during PR creation\n if (!isDryRun) {\n logger.info(`PUBLISH_TARGET_SYNCING: Syncing target branch with remote | Branch: ${targetBranch} | Remote: origin | Purpose: Avoid PR conflicts`);\n try {\n const remoteExists = await run(`git ls-remote --exit-code --heads origin ${targetBranch}`).then(() => true).catch(() => false);\n\n if (remoteExists) {\n await runGitWithLock(process.cwd(), async () => {\n await run(`git fetch origin ${targetBranch}`);\n await run(`git merge origin/${targetBranch} --no-edit`);\n }, `sync ${targetBranch}`);\n logger.info(`PUBLISH_TARGET_SYNCED: Successfully synced target with remote | Branch: ${targetBranch} | Remote: origin | Status: in-sync`);\n } else {\n logger.info(`PUBLISH_TARGET_NO_REMOTE: No remote target branch found | Branch: ${targetBranch} | Remote: origin | Action: Will be created on first push`);\n }\n } catch (syncError: any) {\n if (syncError.message && syncError.message.includes('CONFLICT')) {\n logger.error(`PUBLISH_SYNC_CONFLICTS: Merge conflicts during target sync | Branch: ${targetBranch} | Remote: origin | Status: conflicts-detected`);\n logger.error(`PUBLISH_SYNC_RESOLUTION: Manual conflict resolution steps:`);\n logger.error(` Step 1: Checkout target | Command: git checkout ${targetBranch}`);\n logger.error(` Step 2: Pull and merge | Command: git pull origin ${targetBranch}`);\n logger.error(` Step 3: Resolve conflicts in files`);\n logger.error(` Step 4: Stage resolved files | Command: git add <resolved-files>`);\n logger.error(` Step 5: Complete merge | Command: git commit`);\n logger.error(` Step 6: Return to branch | Command: git checkout ${currentBranch}`);\n logger.error(` Step 7: Resume publish | Command: kodrdriv publish`);\n throw syncError;\n } else {\n logger.warn(`PUBLISH_SYNC_WARNING: Could not sync target with remote | Branch: ${targetBranch} | Remote: origin | Error: ${syncError.message}`);\n // Continue with publish process, but log the warning\n }\n }\n } else {\n logger.info(`Would sync ${targetBranch} with remote to avoid PR conflicts`);\n }\n } catch (error: any) {\n // Check if this is a merge conflict or sync issue\n if (!isDryRun && (error.message.includes('conflict') ||\n error.message.includes('CONFLICT') ||\n error.message.includes('diverged') ||\n error.message.includes('non-fast-forward'))) {\n\n logger.error(`PUBLISH_TARGET_SYNC_FAILED: Failed to sync target branch with remote | Branch: ${targetBranch} | Remote: origin | Impact: Cannot proceed safely`);\n logger.error('');\n logger.error('PUBLISH_SYNC_RECOVERY_OPTIONS: Available recovery options:');\n logger.error(` OPTION_1_AUTO: Attempt automatic resolution | Command: kodrdriv publish --sync-target`);\n logger.error(` OPTION_2_MANUAL: Manually resolve conflicts:`);\n logger.error(` Step 1: Checkout target | Command: git checkout ${targetBranch}`);\n logger.error(` Step 2: Pull from remote | Command: git pull origin ${targetBranch}`);\n logger.error(` Step 3: Resolve conflicts and commit`);\n logger.error(` Step 4: Re-run publish | Command: kodrdriv publish`);\n logger.error('');\n logger.error('PUBLISH_STOPPED_SAFETY: Publish process stopped | Reason: Prevent data loss | Status: safe-to-recover');\n\n throw new Error(`Target branch '${targetBranch}' sync failed. Use recovery options above to resolve.`);\n } else {\n // Re-throw other errors\n throw error;\n }\n }\n\n // Restore stashed changes if we stashed them\n if (hasStashedChanges) {\n logger.info('PUBLISH_STASH_RESTORING: Restoring previously stashed changes | Command: git stash pop | Purpose: Restore working directory state');\n try {\n await runSecure('git', ['stash', 'pop']);\n logger.info('PUBLISH_STASH_RESTORED: Successfully restored stashed changes | Status: restored | Stash: removed');\n } catch (stashError: any) {\n logger.warn(`PUBLISH_STASH_RESTORE_FAILED: Could not restore stashed changes | Error: ${stashError.message} | Impact: Changes still in stash`);\n logger.warn('PUBLISH_STASH_AVAILABLE: Changes available in git stash | Command: git stash list | Purpose: View and restore manually');\n }\n }\n\n // Now create and push the tag on the target branch\n logger.info('Creating release tag...');\n let tagName: string;\n if (isDryRun) {\n logger.info('Would read package.json version and create git tag');\n tagName = 'v1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const { version } = safeJsonParse(packageJsonContents, 'package.json');\n tagName = `v${version}`;\n\n // Check if tag already exists locally\n try {\n // Validate tag name to prevent injection\n if (!validateGitRef(tagName)) {\n throw new Error(`Invalid tag name: ${tagName}`);\n }\n const { stdout } = await runSecure('git', ['tag', '-l', tagName]);\n if (stdout.trim() === tagName) {\n logger.info(`Tag ${tagName} already exists locally, skipping tag creation`);\n } else {\n await runGitWithLock(process.cwd(), async () => {\n await runSecure('git', ['tag', tagName]);\n }, `create tag ${tagName}`);\n logger.info(`Created local tag: ${tagName}`);\n }\n } catch (error) {\n // If git tag -l fails, create the tag anyway\n await runGitWithLock(process.cwd(), async () => {\n await runSecure('git', ['tag', tagName]);\n }, `create tag ${tagName}`);\n logger.info(`Created local tag: ${tagName}`);\n }\n\n // Check if tag exists on remote before pushing\n let tagWasPushed = false;\n try {\n const { stdout } = await runSecure('git', ['ls-remote', 'origin', `refs/tags/${tagName}`]);\n if (stdout.trim()) {\n logger.info(`Tag ${tagName} already exists on remote, skipping push`);\n } else {\n await runGitWithLock(process.cwd(), async () => {\n await runSecure('git', ['push', 'origin', tagName]);\n }, `push tag ${tagName}`);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n }\n } catch (error) {\n // If ls-remote fails, try to push anyway (might be a new remote)\n try {\n await runSecure('git', ['push', 'origin', tagName]);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n } catch (pushError: any) {\n if (pushError.message && pushError.message.includes('already exists')) {\n logger.info(`Tag ${tagName} already exists on remote, continuing...`);\n } else {\n throw pushError;\n }\n }\n }\n\n // If we just pushed a new tag, wait for GitHub to process it\n if (tagWasPushed) {\n logger.verbose('Waiting for GitHub to process the pushed tag...');\n await new Promise(resolve => setTimeout(resolve, 5000)); // 5 second delay\n }\n }\n\n logger.info('Creating GitHub release...');\n if (isDryRun) {\n logger.info('Would read package.json version and create GitHub release with retry logic');\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('Would close milestone for released version');\n } else {\n logger.info('Would skip milestone closure (--no-milestones)');\n }\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n const releaseNotesContent = await storage.readFile(releaseNotesPath, 'utf-8');\n const releaseTitle = await storage.readFile(releaseTitlePath, 'utf-8');\n\n // Create release with retry logic to handle GitHub tag processing delays\n let retries = 3;\n while (retries > 0) {\n try {\n await GitHub.createRelease(tagName, releaseTitle, releaseNotesContent);\n logger.info(`GitHub release created successfully for tag: ${tagName}`);\n\n // Close milestone for this version if enabled\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('PUBLISH_MILESTONE_CLOSING: Closing milestone for released version | Action: Close GitHub milestone | Purpose: Mark release complete');\n const version = tagName.replace(/^v/, ''); // Remove 'v' prefix if present\n await GitHub.closeMilestoneForVersion(version);\n } else {\n logger.debug('Milestone integration disabled via --no-milestones');\n }\n\n break; // Success - exit retry loop\n } catch (error: any) {\n // Check if this is a tag-not-found error that we can retry\n const isTagNotFoundError = error.message && (\n error.message.includes('not found') ||\n error.message.includes('does not exist') ||\n error.message.includes('Reference does not exist')\n );\n\n if (isTagNotFoundError && retries > 1) {\n logger.verbose(`Tag ${tagName} not yet available on GitHub, retrying in 3 seconds... (${retries - 1} retries left)`);\n await new Promise(resolve => setTimeout(resolve, 3000));\n retries--;\n } else if (isTagNotFoundError) {\n // Tag not found error and we're out of retries\n throw new Error(`Tag ${tagName} was not found on GitHub after ${3 - retries + 1} attempts. This may indicate a problem with tag creation or GitHub synchronization.`);\n } else {\n // Not a tag-not-found error - re-throw the original error\n throw error;\n }\n }\n }\n }\n\n // Wait for release workflows to complete (if enabled)\n const waitForWorkflows = runConfig.publish?.waitForReleaseWorkflows !== false; // default to true\n if (waitForWorkflows) {\n logger.info('Waiting for release workflows...');\n if (isDryRun) {\n logger.info('Would monitor GitHub Actions workflows triggered by release');\n } else {\n const workflowTimeout = runConfig.publish?.releaseWorkflowsTimeout || KODRDRIV_DEFAULTS.publish.releaseWorkflowsTimeout;\n const senditMode = runConfig.publish?.sendit || false;\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n // Get workflow names - either from config or auto-detect\n let workflowNames = runConfig.publish?.releaseWorkflowNames;\n\n if (!workflowNames || workflowNames.length === 0) {\n logger.info('No specific workflow names configured, auto-detecting workflows triggered by release events...');\n try {\n workflowNames = await GitHub.getWorkflowsTriggeredByRelease();\n if (workflowNames.length === 0) {\n logger.info('No workflows found that are triggered by release events.');\n } else {\n logger.info(`Auto-detected release workflows: ${workflowNames.join(', ')}`);\n }\n } catch (error: any) {\n logger.warn(`Failed to auto-detect release workflows: ${error.message}`);\n workflowNames = undefined; // Fall back to monitoring all workflows\n }\n }\n\n await GitHub.waitForReleaseWorkflows(tagName, {\n timeout: workflowTimeout,\n workflowNames,\n skipUserConfirmation\n });\n }\n } else {\n logger.verbose('Skipping waiting for release workflows (disabled in config).');\n }\n\n // Switch back to source branch and sync with target\n logger.info('');\n logger.info(`PUBLISH_POST_SYNC: Syncing source branch with target after publish | Purpose: Keep branches synchronized | Strategy: Reset and force push`);\n await runWithDryRunSupport(`git checkout ${currentBranch}`, isDryRun);\n\n if (!isDryRun) {\n // Sync target into source\n // Note: With squash merging, fast-forward will fail because commit histories diverge\n if (mergeMethod === 'squash') {\n // For squash merges, reset to target branch to avoid conflicts\n // The squash merge created a single commit on target that represents all source commits\n logger.info(`Resetting ${currentBranch} to ${targetBranch} (squash merge)...`);\n await run(`git reset --hard ${targetBranch}`);\n logger.info(`PUBLISH_BRANCH_RESET: Reset source branch to target | Source: ${currentBranch} | Target: ${targetBranch} | Status: synchronized`);\n\n // After squash merge and reset, we need to force push\n // This is safe because we just merged to main and are syncing working branch\n logger.info(`PUBLISH_FORCE_PUSHING: Force pushing synchronized branch | Branch: ${currentBranch} | Remote: origin | Purpose: Complete post-publish sync`);\n\n try {\n // Verify that remote working branch is ancestor of main (safety check)\n try {\n await run(`git fetch origin ${currentBranch}`);\n await run(`git merge-base --is-ancestor origin/${currentBranch} ${targetBranch}`);\n logger.verbose(`✓ Safety check passed: origin/${currentBranch} is ancestor of ${targetBranch}`);\n } catch {\n // Remote branch might not exist yet, or already in sync - both OK\n logger.verbose(`Remote ${currentBranch} does not exist or is already synced`);\n }\n\n // Use --force-with-lease for safer force push\n await run(`git push --force-with-lease origin ${currentBranch}`);\n logger.info(`PUBLISH_FORCE_PUSH_SUCCESS: Successfully force pushed to remote | Branch: ${currentBranch} | Remote: origin | Status: synchronized`);\n } catch (pushError: any) {\n // If force push fails, provide helpful message\n logger.warn(`PUBLISH_FORCE_PUSH_FAILED: Could not force push branch | Branch: ${currentBranch} | Remote: origin | Error: ${pushError.message}`);\n logger.warn(`PUBLISH_MANUAL_PUSH_NEEDED: Manual force push required | Action: Push manually`);\n logger.warn(`PUBLISH_MANUAL_PUSH_COMMAND: Force push command | Command: git push --force-with-lease origin ${currentBranch}`);\n }\n } else {\n // For merge/rebase methods, try to merge target back into source\n logger.info(`PUBLISH_MERGE_TARGET_BACK: Merging target back into source | Target: ${targetBranch} | Source: ${currentBranch} | Purpose: Sync branches after publish`);\n\n // Try fast-forward first (works with merge/rebase methods)\n // Use runSecure to avoid error output for expected failure\n let fastForwardSucceeded = false;\n try {\n await runSecure('git', ['merge', targetBranch, '--ff-only']);\n fastForwardSucceeded = true;\n logger.info(`PUBLISH_MERGE_FF_SUCCESS: Fast-forward merged target into source | Target: ${targetBranch} | Source: ${currentBranch} | Status: merged`);\n } catch {\n logger.verbose(`Fast-forward merge not possible, performing regular merge...`);\n }\n\n if (!fastForwardSucceeded) {\n await run(`git merge ${targetBranch} --no-edit`);\n logger.info(`PUBLISH_MERGE_SUCCESS: Merged target into source | Target: ${targetBranch} | Source: ${currentBranch} | Status: merged`);\n }\n }\n\n // Determine version bump based on branch configuration\n let versionCommand = 'prepatch'; // Default\n let versionTag = 'dev'; // Default\n\n if (branchDependentVersioning && runConfig.branches) {\n const sourceBranchConfig = runConfig.branches[currentBranch];\n if (sourceBranchConfig?.version) {\n // Use configured version strategy for source branch\n if (sourceBranchConfig.version.incrementLevel) {\n versionCommand = `pre${sourceBranchConfig.version.incrementLevel}`;\n }\n if (sourceBranchConfig.version.tag) {\n versionTag = sourceBranchConfig.version.tag;\n }\n }\n }\n\n // Bump to next development version\n logger.info(`PUBLISH_DEV_VERSION_BUMPING: Bumping to next development version | Command: ${versionCommand} | Tag: ${versionTag} | Purpose: Prepare for next cycle`);\n try {\n const { stdout: newVersion } = await run(`npm version ${versionCommand} --preid=${versionTag}`);\n logger.info(`PUBLISH_DEV_VERSION_BUMPED: Version bumped successfully | New Version: ${newVersion.trim()} | Type: development | Status: completed`);\n } catch (versionError: any) {\n logger.warn(`PUBLISH_DEV_VERSION_BUMP_FAILED: Failed to bump version | Error: ${versionError.message} | Impact: Version not updated`);\n logger.warn('PUBLISH_MANUAL_VERSION_BUMP: Manual version bump may be needed | Action: Bump manually for next cycle | Command: npm version');\n }\n\n // Push updated source branch\n logger.info(`PUBLISH_PUSH_SOURCE: Pushing updated source branch | Branch: ${currentBranch} | Remote: origin | Purpose: Push development version`);\n try {\n await runGitWithLock(process.cwd(), async () => {\n await run(`git push origin ${currentBranch}`);\n }, `push ${currentBranch}`);\n logger.info(`PUBLISH_PUSH_SOURCE_SUCCESS: Pushed source branch successfully | Branch: ${currentBranch} | Remote: origin | Status: pushed`);\n } catch (pushError: any) {\n logger.warn(`PUBLISH_PUSH_SOURCE_FAILED: Failed to push source branch | Branch: ${currentBranch} | Error: ${pushError.message} | Impact: Need manual push`);\n logger.warn(`PUBLISH_MANUAL_PUSH_COMMAND: Manual push command | Command: git push origin ${currentBranch}`);\n }\n } else {\n logger.info(`PUBLISH_MERGE_DRY_RUN: Would merge target into source | Mode: dry-run | Target: ${targetBranch} | Source: ${currentBranch} | Strategy: ff-only`);\n logger.info(`PUBLISH_VERSION_DRY_RUN: Would bump version to next development | Mode: dry-run | Action: Version bump`);\n logger.info(`PUBLISH_PUSH_DRY_RUN: Would push source to remote | Mode: dry-run | Branch: ${currentBranch} | Remote: origin`);\n }\n\n logger.info('');\n logger.info(`PUBLISH_COMPLETE: Publish workflow completed successfully | Branch: ${currentBranch} | Status: completed | Version: next-development`);\n};\n"],"names":["scanNpmrcForEnvVars","storage","logger","getLogger","npmrcPath","path","join","process","cwd","envVars","exists","npmrcContent","readFile","envVarMatches","match","varName","replace","includes","push","error","warn","message","verbose","debug","cleanupNpmLinkReferences","isDryRun","getDryRunLogger","packageLockPath","fs","access","packageLockContent","packageLock","safeJsonParse","hasFileReferences","packages","pkgPath","pkgInfo","Object","entries","resolved","startsWith","resolvedPath","dependencies","pkgName","version","versionPath","info","unlink","runWithDryRunSupport","validateEnvironmentVariables","requiredEnvVars","missingEnvVars","envVar","env","length","Error","runPrechecks","runConfig","targetBranch","dryRun","createStorage","run","originalMessage","toString","stdout","trim","effectiveTargetBranch","publish","currentBranch","GitHub","getCurrentBranchName","targetBranchExists","localBranchExists","syncStatus","isBranchInSyncWithRemote","inSync","localSha","remoteSha","substring","workflowConfig","hasWorkflows","hasPullRequestTriggers","workflowCount","triggeredWorkflowNames","workflowName","packageJsonPath","packageJson","packageJsonContents","parsed","validatePackageJson","scripts","prepublishOnly","coreRequiredEnvVars","npmrcEnvVars","allRequiredEnvVars","Set","sortObjectKeys","value","Array","isArray","map","sorted","keys","sort","forEach","key","isReleaseNecessaryComparedToTarget","runSecure","necessary","reason","namesStdout","changedFiles","split","s","filter","Boolean","nonVersionFiles","f","basePkgStdout","headPkgStdout","basePkg","headPkg","_baseVersion","baseWithoutVersion","_headVersion","headWithoutVersion","baseSorted","headSorted","equalExceptVersion","JSON","stringify","currentVersion","targetVersion","handleTargetBranchSyncRecovery","syncResult","safeSyncBranchWithRemote","success","conflictResolutionRequired","execute","remoteExists","then","catch","runGitWithLock","branchDependentVersioning","branches","branchConfig","targetBranchConfig","versionType","type","versionTag","tag","versionIncrement","increment","syncTarget","remoteBranchExists","necessity","console","log","pr","branchName","findOpenPullRequestByHeadRef","html_url","releaseConfig","updateDepsScope","updateDeps","Updates","updatesConfig","updates","scope","interProject","updatePatterns","dependencyUpdatePatterns","patternsArg","packageLockExists","filesToStage","Diff","Commit","skipPreMerge","skipPrePublishMerge","fetchError","mergeBase","targetCommit","mergeSucceeded","mergeError","errorText","stderr","conflictedFiles","conflicts","versionFiles","nonVersionConflicts","file","mergeChangesStatus","packageLockExistsPostMerge","filesToStagePostMerge","newVersion","proposedVersion","finalTargetBranch","branchDependentResult","calculateBranchDependentVersion","targetVersionInput","calculateTargetVersion","targetTagName","tagExists","checkIfTagExists","getNpmPublishedVersion","getTagInfo","npmVersion","name","tagInfo","skipAlreadyPublished","commit","forceRepublish","interactive","confirmVersionInteractively","confirmedTagName","confirmedTagExists","writeFile","packageLockExistsVersionBump","filesToStageVersionBump","release","from","fromMain","agentic","selfReflection","releaseSummary","Release","outputDirectory","DEFAULT_OUTPUT_DIRECTORY","ensureDirectory","releaseNotesPath","getOutputPath","releaseTitlePath","body","title","number","labels","rawCommitTitle","commitTitle","filterContent","stopContext","filtered","prBody","createPullRequest","shouldSkipWait","timeout","checksTimeout","KODRDRIV_DEFAULTS","senditMode","sendit","skipUserConfirmation","waitForPullRequestChecks","mergeMethod","mergePullRequest","hasStashedChanges","statusOutput","syncError","stashError","tagName","validateGitRef","tagWasPushed","pushError","Promise","resolve","setTimeout","milestonesEnabled","noMilestones","releaseNotesContent","releaseTitle","retries","createRelease","closeMilestoneForVersion","isTagNotFoundError","waitForWorkflows","waitForReleaseWorkflows","workflowTimeout","releaseWorkflowsTimeout","workflowNames","releaseWorkflowNames","getWorkflowsTriggeredByRelease","undefined","fastForwardSucceeded","versionCommand","sourceBranchConfig","incrementLevel","versionError"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"publish.js","sources":["../../src/commands/publish.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nimport path from 'path';\nimport * as Commit from './commit';\nimport * as Diff from '../content/diff';\nimport * as Release from './release';\n\nimport { getLogger, getDryRunLogger } from '../logging';\nimport { Config, PullRequest } from '../types';\nimport { run, runWithDryRunSupport, runSecure, validateGitRef, safeJsonParse, validatePackageJson, isBranchInSyncWithRemote, safeSyncBranchWithRemote, localBranchExists, remoteBranchExists } from '@eldrforge/git-tools';\nimport * as GitHub from '@eldrforge/github-tools';\nimport { createStorage, incrementPatchVersion, calculateTargetVersion } from '@eldrforge/shared';\nimport { getOutputPath, checkIfTagExists, confirmVersionInteractively, calculateBranchDependentVersion } from '../util/general';\nimport { DEFAULT_OUTPUT_DIRECTORY, KODRDRIV_DEFAULTS } from '../constants';\nimport fs from 'fs/promises';\nimport { runGitWithLock } from '../util/gitMutex';\nimport { filterContent } from '../util/stopContext';\nimport { runAgenticPublish, formatAgenticPublishResult } from '@eldrforge/ai-service';\n\nconst scanNpmrcForEnvVars = async (storage: any): Promise<string[]> => {\n const logger = getLogger();\n const npmrcPath = path.join(process.cwd(), '.npmrc');\n const envVars: string[] = [];\n\n if (await storage.exists(npmrcPath)) {\n try {\n const npmrcContent = await storage.readFile(npmrcPath, 'utf-8');\n // Match environment variable patterns like ${VAR_NAME} or $VAR_NAME\n const envVarMatches = npmrcContent.match(/\\$\\{([^}]+)\\}|\\$([A-Z_][A-Z0-9_]*)/g);\n\n if (envVarMatches) {\n for (const match of envVarMatches) {\n // Extract variable name from ${VAR_NAME} or $VAR_NAME format\n const varName = match.replace(/\\$\\{|\\}|\\$/g, '');\n if (varName && !envVars.includes(varName)) {\n envVars.push(varName);\n }\n }\n }\n\n } catch (error: any) {\n logger.warn(`NPMRC_READ_FAILED: Unable to read .npmrc configuration file | Path: ${npmrcPath} | Error: ${error.message}`);\n logger.verbose('NPMRC_READ_IMPACT: Environment variable detection for publishing may be affected due to failed .npmrc read');\n }\n } else {\n logger.debug('NPMRC_NOT_FOUND: No .npmrc file present in current directory | Action: Skipping environment variable scan | Path: ' + npmrcPath);\n }\n\n return envVars;\n};\n\n/**\n * Checks if package-lock.json contains file: dependencies (from npm link)\n * and cleans them up if found by removing package-lock.json and regenerating it.\n */\nconst cleanupNpmLinkReferences = async (isDryRun: boolean): Promise<void> => {\n const logger = getDryRunLogger(isDryRun);\n const packageLockPath = path.join(process.cwd(), 'package-lock.json');\n\n try {\n // Check if package-lock.json exists\n try {\n await fs.access(packageLockPath);\n } catch {\n // No package-lock.json, nothing to clean\n logger.verbose('PACKAGE_LOCK_NOT_FOUND: No package-lock.json file exists | Action: Skipping npm link cleanup | Path: ' + packageLockPath);\n return;\n }\n\n // Read and parse package-lock.json\n const packageLockContent = await fs.readFile(packageLockPath, 'utf-8');\n const packageLock = safeJsonParse(packageLockContent, packageLockPath);\n\n // Check for file: dependencies in the lockfile\n let hasFileReferences = false;\n\n // Check in packages (npm v7+)\n if (packageLock.packages) {\n for (const [pkgPath, pkgInfo] of Object.entries(packageLock.packages as Record<string, any>)) {\n if (pkgInfo.resolved && typeof pkgInfo.resolved === 'string' && pkgInfo.resolved.startsWith('file:')) {\n // Check if it's a relative path (from npm link) rather than a workspace path\n const resolvedPath = pkgInfo.resolved.replace('file:', '');\n if (resolvedPath.startsWith('../') || resolvedPath.startsWith('./')) {\n hasFileReferences = true;\n logger.verbose(`NPM_LINK_DETECTED: Found npm link reference in packages section | Package: ${pkgPath} | Resolved: ${pkgInfo.resolved} | Type: relative_file_dependency`);\n break;\n }\n }\n }\n }\n\n // Check in dependencies (npm v6)\n if (!hasFileReferences && packageLock.dependencies) {\n for (const [pkgName, pkgInfo] of Object.entries(packageLock.dependencies as Record<string, any>)) {\n if (pkgInfo.version && typeof pkgInfo.version === 'string' && pkgInfo.version.startsWith('file:')) {\n const versionPath = pkgInfo.version.replace('file:', '');\n if (versionPath.startsWith('../') || versionPath.startsWith('./')) {\n hasFileReferences = true;\n logger.verbose(`NPM_LINK_DETECTED: Found npm link reference in dependencies section | Package: ${pkgName} | Version: ${pkgInfo.version} | Type: relative_file_dependency`);\n break;\n }\n }\n }\n }\n\n if (hasFileReferences) {\n logger.info('NPM_LINK_CLEANUP_REQUIRED: Detected npm link references in package-lock.json | File: package-lock.json | Impact: Must be cleaned before publish');\n logger.info('NPM_LINK_CLEANUP_STARTING: Removing package-lock.json and regenerating clean version | Action: Remove file with relative dependencies');\n\n if (isDryRun) {\n logger.info('DRY_RUN_OPERATION: Would remove package-lock.json and regenerate it | Mode: dry-run | File: package-lock.json');\n } else {\n // Remove package-lock.json\n await fs.unlink(packageLockPath);\n logger.verbose('NPM_LINK_CLEANUP_FILE_REMOVED: Deleted package-lock.json containing npm link references | Path: ' + packageLockPath);\n\n // Regenerate clean package-lock.json\n logger.verbose('NPM_LOCK_REGENERATING: Executing npm install to regenerate package-lock.json from package.json | Command: npm install --package-lock-only --no-audit --no-fund');\n await runWithDryRunSupport('npm install --package-lock-only --no-audit --no-fund', isDryRun);\n logger.info('NPM_LOCK_REGENERATED: Successfully regenerated clean package-lock.json without link references | Path: ' + packageLockPath);\n }\n } else {\n logger.verbose('NPM_LINK_CHECK_CLEAN: No npm link references found in package-lock.json | Status: Ready for publish | File: ' + packageLockPath);\n }\n } catch (error: any) {\n // Log warning but don't fail - let npm update handle any issues\n logger.warn(`NPM_LINK_CHECK_FAILED: Unable to check or clean npm link references | Error: ${error.message} | Impact: Continuing with publish, npm will handle issues`);\n logger.verbose('PUBLISH_PROCESS_CONTINUING: Proceeding with publish workflow despite npm link check failure | Next: Standard npm publish validation');\n }\n};\n\nconst validateEnvironmentVariables = (requiredEnvVars: string[], isDryRun: boolean): void => {\n const logger = getDryRunLogger(isDryRun);\n const missingEnvVars: string[] = [];\n\n for (const envVar of requiredEnvVars) {\n if (!process.env[envVar]) {\n missingEnvVars.push(envVar);\n }\n }\n\n if (missingEnvVars.length > 0) {\n if (isDryRun) {\n logger.warn(`ENV_VARS_MISSING: Required environment variables not set | Variables: ${missingEnvVars.join(', ')} | Mode: dry-run | Impact: Would fail in real publish`);\n } else {\n logger.error(`ENV_VARS_MISSING: Required environment variables not set | Variables: ${missingEnvVars.join(', ')} | Action: Must set before publish | Source: .npmrc configuration`);\n throw new Error(`Missing required environment variables: ${missingEnvVars.join(', ')}. Please set these environment variables before running publish.`);\n }\n }\n};\n\nconst runPrechecks = async (runConfig: Config, targetBranch?: string): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage();\n\n logger.info('PRECHECK_STARTING: Executing publish prechecks | Phase: validation | Target: ' + (targetBranch || 'default'));\n\n // Check if we're in a git repository\n try {\n if (isDryRun) {\n logger.info('PRECHECK_GIT_REPO: Would verify git repository | Mode: dry-run | Command: git rev-parse --git-dir');\n } else {\n await run('git rev-parse --git-dir');\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Not in a git repository or git command failed: ${originalMessage}. Please run this command from within a git repository.`);\n }\n }\n\n // Check for uncommitted changes\n logger.info('PRECHECK_GIT_STATUS: Checking for uncommitted changes | Command: git status --porcelain | Requirement: Clean working directory');\n try {\n if (isDryRun) {\n logger.info('PRECHECK_GIT_STATUS: Would verify clean working directory | Mode: dry-run | Command: git status --porcelain');\n } else {\n const { stdout } = await run('git status --porcelain');\n if (stdout.trim()) {\n throw new Error('Working directory has uncommitted changes. Please commit or stash your changes before running publish.');\n }\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Failed to check git status: ${originalMessage}. Please ensure you are in a valid git repository and try again.`);\n }\n }\n\n // Use the passed target branch or fallback to config/default\n const effectiveTargetBranch = targetBranch || runConfig.publish?.targetBranch || 'main';\n\n // Check that we're not running from the target branch\n logger.info('PRECHECK_BRANCH: Verifying current branch is not target branch | Target: ' + effectiveTargetBranch + ' | Requirement: Must run from feature branch');\n if (isDryRun) {\n logger.info(`PRECHECK_BRANCH: Would verify current branch is not target branch | Mode: dry-run | Target: ${effectiveTargetBranch}`);\n } else {\n const currentBranch = await GitHub.getCurrentBranchName();\n if (currentBranch === effectiveTargetBranch) {\n throw new Error(`Cannot run publish from the target branch '${effectiveTargetBranch}'. Please switch to a different branch before running publish.`);\n }\n }\n\n // Check target branch sync with remote\n logger.info(`PRECHECK_BRANCH_SYNC: Checking target branch sync with remote | Branch: ${effectiveTargetBranch} | Remote: origin | Requirement: Branches must be synchronized`);\n if (isDryRun) {\n logger.info(`PRECHECK_BRANCH_SYNC: Would verify target branch is in sync with remote | Mode: dry-run | Branch: ${effectiveTargetBranch} | Remote: origin`);\n } else {\n // Only check if local target branch exists (it's okay if it doesn't exist locally)\n const targetBranchExists = await localBranchExists(effectiveTargetBranch);\n if (targetBranchExists) {\n const syncStatus = await isBranchInSyncWithRemote(effectiveTargetBranch);\n\n if (!syncStatus.inSync) {\n logger.error(`BRANCH_SYNC_FAILED: Target branch not synchronized with remote | Branch: ${effectiveTargetBranch} | Status: out-of-sync | Impact: Cannot proceed with publish`);\n logger.error('');\n\n if (syncStatus.error) {\n logger.error(`BRANCH_SYNC_ERROR: ${syncStatus.error}`);\n } else if (syncStatus.localSha && syncStatus.remoteSha) {\n logger.error(`BRANCH_SYNC_DIVERGENCE: Local and remote commits differ | Local SHA: ${syncStatus.localSha.substring(0, 8)} | Remote SHA: ${syncStatus.remoteSha.substring(0, 8)}`);\n }\n\n // Check if agentic publish is enabled\n if (runConfig.publish?.agenticPublish) {\n logger.info('');\n logger.info('AGENTIC_PUBLISH_STARTING: Attempting automatic diagnosis and fix | Mode: agentic | Feature: AI-powered recovery');\n\n try {\n const currentBranch = await GitHub.getCurrentBranchName();\n const agenticResult = await runAgenticPublish({\n targetBranch: effectiveTargetBranch,\n sourceBranch: currentBranch,\n issue: 'branch_sync',\n issueDetails: syncStatus.error || `Local SHA: ${syncStatus.localSha?.substring(0, 8)}, Remote SHA: ${syncStatus.remoteSha?.substring(0, 8)}`,\n workingDirectory: process.cwd(),\n maxIterations: runConfig.publish?.agenticPublishMaxIterations || 10,\n storage,\n logger,\n dryRun: runConfig.dryRun,\n });\n\n // Display the formatted result\n const formattedResult = formatAgenticPublishResult(agenticResult);\n logger.info(formattedResult);\n\n if (agenticResult.success) {\n logger.info('AGENTIC_PUBLISH_SUCCESS: Issue resolved automatically | Status: ready-to-retry | Action: Re-running prechecks');\n // Re-run the sync check to verify it was fixed\n const reSyncStatus = await isBranchInSyncWithRemote(effectiveTargetBranch);\n if (reSyncStatus.inSync) {\n logger.info(`BRANCH_SYNC_VERIFIED: Target branch is now synchronized with remote | Branch: ${effectiveTargetBranch} | Status: in-sync`);\n return; // Continue with publish\n } else {\n logger.warn('AGENTIC_PUBLISH_VERIFICATION_FAILED: Branch still not in sync after agentic fix | Status: needs-attention');\n }\n }\n\n if (agenticResult.requiresManualIntervention) {\n throw new Error(`Target branch '${effectiveTargetBranch}' requires manual intervention. Please see the steps above.`);\n } else {\n throw new Error(`Agentic publish could not resolve the issue automatically. Please see the analysis above.`);\n }\n } catch (agenticError: any) {\n logger.warn(`AGENTIC_PUBLISH_FAILED: Agentic recovery failed | Error: ${agenticError.message} | Fallback: Manual steps`);\n // Fall through to manual steps\n }\n }\n\n logger.error('');\n logger.error('RESOLUTION_STEPS: Manual intervention required to sync branches:');\n logger.error(` Step 1: Switch to target branch | Command: git checkout ${effectiveTargetBranch}`);\n logger.error(` Step 2: Pull latest changes | Command: git pull origin ${effectiveTargetBranch}`);\n logger.error(' Step 3: Resolve merge conflicts if present');\n logger.error(' Step 4: Return to feature branch and retry publish');\n logger.error('');\n logger.error(`ALTERNATIVE_OPTION: Automatic sync available | Command: kodrdriv publish --sync-target | Branch: ${effectiveTargetBranch}`);\n logger.error(`ALTERNATIVE_OPTION_AI: AI-powered recovery available | Command: kodrdriv publish --agentic-publish | Branch: ${effectiveTargetBranch}`);\n\n throw new Error(`Target branch '${effectiveTargetBranch}' is not in sync with remote. Please sync the branch before running publish.`);\n } else {\n logger.info(`BRANCH_SYNC_VERIFIED: Target branch is synchronized with remote | Branch: ${effectiveTargetBranch} | Status: in-sync`);\n }\n } else {\n logger.info(`BRANCH_NOT_LOCAL: Target branch does not exist locally | Branch: ${effectiveTargetBranch} | Action: Will be created during publish process`);\n }\n }\n\n // Check GitHub Actions workflow configuration\n logger.info('PRECHECK_WORKFLOW: Checking GitHub Actions workflow configuration | Target: PR automation | Requirement: Workflows should trigger on pull requests');\n if (isDryRun) {\n logger.info('PRECHECK_WORKFLOW: Would check if GitHub Actions workflows are configured for pull requests | Mode: dry-run');\n } else {\n try {\n // TODO: Re-enable when checkWorkflowConfiguration is exported from github-tools\n // const workflowConfig = await GitHub.checkWorkflowConfiguration(effectiveTargetBranch);\n const workflowConfig = {\n hasWorkflows: true,\n hasPullRequestTriggers: true,\n workflowCount: 0,\n triggeredWorkflowNames: [] as string[]\n };\n\n if (!workflowConfig.hasWorkflows) {\n logger.warn('WORKFLOW_NOT_CONFIGURED: No GitHub Actions workflows found in repository | Impact: PR will be created but no automated checks will run | Recommendation: Add workflow file at .github/workflows/ci.yml');\n logger.warn('WORKFLOW_BEHAVIOR: Publish process will proceed without waiting for checks | PR State: Will be created | Check Status: None');\n logger.warn('WORKFLOW_RECOMMENDATION: Consider adding CI workflow to validate PRs automatically | Example: .github/workflows/ci.yml with PR triggers');\n } else if (!workflowConfig.hasPullRequestTriggers) {\n logger.warn(`WORKFLOW_NO_PR_TRIGGER: Found workflows but none trigger on pull requests | Workflow Count: ${workflowConfig.workflowCount} | Target Branch: ${effectiveTargetBranch} | Impact: No checks will run on PR`);\n logger.warn('WORKFLOW_BEHAVIOR: Publish process will create PR without automated checks | PR State: Will be created | Check Status: None');\n logger.warn(`WORKFLOW_RECOMMENDATION: Update workflow triggers to include PR events | Configuration: on.pull_request.branches: [${effectiveTargetBranch}]`);\n } else {\n logger.info(`WORKFLOW_CONFIGURED: Found workflows that will trigger on pull requests | Target Branch: ${effectiveTargetBranch} | Workflow Count: ${workflowConfig.triggeredWorkflowNames.length}`);\n for (const workflowName of workflowConfig.triggeredWorkflowNames) {\n logger.info(`WORKFLOW_ACTIVE: ${workflowName} | Trigger: pull_request | Target: ${effectiveTargetBranch}`);\n }\n }\n } catch (error: any) {\n // Don't fail the precheck if we can't verify workflows\n // The wait logic will handle it later\n logger.debug(`WORKFLOW_CHECK_FAILED: Unable to verify workflow configuration | Error: ${error.message} | Impact: Will proceed with publish | Note: Wait logic will handle checks later`);\n }\n }\n\n // Check if prepublishOnly script exists in package.json\n logger.info('PRECHECK_PREPUBLISH: Checking for prepublishOnly script in package.json | Requirement: Must exist to run pre-flight checks | Expected: clean, lint, build, test');\n const packageJsonPath = path.join(process.cwd(), 'package.json');\n\n if (!await storage.exists(packageJsonPath)) {\n if (!isDryRun) {\n throw new Error('package.json not found in current directory.');\n } else {\n logger.warn('PACKAGE_JSON_NOT_FOUND: No package.json in current directory | Mode: dry-run | Impact: Cannot verify prepublishOnly script | Path: ' + packageJsonPath);\n }\n } else {\n let packageJson;\n try {\n const packageJsonContents = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, packageJsonPath);\n packageJson = validatePackageJson(parsed, packageJsonPath);\n\n } catch (error) {\n if (!isDryRun) {\n throw new Error('Failed to parse package.json. Please ensure it contains valid JSON.');\n } else {\n logger.warn('PACKAGE_JSON_PARSE_FAILED: Unable to parse package.json | Mode: dry-run | Impact: Cannot verify prepublishOnly script | Path: ' + packageJsonPath + ' | Requirement: Valid JSON format');\n }\n }\n\n if (packageJson && !packageJson.scripts?.prepublishOnly) {\n if (!isDryRun) {\n throw new Error('prepublishOnly script is required in package.json but was not found. Please add a prepublishOnly script that runs your pre-flight checks (e.g., clean, lint, build, test).');\n } else {\n logger.warn('PREPUBLISH_SCRIPT_MISSING: No prepublishOnly script found in package.json | Mode: dry-run | Requirement: Script must exist | Expected Tasks: clean, lint, build, test | Path: ' + packageJsonPath);\n }\n }\n }\n\n // Check required environment variables\n logger.verbose('PRECHECK_ENV_VARS: Checking required environment variables | Source: Configuration and .npmrc | Requirement: All required vars must be set');\n const coreRequiredEnvVars = runConfig.publish?.requiredEnvVars || [];\n const npmrcEnvVars = isDryRun ? [] : await scanNpmrcForEnvVars(storage); // Skip .npmrc scan in dry run\n const allRequiredEnvVars = [...new Set([...coreRequiredEnvVars, ...npmrcEnvVars])];\n\n if (allRequiredEnvVars.length > 0) {\n logger.verbose(`ENV_VARS_REQUIRED: Environment variables needed for publish | Variables: ${allRequiredEnvVars.join(', ')} | Count: ${allRequiredEnvVars.length} | Source: config + .npmrc`);\n validateEnvironmentVariables(allRequiredEnvVars, isDryRun);\n } else {\n logger.verbose('ENV_VARS_NONE: No required environment variables specified | Status: No validation needed | Source: config + .npmrc');\n }\n\n logger.info('PRECHECK_COMPLETE: All publish prechecks passed successfully | Status: Ready to proceed | Next: Execute publish workflow');\n};\n\n// Helper: deep-sort object keys for stable comparison\nconst sortObjectKeys = (value: any): any => {\n if (Array.isArray(value)) {\n return value.map(sortObjectKeys);\n }\n if (value && typeof value === 'object') {\n const sorted: any = {};\n Object.keys(value).sort().forEach((key) => {\n sorted[key] = sortObjectKeys(value[key]);\n });\n return sorted;\n }\n return value;\n};\n\n// Determine if there are substantive changes compared to the target branch (beyond just version bump)\nconst isReleaseNecessaryComparedToTarget = async (targetBranch: string, isDryRun: boolean): Promise<{ necessary: boolean; reason: string }> => {\n const logger = getDryRunLogger(isDryRun);\n\n // We compare current HEAD branch to the provided target branch\n const currentBranch = await GitHub.getCurrentBranchName();\n\n // Check if target branch exists before trying to compare\n try {\n // Validate target branch exists and is accessible\n await runSecure('git', ['rev-parse', '--verify', targetBranch]);\n } catch (error: any) {\n // Target branch doesn't exist or isn't accessible\n logger.verbose(`RELEASE_CHECK_NO_TARGET: Target branch does not exist or is not accessible | Branch: ${targetBranch} | Action: Proceeding with publish | Reason: First release to this branch`);\n return { necessary: true, reason: `Target branch '${targetBranch}' does not exist; first release to this branch` };\n }\n\n // If branches are identical, nothing to release\n const { stdout: namesStdout } = await runSecure('git', ['diff', '--name-only', `${targetBranch}..${currentBranch}`]);\n const changedFiles = namesStdout.split('\\n').map(s => s.trim()).filter(Boolean);\n\n if (changedFiles.length === 0) {\n // No definitive signal; proceed with publish rather than skipping\n return { necessary: true, reason: 'No detectable changes via diff; proceeding conservatively' };\n }\n\n // If any files changed other than package.json or package-lock.json, a release is necessary\n const nonVersionFiles = changedFiles.filter(f => f !== 'package.json' && f !== 'package-lock.json');\n if (nonVersionFiles.length > 0) {\n return { necessary: true, reason: `Changed files beyond version bump: ${nonVersionFiles.join(', ')}` };\n }\n\n // Only package.json and/or package-lock.json changed. Verify package.json change is only the version field\n try {\n // Read package.json content from both branches\n const { stdout: basePkgStdout } = await runSecure('git', ['show', `${targetBranch}:package.json`]);\n const { stdout: headPkgStdout } = await runSecure('git', ['show', `${currentBranch}:package.json`]);\n\n const basePkg = validatePackageJson(safeJsonParse(basePkgStdout, `${targetBranch}:package.json`), `${targetBranch}:package.json`);\n const headPkg = validatePackageJson(safeJsonParse(headPkgStdout, `${currentBranch}:package.json`), `${currentBranch}:package.json`);\n\n const { version: _baseVersion, ...baseWithoutVersion } = basePkg;\n const { version: _headVersion, ...headWithoutVersion } = headPkg;\n\n const baseSorted = sortObjectKeys(baseWithoutVersion);\n const headSorted = sortObjectKeys(headWithoutVersion);\n\n const equalExceptVersion = JSON.stringify(baseSorted) === JSON.stringify(headSorted);\n if (equalExceptVersion) {\n const currentVersion = headPkg.version;\n const targetVersion = basePkg.version;\n return {\n necessary: false,\n reason: `No meaningful changes detected:\\n • Current version: ${currentVersion}\\n • Target branch version: ${targetVersion}\\n • Only package.json version field differs\\n\\n To force republish: Add meaningful code changes or use --force (not yet implemented)`\n };\n }\n\n // Other fields changed inside package.json\n return { necessary: true, reason: 'package.json changes beyond version field' };\n } catch (error: any) {\n // Conservative: if we cannot prove it is only a version change, proceed with release\n logger.verbose(`RELEASE_CHECK_COMPARISON_FAILED: Unable to conclusively compare package.json changes | Error: ${error.message} | Action: Proceeding conservatively with publish | Reason: Cannot verify version-only change`);\n return { necessary: true, reason: 'Could not compare package.json safely' };\n }\n};\n\nconst handleTargetBranchSyncRecovery = async (runConfig: Config, targetBranch: string): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n\n logger.info(`BRANCH_SYNC_ATTEMPTING: Initiating sync of target branch with remote | Branch: ${targetBranch} | Remote: origin | Operation: fetch + merge`);\n\n if (isDryRun) {\n logger.info(`BRANCH_SYNC_DRY_RUN: Would attempt to sync branch with remote | Mode: dry-run | Branch: ${targetBranch} | Remote: origin`);\n return;\n }\n\n const syncResult = await safeSyncBranchWithRemote(targetBranch);\n\n if (syncResult.success) {\n logger.info(`BRANCH_SYNC_SUCCESS: Successfully synchronized branch with remote | Branch: ${targetBranch} | Remote: origin | Status: in-sync`);\n logger.info('BRANCH_SYNC_NEXT_STEP: Ready to proceed with publish | Action: Re-run publish command | Branch: ' + targetBranch);\n } else if (syncResult.conflictResolutionRequired) {\n logger.error(`BRANCH_SYNC_CONFLICTS: Sync failed due to merge conflicts | Branch: ${targetBranch} | Status: conflicts-detected | Resolution: Manual intervention required`);\n logger.error('');\n logger.error('CONFLICT_RESOLUTION_STEPS: Manual conflict resolution required:');\n logger.error(` Step 1: Switch to target branch | Command: git checkout ${targetBranch}`);\n logger.error(` Step 2: Pull and resolve conflicts | Command: git pull origin ${targetBranch}`);\n logger.error(' Step 3: Commit resolved changes | Command: git commit');\n logger.error(' Step 4: Return to feature branch and retry | Command: kodrdriv publish');\n logger.error('');\n throw new Error(`Target branch '${targetBranch}' has conflicts that require manual resolution.`);\n } else {\n logger.error(`BRANCH_SYNC_FAILED: Sync operation failed | Branch: ${targetBranch} | Error: ${syncResult.error} | Remote: origin`);\n throw new Error(`Failed to sync target branch: ${syncResult.error}`);\n }\n};\n\nexport const execute = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage();\n\n // Get current branch for branch-dependent targeting\n let currentBranch: string;\n if (isDryRun) {\n currentBranch = 'mock-branch';\n } else {\n currentBranch = await GitHub.getCurrentBranchName();\n\n // Fetch latest remote information to avoid conflicts\n logger.info('GIT_FETCH_STARTING: Fetching latest remote information | Remote: origin | Purpose: Avoid conflicts during publish | Command: git fetch origin');\n try {\n await run('git fetch origin');\n logger.info('GIT_FETCH_SUCCESS: Successfully fetched latest remote information | Remote: origin | Status: up-to-date');\n } catch (error: any) {\n logger.warn(`GIT_FETCH_FAILED: Unable to fetch from remote | Remote: origin | Error: ${error.message} | Impact: May cause conflicts if remote has changes`);\n }\n\n // Sync current branch with remote to avoid conflicts\n logger.info(`CURRENT_BRANCH_SYNC: Synchronizing current branch with remote | Branch: ${currentBranch} | Remote: origin | Purpose: Avoid conflicts during publish`);\n try {\n const remoteExists = await run(`git ls-remote --exit-code --heads origin ${currentBranch}`).then(() => true).catch(() => false);\n\n if (remoteExists) {\n // Use explicit fetch+merge instead of pull to avoid git config conflicts\n await runGitWithLock(process.cwd(), async () => {\n await run(`git fetch origin ${currentBranch}`);\n await run(`git merge origin/${currentBranch} --no-edit`);\n }, `sync ${currentBranch}`);\n logger.info(`CURRENT_BRANCH_SYNCED: Successfully synchronized current branch with remote | Branch: ${currentBranch} | Remote: origin/${currentBranch} | Status: in-sync`);\n } else {\n logger.info(`REMOTE_BRANCH_NOT_FOUND: No remote branch exists | Branch: ${currentBranch} | Remote: origin | Action: Will be created on first push`);\n }\n } catch (error: any) {\n if (error.message && error.message.includes('CONFLICT')) {\n logger.error(`MERGE_CONFLICTS_DETECTED: Conflicts found when syncing current branch with remote | Branch: ${currentBranch} | Remote: origin/${currentBranch} | Status: conflicts-require-resolution`);\n logger.error(`CONFLICT_RESOLUTION_REQUIRED: Manual intervention needed to resolve conflicts and continue:`);\n logger.error(` Step 1: Resolve conflicts in affected files`);\n logger.error(` Step 2: Stage resolved files | Command: git add <resolved-files>`);\n logger.error(` Step 3: Commit resolution | Command: git commit`);\n logger.error(` Step 4: Retry publish | Command: kodrdriv publish`);\n throw new Error(`Merge conflicts detected when syncing ${currentBranch} with remote. Please resolve conflicts manually.`);\n } else {\n logger.warn(`CURRENT_BRANCH_SYNC_FAILED: Unable to sync current branch with remote | Branch: ${currentBranch} | Remote: origin/${currentBranch} | Error: ${error.message} | Impact: May cause issues during publish`);\n }\n }\n }\n\n // Determine target branch and version strategy based on branch configuration\n let targetBranch = runConfig.publish?.targetBranch || 'main';\n let branchDependentVersioning = false;\n\n // Check for branches configuration\n if (runConfig.branches && runConfig.branches[currentBranch]) {\n branchDependentVersioning = true;\n\n const branchConfig = runConfig.branches[currentBranch];\n\n if (branchConfig.targetBranch) {\n targetBranch = branchConfig.targetBranch;\n }\n\n logger.info(`BRANCH_DEPENDENT_TARGETING: Branch-specific configuration active | Source: ${currentBranch} | Target: ${targetBranch} | Feature: Branch-dependent versioning and targeting`);\n logger.info(`BRANCH_CONFIGURATION_SOURCE: Current branch | Branch: ${currentBranch} | Type: source`);\n logger.info(`BRANCH_CONFIGURATION_TARGET: Target branch for publish | Branch: ${targetBranch} | Type: destination`);\n\n // Look at target branch config to show version strategy\n const targetBranchConfig = runConfig.branches[targetBranch];\n if (targetBranchConfig?.version) {\n const versionType = targetBranchConfig.version.type;\n const versionTag = targetBranchConfig.version.tag;\n const versionIncrement = targetBranchConfig.version.increment;\n\n logger.info(`VERSION_STRATEGY: Target branch version configuration | Branch: ${targetBranch} | Type: ${versionType} | Tag: ${versionTag || 'none'} | Increment: ${versionIncrement ? 'enabled' : 'disabled'}`);\n }\n } else {\n logger.debug(`BRANCH_TARGETING_DEFAULT: No branch-specific configuration found | Branch: ${currentBranch} | Action: Using default target | Target: ${targetBranch}`);\n }\n\n // Handle --sync-target flag\n if (runConfig.publish?.syncTarget) {\n await handleTargetBranchSyncRecovery(runConfig, targetBranch);\n return; // Exit after sync operation\n }\n\n // Check if target branch exists and create it if needed\n logger.info(`TARGET_BRANCH_CHECK: Verifying target branch existence | Branch: ${targetBranch} | Action: Create if missing | Source: Current HEAD`);\n if (isDryRun) {\n logger.info(`TARGET_BRANCH_CHECK: Would verify target branch exists and create if needed | Mode: dry-run | Branch: ${targetBranch}`);\n } else {\n const targetBranchExists = await localBranchExists(targetBranch);\n if (!targetBranchExists) {\n // Check if it exists on remote\n const remoteExists = await remoteBranchExists(targetBranch);\n\n if (remoteExists) {\n logger.info(`TARGET_BRANCH_TRACKING: Target branch exists on remote but not locally, tracking origin/${targetBranch} | Branch: ${targetBranch}`);\n try {\n await runGitWithLock(process.cwd(), async () => {\n // Create local branch tracking remote\n await runSecure('git', ['branch', targetBranch, `origin/${targetBranch}`]);\n logger.info(`TARGET_BRANCH_CREATED: Successfully created local tracking branch | Branch: ${targetBranch} | Source: origin/${targetBranch}`);\n }, `track target branch ${targetBranch}`);\n } catch (error: any) {\n throw new Error(`Failed to track target branch '${targetBranch}': ${error.message}`);\n }\n } else {\n logger.info(`TARGET_BRANCH_CREATING: Target branch does not exist locally or on remote, creating from current branch | Branch: ${targetBranch} | Source: HEAD | Remote: origin`);\n try {\n // Wrap git branch and push operations with lock\n await runGitWithLock(process.cwd(), async () => {\n // Create the target branch from the current HEAD\n await runSecure('git', ['branch', targetBranch, 'HEAD']);\n logger.info(`TARGET_BRANCH_CREATED: Successfully created target branch locally | Branch: ${targetBranch} | Source: HEAD`);\n\n // Push the new branch to origin\n await runSecure('git', ['push', 'origin', targetBranch]);\n logger.info(`TARGET_BRANCH_PUSHED: Successfully pushed new target branch to remote | Branch: ${targetBranch} | Remote: origin/${targetBranch}`);\n }, `create and push target branch ${targetBranch}`);\n } catch (error: any) {\n throw new Error(`Failed to create target branch '${targetBranch}': ${error.message}`);\n }\n }\n } else {\n logger.info(`TARGET_BRANCH_EXISTS: Target branch already exists locally | Branch: ${targetBranch} | Status: ready`);\n }\n }\n\n // Run prechecks before starting any work\n await runPrechecks(runConfig, targetBranch);\n\n // Early check: determine if a release is necessary compared to target branch\n logger.info('RELEASE_NECESSITY_CHECK: Evaluating if release is required | Comparison: current branch vs target | Target: ' + targetBranch + ' | Purpose: Avoid unnecessary publishes');\n try {\n const necessity = await isReleaseNecessaryComparedToTarget(targetBranch, isDryRun);\n if (!necessity.necessary) {\n logger.info(`\\nRELEASE_SKIPPED: No meaningful changes detected, skipping publish | Reason: ${necessity.reason} | Target: ${targetBranch}`);\n // Emit a machine-readable marker so tree mode can detect skip and avoid propagating versions\n // CRITICAL: Use console.log to write to stdout (logger.info goes to stderr via winston)\n // eslint-disable-next-line no-console\n console.log('KODRDRIV_PUBLISH_SKIPPED');\n return;\n } else {\n logger.verbose(`RELEASE_PROCEEDING: Meaningful changes detected, continuing with publish | Reason: ${necessity.reason} | Target: ${targetBranch}`);\n }\n } catch (error: any) {\n // On unexpected errors, proceed with publish to avoid false negatives blocking releases\n logger.verbose(`RELEASE_NECESSITY_CHECK_ERROR: Unable to determine release necessity | Error: ${error.message} | Action: Proceeding conservatively with publish | Rationale: Avoid blocking valid releases`);\n }\n\n logger.info('RELEASE_PROCESS_STARTING: Initiating release workflow | Target: ' + targetBranch + ' | Phase: dependency updates and version management');\n\n\n let pr: PullRequest | null = null;\n\n if (isDryRun) {\n logger.info('PR_CHECK: Would check for existing pull request | Mode: dry-run | Action: Skip PR lookup');\n logger.info('PR_ASSUMPTION: Assuming no existing PR found | Mode: dry-run | Purpose: Demo workflow');\n } else {\n const branchName = await GitHub.getCurrentBranchName();\n pr = await GitHub.findOpenPullRequestByHeadRef(branchName);\n }\n\n if (pr) {\n logger.info(`PR_FOUND: Existing pull request detected for current branch | URL: ${pr.html_url} | Status: open`);\n } else {\n logger.info('PR_NOT_FOUND: No open pull request exists for current branch | Action: Starting new release publishing process | Next: Prepare dependencies and version');\n\n // STEP 1: Prepare for release (update dependencies and run prepublish checks) with NO version bump yet\n logger.verbose('RELEASE_PREP_STARTING: Preparing for release | Phase: dependency management | Action: Switch from workspace to remote dependencies | Version Bump: Not yet applied');\n\n // Clean up any npm link references before updating dependencies\n logger.verbose('NPM_LINK_CHECK: Scanning package-lock.json for npm link references | File: package-lock.json | Purpose: Remove development symlinks before publish');\n await cleanupNpmLinkReferences(isDryRun);\n\n // Update inter-project dependencies if --update-deps flag is present\n const updateDepsScope = runConfig.publish?.updateDeps;\n if (updateDepsScope) {\n logger.info(`INTER_PROJECT_DEPS_UPDATE: Updating inter-project dependencies | Scope: ${updateDepsScope} | Type: inter-project | Command: kodrdriv updates`);\n const Updates = await import('./updates');\n const updatesConfig: Config = {\n ...runConfig,\n dryRun: isDryRun,\n updates: {\n scope: updateDepsScope,\n interProject: true\n }\n };\n await Updates.execute(updatesConfig);\n }\n\n logger.verbose('DEPS_UPDATE_REGISTRY: Updating dependencies to latest versions from npm registry | Source: registry | Target: package.json');\n const updatePatterns = runConfig.publish?.dependencyUpdatePatterns;\n if (updatePatterns && updatePatterns.length > 0) {\n logger.verbose(`DEPS_UPDATE_PATTERNS: Updating dependencies matching specified patterns | Patterns: ${updatePatterns.join(', ')} | Count: ${updatePatterns.length} | Command: npm update`);\n const patternsArg = updatePatterns.join(' ');\n await runWithDryRunSupport(`npm update ${patternsArg}`, isDryRun);\n } else {\n logger.verbose('DEPS_UPDATE_ALL: No dependency patterns specified, updating all dependencies | Scope: all | Command: npm update');\n await runWithDryRunSupport('npm update', isDryRun);\n }\n\n logger.info('PREPUBLISH_SCRIPT_RUNNING: Executing prepublishOnly script | Script: prepublishOnly | Purpose: Run pre-flight checks (clean, lint, build, test)');\n await runWithDryRunSupport('npm run prepublishOnly', isDryRun, {}, true); // Use inherited stdio\n\n // STEP 2: Commit dependency updates if any (still no version bump)\n logger.verbose('DEPS_STAGING: Staging dependency updates for commit | Files: package.json + package-lock.json | Command: git add | Note: Version bump not yet applied');\n // Check if package-lock.json exists before trying to stage it\n const packageLockExists = await storage.exists('package-lock.json');\n const filesToStage = packageLockExists ? 'package.json package-lock.json' : 'package.json';\n\n // Wrap git operations with repository lock to prevent .git/index.lock conflicts\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git add ${filesToStage}`, isDryRun);\n }, 'stage dependency updates');\n\n logger.verbose('DEPS_COMMIT_CHECK: Checking for staged dependency updates | Command: git status | Purpose: Determine if commit needed');\n if (isDryRun) {\n logger.verbose('DEPS_COMMIT_DRY_RUN: Would create dependency update commit if changes are staged | Mode: dry-run');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('DEPS_COMMIT_CREATING: Staged dependency changes detected, creating commit | Files: ' + filesToStage + ' | Action: Execute commit command');\n // Commit also needs git lock\n await runGitWithLock(process.cwd(), async () => {\n await Commit.execute(runConfig);\n }, 'commit dependency updates');\n } else {\n logger.verbose('DEPS_COMMIT_SKIPPED: No dependency changes to commit | Files: ' + filesToStage + ' | Action: Skipping commit step');\n }\n }\n\n // STEP 3: Merge target branch into working branch (optional - now skipped by default since post-publish sync keeps branches in sync)\n const skipPreMerge = runConfig.publish?.skipPrePublishMerge !== false; // Default to true (skip)\n\n if (skipPreMerge) {\n logger.verbose(`PRE_MERGE_SKIPPED: Skipping pre-publish merge of target branch | Reason: Post-publish sync handles branch synchronization | Target: ${targetBranch} | Config: skipPrePublishMerge=true`);\n } else {\n logger.info(`PRE_MERGE_STARTING: Merging target branch into current branch | Target: ${targetBranch} | Purpose: Avoid version conflicts | Phase: pre-publish`);\n if (isDryRun) {\n logger.info(`Would merge ${targetBranch} into current branch`);\n } else {\n // Wrap entire merge process with git lock (involves fetch, merge, checkout, add, commit)\n await runGitWithLock(process.cwd(), async () => {\n // Fetch the latest target branch\n try {\n await run(`git fetch origin ${targetBranch}:${targetBranch}`);\n logger.info(`TARGET_BRANCH_FETCHED: Successfully fetched latest target branch | Branch: ${targetBranch} | Remote: origin/${targetBranch} | Purpose: Pre-merge sync`);\n } catch (fetchError: any) {\n logger.warn(`TARGET_BRANCH_FETCH_FAILED: Unable to fetch target branch | Branch: ${targetBranch} | Error: ${fetchError.message} | Impact: Proceeding without merge, PR may have conflicts`);\n logger.warn('MERGE_SKIPPED_NO_FETCH: Continuing without pre-merge | Reason: Target branch fetch failed | Impact: PR may require manual conflict resolution');\n }\n\n // Check if merge is needed (avoid unnecessary merge commits)\n try {\n const { stdout: mergeBase } = await run(`git merge-base HEAD ${targetBranch}`);\n const { stdout: targetCommit } = await run(`git rev-parse ${targetBranch}`);\n\n if (mergeBase.trim() === targetCommit.trim()) {\n logger.info(`MERGE_NOT_NEEDED: Current branch already up-to-date with target | Branch: ${targetBranch} | Status: in-sync | Action: Skipping merge`);\n } else {\n // Try to merge target branch into current branch\n let mergeSucceeded = false;\n try {\n await run(`git merge ${targetBranch} --no-edit -m \"Merge ${targetBranch} to sync before version bump\"`);\n logger.info(`MERGE_SUCCESS: Successfully merged target branch into current branch | Target: ${targetBranch} | Purpose: Sync before version bump`);\n mergeSucceeded = true;\n } catch (mergeError: any) {\n // If merge conflicts occur, check if they're only in version-related files\n const errorText = [mergeError.message || '', mergeError.stdout || '', mergeError.stderr || ''].join(' ');\n if (errorText.includes('CONFLICT')) {\n logger.warn(`MERGE_CONFLICTS_DETECTED: Merge conflicts found, attempting automatic resolution | Target: ${targetBranch} | Strategy: Auto-resolve version files`);\n\n // Get list of conflicted files\n const { stdout: conflictedFiles } = await run('git diff --name-only --diff-filter=U');\n const conflicts = conflictedFiles.trim().split('\\n').filter(Boolean);\n\n logger.verbose(`MERGE_CONFLICTS_LIST: Conflicted files detected | Files: ${conflicts.join(', ')} | Count: ${conflicts.length}`);\n\n // Check if conflicts are only in package.json and package-lock.json\n const versionFiles = ['package.json', 'package-lock.json'];\n const nonVersionConflicts = conflicts.filter(f => !versionFiles.includes(f));\n\n if (nonVersionConflicts.length > 0) {\n logger.error(`MERGE_AUTO_RESOLVE_FAILED: Cannot auto-resolve conflicts in non-version files | Files: ${nonVersionConflicts.join(', ')} | Count: ${nonVersionConflicts.length} | Resolution: Manual intervention required`);\n logger.error('');\n logger.error('CONFLICT_RESOLUTION_REQUIRED: Manual steps to resolve conflicts:');\n logger.error(' Step 1: Resolve conflicts in the files listed above');\n logger.error(' Step 2: Stage resolved files | Command: git add <resolved-files>');\n logger.error(' Step 3: Complete merge commit | Command: git commit');\n logger.error(' Step 4: Resume publish process | Command: kodrdriv publish');\n logger.error('');\n throw new Error(`Merge conflicts in non-version files. Please resolve manually.`);\n }\n\n // Auto-resolve version conflicts by accepting current branch versions\n // (keep our working branch's version, which is likely already updated)\n logger.info(`MERGE_AUTO_RESOLVING: Automatically resolving version conflicts | Strategy: Keep current branch versions | Files: ${versionFiles.join(', ')}`);\n for (const file of conflicts) {\n if (versionFiles.includes(file)) {\n await run(`git checkout --ours ${file}`);\n await run(`git add ${file}`);\n logger.verbose(`MERGE_FILE_RESOLVED: Resolved file using current branch version | File: ${file} | Strategy: checkout --ours`);\n }\n }\n\n // Complete the merge\n await run(`git commit --no-edit -m \"Merge ${targetBranch} to sync before version bump (auto-resolved version conflicts)\"`);\n logger.info(`MERGE_AUTO_RESOLVE_SUCCESS: Successfully auto-resolved version conflicts and completed merge | Target: ${targetBranch} | Files: ${versionFiles.join(', ')}`);\n mergeSucceeded = true;\n } else {\n // Not a conflict error, re-throw\n throw mergeError;\n }\n }\n\n // Only run npm install if merge actually happened\n if (mergeSucceeded) {\n // Run npm install to update package-lock.json based on merged package.json\n logger.info('POST_MERGE_NPM_INSTALL: Running npm install after merge | Purpose: Update package-lock.json based on merged package.json | Command: npm install');\n await run('npm install');\n logger.info('POST_MERGE_NPM_COMPLETE: npm install completed successfully | Status: Dependencies synchronized');\n\n // Commit any changes from npm install (e.g., package-lock.json updates)\n const { stdout: mergeChangesStatus } = await run('git status --porcelain');\n if (mergeChangesStatus.trim()) {\n logger.verbose('POST_MERGE_CHANGES_DETECTED: Changes detected after npm install | Action: Staging for commit | Command: git add');\n // Check if package-lock.json exists before trying to stage it\n const packageLockExistsPostMerge = await storage.exists('package-lock.json');\n const filesToStagePostMerge = packageLockExistsPostMerge ? 'package.json package-lock.json' : 'package.json';\n await run(`git add ${filesToStagePostMerge}`);\n\n if (await Diff.hasStagedChanges()) {\n logger.verbose('POST_MERGE_COMMIT: Committing post-merge changes | Files: ' + filesToStagePostMerge + ' | Purpose: Finalize merge');\n await Commit.execute(runConfig);\n }\n }\n }\n }\n } catch (error: any) {\n // Only catch truly unexpected errors here\n logger.error(`MERGE_UNEXPECTED_ERROR: Unexpected error during merge process | Error: ${error.message} | Target: ${targetBranch} | Action: Aborting publish`);\n throw error;\n }\n }, `merge ${targetBranch} into current branch`);\n }\n }\n\n // STEP 4: Determine and set target version AFTER checks, dependency commit, and target branch merge\n logger.info('Determining target version...');\n let newVersion: string;\n\n if (isDryRun) {\n logger.info('Would determine target version and update package.json');\n newVersion = '1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, 'package.json');\n const packageJson = validatePackageJson(parsed, 'package.json');\n const currentVersion = packageJson.version;\n\n let proposedVersion: string;\n let finalTargetBranch = targetBranch;\n\n if (branchDependentVersioning && runConfig.branches) {\n // Use branch-dependent versioning logic\n const branchDependentResult = await calculateBranchDependentVersion(\n currentVersion,\n currentBranch,\n runConfig.branches,\n targetBranch\n );\n proposedVersion = branchDependentResult.version;\n finalTargetBranch = branchDependentResult.targetBranch;\n\n logger.info(`VERSION_BRANCH_DEPENDENT_CALCULATED: Branch-dependent version calculated | Current: ${currentVersion} | Proposed: ${proposedVersion} | Strategy: branch-dependent`);\n logger.info(`TARGET_BRANCH_FINAL: Final target branch determined | Branch: ${finalTargetBranch} | Source: branch-dependent config`);\n\n // Update targetBranch for the rest of the function\n targetBranch = finalTargetBranch;\n } else {\n // Use existing logic for backward compatibility\n const targetVersionInput = runConfig.publish?.targetVersion || 'patch';\n proposedVersion = calculateTargetVersion(currentVersion, targetVersionInput);\n }\n\n const targetTagName = `v${proposedVersion}`;\n const tagExists = await checkIfTagExists(targetTagName);\n\n // Smart tag conflict handling\n if (tagExists) {\n const { getNpmPublishedVersion, getTagInfo } = await import('../util/general');\n\n logger.warn(`TAG_ALREADY_EXISTS: Tag already exists in repository | Tag: ${targetTagName} | Status: conflict | Action: Check npm registry`);\n\n // Check if this version is published on npm\n const npmVersion = await getNpmPublishedVersion(packageJson.name);\n const tagInfo = await getTagInfo(targetTagName);\n\n if (npmVersion === proposedVersion) {\n // Version is already published on npm\n logger.info(`VERSION_ALREADY_PUBLISHED: Version already published on npm registry | Version: ${proposedVersion} | Status: published | Action: Skipping`);\n logger.info(`PUBLISH_SKIPPED_DUPLICATE: Skipping publish operation | Reason: Package already at target version | Version: ${proposedVersion}`);\n logger.info('');\n logger.info('REPUBLISH_OPTIONS: Options if you need to republish:');\n logger.info(` Option 1: Bump version | Command: npm version patch (or minor/major)`);\n logger.info(` Option 2: Re-run publish | Command: kodrdriv publish`);\n logger.info('');\n\n if (runConfig.publish?.skipAlreadyPublished) {\n logger.info('PUBLISH_SKIPPED_FLAG: Skipping package due to flag | Flag: --skip-already-published | Version: ' + proposedVersion + ' | Status: skipped');\n // Emit skip marker for tree mode detection\n // eslint-disable-next-line no-console\n console.log('KODRDRIV_PUBLISH_SKIPPED');\n return; // Exit without error\n } else {\n throw new Error(`Version ${proposedVersion} already published. Use --skip-already-published to continue.`);\n }\n } else {\n // Tag exists but version not on npm - likely failed previous publish\n logger.warn('');\n logger.warn('PUBLISH_SITUATION_ANALYSIS: Analyzing publish conflict situation | Tag: ' + targetTagName + ' | npm: ' + (npmVersion || 'not published'));\n logger.warn(`PUBLISH_ANALYSIS_TAG_EXISTS: Tag exists locally | Tag: ${targetTagName} | Commit: ${tagInfo?.commit?.substring(0, 8)}`);\n logger.warn(`PUBLISH_ANALYSIS_NPM_STATUS: npm registry status | Version: ${npmVersion || 'not published'} | Status: ${npmVersion ? 'published' : 'missing'}`);\n logger.warn(`PUBLISH_ANALYSIS_CONCLUSION: Previous publish likely failed after tag creation | Reason: Tag exists but not on npm | Resolution: Recovery needed`);\n logger.warn('');\n logger.warn('PUBLISH_RECOVERY_OPTIONS: Recovery options available:');\n logger.warn(' OPTION_1_FORCE: Force republish by deleting tag | Command: kodrdriv publish --force-republish');\n logger.warn(' OPTION_2_BUMP: Skip version and bump | Command: npm version patch && kodrdriv publish');\n logger.warn(' OPTION_3_MANUAL: Manually delete tag:');\n logger.warn(` Command: git tag -d ${targetTagName}`);\n logger.warn(` Command: git push origin :refs/tags/${targetTagName}`);\n logger.warn('');\n\n if (runConfig.publish?.forceRepublish) {\n logger.info('PUBLISH_FORCE_REPUBLISH: Force republish mode enabled | Action: Deleting existing tag | Tag: ' + targetTagName + ' | Purpose: Allow republish');\n\n if (!isDryRun) {\n const { runSecure } = await import('@eldrforge/git-tools');\n\n // Delete local tag\n try {\n await runSecure('git', ['tag', '-d', targetTagName]);\n logger.info(`TAG_DELETED_LOCAL: Deleted local tag | Tag: ${targetTagName} | Status: removed-local`);\n } catch (error: any) {\n logger.debug(`Could not delete local tag: ${error.message}`);\n }\n\n // Delete remote tag\n try {\n await runSecure('git', ['push', 'origin', `:refs/tags/${targetTagName}`]);\n logger.info(`TAG_DELETED_REMOTE: Deleted remote tag | Tag: ${targetTagName} | Remote: origin | Status: removed-remote`);\n } catch (error: any) {\n logger.debug(`Could not delete remote tag: ${error.message}`);\n }\n\n logger.info('PUBLISH_TAG_CLEANUP_COMPLETE: Tag deleted successfully | Status: ready-for-publish | Next: Continue with publish workflow');\n } else {\n logger.info('Would delete tags and continue with publish');\n }\n } else {\n throw new Error(`Tag ${targetTagName} already exists. Use --force-republish to override.`);\n }\n }\n }\n\n if (runConfig.publish?.interactive) {\n newVersion = await confirmVersionInteractively(currentVersion, proposedVersion, runConfig.publish?.targetVersion);\n const confirmedTagName = `v${newVersion}`;\n const confirmedTagExists = await checkIfTagExists(confirmedTagName);\n\n if (confirmedTagExists) {\n const { getNpmPublishedVersion } = await import('../util/general');\n const npmVersion = await getNpmPublishedVersion(packageJson.name);\n\n if (npmVersion === newVersion) {\n throw new Error(`Tag ${confirmedTagName} already exists and version is published on npm. Please choose a different version.`);\n } else if (!runConfig.publish?.forceRepublish) {\n throw new Error(`Tag ${confirmedTagName} already exists. Use --force-republish to override.`);\n }\n // If forceRepublish is set, we'll continue (tag will be deleted later)\n }\n } else {\n newVersion = proposedVersion;\n }\n\n logger.info(`Bumping version from ${currentVersion} to ${newVersion}`);\n packageJson.version = newVersion;\n await storage.writeFile('package.json', JSON.stringify(packageJson, null, 2) + '\\n', 'utf-8');\n logger.info(`Version updated in package.json: ${newVersion}`);\n }\n\n // STEP 5: Commit version bump as a separate commit\n logger.verbose('Staging version bump for commit');\n // Check if package-lock.json exists before trying to stage it\n const packageLockExistsVersionBump = await storage.exists('package-lock.json');\n const filesToStageVersionBump = packageLockExistsVersionBump ? 'package.json package-lock.json' : 'package.json';\n\n // Wrap git operations with lock\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git add ${filesToStageVersionBump}`, isDryRun);\n }, 'stage version bump');\n\n if (isDryRun) {\n logger.verbose('Would create version bump commit');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('Creating version bump commit...');\n await runGitWithLock(process.cwd(), async () => {\n await Commit.execute(runConfig);\n }, 'commit version bump');\n } else {\n logger.verbose('No version changes to commit.');\n }\n }\n\n logger.info('Generating release notes...');\n\n // Use the existing currentBranch variable for tag detection\n logger.debug(`Current branch for release notes: ${currentBranch}`);\n\n // Create a modified config for release notes generation that includes the publish --from, --interactive, and --from-main options\n const releaseConfig = { ...runConfig };\n releaseConfig.release = {\n ...runConfig.release,\n currentBranch: currentBranch, // Pass current branch\n ...(runConfig.publish?.from && { from: runConfig.publish.from }),\n ...(runConfig.publish?.interactive && { interactive: runConfig.publish.interactive }),\n ...(runConfig.publish?.fromMain && { fromMain: runConfig.publish.fromMain })\n };\n if (runConfig.publish?.from) {\n logger.verbose(`Using custom 'from' reference for release notes: ${runConfig.publish.from}`);\n }\n if (runConfig.publish?.interactive) {\n logger.verbose('Interactive mode enabled for release notes generation');\n }\n if (runConfig.publish?.fromMain) {\n logger.verbose('Forcing comparison against main branch for release notes');\n }\n // Log agentic mode settings for debugging\n if (releaseConfig.release?.agentic) {\n logger.verbose('Agentic mode enabled for release notes generation');\n }\n if (releaseConfig.release?.selfReflection) {\n logger.verbose('Self-reflection enabled for release notes generation');\n }\n\n const releaseSummary = await Release.execute(releaseConfig);\n\n if (isDryRun) {\n logger.info('Would write release notes to RELEASE_NOTES.md and RELEASE_TITLE.md in output directory');\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n await storage.ensureDirectory(outputDirectory);\n\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n await storage.writeFile(releaseNotesPath, releaseSummary.body, 'utf-8');\n await storage.writeFile(releaseTitlePath, releaseSummary.title, 'utf-8');\n logger.info(`Release notes and title generated and saved to ${releaseNotesPath} and ${releaseTitlePath}.`);\n }\n\n logger.info('Pushing to origin...');\n // Get current branch name and push explicitly to avoid pushing to wrong remote/branch\n const branchName = await GitHub.getCurrentBranchName();\n\n // Wrap git push with lock\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git push origin ${branchName}`, isDryRun);\n }, `push ${branchName}`);\n\n logger.info('Creating pull request...');\n if (isDryRun) {\n logger.info('Would get commit title and create PR with GitHub API');\n pr = { number: 123, html_url: 'https://github.com/mock/repo/pull/123', labels: [] } as PullRequest;\n } else {\n const { stdout: rawCommitTitle } = await run('git log -1 --pretty=%B');\n\n // Apply stop-context filtering to PR title and body\n const commitTitle = filterContent(rawCommitTitle, runConfig.stopContext).filtered;\n const prBody = filterContent('Automated release PR.', runConfig.stopContext).filtered;\n\n pr = await GitHub.createPullRequest(commitTitle, prBody, branchName, targetBranch);\n if (!pr) {\n throw new Error('Failed to create pull request.');\n }\n logger.info(`Pull request created: ${pr.html_url} (${branchName} → ${targetBranch})`);\n }\n }\n\n logger.info(`Waiting for PR #${pr!.number} checks to complete...`);\n if (!isDryRun) {\n // Check if we already know from prechecks that no workflows will trigger\n let shouldSkipWait = false;\n try {\n // TODO: Re-enable when checkWorkflowConfiguration is exported from github-tools\n // const workflowConfig = await GitHub.checkWorkflowConfiguration(targetBranch);\n const workflowConfig = {\n hasWorkflows: true,\n hasPullRequestTriggers: true,\n workflowCount: 0,\n triggeredWorkflowNames: [] as string[]\n };\n if (!workflowConfig.hasWorkflows || !workflowConfig.hasPullRequestTriggers) {\n logger.info('PUBLISH_CHECK_WAIT_SKIPPED: Skipping check wait | Reason: No workflows configured for PR | Status: no-workflows | Next: Proceed with merge');\n shouldSkipWait = true;\n }\n } catch (error: any) {\n // If we can't verify, proceed with waiting to be safe\n logger.debug(`Could not verify workflow configuration for wait skip: ${error.message}`);\n }\n\n if (!shouldSkipWait) {\n // Configure timeout and user confirmation behavior\n const timeout = runConfig.publish?.checksTimeout || KODRDRIV_DEFAULTS.publish.checksTimeout;\n const senditMode = runConfig.publish?.sendit || false;\n // sendit flag overrides skipUserConfirmation - if sendit is true, skip confirmation\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n await GitHub.waitForPullRequestChecks(pr!.number, {\n timeout,\n skipUserConfirmation\n });\n }\n }\n\n const mergeMethod = runConfig.publish?.mergeMethod || 'squash';\n if (isDryRun) {\n logger.info(`Would merge PR #${pr!.number} using ${mergeMethod} method`);\n } else {\n try {\n await GitHub.mergePullRequest(pr!.number, mergeMethod, false); // Don't delete branch\n } catch (error: any) {\n // Check if this is a merge conflict error\n if (error.message && (\n error.message.includes('not mergeable') ||\n error.message.includes('Pull Request is not mergeable') ||\n error.message.includes('merge conflict')\n )) {\n logger.error(`PR_MERGE_CONFLICTS: Pull request has merge conflicts | PR Number: ${pr!.number} | Status: conflicts | Resolution: Manual intervention required`);\n logger.error('');\n logger.error('PR_CONFLICT_RESOLUTION: Steps to resolve conflicts:');\n logger.error(` Step 1: Visit pull request | URL: ${pr!.html_url}`);\n logger.error(' Step 2: Resolve merge conflicts | Method: GitHub UI or local');\n logger.error(' Step 3: Re-run publish command | Command: kodrdriv publish');\n logger.error('');\n logger.error('PR_AUTO_CONTINUE: Command will auto-detect existing PR | Behavior: Continues from where it left off | No re-creation needed');\n throw new Error(`Merge conflicts detected in PR #${pr!.number}. Please resolve conflicts and re-run the command.`);\n } else {\n // Re-throw other merge errors\n throw error;\n }\n }\n }\n\n // Switch to target branch and pull latest changes\n logger.info(`Checking out target branch: ${targetBranch}...`);\n\n // Check for uncommitted changes and stash them if necessary\n let hasStashedChanges = false;\n if (!isDryRun) {\n const { stdout: statusOutput } = await runSecure('git', ['status', '--porcelain']);\n if (statusOutput.trim()) {\n logger.info('PUBLISH_STASH_SAVING: Stashing uncommitted changes before checkout | Command: git stash push | Purpose: Protect changes during branch switch');\n await runSecure('git', ['stash', 'push', '-m', 'kodrdriv: stash before checkout target branch']);\n hasStashedChanges = true;\n logger.info('PUBLISH_STASH_SUCCESS: Successfully stashed uncommitted changes | Status: saved | Name: kodrdriv stash');\n }\n }\n\n try {\n // Wrap git checkout and pull with lock\n await runGitWithLock(process.cwd(), async () => {\n await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);\n }, `checkout ${targetBranch}`);\n\n // Sync target branch with remote to avoid conflicts during PR creation\n if (!isDryRun) {\n logger.info(`PUBLISH_TARGET_SYNCING: Syncing target branch with remote | Branch: ${targetBranch} | Remote: origin | Purpose: Avoid PR conflicts`);\n try {\n const remoteExists = await run(`git ls-remote --exit-code --heads origin ${targetBranch}`).then(() => true).catch(() => false);\n\n if (remoteExists) {\n await runGitWithLock(process.cwd(), async () => {\n await run(`git fetch origin ${targetBranch}`);\n await run(`git merge origin/${targetBranch} --no-edit`);\n }, `sync ${targetBranch}`);\n logger.info(`PUBLISH_TARGET_SYNCED: Successfully synced target with remote | Branch: ${targetBranch} | Remote: origin | Status: in-sync`);\n } else {\n logger.info(`PUBLISH_TARGET_NO_REMOTE: No remote target branch found | Branch: ${targetBranch} | Remote: origin | Action: Will be created on first push`);\n }\n } catch (syncError: any) {\n if (syncError.message && syncError.message.includes('CONFLICT')) {\n logger.error(`PUBLISH_SYNC_CONFLICTS: Merge conflicts during target sync | Branch: ${targetBranch} | Remote: origin | Status: conflicts-detected`);\n logger.error(`PUBLISH_SYNC_RESOLUTION: Manual conflict resolution steps:`);\n logger.error(` Step 1: Checkout target | Command: git checkout ${targetBranch}`);\n logger.error(` Step 2: Pull and merge | Command: git pull origin ${targetBranch}`);\n logger.error(` Step 3: Resolve conflicts in files`);\n logger.error(` Step 4: Stage resolved files | Command: git add <resolved-files>`);\n logger.error(` Step 5: Complete merge | Command: git commit`);\n logger.error(` Step 6: Return to branch | Command: git checkout ${currentBranch}`);\n logger.error(` Step 7: Resume publish | Command: kodrdriv publish`);\n throw syncError;\n } else {\n logger.warn(`PUBLISH_SYNC_WARNING: Could not sync target with remote | Branch: ${targetBranch} | Remote: origin | Error: ${syncError.message}`);\n // Continue with publish process, but log the warning\n }\n }\n } else {\n logger.info(`Would sync ${targetBranch} with remote to avoid PR conflicts`);\n }\n } catch (error: any) {\n // Check if this is a merge conflict or sync issue\n if (!isDryRun && (error.message.includes('conflict') ||\n error.message.includes('CONFLICT') ||\n error.message.includes('diverged') ||\n error.message.includes('non-fast-forward'))) {\n\n logger.error(`PUBLISH_TARGET_SYNC_FAILED: Failed to sync target branch with remote | Branch: ${targetBranch} | Remote: origin | Impact: Cannot proceed safely`);\n logger.error('');\n logger.error('PUBLISH_SYNC_RECOVERY_OPTIONS: Available recovery options:');\n logger.error(` OPTION_1_AUTO: Attempt automatic resolution | Command: kodrdriv publish --sync-target`);\n logger.error(` OPTION_2_MANUAL: Manually resolve conflicts:`);\n logger.error(` Step 1: Checkout target | Command: git checkout ${targetBranch}`);\n logger.error(` Step 2: Pull from remote | Command: git pull origin ${targetBranch}`);\n logger.error(` Step 3: Resolve conflicts and commit`);\n logger.error(` Step 4: Re-run publish | Command: kodrdriv publish`);\n logger.error('');\n logger.error('PUBLISH_STOPPED_SAFETY: Publish process stopped | Reason: Prevent data loss | Status: safe-to-recover');\n\n throw new Error(`Target branch '${targetBranch}' sync failed. Use recovery options above to resolve.`);\n } else {\n // Re-throw other errors\n throw error;\n }\n }\n\n // Restore stashed changes if we stashed them\n if (hasStashedChanges) {\n logger.info('PUBLISH_STASH_RESTORING: Restoring previously stashed changes | Command: git stash pop | Purpose: Restore working directory state');\n try {\n await runSecure('git', ['stash', 'pop']);\n logger.info('PUBLISH_STASH_RESTORED: Successfully restored stashed changes | Status: restored | Stash: removed');\n } catch (stashError: any) {\n logger.warn(`PUBLISH_STASH_RESTORE_FAILED: Could not restore stashed changes | Error: ${stashError.message} | Impact: Changes still in stash`);\n logger.warn('PUBLISH_STASH_AVAILABLE: Changes available in git stash | Command: git stash list | Purpose: View and restore manually');\n }\n }\n\n // Now create and push the tag on the target branch\n logger.info('Creating release tag...');\n let tagName: string;\n if (isDryRun) {\n logger.info('Would read package.json version and create git tag');\n tagName = 'v1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const { version } = safeJsonParse(packageJsonContents, 'package.json');\n tagName = `v${version}`;\n\n // Check if tag already exists locally\n try {\n // Validate tag name to prevent injection\n if (!validateGitRef(tagName)) {\n throw new Error(`Invalid tag name: ${tagName}`);\n }\n const { stdout } = await runSecure('git', ['tag', '-l', tagName]);\n if (stdout.trim() === tagName) {\n logger.info(`Tag ${tagName} already exists locally, skipping tag creation`);\n } else {\n await runGitWithLock(process.cwd(), async () => {\n await runSecure('git', ['tag', tagName]);\n }, `create tag ${tagName}`);\n logger.info(`Created local tag: ${tagName}`);\n }\n } catch (error) {\n // If git tag -l fails, create the tag anyway\n await runGitWithLock(process.cwd(), async () => {\n await runSecure('git', ['tag', tagName]);\n }, `create tag ${tagName}`);\n logger.info(`Created local tag: ${tagName}`);\n }\n\n // Check if tag exists on remote before pushing\n let tagWasPushed = false;\n try {\n const { stdout } = await runSecure('git', ['ls-remote', 'origin', `refs/tags/${tagName}`]);\n if (stdout.trim()) {\n logger.info(`Tag ${tagName} already exists on remote, skipping push`);\n } else {\n await runGitWithLock(process.cwd(), async () => {\n await runSecure('git', ['push', 'origin', tagName]);\n }, `push tag ${tagName}`);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n }\n } catch (error) {\n // If ls-remote fails, try to push anyway (might be a new remote)\n try {\n await runSecure('git', ['push', 'origin', tagName]);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n } catch (pushError: any) {\n if (pushError.message && pushError.message.includes('already exists')) {\n logger.info(`Tag ${tagName} already exists on remote, continuing...`);\n } else {\n throw pushError;\n }\n }\n }\n\n // If we just pushed a new tag, wait for GitHub to process it\n if (tagWasPushed) {\n logger.verbose('Waiting for GitHub to process the pushed tag...');\n await new Promise(resolve => setTimeout(resolve, 5000)); // 5 second delay\n }\n }\n\n logger.info('Creating GitHub release...');\n if (isDryRun) {\n logger.info('Would read package.json version and create GitHub release with retry logic');\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('Would close milestone for released version');\n } else {\n logger.info('Would skip milestone closure (--no-milestones)');\n }\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n const releaseNotesContent = await storage.readFile(releaseNotesPath, 'utf-8');\n const releaseTitle = await storage.readFile(releaseTitlePath, 'utf-8');\n\n // Create release with retry logic to handle GitHub tag processing delays\n let retries = 3;\n while (retries > 0) {\n try {\n await GitHub.createRelease(tagName, releaseTitle, releaseNotesContent);\n logger.info(`GitHub release created successfully for tag: ${tagName}`);\n\n // Close milestone for this version if enabled\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('PUBLISH_MILESTONE_CLOSING: Closing milestone for released version | Action: Close GitHub milestone | Purpose: Mark release complete');\n const version = tagName.replace(/^v/, ''); // Remove 'v' prefix if present\n await GitHub.closeMilestoneForVersion(version);\n } else {\n logger.debug('Milestone integration disabled via --no-milestones');\n }\n\n break; // Success - exit retry loop\n } catch (error: any) {\n // Check if this is a tag-not-found error that we can retry\n const isTagNotFoundError = error.message && (\n error.message.includes('not found') ||\n error.message.includes('does not exist') ||\n error.message.includes('Reference does not exist')\n );\n\n if (isTagNotFoundError && retries > 1) {\n logger.verbose(`Tag ${tagName} not yet available on GitHub, retrying in 3 seconds... (${retries - 1} retries left)`);\n await new Promise(resolve => setTimeout(resolve, 3000));\n retries--;\n } else if (isTagNotFoundError) {\n // Tag not found error and we're out of retries\n throw new Error(`Tag ${tagName} was not found on GitHub after ${3 - retries + 1} attempts. This may indicate a problem with tag creation or GitHub synchronization.`);\n } else {\n // Not a tag-not-found error - re-throw the original error\n throw error;\n }\n }\n }\n }\n\n // Wait for release workflows to complete (if enabled)\n const waitForWorkflows = runConfig.publish?.waitForReleaseWorkflows !== false; // default to true\n if (waitForWorkflows) {\n logger.info('Waiting for release workflows...');\n if (isDryRun) {\n logger.info('Would monitor GitHub Actions workflows triggered by release');\n } else {\n const workflowTimeout = runConfig.publish?.releaseWorkflowsTimeout || KODRDRIV_DEFAULTS.publish.releaseWorkflowsTimeout;\n const senditMode = runConfig.publish?.sendit || false;\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n // Get workflow names - either from config or auto-detect\n let workflowNames = runConfig.publish?.releaseWorkflowNames;\n\n if (!workflowNames || workflowNames.length === 0) {\n logger.info('No specific workflow names configured, auto-detecting workflows triggered by release events...');\n try {\n workflowNames = await GitHub.getWorkflowsTriggeredByRelease();\n if (workflowNames.length === 0) {\n logger.info('No workflows found that are triggered by release events.');\n } else {\n logger.info(`Auto-detected release workflows: ${workflowNames.join(', ')}`);\n }\n } catch (error: any) {\n logger.warn(`Failed to auto-detect release workflows: ${error.message}`);\n workflowNames = undefined; // Fall back to monitoring all workflows\n }\n }\n\n await GitHub.waitForReleaseWorkflows(tagName, {\n timeout: workflowTimeout,\n workflowNames,\n skipUserConfirmation\n });\n }\n } else {\n logger.verbose('Skipping waiting for release workflows (disabled in config).');\n }\n\n // Switch back to source branch and sync with target\n logger.info('');\n logger.info(`PUBLISH_POST_SYNC: Syncing source branch with target after publish | Purpose: Keep branches synchronized | Strategy: Reset and force push`);\n await runWithDryRunSupport(`git checkout ${currentBranch}`, isDryRun);\n\n if (!isDryRun) {\n // Sync target into source\n // Note: With squash merging, fast-forward will fail because commit histories diverge\n if (mergeMethod === 'squash') {\n // For squash merges, reset to target branch to avoid conflicts\n // The squash merge created a single commit on target that represents all source commits\n logger.info(`Resetting ${currentBranch} to ${targetBranch} (squash merge)...`);\n await run(`git reset --hard ${targetBranch}`);\n logger.info(`PUBLISH_BRANCH_RESET: Reset source branch to target | Source: ${currentBranch} | Target: ${targetBranch} | Status: synchronized`);\n\n // After squash merge and reset, we need to force push\n // This is safe because we just merged to main and are syncing working branch\n logger.info(`PUBLISH_FORCE_PUSHING: Force pushing synchronized branch | Branch: ${currentBranch} | Remote: origin | Purpose: Complete post-publish sync`);\n\n try {\n // Verify that remote working branch is ancestor of main (safety check)\n try {\n await run(`git fetch origin ${currentBranch}`);\n await run(`git merge-base --is-ancestor origin/${currentBranch} ${targetBranch}`);\n logger.verbose(`✓ Safety check passed: origin/${currentBranch} is ancestor of ${targetBranch}`);\n } catch {\n // Remote branch might not exist yet, or already in sync - both OK\n logger.verbose(`Remote ${currentBranch} does not exist or is already synced`);\n }\n\n // Use --force-with-lease for safer force push\n await run(`git push --force-with-lease origin ${currentBranch}`);\n logger.info(`PUBLISH_FORCE_PUSH_SUCCESS: Successfully force pushed to remote | Branch: ${currentBranch} | Remote: origin | Status: synchronized`);\n } catch (pushError: any) {\n // If force push fails, provide helpful message\n logger.warn(`PUBLISH_FORCE_PUSH_FAILED: Could not force push branch | Branch: ${currentBranch} | Remote: origin | Error: ${pushError.message}`);\n logger.warn(`PUBLISH_MANUAL_PUSH_NEEDED: Manual force push required | Action: Push manually`);\n logger.warn(`PUBLISH_MANUAL_PUSH_COMMAND: Force push command | Command: git push --force-with-lease origin ${currentBranch}`);\n }\n } else {\n // For merge/rebase methods, try to merge target back into source\n logger.info(`PUBLISH_MERGE_TARGET_BACK: Merging target back into source | Target: ${targetBranch} | Source: ${currentBranch} | Purpose: Sync branches after publish`);\n\n // Try fast-forward first (works with merge/rebase methods)\n // Use runSecure to avoid error output for expected failure\n let fastForwardSucceeded = false;\n try {\n await runSecure('git', ['merge', targetBranch, '--ff-only']);\n fastForwardSucceeded = true;\n logger.info(`PUBLISH_MERGE_FF_SUCCESS: Fast-forward merged target into source | Target: ${targetBranch} | Source: ${currentBranch} | Status: merged`);\n } catch {\n logger.verbose(`Fast-forward merge not possible, performing regular merge...`);\n }\n\n if (!fastForwardSucceeded) {\n await run(`git merge ${targetBranch} --no-edit`);\n logger.info(`PUBLISH_MERGE_SUCCESS: Merged target into source | Target: ${targetBranch} | Source: ${currentBranch} | Status: merged`);\n }\n }\n\n // Determine version bump based on branch configuration\n let versionCommand = 'prepatch'; // Default\n let versionTag = 'dev'; // Default\n\n if (branchDependentVersioning && runConfig.branches) {\n const sourceBranchConfig = runConfig.branches[currentBranch];\n if (sourceBranchConfig?.version) {\n // Use configured version strategy for source branch\n if (sourceBranchConfig.version.incrementLevel) {\n versionCommand = `pre${sourceBranchConfig.version.incrementLevel}`;\n }\n if (sourceBranchConfig.version.tag) {\n versionTag = sourceBranchConfig.version.tag;\n }\n }\n }\n\n // Bump to next development version\n logger.info(`PUBLISH_DEV_VERSION_BUMPING: Bumping to next development version | Command: ${versionCommand} | Tag: ${versionTag} | Purpose: Prepare for next cycle`);\n try {\n const { stdout: newVersion } = await run(`npm version ${versionCommand} --preid=${versionTag}`);\n logger.info(`PUBLISH_DEV_VERSION_BUMPED: Version bumped successfully | New Version: ${newVersion.trim()} | Type: development | Status: completed`);\n } catch (versionError: any) {\n logger.warn(`PUBLISH_DEV_VERSION_BUMP_FAILED: Failed to bump version | Error: ${versionError.message} | Impact: Version not updated`);\n logger.warn('PUBLISH_MANUAL_VERSION_BUMP: Manual version bump may be needed | Action: Bump manually for next cycle | Command: npm version');\n }\n\n // Push updated source branch\n logger.info(`PUBLISH_PUSH_SOURCE: Pushing updated source branch | Branch: ${currentBranch} | Remote: origin | Purpose: Push development version`);\n try {\n await runGitWithLock(process.cwd(), async () => {\n await run(`git push origin ${currentBranch}`);\n }, `push ${currentBranch}`);\n logger.info(`PUBLISH_PUSH_SOURCE_SUCCESS: Pushed source branch successfully | Branch: ${currentBranch} | Remote: origin | Status: pushed`);\n } catch (pushError: any) {\n logger.warn(`PUBLISH_PUSH_SOURCE_FAILED: Failed to push source branch | Branch: ${currentBranch} | Error: ${pushError.message} | Impact: Need manual push`);\n logger.warn(`PUBLISH_MANUAL_PUSH_COMMAND: Manual push command | Command: git push origin ${currentBranch}`);\n }\n } else {\n logger.info(`PUBLISH_MERGE_DRY_RUN: Would merge target into source | Mode: dry-run | Target: ${targetBranch} | Source: ${currentBranch} | Strategy: ff-only`);\n logger.info(`PUBLISH_VERSION_DRY_RUN: Would bump version to next development | Mode: dry-run | Action: Version bump`);\n logger.info(`PUBLISH_PUSH_DRY_RUN: Would push source to remote | Mode: dry-run | Branch: ${currentBranch} | Remote: origin`);\n }\n\n logger.info('');\n logger.info(`PUBLISH_COMPLETE: Publish workflow completed successfully | Branch: ${currentBranch} | Status: completed | Version: next-development`);\n};\n"],"names":["scanNpmrcForEnvVars","storage","logger","getLogger","npmrcPath","path","join","process","cwd","envVars","exists","npmrcContent","readFile","envVarMatches","match","varName","replace","includes","push","error","warn","message","verbose","debug","cleanupNpmLinkReferences","isDryRun","getDryRunLogger","packageLockPath","fs","access","packageLockContent","packageLock","safeJsonParse","hasFileReferences","packages","pkgPath","pkgInfo","Object","entries","resolved","startsWith","resolvedPath","dependencies","pkgName","version","versionPath","info","unlink","runWithDryRunSupport","validateEnvironmentVariables","requiredEnvVars","missingEnvVars","envVar","env","length","Error","runPrechecks","runConfig","targetBranch","dryRun","createStorage","run","originalMessage","toString","stdout","trim","effectiveTargetBranch","publish","currentBranch","GitHub","getCurrentBranchName","targetBranchExists","localBranchExists","syncStatus","isBranchInSyncWithRemote","inSync","localSha","remoteSha","substring","agenticPublish","agenticResult","runAgenticPublish","sourceBranch","issue","issueDetails","workingDirectory","maxIterations","agenticPublishMaxIterations","formattedResult","formatAgenticPublishResult","success","reSyncStatus","requiresManualIntervention","agenticError","workflowConfig","hasWorkflows","hasPullRequestTriggers","workflowCount","triggeredWorkflowNames","workflowName","packageJsonPath","packageJson","packageJsonContents","parsed","validatePackageJson","scripts","prepublishOnly","coreRequiredEnvVars","npmrcEnvVars","allRequiredEnvVars","Set","sortObjectKeys","value","Array","isArray","map","sorted","keys","sort","forEach","key","isReleaseNecessaryComparedToTarget","runSecure","necessary","reason","namesStdout","changedFiles","split","s","filter","Boolean","nonVersionFiles","f","basePkgStdout","headPkgStdout","basePkg","headPkg","_baseVersion","baseWithoutVersion","_headVersion","headWithoutVersion","baseSorted","headSorted","equalExceptVersion","JSON","stringify","currentVersion","targetVersion","handleTargetBranchSyncRecovery","syncResult","safeSyncBranchWithRemote","conflictResolutionRequired","execute","remoteExists","then","catch","runGitWithLock","branchDependentVersioning","branches","branchConfig","targetBranchConfig","versionType","type","versionTag","tag","versionIncrement","increment","syncTarget","remoteBranchExists","necessity","console","log","pr","branchName","findOpenPullRequestByHeadRef","html_url","releaseConfig","updateDepsScope","updateDeps","Updates","updatesConfig","updates","scope","interProject","updatePatterns","dependencyUpdatePatterns","patternsArg","packageLockExists","filesToStage","Diff","Commit","skipPreMerge","skipPrePublishMerge","fetchError","mergeBase","targetCommit","mergeSucceeded","mergeError","errorText","stderr","conflictedFiles","conflicts","versionFiles","nonVersionConflicts","file","mergeChangesStatus","packageLockExistsPostMerge","filesToStagePostMerge","newVersion","proposedVersion","finalTargetBranch","branchDependentResult","calculateBranchDependentVersion","targetVersionInput","calculateTargetVersion","targetTagName","tagExists","checkIfTagExists","getNpmPublishedVersion","getTagInfo","npmVersion","name","tagInfo","skipAlreadyPublished","commit","forceRepublish","interactive","confirmVersionInteractively","confirmedTagName","confirmedTagExists","writeFile","packageLockExistsVersionBump","filesToStageVersionBump","release","from","fromMain","agentic","selfReflection","releaseSummary","Release","outputDirectory","DEFAULT_OUTPUT_DIRECTORY","ensureDirectory","releaseNotesPath","getOutputPath","releaseTitlePath","body","title","number","labels","rawCommitTitle","commitTitle","filterContent","stopContext","filtered","prBody","createPullRequest","shouldSkipWait","timeout","checksTimeout","KODRDRIV_DEFAULTS","senditMode","sendit","skipUserConfirmation","waitForPullRequestChecks","mergeMethod","mergePullRequest","hasStashedChanges","statusOutput","syncError","stashError","tagName","validateGitRef","tagWasPushed","pushError","Promise","resolve","setTimeout","milestonesEnabled","noMilestones","releaseNotesContent","releaseTitle","retries","createRelease","closeMilestoneForVersion","isTagNotFoundError","waitForWorkflows","waitForReleaseWorkflows","workflowTimeout","releaseWorkflowsTimeout","workflowNames","releaseWorkflowNames","getWorkflowsTriggeredByRelease","undefined","fastForwardSucceeded","versionCommand","sourceBranchConfig","incrementLevel","versionError"],"mappings":"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"}
|