refactor(shared): derive requirements from metadata

This commit is contained in:
Peter Steinberger
2026-02-14 14:40:59 +00:00
parent 7bd073340a
commit 270779b2cd
4 changed files with 76 additions and 44 deletions

View File

@@ -12,6 +12,11 @@ export type RequirementConfigCheck = {
satisfied: boolean;
};
export type RequirementsMetadata = {
requires?: Partial<Pick<Requirements, "bins" | "anyBins" | "env" | "config">>;
os?: string[];
};
export function resolveMissingBins(params: {
required: string[];
hasLocalBin: (bin: string) => boolean;
@@ -147,3 +152,43 @@ export function evaluateRequirements(params: {
return { missing, eligible, configChecks };
}
export function evaluateRequirementsFromMetadata(params: {
always: boolean;
metadata?: RequirementsMetadata;
hasLocalBin: (bin: string) => boolean;
hasRemoteBin?: (bin: string) => boolean;
hasRemoteAnyBin?: (bins: string[]) => boolean;
localPlatform: string;
remotePlatforms?: string[];
isEnvSatisfied: (envName: string) => boolean;
resolveConfigValue: (pathStr: string) => unknown;
isConfigSatisfied: (pathStr: string) => boolean;
}): {
required: Requirements;
missing: Requirements;
eligible: boolean;
configChecks: RequirementConfigCheck[];
} {
const required: Requirements = {
bins: params.metadata?.requires?.bins ?? [],
anyBins: params.metadata?.requires?.anyBins ?? [],
env: params.metadata?.requires?.env ?? [],
config: params.metadata?.requires?.config ?? [],
os: params.metadata?.os ?? [],
};
const result = evaluateRequirements({
always: params.always,
required,
hasLocalBin: params.hasLocalBin,
hasRemoteBin: params.hasRemoteBin,
hasRemoteAnyBin: params.hasRemoteAnyBin,
localPlatform: params.localPlatform,
remotePlatforms: params.remotePlatforms,
isEnvSatisfied: params.isEnvSatisfied,
resolveConfigValue: params.resolveConfigValue,
isConfigSatisfied: params.isConfigSatisfied,
});
return { required, ...result };
}