feat: support setting up llvm as the compiler

This commit is contained in:
Amin Yahyaabadi 2021-09-16 02:51:41 -05:00
parent 2761be4b10
commit 16b25286f9
2 changed files with 30 additions and 1 deletions

View File

@ -5,6 +5,7 @@ import { setupTmpDir, cleanupTmpDir } from "../../utils/tests/test-helpers"
import { addBinExtension } from "../../utils/setup/setupBin" import { addBinExtension } from "../../utils/setup/setupBin"
import { join } from "path" import { join } from "path"
import { spawnSync as spawn } from "child_process" import { spawnSync as spawn } from "child_process"
import { which } from "@actions/io"
jest.setTimeout(200000) jest.setTimeout(200000)
async function testUrl(version: string) { async function testUrl(version: string) {
@ -55,6 +56,8 @@ describe("setup-llvm", () => {
encoding: "utf8", encoding: "utf8",
}) })
expect(status).toBe(0) expect(status).toBe(0)
expect(await which("clang", true)).toBe(clangBin)
}) })
afterAll(async () => { afterAll(async () => {

View File

@ -1,10 +1,12 @@
import * as core from "@actions/core" import * as core from "@actions/core"
import * as path from "path" import * as path from "path"
import semverLte from "semver/functions/lte" import semverLte from "semver/functions/lte"
import semverMajor from "semver/functions/major"
import { isValidUrl } from "../utils/http/validate_url" import { isValidUrl } from "../utils/http/validate_url"
import { InstallationInfo, PackageInfo, setupBin } from "../utils/setup/setupBin" import { InstallationInfo, PackageInfo, setupBin } from "../utils/setup/setupBin"
import { extractExe, extractTarByExe } from "../utils/setup/extract" import { extractExe, extractTarByExe } from "../utils/setup/extract"
import { getSpecificVersionAndUrl, getVersions } from "../utils/setup/version" import { getSpecificVersionAndUrl, getVersions } from "../utils/setup/version"
import { getExecOutput } from "@actions/exec"
//================================================ //================================================
// Version // Version
@ -246,9 +248,33 @@ export async function setupLLVM(version: string, directoryGiven?: string): Promi
const ld = process.env.LD_LIBRARY_PATH ?? "" const ld = process.env.LD_LIBRARY_PATH ?? ""
const dyld = process.env.DYLD_LIBRARY_PATH ?? "" const dyld = process.env.DYLD_LIBRARY_PATH ?? ""
core.exportVariable("LLVM_PATH", directory) core.exportVariable("LLVM_PATH", directory) // the output of this action
const llvmMajor = semverMajor(version)
// Setup LLVM as the compiler
core.exportVariable("LD_LIBRARY_PATH", `${lib}${path.delimiter}${ld}`) core.exportVariable("LD_LIBRARY_PATH", `${lib}${path.delimiter}${ld}`)
core.exportVariable("DYLD_LIBRARY_PATH", `${lib}${path.delimiter}${dyld}`) core.exportVariable("DYLD_LIBRARY_PATH", `${lib}${path.delimiter}${dyld}`)
core.exportVariable("CPATH", `${directory}/lib/clang/${llvmMajor}/include`)
core.exportVariable("LDFLAGS", `-L${directory}/lib`)
core.exportVariable("CPPFLAGS", `-I${directory}/include`)
core.exportVariable("CC", `${directory}/bin/clang`)
core.exportVariable("CXX", `${directory}/bin/clang++`)
core.exportVariable("LIBRARY_PATH", `${directory}/lib`)
if (process.platform === "darwin") {
try {
const xcrun = await getExecOutput("xcrun --sdk macos --show-sdk-path")
const sdkroot = xcrun.stdout || xcrun.stderr
core.exportVariable("SDKROOT", sdkroot)
} catch (e) {
core.error(e as Error | string)
}
}
return installationInfo return installationInfo
} }