1import { PackageManagerOptions } from '../PackageManager';
2import { BunPackageManager } from '../node/BunPackageManager';
3import { NpmPackageManager } from '../node/NpmPackageManager';
4import { PnpmPackageManager } from '../node/PnpmPackageManager';
5import { YarnPackageManager } from '../node/YarnPackageManager';
6export type NodePackageManager = NpmPackageManager | PnpmPackageManager | YarnPackageManager | BunPackageManager;
7export type NodePackageManagerForProject = PackageManagerOptions & Partial<Record<NodePackageManager['name'], boolean>>;
8/** The order of the package managers to use when resolving automatically */
9export declare const RESOLUTION_ORDER: NodePackageManager['name'][];
10/**
11 * Resolve the workspace root for a project, if its part of a monorepo.
12 * Optionally, provide a specific packager to only resolve that one specifically.
13 */
14export declare function findWorkspaceRoot(projectRoot: string, preferredManager?: NodePackageManager['name']): string | null;
15/**
16 * Resolve the used node package manager for a project by checking the lockfile.
17 * This also tries to resolve the workspace root, if its part of a monorepo.
18 * Optionally, provide a preferred packager to only resolve that one specifically.
19 */
20export declare function resolvePackageManager(projectRoot: string, preferredManager?: NodePackageManager['name']): NodePackageManager['name'] | null;
21/**
22 * This creates a Node package manager from the provided options.
23 * If these options are not provided, it will infer the package manager from lockfiles.
24 * When no package manager is found, it falls back to npm.
25 */
26export declare function createForProject(projectRoot: string, options?: NodePackageManagerForProject): NodePackageManager;
27