diff --git a/dist/index.js b/dist/index.js index 89e776f..357dc2c 100644 --- a/dist/index.js +++ b/dist/index.js @@ -11496,7 +11496,7 @@ function getRustTarget(args) { } return ((_c = TARGET_ALIASES[process.platform]) === null || _c === void 0 ? void 0 : _c[target]) || target; } -function getManifestDir(args) { +function getWorkingDirectory() { const workspace = process.env.GITHUB_WORKSPACE; let workdir = core.getInput('working-directory'); if (workdir.length > 0) { @@ -11505,6 +11505,10 @@ function getManifestDir(args) { else { workdir = workspace; } + return workdir; +} +function getManifestDir(args) { + const workdir = getWorkingDirectory(); const manifestPath = getCliValue(args, '--manifest-path') || getCliValue(args, '-m'); return manifestPath ? path.dirname(path.join(workdir, manifestPath)) : workdir; } @@ -11518,21 +11522,44 @@ async function getRustToolchain(args) { if (rustToolchain.length > 0) { return rustToolchain; } + const root = process.env.GITHUB_WORKSPACE; const manifestDir = getManifestDir(args); - const rustToolchainToml = path.join(manifestDir, 'rust-toolchain.toml'); - if ((0, fs_1.existsSync)(rustToolchainToml)) { - const content = await fs_1.promises.readFile(rustToolchainToml); - rustToolchain = parseRustToolchain(content.toString()); - core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain.toml `); - } - else if ((0, fs_1.existsSync)(path.join(manifestDir, 'rust-toolchain'))) { - rustToolchain = (await fs_1.promises.readFile(path.join(manifestDir, 'rust-toolchain'))) - .toString() - .trim(); - if (rustToolchain.includes('[toolchain]')) { - rustToolchain = parseRustToolchain(rustToolchain); + let currentDir = manifestDir; + while (true) { + const relative = path.relative(root, currentDir); + if (relative && !relative.startsWith('..') && !path.isAbsolute(relative)) { + const toolchainToml = path.join(currentDir, 'rust-toolchain.toml'); + const toolchain = path.join(currentDir, 'rust-toolchain'); + if ((0, fs_1.existsSync)(toolchainToml)) { + const content = await fs_1.promises.readFile(toolchainToml); + rustToolchain = parseRustToolchain(content.toString()); + core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain.toml `); + break; + } + else { + core.debug(`${toolchainToml} doesn't exist`); + } + if ((0, fs_1.existsSync)(toolchain)) { + rustToolchain = (await fs_1.promises.readFile(toolchain)).toString().trim(); + if (rustToolchain.includes('[toolchain]')) { + rustToolchain = parseRustToolchain(rustToolchain); + } + core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain `); + break; + } + else { + core.debug(`${toolchain} doesn't exist`); + } } - core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain `); + else { + core.debug(`No rust-toolchain.toml or rust-toolchain found inside ${root}`); + break; + } + if (currentDir === root) { + core.debug(`Give up finding rust-toolchain.toml or rust-toolchain in ${root}`); + break; + } + currentDir = path.dirname(currentDir); } return rustToolchain; } @@ -11744,10 +11771,11 @@ async function dockerBuild(container, maturinRelease, args) { 'echo "::group::Install Rust"', `which rustup > /dev/null || curl --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --profile minimal --default-toolchain ${rustToolchain}`, 'export PATH="$HOME/.cargo/bin:$PATH"', + `echo "Install Rust toolchain ${rustToolchain}"`, `rustup override set ${rustToolchain}`, `rustup component add llvm-tools-preview || true`, 'echo "::endgroup::"', - 'export PATH="$PATH:/opt/python/cp37-cp37m/bin:/opt/python/cp38-cp38/bin:/opt/python/cp39-cp39/bin:/opt/python/cp310-cp310/bin:/opt/python/cp311-cp311/bin"', + 'export PATH="$PATH:/opt/python/cp37-cp37m/bin:/opt/python/cp38-cp38/bin:/opt/python/cp39-cp39/bin:/opt/python/cp310-cp310/bin:/opt/python/cp311-cp311/bin:/opt/python/cp312-cp312/bin"', 'echo "::group::Install maturin"', `curl -L ${url} | tar -xz -C /usr/local/bin`, 'maturin --version || true', @@ -11814,13 +11842,7 @@ async function dockerBuild(container, maturinRelease, args) { dockerEnvs.push(env); } } - let workdir = core.getInput('working-directory'); - if (workdir.length > 0) { - workdir = path.join(workspace, workdir); - } - else { - workdir = workspace; - } + const workdir = getWorkingDirectory(); const dockerVolumes = []; const ssh_auth_sock = process.env.SSH_AUTH_SOCK; if (ssh_auth_sock) { @@ -11927,11 +11949,12 @@ async function hostBuild(maturinRelease, args) { const target = getRustTarget(args); const rustToolchain = await getRustToolchain(args); const rustupComponents = core.getInput('rustup-components'); - const workdir = core.getInput('working-directory') || process.cwd(); + const workdir = getWorkingDirectory(); const sccache = core.getBooleanInput('sccache'); const isUniversal2 = args.includes('--universal2') || target === 'universal2-apple-darwin'; core.startGroup('Install Rust target'); if (rustToolchain.length > 0) { + core.info(`Installing Rust toolchain ${rustToolchain}`); await exec.exec('rustup', ['override', 'set', rustToolchain]); await exec.exec('rustup', ['component', 'add', 'llvm-tools-preview'], { ignoreReturnCode: true diff --git a/src/index.ts b/src/index.ts index 2e3dac6..e6a7b4d 100644 --- a/src/index.ts +++ b/src/index.ts @@ -175,7 +175,7 @@ function getRustTarget(args: string[]): string { return TARGET_ALIASES[process.platform]?.[target] || target } -function getManifestDir(args: string[]): string { +function getWorkingDirectory(): string { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const workspace = process.env.GITHUB_WORKSPACE! let workdir = core.getInput('working-directory') @@ -184,6 +184,11 @@ function getManifestDir(args: string[]): string { } else { workdir = workspace } + return workdir +} + +function getManifestDir(args: string[]): string { + const workdir = getWorkingDirectory() const manifestPath = getCliValue(args, '--manifest-path') || getCliValue(args, '-m') return manifestPath ? path.dirname(path.join(workdir, manifestPath)) : workdir @@ -200,22 +205,49 @@ async function getRustToolchain(args: string[]): Promise { if (rustToolchain.length > 0) { return rustToolchain } + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + const root = process.env.GITHUB_WORKSPACE! const manifestDir = getManifestDir(args) - const rustToolchainToml = path.join(manifestDir, 'rust-toolchain.toml') - if (existsSync(rustToolchainToml)) { - const content = await fs.readFile(rustToolchainToml) - rustToolchain = parseRustToolchain(content.toString()) - core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain.toml `) - } else if (existsSync(path.join(manifestDir, 'rust-toolchain'))) { - rustToolchain = ( - await fs.readFile(path.join(manifestDir, 'rust-toolchain')) - ) - .toString() - .trim() - if (rustToolchain.includes('[toolchain]')) { - rustToolchain = parseRustToolchain(rustToolchain) + let currentDir = manifestDir + // eslint-disable-next-line no-constant-condition + while (true) { + const relative = path.relative(root, currentDir) + if (relative && !relative.startsWith('..') && !path.isAbsolute(relative)) { + const toolchainToml = path.join(currentDir, 'rust-toolchain.toml') + const toolchain = path.join(currentDir, 'rust-toolchain') + if (existsSync(toolchainToml)) { + const content = await fs.readFile(toolchainToml) + rustToolchain = parseRustToolchain(content.toString()) + core.info( + `Found Rust toolchain ${rustToolchain} in rust-toolchain.toml ` + ) + break + } else { + core.debug(`${toolchainToml} doesn't exist`) + } + if (existsSync(toolchain)) { + rustToolchain = (await fs.readFile(toolchain)).toString().trim() + if (rustToolchain.includes('[toolchain]')) { + rustToolchain = parseRustToolchain(rustToolchain) + } + core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain `) + break + } else { + core.debug(`${toolchain} doesn't exist`) + } + } else { + core.debug( + `No rust-toolchain.toml or rust-toolchain found inside ${root}` + ) + break } - core.info(`Found Rust toolchain ${rustToolchain} in rust-toolchain `) + if (currentDir === root) { + core.debug( + `Give up finding rust-toolchain.toml or rust-toolchain in ${root}` + ) + break + } + currentDir = path.dirname(currentDir) } return rustToolchain } @@ -494,11 +526,12 @@ async function dockerBuild( 'echo "::group::Install Rust"', `which rustup > /dev/null || curl --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --profile minimal --default-toolchain ${rustToolchain}`, 'export PATH="$HOME/.cargo/bin:$PATH"', + `echo "Install Rust toolchain ${rustToolchain}"`, `rustup override set ${rustToolchain}`, `rustup component add llvm-tools-preview || true`, 'echo "::endgroup::"', // Add all supported python versions to PATH - 'export PATH="$PATH:/opt/python/cp37-cp37m/bin:/opt/python/cp38-cp38/bin:/opt/python/cp39-cp39/bin:/opt/python/cp310-cp310/bin:/opt/python/cp311-cp311/bin"', + 'export PATH="$PATH:/opt/python/cp37-cp37m/bin:/opt/python/cp38-cp38/bin:/opt/python/cp39-cp39/bin:/opt/python/cp310-cp310/bin:/opt/python/cp311-cp311/bin:/opt/python/cp312-cp312/bin"', // Install maturin 'echo "::group::Install maturin"', `curl -L ${url} | tar -xz -C /usr/local/bin`, @@ -601,13 +634,7 @@ async function dockerBuild( } } - let workdir = core.getInput('working-directory') - if (workdir.length > 0) { - workdir = path.join(workspace, workdir) - } else { - workdir = workspace - } - + const workdir = getWorkingDirectory() const dockerVolumes = [] // forward ssh agent @@ -744,13 +771,14 @@ async function hostBuild( const target = getRustTarget(args) const rustToolchain = await getRustToolchain(args) const rustupComponents = core.getInput('rustup-components') - const workdir = core.getInput('working-directory') || process.cwd() + const workdir = getWorkingDirectory() const sccache = core.getBooleanInput('sccache') const isUniversal2 = args.includes('--universal2') || target === 'universal2-apple-darwin' core.startGroup('Install Rust target') if (rustToolchain.length > 0) { + core.info(`Installing Rust toolchain ${rustToolchain}`) await exec.exec('rustup', ['override', 'set', rustToolchain]) await exec.exec('rustup', ['component', 'add', 'llvm-tools-preview'], { ignoreReturnCode: true