Merge branch 'actions:main' into main

This commit is contained in:
GolanTrevize10 2025-08-14 10:32:34 +02:00 committed by GitHub
commit 3d5817b330
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
31 changed files with 3565 additions and 430 deletions

View file

@ -325,14 +325,54 @@ export function getVersionInputFromToolVersions(versionFile: string): string[] {
return [];
}
}
/**
* Python version extracted from a plain, .tool-versions or TOML file.
* Python version extracted from the Pipfile file.
*/
export function getVersionInputFromPipfileFile(versionFile: string): string[] {
core.debug(`Trying to resolve version from ${versionFile}`);
if (!fs.existsSync(versionFile)) {
core.warning(`File ${versionFile} does not exist.`);
return [];
}
let pipfileFile = fs.readFileSync(versionFile, 'utf8');
// Normalize the line endings in the pipfileFile
pipfileFile = pipfileFile.replace(/\r\n/g, '\n');
const pipfileConfig = toml.parse(pipfileFile);
const keys = ['requires'];
if (!('requires' in pipfileConfig)) {
core.warning(`No Python version found in ${versionFile}`);
return [];
}
if ('python_full_version' in (pipfileConfig['requires'] as toml.JsonMap)) {
// specifies a full python version
keys.push('python_full_version');
} else {
keys.push('python_version');
}
const versions = [];
const version = extractValue(pipfileConfig, keys);
if (version !== undefined) {
versions.push(version);
}
core.info(`Extracted ${versions} from ${versionFile}`);
return versions;
}
/**
* Python version extracted from a plain, .tool-versions, Pipfile or TOML file.
*/
export function getVersionInputFromFile(versionFile: string): string[] {
if (versionFile.endsWith('.toml')) {
return getVersionInputFromTomlFile(versionFile);
} else if (versionFile.match('.tool-versions')) {
return getVersionInputFromToolVersions(versionFile);
} else if (versionFile.match('Pipfile')) {
return getVersionInputFromPipfileFile(versionFile);
} else {
return getVersionsInputFromPlainFile(versionFile);
}