mirror of
https://github.com/astral-sh/setup-uv.git
synced 2026-06-10 14:42:22 +00:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| edc4037b1b |
@@ -26,7 +26,6 @@ Use this skill when the user wants to:
|
|||||||
- Inspect `package.json` before editing.
|
- Inspect `package.json` before editing.
|
||||||
- Run `npm ci --ignore-scripts` before applying updates.
|
- Run `npm ci --ignore-scripts` before applying updates.
|
||||||
- Use `npm install ... --ignore-scripts` for direct dependency changes so `package-lock.json` stays in sync.
|
- Use `npm install ... --ignore-scripts` for direct dependency changes so `package-lock.json` stays in sync.
|
||||||
- When updating `@biomejs/biome`, also update the Biome schema URL version in `biome.json` to match the installed Biome version.
|
|
||||||
7. Run `npm run all`.
|
7. Run `npm run all`.
|
||||||
8. If requested, commit the changed source, lockfile, and generated artifacts, then push and open a PR.
|
8. If requested, commit the changed source, lockfile, and generated artifacts, then push and open a PR.
|
||||||
|
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ jobs:
|
|||||||
|
|
||||||
# Initializes the CodeQL tools for scanning.
|
# Initializes the CodeQL tools for scanning.
|
||||||
- name: Initialize CodeQL
|
- name: Initialize CodeQL
|
||||||
uses: github/codeql-action/init@7211b7c8077ea37d8641b6271f6a365a22a5fbfa # v4.36.0
|
uses: github/codeql-action/init@68bde559dea0fdcac2102bfdf6230c5f70eb485e # v4.35.4
|
||||||
with:
|
with:
|
||||||
languages: ${{ matrix.language }}
|
languages: ${{ matrix.language }}
|
||||||
source-root: src
|
source-root: src
|
||||||
@@ -59,7 +59,7 @@ jobs:
|
|||||||
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
|
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
|
||||||
# If this step fails, then you should remove it and run the build manually (see below)
|
# If this step fails, then you should remove it and run the build manually (see below)
|
||||||
- name: Autobuild
|
- name: Autobuild
|
||||||
uses: github/codeql-action/autobuild@7211b7c8077ea37d8641b6271f6a365a22a5fbfa # v4.36.0
|
uses: github/codeql-action/autobuild@68bde559dea0fdcac2102bfdf6230c5f70eb485e # v4.35.4
|
||||||
|
|
||||||
# ℹ️ Command-line programs to run using the OS shell.
|
# ℹ️ Command-line programs to run using the OS shell.
|
||||||
# 📚 https://git.io/JvXDl
|
# 📚 https://git.io/JvXDl
|
||||||
@@ -73,4 +73,4 @@ jobs:
|
|||||||
# make release
|
# make release
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
- name: Perform CodeQL Analysis
|
||||||
uses: github/codeql-action/analyze@7211b7c8077ea37d8641b6271f6a365a22a5fbfa # v4.36.0
|
uses: github/codeql-action/analyze@68bde559dea0fdcac2102bfdf6230c5f70eb485e # v4.35.4
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ jobs:
|
|||||||
pull-requests: read
|
pull-requests: read
|
||||||
steps:
|
steps:
|
||||||
- name: 🚀 Run Release Drafter
|
- name: 🚀 Run Release Drafter
|
||||||
uses: release-drafter/release-drafter@693d20e7c1ce1a81d3a41962f85914253b518449 # v7.3.1
|
uses: release-drafter/release-drafter@5de93583980a40bd78603b6dfdcda5b4df377b32 # v7.2.0
|
||||||
with:
|
with:
|
||||||
commitish: ${{ github.sha }}
|
commitish: ${{ github.sha }}
|
||||||
env:
|
env:
|
||||||
|
|||||||
@@ -25,9 +25,9 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
persist-credentials: false
|
persist-credentials: false
|
||||||
- name: Actionlint
|
- name: Actionlint
|
||||||
uses: eifinger/actionlint-action@1fc89649be682d16ec5cf65ea16e269eb88d3982 # v1.10.2
|
uses: eifinger/actionlint-action@7802e0cc3ab3f81cbffb36fb0bf1a3621d994b89 # v1.10.1
|
||||||
- name: Run zizmor
|
- name: Run zizmor
|
||||||
uses: zizmorcore/zizmor-action@5f14fd08f7cf1cb1609c1e344975f152c7ee938d # v0.5.6
|
uses: zizmorcore/zizmor-action@a16621b09c6db4281f81a93cb393b05dcd7b7165 # v0.5.5
|
||||||
- uses: actions/setup-node@48b55a011bda9f5d6aeb4c2d9c7362e8dae4041e # v6.4.0
|
- uses: actions/setup-node@48b55a011bda9f5d6aeb4c2d9c7362e8dae4041e # v6.4.0
|
||||||
with:
|
with:
|
||||||
node-version-file: .nvmrc
|
node-version-file: .nvmrc
|
||||||
@@ -861,20 +861,6 @@ jobs:
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
test-download-from-astral-mirror-false:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
||||||
with:
|
|
||||||
persist-credentials: false
|
|
||||||
- name: Install with download-from-astral-mirror disabled
|
|
||||||
id: setup-uv
|
|
||||||
uses: ./
|
|
||||||
with:
|
|
||||||
download-from-astral-mirror: false
|
|
||||||
- name: Verify uv is installed
|
|
||||||
run: uv --version
|
|
||||||
|
|
||||||
test-absolute-path:
|
test-absolute-path:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
@@ -1133,7 +1119,6 @@ jobs:
|
|||||||
- test-restore-cache-restore-cache-false
|
- test-restore-cache-restore-cache-false
|
||||||
- test-no-python-version
|
- test-no-python-version
|
||||||
- test-custom-manifest-file
|
- test-custom-manifest-file
|
||||||
- test-download-from-astral-mirror-false
|
|
||||||
- test-absolute-path
|
- test-absolute-path
|
||||||
- test-relative-path
|
- test-relative-path
|
||||||
- test-cache-prune-force
|
- test-cache-prune-force
|
||||||
|
|||||||
@@ -120,14 +120,8 @@ Have a look under [Advanced Configuration](#advanced-configuration) for detailed
|
|||||||
# URL to a custom manifest file in the astral-sh/versions format
|
# URL to a custom manifest file in the astral-sh/versions format
|
||||||
manifest-file: ""
|
manifest-file: ""
|
||||||
|
|
||||||
# Download uv from the Astral mirror instead of directly from GitHub Releases
|
|
||||||
download-from-astral-mirror: "true"
|
|
||||||
|
|
||||||
# Add problem matchers
|
# Add problem matchers
|
||||||
add-problem-matchers: "true"
|
add-problem-matchers: "true"
|
||||||
|
|
||||||
# Suppress info-level log output. Only warnings and errors are shown
|
|
||||||
quiet: "false"
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Outputs
|
### Outputs
|
||||||
|
|||||||
@@ -376,32 +376,6 @@ describe("download-version", () => {
|
|||||||
"0.9.26",
|
"0.9.26",
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("skips the Astral mirror when downloadFromAstralMirror is false", async () => {
|
|
||||||
mockGetArtifact.mockResolvedValue({
|
|
||||||
archiveFormat: "tar.gz",
|
|
||||||
checksum: "abc123",
|
|
||||||
downloadUrl:
|
|
||||||
"https://github.com/astral-sh/uv/releases/download/0.9.26/uv-x86_64-unknown-linux-gnu.tar.gz",
|
|
||||||
});
|
|
||||||
|
|
||||||
await downloadVersion(
|
|
||||||
"unknown-linux-gnu",
|
|
||||||
"x86_64",
|
|
||||||
"0.9.26",
|
|
||||||
undefined,
|
|
||||||
"token",
|
|
||||||
undefined,
|
|
||||||
false,
|
|
||||||
);
|
|
||||||
|
|
||||||
expect(mockDownloadTool).toHaveBeenCalledWith(
|
|
||||||
"https://github.com/astral-sh/uv/releases/download/0.9.26/uv-x86_64-unknown-linux-gnu.tar.gz",
|
|
||||||
undefined,
|
|
||||||
"token",
|
|
||||||
);
|
|
||||||
expect(mockDownloadTool).toHaveBeenCalledTimes(1);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("rewriteToMirror", () => {
|
describe("rewriteToMirror", () => {
|
||||||
|
|||||||
@@ -52,12 +52,8 @@ inputs:
|
|||||||
type: string
|
type: string
|
||||||
manifest-file:
|
manifest-file:
|
||||||
type: string
|
type: string
|
||||||
download-from-astral-mirror:
|
|
||||||
type: boolean
|
|
||||||
add-problem-matchers:
|
add-problem-matchers:
|
||||||
type: boolean
|
type: boolean
|
||||||
quiet:
|
|
||||||
type: boolean
|
|
||||||
resolution-strategy:
|
resolution-strategy:
|
||||||
type: enum
|
type: enum
|
||||||
allowed-values:
|
allowed-values:
|
||||||
|
|||||||
@@ -80,15 +80,9 @@ inputs:
|
|||||||
manifest-file:
|
manifest-file:
|
||||||
description: "URL to a custom manifest file in the astral-sh/versions format."
|
description: "URL to a custom manifest file in the astral-sh/versions format."
|
||||||
required: false
|
required: false
|
||||||
download-from-astral-mirror:
|
|
||||||
description: "Download uv from the Astral mirror instead of directly from GitHub Releases."
|
|
||||||
default: "true"
|
|
||||||
add-problem-matchers:
|
add-problem-matchers:
|
||||||
description: "Add problem matchers."
|
description: "Add problem matchers."
|
||||||
default: "true"
|
default: "true"
|
||||||
quiet:
|
|
||||||
description: "Suppress info-level log output. Only warnings and errors are shown."
|
|
||||||
default: "false"
|
|
||||||
resolution-strategy:
|
resolution-strategy:
|
||||||
description: "Resolution strategy to use when resolving version ranges. 'highest' uses the latest compatible version, 'lowest' uses the oldest compatible version."
|
description: "Resolution strategy to use when resolving version ranges. 'highest' uses the latest compatible version, 'lowest' uses the oldest compatible version."
|
||||||
default: "highest"
|
default: "highest"
|
||||||
|
|||||||
+1
-1
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"$schema": "https://biomejs.dev/schemas/2.4.15/schema.json",
|
"$schema": "https://biomejs.dev/schemas/2.4.7/schema.json",
|
||||||
"assist": {
|
"assist": {
|
||||||
"actions": {
|
"actions": {
|
||||||
"source": {
|
"source": {
|
||||||
|
|||||||
+147
-185
@@ -133,7 +133,7 @@ var require_tunnel = __commonJS({
|
|||||||
connectOptions.headers = connectOptions.headers || {};
|
connectOptions.headers = connectOptions.headers || {};
|
||||||
connectOptions.headers["Proxy-Authorization"] = "Basic " + new Buffer(connectOptions.proxyAuth).toString("base64");
|
connectOptions.headers["Proxy-Authorization"] = "Basic " + new Buffer(connectOptions.proxyAuth).toString("base64");
|
||||||
}
|
}
|
||||||
debug3("making CONNECT request");
|
debug2("making CONNECT request");
|
||||||
var connectReq = self2.request(connectOptions);
|
var connectReq = self2.request(connectOptions);
|
||||||
connectReq.useChunkedEncodingByDefault = false;
|
connectReq.useChunkedEncodingByDefault = false;
|
||||||
connectReq.once("response", onResponse);
|
connectReq.once("response", onResponse);
|
||||||
@@ -153,7 +153,7 @@ var require_tunnel = __commonJS({
|
|||||||
connectReq.removeAllListeners();
|
connectReq.removeAllListeners();
|
||||||
socket.removeAllListeners();
|
socket.removeAllListeners();
|
||||||
if (res.statusCode !== 200) {
|
if (res.statusCode !== 200) {
|
||||||
debug3(
|
debug2(
|
||||||
"tunneling socket could not be established, statusCode=%d",
|
"tunneling socket could not be established, statusCode=%d",
|
||||||
res.statusCode
|
res.statusCode
|
||||||
);
|
);
|
||||||
@@ -165,7 +165,7 @@ var require_tunnel = __commonJS({
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (head.length > 0) {
|
if (head.length > 0) {
|
||||||
debug3("got illegal response body from proxy");
|
debug2("got illegal response body from proxy");
|
||||||
socket.destroy();
|
socket.destroy();
|
||||||
var error2 = new Error("got illegal response body from proxy");
|
var error2 = new Error("got illegal response body from proxy");
|
||||||
error2.code = "ECONNRESET";
|
error2.code = "ECONNRESET";
|
||||||
@@ -173,13 +173,13 @@ var require_tunnel = __commonJS({
|
|||||||
self2.removeSocket(placeholder);
|
self2.removeSocket(placeholder);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
debug3("tunneling connection has established");
|
debug2("tunneling connection has established");
|
||||||
self2.sockets[self2.sockets.indexOf(placeholder)] = socket;
|
self2.sockets[self2.sockets.indexOf(placeholder)] = socket;
|
||||||
return cb(socket);
|
return cb(socket);
|
||||||
}
|
}
|
||||||
function onError(cause) {
|
function onError(cause) {
|
||||||
connectReq.removeAllListeners();
|
connectReq.removeAllListeners();
|
||||||
debug3(
|
debug2(
|
||||||
"tunneling socket could not be established, cause=%s\n",
|
"tunneling socket could not be established, cause=%s\n",
|
||||||
cause.message,
|
cause.message,
|
||||||
cause.stack
|
cause.stack
|
||||||
@@ -241,9 +241,9 @@ var require_tunnel = __commonJS({
|
|||||||
}
|
}
|
||||||
return target;
|
return target;
|
||||||
}
|
}
|
||||||
var debug3;
|
var debug2;
|
||||||
if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) {
|
if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) {
|
||||||
debug3 = function() {
|
debug2 = function() {
|
||||||
var args = Array.prototype.slice.call(arguments);
|
var args = Array.prototype.slice.call(arguments);
|
||||||
if (typeof args[0] === "string") {
|
if (typeof args[0] === "string") {
|
||||||
args[0] = "TUNNEL: " + args[0];
|
args[0] = "TUNNEL: " + args[0];
|
||||||
@@ -253,10 +253,10 @@ var require_tunnel = __commonJS({
|
|||||||
console.error.apply(console, args);
|
console.error.apply(console, args);
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
debug3 = function() {
|
debug2 = function() {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
exports2.debug = debug3;
|
exports2.debug = debug2;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -18936,7 +18936,7 @@ var require_minimatch = __commonJS({
|
|||||||
}
|
}
|
||||||
this.parseNegate();
|
this.parseNegate();
|
||||||
var set = this.globSet = this.braceExpand();
|
var set = this.globSet = this.braceExpand();
|
||||||
if (options.debug) this.debug = function debug3() {
|
if (options.debug) this.debug = function debug2() {
|
||||||
console.error.apply(console, arguments);
|
console.error.apply(console, arguments);
|
||||||
};
|
};
|
||||||
this.debug(this.pattern, set);
|
this.debug(this.pattern, set);
|
||||||
@@ -19414,9 +19414,9 @@ var require_constants6 = __commonJS({
|
|||||||
var require_debug = __commonJS({
|
var require_debug = __commonJS({
|
||||||
"node_modules/@actions/cache/node_modules/semver/internal/debug.js"(exports2, module2) {
|
"node_modules/@actions/cache/node_modules/semver/internal/debug.js"(exports2, module2) {
|
||||||
"use strict";
|
"use strict";
|
||||||
var debug3 = typeof process === "object" && process.env && process.env.NODE_DEBUG && /\bsemver\b/i.test(process.env.NODE_DEBUG) ? (...args) => console.error("SEMVER", ...args) : () => {
|
var debug2 = typeof process === "object" && process.env && process.env.NODE_DEBUG && /\bsemver\b/i.test(process.env.NODE_DEBUG) ? (...args) => console.error("SEMVER", ...args) : () => {
|
||||||
};
|
};
|
||||||
module2.exports = debug3;
|
module2.exports = debug2;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -19429,7 +19429,7 @@ var require_re = __commonJS({
|
|||||||
MAX_SAFE_BUILD_LENGTH,
|
MAX_SAFE_BUILD_LENGTH,
|
||||||
MAX_LENGTH
|
MAX_LENGTH
|
||||||
} = require_constants6();
|
} = require_constants6();
|
||||||
var debug3 = require_debug();
|
var debug2 = require_debug();
|
||||||
exports2 = module2.exports = {};
|
exports2 = module2.exports = {};
|
||||||
var re = exports2.re = [];
|
var re = exports2.re = [];
|
||||||
var safeRe = exports2.safeRe = [];
|
var safeRe = exports2.safeRe = [];
|
||||||
@@ -19452,7 +19452,7 @@ var require_re = __commonJS({
|
|||||||
var createToken = (name, value, isGlobal) => {
|
var createToken = (name, value, isGlobal) => {
|
||||||
const safe = makeSafeRegex(value);
|
const safe = makeSafeRegex(value);
|
||||||
const index = R++;
|
const index = R++;
|
||||||
debug3(name, index, value);
|
debug2(name, index, value);
|
||||||
t[name] = index;
|
t[name] = index;
|
||||||
src[index] = value;
|
src[index] = value;
|
||||||
safeSrc[index] = safe;
|
safeSrc[index] = safe;
|
||||||
@@ -19556,7 +19556,7 @@ var require_identifiers = __commonJS({
|
|||||||
var require_semver = __commonJS({
|
var require_semver = __commonJS({
|
||||||
"node_modules/@actions/cache/node_modules/semver/classes/semver.js"(exports2, module2) {
|
"node_modules/@actions/cache/node_modules/semver/classes/semver.js"(exports2, module2) {
|
||||||
"use strict";
|
"use strict";
|
||||||
var debug3 = require_debug();
|
var debug2 = require_debug();
|
||||||
var { MAX_LENGTH, MAX_SAFE_INTEGER } = require_constants6();
|
var { MAX_LENGTH, MAX_SAFE_INTEGER } = require_constants6();
|
||||||
var { safeRe: re, t } = require_re();
|
var { safeRe: re, t } = require_re();
|
||||||
var parseOptions = require_parse_options();
|
var parseOptions = require_parse_options();
|
||||||
@@ -19578,7 +19578,7 @@ var require_semver = __commonJS({
|
|||||||
`version is longer than ${MAX_LENGTH} characters`
|
`version is longer than ${MAX_LENGTH} characters`
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
debug3("SemVer", version3, options);
|
debug2("SemVer", version3, options);
|
||||||
this.options = options;
|
this.options = options;
|
||||||
this.loose = !!options.loose;
|
this.loose = !!options.loose;
|
||||||
this.includePrerelease = !!options.includePrerelease;
|
this.includePrerelease = !!options.includePrerelease;
|
||||||
@@ -19626,7 +19626,7 @@ var require_semver = __commonJS({
|
|||||||
return this.version;
|
return this.version;
|
||||||
}
|
}
|
||||||
compare(other) {
|
compare(other) {
|
||||||
debug3("SemVer.compare", this.version, this.options, other);
|
debug2("SemVer.compare", this.version, this.options, other);
|
||||||
if (!(other instanceof _SemVer)) {
|
if (!(other instanceof _SemVer)) {
|
||||||
if (typeof other === "string" && other === this.version) {
|
if (typeof other === "string" && other === this.version) {
|
||||||
return 0;
|
return 0;
|
||||||
@@ -19677,7 +19677,7 @@ var require_semver = __commonJS({
|
|||||||
do {
|
do {
|
||||||
const a = this.prerelease[i];
|
const a = this.prerelease[i];
|
||||||
const b = other.prerelease[i];
|
const b = other.prerelease[i];
|
||||||
debug3("prerelease compare", i, a, b);
|
debug2("prerelease compare", i, a, b);
|
||||||
if (a === void 0 && b === void 0) {
|
if (a === void 0 && b === void 0) {
|
||||||
return 0;
|
return 0;
|
||||||
} else if (b === void 0) {
|
} else if (b === void 0) {
|
||||||
@@ -19699,7 +19699,7 @@ var require_semver = __commonJS({
|
|||||||
do {
|
do {
|
||||||
const a = this.build[i];
|
const a = this.build[i];
|
||||||
const b = other.build[i];
|
const b = other.build[i];
|
||||||
debug3("build compare", i, a, b);
|
debug2("build compare", i, a, b);
|
||||||
if (a === void 0 && b === void 0) {
|
if (a === void 0 && b === void 0) {
|
||||||
return 0;
|
return 0;
|
||||||
} else if (b === void 0) {
|
} else if (b === void 0) {
|
||||||
@@ -20327,21 +20327,21 @@ var require_range = __commonJS({
|
|||||||
const loose = this.options.loose;
|
const loose = this.options.loose;
|
||||||
const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE];
|
const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE];
|
||||||
range2 = range2.replace(hr, hyphenReplace(this.options.includePrerelease));
|
range2 = range2.replace(hr, hyphenReplace(this.options.includePrerelease));
|
||||||
debug3("hyphen replace", range2);
|
debug2("hyphen replace", range2);
|
||||||
range2 = range2.replace(re[t.COMPARATORTRIM], comparatorTrimReplace);
|
range2 = range2.replace(re[t.COMPARATORTRIM], comparatorTrimReplace);
|
||||||
debug3("comparator trim", range2);
|
debug2("comparator trim", range2);
|
||||||
range2 = range2.replace(re[t.TILDETRIM], tildeTrimReplace);
|
range2 = range2.replace(re[t.TILDETRIM], tildeTrimReplace);
|
||||||
debug3("tilde trim", range2);
|
debug2("tilde trim", range2);
|
||||||
range2 = range2.replace(re[t.CARETTRIM], caretTrimReplace);
|
range2 = range2.replace(re[t.CARETTRIM], caretTrimReplace);
|
||||||
debug3("caret trim", range2);
|
debug2("caret trim", range2);
|
||||||
let rangeList = range2.split(" ").map((comp26) => parseComparator(comp26, this.options)).join(" ").split(/\s+/).map((comp26) => replaceGTE0(comp26, this.options));
|
let rangeList = range2.split(" ").map((comp26) => parseComparator(comp26, this.options)).join(" ").split(/\s+/).map((comp26) => replaceGTE0(comp26, this.options));
|
||||||
if (loose) {
|
if (loose) {
|
||||||
rangeList = rangeList.filter((comp26) => {
|
rangeList = rangeList.filter((comp26) => {
|
||||||
debug3("loose invalid filter", comp26, this.options);
|
debug2("loose invalid filter", comp26, this.options);
|
||||||
return !!comp26.match(re[t.COMPARATORLOOSE]);
|
return !!comp26.match(re[t.COMPARATORLOOSE]);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
debug3("range list", rangeList);
|
debug2("range list", rangeList);
|
||||||
const rangeMap = /* @__PURE__ */ new Map();
|
const rangeMap = /* @__PURE__ */ new Map();
|
||||||
const comparators = rangeList.map((comp26) => new Comparator(comp26, this.options));
|
const comparators = rangeList.map((comp26) => new Comparator(comp26, this.options));
|
||||||
for (const comp26 of comparators) {
|
for (const comp26 of comparators) {
|
||||||
@@ -20396,7 +20396,7 @@ var require_range = __commonJS({
|
|||||||
var cache = new LRU();
|
var cache = new LRU();
|
||||||
var parseOptions = require_parse_options();
|
var parseOptions = require_parse_options();
|
||||||
var Comparator = require_comparator();
|
var Comparator = require_comparator();
|
||||||
var debug3 = require_debug();
|
var debug2 = require_debug();
|
||||||
var SemVer = require_semver();
|
var SemVer = require_semver();
|
||||||
var {
|
var {
|
||||||
safeRe: re,
|
safeRe: re,
|
||||||
@@ -20422,15 +20422,15 @@ var require_range = __commonJS({
|
|||||||
};
|
};
|
||||||
var parseComparator = (comp26, options) => {
|
var parseComparator = (comp26, options) => {
|
||||||
comp26 = comp26.replace(re[t.BUILD], "");
|
comp26 = comp26.replace(re[t.BUILD], "");
|
||||||
debug3("comp", comp26, options);
|
debug2("comp", comp26, options);
|
||||||
comp26 = replaceCarets(comp26, options);
|
comp26 = replaceCarets(comp26, options);
|
||||||
debug3("caret", comp26);
|
debug2("caret", comp26);
|
||||||
comp26 = replaceTildes(comp26, options);
|
comp26 = replaceTildes(comp26, options);
|
||||||
debug3("tildes", comp26);
|
debug2("tildes", comp26);
|
||||||
comp26 = replaceXRanges(comp26, options);
|
comp26 = replaceXRanges(comp26, options);
|
||||||
debug3("xrange", comp26);
|
debug2("xrange", comp26);
|
||||||
comp26 = replaceStars(comp26, options);
|
comp26 = replaceStars(comp26, options);
|
||||||
debug3("stars", comp26);
|
debug2("stars", comp26);
|
||||||
return comp26;
|
return comp26;
|
||||||
};
|
};
|
||||||
var isX = (id) => !id || id.toLowerCase() === "x" || id === "*";
|
var isX = (id) => !id || id.toLowerCase() === "x" || id === "*";
|
||||||
@@ -20440,7 +20440,7 @@ var require_range = __commonJS({
|
|||||||
var replaceTilde = (comp26, options) => {
|
var replaceTilde = (comp26, options) => {
|
||||||
const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE];
|
const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE];
|
||||||
return comp26.replace(r, (_, M, m, p, pr) => {
|
return comp26.replace(r, (_, M, m, p, pr) => {
|
||||||
debug3("tilde", comp26, _, M, m, p, pr);
|
debug2("tilde", comp26, _, M, m, p, pr);
|
||||||
let ret;
|
let ret;
|
||||||
if (isX(M)) {
|
if (isX(M)) {
|
||||||
ret = "";
|
ret = "";
|
||||||
@@ -20449,12 +20449,12 @@ var require_range = __commonJS({
|
|||||||
} else if (isX(p)) {
|
} else if (isX(p)) {
|
||||||
ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`;
|
ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`;
|
||||||
} else if (pr) {
|
} else if (pr) {
|
||||||
debug3("replaceTilde pr", pr);
|
debug2("replaceTilde pr", pr);
|
||||||
ret = `>=${M}.${m}.${p}-${pr} <${M}.${+m + 1}.0-0`;
|
ret = `>=${M}.${m}.${p}-${pr} <${M}.${+m + 1}.0-0`;
|
||||||
} else {
|
} else {
|
||||||
ret = `>=${M}.${m}.${p} <${M}.${+m + 1}.0-0`;
|
ret = `>=${M}.${m}.${p} <${M}.${+m + 1}.0-0`;
|
||||||
}
|
}
|
||||||
debug3("tilde return", ret);
|
debug2("tilde return", ret);
|
||||||
return ret;
|
return ret;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@@ -20462,11 +20462,11 @@ var require_range = __commonJS({
|
|||||||
return comp26.trim().split(/\s+/).map((c) => replaceCaret(c, options)).join(" ");
|
return comp26.trim().split(/\s+/).map((c) => replaceCaret(c, options)).join(" ");
|
||||||
};
|
};
|
||||||
var replaceCaret = (comp26, options) => {
|
var replaceCaret = (comp26, options) => {
|
||||||
debug3("caret", comp26, options);
|
debug2("caret", comp26, options);
|
||||||
const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET];
|
const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET];
|
||||||
const z = options.includePrerelease ? "-0" : "";
|
const z = options.includePrerelease ? "-0" : "";
|
||||||
return comp26.replace(r, (_, M, m, p, pr) => {
|
return comp26.replace(r, (_, M, m, p, pr) => {
|
||||||
debug3("caret", comp26, _, M, m, p, pr);
|
debug2("caret", comp26, _, M, m, p, pr);
|
||||||
let ret;
|
let ret;
|
||||||
if (isX(M)) {
|
if (isX(M)) {
|
||||||
ret = "";
|
ret = "";
|
||||||
@@ -20479,7 +20479,7 @@ var require_range = __commonJS({
|
|||||||
ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`;
|
ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`;
|
||||||
}
|
}
|
||||||
} else if (pr) {
|
} else if (pr) {
|
||||||
debug3("replaceCaret pr", pr);
|
debug2("replaceCaret pr", pr);
|
||||||
if (M === "0") {
|
if (M === "0") {
|
||||||
if (m === "0") {
|
if (m === "0") {
|
||||||
ret = `>=${M}.${m}.${p}-${pr} <${M}.${m}.${+p + 1}-0`;
|
ret = `>=${M}.${m}.${p}-${pr} <${M}.${m}.${+p + 1}-0`;
|
||||||
@@ -20490,7 +20490,7 @@ var require_range = __commonJS({
|
|||||||
ret = `>=${M}.${m}.${p}-${pr} <${+M + 1}.0.0-0`;
|
ret = `>=${M}.${m}.${p}-${pr} <${+M + 1}.0.0-0`;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
debug3("no pr");
|
debug2("no pr");
|
||||||
if (M === "0") {
|
if (M === "0") {
|
||||||
if (m === "0") {
|
if (m === "0") {
|
||||||
ret = `>=${M}.${m}.${p}${z} <${M}.${m}.${+p + 1}-0`;
|
ret = `>=${M}.${m}.${p}${z} <${M}.${m}.${+p + 1}-0`;
|
||||||
@@ -20501,19 +20501,19 @@ var require_range = __commonJS({
|
|||||||
ret = `>=${M}.${m}.${p} <${+M + 1}.0.0-0`;
|
ret = `>=${M}.${m}.${p} <${+M + 1}.0.0-0`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
debug3("caret return", ret);
|
debug2("caret return", ret);
|
||||||
return ret;
|
return ret;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
var replaceXRanges = (comp26, options) => {
|
var replaceXRanges = (comp26, options) => {
|
||||||
debug3("replaceXRanges", comp26, options);
|
debug2("replaceXRanges", comp26, options);
|
||||||
return comp26.split(/\s+/).map((c) => replaceXRange(c, options)).join(" ");
|
return comp26.split(/\s+/).map((c) => replaceXRange(c, options)).join(" ");
|
||||||
};
|
};
|
||||||
var replaceXRange = (comp26, options) => {
|
var replaceXRange = (comp26, options) => {
|
||||||
comp26 = comp26.trim();
|
comp26 = comp26.trim();
|
||||||
const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE];
|
const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE];
|
||||||
return comp26.replace(r, (ret, gtlt, M, m, p, pr) => {
|
return comp26.replace(r, (ret, gtlt, M, m, p, pr) => {
|
||||||
debug3("xRange", comp26, ret, gtlt, M, m, p, pr);
|
debug2("xRange", comp26, ret, gtlt, M, m, p, pr);
|
||||||
const xM = isX(M);
|
const xM = isX(M);
|
||||||
const xm = xM || isX(m);
|
const xm = xM || isX(m);
|
||||||
const xp = xm || isX(p);
|
const xp = xm || isX(p);
|
||||||
@@ -20560,16 +20560,16 @@ var require_range = __commonJS({
|
|||||||
} else if (xp) {
|
} else if (xp) {
|
||||||
ret = `>=${M}.${m}.0${pr} <${M}.${+m + 1}.0-0`;
|
ret = `>=${M}.${m}.0${pr} <${M}.${+m + 1}.0-0`;
|
||||||
}
|
}
|
||||||
debug3("xRange return", ret);
|
debug2("xRange return", ret);
|
||||||
return ret;
|
return ret;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
var replaceStars = (comp26, options) => {
|
var replaceStars = (comp26, options) => {
|
||||||
debug3("replaceStars", comp26, options);
|
debug2("replaceStars", comp26, options);
|
||||||
return comp26.trim().replace(re[t.STAR], "");
|
return comp26.trim().replace(re[t.STAR], "");
|
||||||
};
|
};
|
||||||
var replaceGTE0 = (comp26, options) => {
|
var replaceGTE0 = (comp26, options) => {
|
||||||
debug3("replaceGTE0", comp26, options);
|
debug2("replaceGTE0", comp26, options);
|
||||||
return comp26.trim().replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], "");
|
return comp26.trim().replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], "");
|
||||||
};
|
};
|
||||||
var hyphenReplace = (incPr) => ($0, from, fM, fm, fp, fpr, fb, to, tM, tm, tp, tpr) => {
|
var hyphenReplace = (incPr) => ($0, from, fM, fm, fp, fpr, fb, to, tM, tm, tp, tpr) => {
|
||||||
@@ -20607,7 +20607,7 @@ var require_range = __commonJS({
|
|||||||
}
|
}
|
||||||
if (version3.prerelease.length && !options.includePrerelease) {
|
if (version3.prerelease.length && !options.includePrerelease) {
|
||||||
for (let i = 0; i < set.length; i++) {
|
for (let i = 0; i < set.length; i++) {
|
||||||
debug3(set[i].semver);
|
debug2(set[i].semver);
|
||||||
if (set[i].semver === Comparator.ANY) {
|
if (set[i].semver === Comparator.ANY) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@@ -20644,7 +20644,7 @@ var require_comparator = __commonJS({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
comp26 = comp26.trim().split(/\s+/).join(" ");
|
comp26 = comp26.trim().split(/\s+/).join(" ");
|
||||||
debug3("comparator", comp26, options);
|
debug2("comparator", comp26, options);
|
||||||
this.options = options;
|
this.options = options;
|
||||||
this.loose = !!options.loose;
|
this.loose = !!options.loose;
|
||||||
this.parse(comp26);
|
this.parse(comp26);
|
||||||
@@ -20653,7 +20653,7 @@ var require_comparator = __commonJS({
|
|||||||
} else {
|
} else {
|
||||||
this.value = this.operator + this.semver.version;
|
this.value = this.operator + this.semver.version;
|
||||||
}
|
}
|
||||||
debug3("comp", this);
|
debug2("comp", this);
|
||||||
}
|
}
|
||||||
parse(comp26) {
|
parse(comp26) {
|
||||||
const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR];
|
const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR];
|
||||||
@@ -20675,7 +20675,7 @@ var require_comparator = __commonJS({
|
|||||||
return this.value;
|
return this.value;
|
||||||
}
|
}
|
||||||
test(version3) {
|
test(version3) {
|
||||||
debug3("Comparator.test", version3, this.options.loose);
|
debug2("Comparator.test", version3, this.options.loose);
|
||||||
if (this.semver === ANY || version3 === ANY) {
|
if (this.semver === ANY || version3 === ANY) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -20732,7 +20732,7 @@ var require_comparator = __commonJS({
|
|||||||
var parseOptions = require_parse_options();
|
var parseOptions = require_parse_options();
|
||||||
var { safeRe: re, t } = require_re();
|
var { safeRe: re, t } = require_re();
|
||||||
var cmp = require_cmp();
|
var cmp = require_cmp();
|
||||||
var debug3 = require_debug();
|
var debug2 = require_debug();
|
||||||
var SemVer = require_semver();
|
var SemVer = require_semver();
|
||||||
var Range = require_range();
|
var Range = require_range();
|
||||||
}
|
}
|
||||||
@@ -21456,11 +21456,11 @@ var require_common = __commonJS({
|
|||||||
let enableOverride = null;
|
let enableOverride = null;
|
||||||
let namespacesCache;
|
let namespacesCache;
|
||||||
let enabledCache;
|
let enabledCache;
|
||||||
function debug3(...args) {
|
function debug2(...args) {
|
||||||
if (!debug3.enabled) {
|
if (!debug2.enabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const self2 = debug3;
|
const self2 = debug2;
|
||||||
const curr = Number(/* @__PURE__ */ new Date());
|
const curr = Number(/* @__PURE__ */ new Date());
|
||||||
const ms = curr - (prevTime || curr);
|
const ms = curr - (prevTime || curr);
|
||||||
self2.diff = ms;
|
self2.diff = ms;
|
||||||
@@ -21490,12 +21490,12 @@ var require_common = __commonJS({
|
|||||||
const logFn = self2.log || createDebug.log;
|
const logFn = self2.log || createDebug.log;
|
||||||
logFn.apply(self2, args);
|
logFn.apply(self2, args);
|
||||||
}
|
}
|
||||||
debug3.namespace = namespace;
|
debug2.namespace = namespace;
|
||||||
debug3.useColors = createDebug.useColors();
|
debug2.useColors = createDebug.useColors();
|
||||||
debug3.color = createDebug.selectColor(namespace);
|
debug2.color = createDebug.selectColor(namespace);
|
||||||
debug3.extend = extend2;
|
debug2.extend = extend2;
|
||||||
debug3.destroy = createDebug.destroy;
|
debug2.destroy = createDebug.destroy;
|
||||||
Object.defineProperty(debug3, "enabled", {
|
Object.defineProperty(debug2, "enabled", {
|
||||||
enumerable: true,
|
enumerable: true,
|
||||||
configurable: false,
|
configurable: false,
|
||||||
get: () => {
|
get: () => {
|
||||||
@@ -21513,9 +21513,9 @@ var require_common = __commonJS({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (typeof createDebug.init === "function") {
|
if (typeof createDebug.init === "function") {
|
||||||
createDebug.init(debug3);
|
createDebug.init(debug2);
|
||||||
}
|
}
|
||||||
return debug3;
|
return debug2;
|
||||||
}
|
}
|
||||||
function extend2(namespace, delimiter3) {
|
function extend2(namespace, delimiter3) {
|
||||||
const newDebug = createDebug(this.namespace + (typeof delimiter3 === "undefined" ? ":" : delimiter3) + namespace);
|
const newDebug = createDebug(this.namespace + (typeof delimiter3 === "undefined" ? ":" : delimiter3) + namespace);
|
||||||
@@ -22025,11 +22025,11 @@ var require_node = __commonJS({
|
|||||||
function load() {
|
function load() {
|
||||||
return process.env.DEBUG;
|
return process.env.DEBUG;
|
||||||
}
|
}
|
||||||
function init(debug3) {
|
function init(debug2) {
|
||||||
debug3.inspectOpts = {};
|
debug2.inspectOpts = {};
|
||||||
const keys = Object.keys(exports2.inspectOpts);
|
const keys = Object.keys(exports2.inspectOpts);
|
||||||
for (let i = 0; i < keys.length; i++) {
|
for (let i = 0; i < keys.length; i++) {
|
||||||
debug3.inspectOpts[keys[i]] = exports2.inspectOpts[keys[i]];
|
debug2.inspectOpts[keys[i]] = exports2.inspectOpts[keys[i]];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
module2.exports = require_common()(exports2);
|
module2.exports = require_common()(exports2);
|
||||||
@@ -22292,7 +22292,7 @@ var require_parse_proxy_response = __commonJS({
|
|||||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||||
exports2.parseProxyResponse = void 0;
|
exports2.parseProxyResponse = void 0;
|
||||||
var debug_1 = __importDefault(require_src());
|
var debug_1 = __importDefault(require_src());
|
||||||
var debug3 = (0, debug_1.default)("https-proxy-agent:parse-proxy-response");
|
var debug2 = (0, debug_1.default)("https-proxy-agent:parse-proxy-response");
|
||||||
function parseProxyResponse(socket) {
|
function parseProxyResponse(socket) {
|
||||||
return new Promise((resolve2, reject) => {
|
return new Promise((resolve2, reject) => {
|
||||||
let buffersLength = 0;
|
let buffersLength = 0;
|
||||||
@@ -22311,12 +22311,12 @@ var require_parse_proxy_response = __commonJS({
|
|||||||
}
|
}
|
||||||
function onend() {
|
function onend() {
|
||||||
cleanup();
|
cleanup();
|
||||||
debug3("onend");
|
debug2("onend");
|
||||||
reject(new Error("Proxy connection ended before receiving CONNECT response"));
|
reject(new Error("Proxy connection ended before receiving CONNECT response"));
|
||||||
}
|
}
|
||||||
function onerror(err) {
|
function onerror(err) {
|
||||||
cleanup();
|
cleanup();
|
||||||
debug3("onerror %o", err);
|
debug2("onerror %o", err);
|
||||||
reject(err);
|
reject(err);
|
||||||
}
|
}
|
||||||
function ondata(b) {
|
function ondata(b) {
|
||||||
@@ -22325,7 +22325,7 @@ var require_parse_proxy_response = __commonJS({
|
|||||||
const buffered = Buffer.concat(buffers, buffersLength);
|
const buffered = Buffer.concat(buffers, buffersLength);
|
||||||
const endOfHeaders = buffered.indexOf("\r\n\r\n");
|
const endOfHeaders = buffered.indexOf("\r\n\r\n");
|
||||||
if (endOfHeaders === -1) {
|
if (endOfHeaders === -1) {
|
||||||
debug3("have not received end of HTTP headers yet...");
|
debug2("have not received end of HTTP headers yet...");
|
||||||
read();
|
read();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -22358,7 +22358,7 @@ var require_parse_proxy_response = __commonJS({
|
|||||||
headers[key] = value;
|
headers[key] = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
debug3("got proxy server response: %o %o", firstLine, headers);
|
debug2("got proxy server response: %o %o", firstLine, headers);
|
||||||
cleanup();
|
cleanup();
|
||||||
resolve2({
|
resolve2({
|
||||||
connect: {
|
connect: {
|
||||||
@@ -22421,7 +22421,7 @@ var require_dist2 = __commonJS({
|
|||||||
var agent_base_1 = require_dist();
|
var agent_base_1 = require_dist();
|
||||||
var url_1 = require("url");
|
var url_1 = require("url");
|
||||||
var parse_proxy_response_1 = require_parse_proxy_response();
|
var parse_proxy_response_1 = require_parse_proxy_response();
|
||||||
var debug3 = (0, debug_1.default)("https-proxy-agent");
|
var debug2 = (0, debug_1.default)("https-proxy-agent");
|
||||||
var setServernameFromNonIpHost = (options) => {
|
var setServernameFromNonIpHost = (options) => {
|
||||||
if (options.servername === void 0 && options.host && !net.isIP(options.host)) {
|
if (options.servername === void 0 && options.host && !net.isIP(options.host)) {
|
||||||
return {
|
return {
|
||||||
@@ -22437,7 +22437,7 @@ var require_dist2 = __commonJS({
|
|||||||
this.options = { path: void 0 };
|
this.options = { path: void 0 };
|
||||||
this.proxy = typeof proxy === "string" ? new url_1.URL(proxy) : proxy;
|
this.proxy = typeof proxy === "string" ? new url_1.URL(proxy) : proxy;
|
||||||
this.proxyHeaders = opts?.headers ?? {};
|
this.proxyHeaders = opts?.headers ?? {};
|
||||||
debug3("Creating new HttpsProxyAgent instance: %o", this.proxy.href);
|
debug2("Creating new HttpsProxyAgent instance: %o", this.proxy.href);
|
||||||
const host = (this.proxy.hostname || this.proxy.host).replace(/^\[|\]$/g, "");
|
const host = (this.proxy.hostname || this.proxy.host).replace(/^\[|\]$/g, "");
|
||||||
const port = this.proxy.port ? parseInt(this.proxy.port, 10) : this.proxy.protocol === "https:" ? 443 : 80;
|
const port = this.proxy.port ? parseInt(this.proxy.port, 10) : this.proxy.protocol === "https:" ? 443 : 80;
|
||||||
this.connectOpts = {
|
this.connectOpts = {
|
||||||
@@ -22459,10 +22459,10 @@ var require_dist2 = __commonJS({
|
|||||||
}
|
}
|
||||||
let socket;
|
let socket;
|
||||||
if (proxy.protocol === "https:") {
|
if (proxy.protocol === "https:") {
|
||||||
debug3("Creating `tls.Socket`: %o", this.connectOpts);
|
debug2("Creating `tls.Socket`: %o", this.connectOpts);
|
||||||
socket = tls.connect(setServernameFromNonIpHost(this.connectOpts));
|
socket = tls.connect(setServernameFromNonIpHost(this.connectOpts));
|
||||||
} else {
|
} else {
|
||||||
debug3("Creating `net.Socket`: %o", this.connectOpts);
|
debug2("Creating `net.Socket`: %o", this.connectOpts);
|
||||||
socket = net.connect(this.connectOpts);
|
socket = net.connect(this.connectOpts);
|
||||||
}
|
}
|
||||||
const headers = typeof this.proxyHeaders === "function" ? this.proxyHeaders() : { ...this.proxyHeaders };
|
const headers = typeof this.proxyHeaders === "function" ? this.proxyHeaders() : { ...this.proxyHeaders };
|
||||||
@@ -22490,7 +22490,7 @@ var require_dist2 = __commonJS({
|
|||||||
if (connect.statusCode === 200) {
|
if (connect.statusCode === 200) {
|
||||||
req.once("socket", resume);
|
req.once("socket", resume);
|
||||||
if (opts.secureEndpoint) {
|
if (opts.secureEndpoint) {
|
||||||
debug3("Upgrading socket connection to TLS");
|
debug2("Upgrading socket connection to TLS");
|
||||||
return tls.connect({
|
return tls.connect({
|
||||||
...omit(setServernameFromNonIpHost(opts), "host", "path", "port"),
|
...omit(setServernameFromNonIpHost(opts), "host", "path", "port"),
|
||||||
socket
|
socket
|
||||||
@@ -22502,7 +22502,7 @@ var require_dist2 = __commonJS({
|
|||||||
const fakeSocket = new net.Socket({ writable: false });
|
const fakeSocket = new net.Socket({ writable: false });
|
||||||
fakeSocket.readable = true;
|
fakeSocket.readable = true;
|
||||||
req.once("socket", (s) => {
|
req.once("socket", (s) => {
|
||||||
debug3("Replaying proxy buffer for failed request");
|
debug2("Replaying proxy buffer for failed request");
|
||||||
(0, assert_1.default)(s.listenerCount("data") > 0);
|
(0, assert_1.default)(s.listenerCount("data") > 0);
|
||||||
s.push(buffered);
|
s.push(buffered);
|
||||||
s.push(null);
|
s.push(null);
|
||||||
@@ -22570,13 +22570,13 @@ var require_dist3 = __commonJS({
|
|||||||
var events_1 = require("events");
|
var events_1 = require("events");
|
||||||
var agent_base_1 = require_dist();
|
var agent_base_1 = require_dist();
|
||||||
var url_1 = require("url");
|
var url_1 = require("url");
|
||||||
var debug3 = (0, debug_1.default)("http-proxy-agent");
|
var debug2 = (0, debug_1.default)("http-proxy-agent");
|
||||||
var HttpProxyAgent2 = class extends agent_base_1.Agent {
|
var HttpProxyAgent2 = class extends agent_base_1.Agent {
|
||||||
constructor(proxy, opts) {
|
constructor(proxy, opts) {
|
||||||
super(opts);
|
super(opts);
|
||||||
this.proxy = typeof proxy === "string" ? new url_1.URL(proxy) : proxy;
|
this.proxy = typeof proxy === "string" ? new url_1.URL(proxy) : proxy;
|
||||||
this.proxyHeaders = opts?.headers ?? {};
|
this.proxyHeaders = opts?.headers ?? {};
|
||||||
debug3("Creating new HttpProxyAgent instance: %o", this.proxy.href);
|
debug2("Creating new HttpProxyAgent instance: %o", this.proxy.href);
|
||||||
const host = (this.proxy.hostname || this.proxy.host).replace(/^\[|\]$/g, "");
|
const host = (this.proxy.hostname || this.proxy.host).replace(/^\[|\]$/g, "");
|
||||||
const port = this.proxy.port ? parseInt(this.proxy.port, 10) : this.proxy.protocol === "https:" ? 443 : 80;
|
const port = this.proxy.port ? parseInt(this.proxy.port, 10) : this.proxy.protocol === "https:" ? 443 : 80;
|
||||||
this.connectOpts = {
|
this.connectOpts = {
|
||||||
@@ -22622,21 +22622,21 @@ var require_dist3 = __commonJS({
|
|||||||
}
|
}
|
||||||
let first;
|
let first;
|
||||||
let endOfHeaders;
|
let endOfHeaders;
|
||||||
debug3("Regenerating stored HTTP header string for request");
|
debug2("Regenerating stored HTTP header string for request");
|
||||||
req._implicitHeader();
|
req._implicitHeader();
|
||||||
if (req.outputData && req.outputData.length > 0) {
|
if (req.outputData && req.outputData.length > 0) {
|
||||||
debug3("Patching connection write() output buffer with updated header");
|
debug2("Patching connection write() output buffer with updated header");
|
||||||
first = req.outputData[0].data;
|
first = req.outputData[0].data;
|
||||||
endOfHeaders = first.indexOf("\r\n\r\n") + 4;
|
endOfHeaders = first.indexOf("\r\n\r\n") + 4;
|
||||||
req.outputData[0].data = req._header + first.substring(endOfHeaders);
|
req.outputData[0].data = req._header + first.substring(endOfHeaders);
|
||||||
debug3("Output buffer: %o", req.outputData[0].data);
|
debug2("Output buffer: %o", req.outputData[0].data);
|
||||||
}
|
}
|
||||||
let socket;
|
let socket;
|
||||||
if (this.proxy.protocol === "https:") {
|
if (this.proxy.protocol === "https:") {
|
||||||
debug3("Creating `tls.Socket`: %o", this.connectOpts);
|
debug2("Creating `tls.Socket`: %o", this.connectOpts);
|
||||||
socket = tls.connect(this.connectOpts);
|
socket = tls.connect(this.connectOpts);
|
||||||
} else {
|
} else {
|
||||||
debug3("Creating `net.Socket`: %o", this.connectOpts);
|
debug2("Creating `net.Socket`: %o", this.connectOpts);
|
||||||
socket = net.connect(this.connectOpts);
|
socket = net.connect(this.connectOpts);
|
||||||
}
|
}
|
||||||
await (0, events_1.once)(socket, "connect");
|
await (0, events_1.once)(socket, "connect");
|
||||||
@@ -24039,9 +24039,9 @@ var require_reflection_type_check = __commonJS({
|
|||||||
var reflection_info_1 = require_reflection_info();
|
var reflection_info_1 = require_reflection_info();
|
||||||
var oneof_1 = require_oneof();
|
var oneof_1 = require_oneof();
|
||||||
var ReflectionTypeCheck = class {
|
var ReflectionTypeCheck = class {
|
||||||
constructor(info3) {
|
constructor(info2) {
|
||||||
var _a;
|
var _a;
|
||||||
this.fields = (_a = info3.fields) !== null && _a !== void 0 ? _a : [];
|
this.fields = (_a = info2.fields) !== null && _a !== void 0 ? _a : [];
|
||||||
}
|
}
|
||||||
prepare() {
|
prepare() {
|
||||||
if (this.data)
|
if (this.data)
|
||||||
@@ -24287,8 +24287,8 @@ var require_reflection_json_reader = __commonJS({
|
|||||||
var assert_1 = require_assert();
|
var assert_1 = require_assert();
|
||||||
var reflection_long_convert_1 = require_reflection_long_convert();
|
var reflection_long_convert_1 = require_reflection_long_convert();
|
||||||
var ReflectionJsonReader = class {
|
var ReflectionJsonReader = class {
|
||||||
constructor(info3) {
|
constructor(info2) {
|
||||||
this.info = info3;
|
this.info = info2;
|
||||||
}
|
}
|
||||||
prepare() {
|
prepare() {
|
||||||
var _a;
|
var _a;
|
||||||
@@ -24584,9 +24584,9 @@ var require_reflection_json_writer = __commonJS({
|
|||||||
var reflection_info_1 = require_reflection_info();
|
var reflection_info_1 = require_reflection_info();
|
||||||
var assert_1 = require_assert();
|
var assert_1 = require_assert();
|
||||||
var ReflectionJsonWriter = class {
|
var ReflectionJsonWriter = class {
|
||||||
constructor(info3) {
|
constructor(info2) {
|
||||||
var _a;
|
var _a;
|
||||||
this.fields = (_a = info3.fields) !== null && _a !== void 0 ? _a : [];
|
this.fields = (_a = info2.fields) !== null && _a !== void 0 ? _a : [];
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Converts the message to a JSON object, based on the field descriptors.
|
* Converts the message to a JSON object, based on the field descriptors.
|
||||||
@@ -24839,8 +24839,8 @@ var require_reflection_binary_reader = __commonJS({
|
|||||||
var reflection_long_convert_1 = require_reflection_long_convert();
|
var reflection_long_convert_1 = require_reflection_long_convert();
|
||||||
var reflection_scalar_default_1 = require_reflection_scalar_default();
|
var reflection_scalar_default_1 = require_reflection_scalar_default();
|
||||||
var ReflectionBinaryReader = class {
|
var ReflectionBinaryReader = class {
|
||||||
constructor(info3) {
|
constructor(info2) {
|
||||||
this.info = info3;
|
this.info = info2;
|
||||||
}
|
}
|
||||||
prepare() {
|
prepare() {
|
||||||
var _a;
|
var _a;
|
||||||
@@ -25013,8 +25013,8 @@ var require_reflection_binary_writer = __commonJS({
|
|||||||
var assert_1 = require_assert();
|
var assert_1 = require_assert();
|
||||||
var pb_long_1 = require_pb_long();
|
var pb_long_1 = require_pb_long();
|
||||||
var ReflectionBinaryWriter = class {
|
var ReflectionBinaryWriter = class {
|
||||||
constructor(info3) {
|
constructor(info2) {
|
||||||
this.info = info3;
|
this.info = info2;
|
||||||
}
|
}
|
||||||
prepare() {
|
prepare() {
|
||||||
if (!this.fields) {
|
if (!this.fields) {
|
||||||
@@ -25264,9 +25264,9 @@ var require_reflection_merge_partial = __commonJS({
|
|||||||
"use strict";
|
"use strict";
|
||||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||||
exports2.reflectionMergePartial = void 0;
|
exports2.reflectionMergePartial = void 0;
|
||||||
function reflectionMergePartial4(info3, target, source) {
|
function reflectionMergePartial4(info2, target, source) {
|
||||||
let fieldValue, input = source, output;
|
let fieldValue, input = source, output;
|
||||||
for (let field of info3.fields) {
|
for (let field of info2.fields) {
|
||||||
let name = field.localName;
|
let name = field.localName;
|
||||||
if (field.oneof) {
|
if (field.oneof) {
|
||||||
const group = input[field.oneof];
|
const group = input[field.oneof];
|
||||||
@@ -25335,12 +25335,12 @@ var require_reflection_equals = __commonJS({
|
|||||||
Object.defineProperty(exports2, "__esModule", { value: true });
|
Object.defineProperty(exports2, "__esModule", { value: true });
|
||||||
exports2.reflectionEquals = void 0;
|
exports2.reflectionEquals = void 0;
|
||||||
var reflection_info_1 = require_reflection_info();
|
var reflection_info_1 = require_reflection_info();
|
||||||
function reflectionEquals(info3, a, b) {
|
function reflectionEquals(info2, a, b) {
|
||||||
if (a === b)
|
if (a === b)
|
||||||
return true;
|
return true;
|
||||||
if (!a || !b)
|
if (!a || !b)
|
||||||
return false;
|
return false;
|
||||||
for (let field of info3.fields) {
|
for (let field of info2.fields) {
|
||||||
let localName = field.localName;
|
let localName = field.localName;
|
||||||
let val_a = field.oneof ? a[field.oneof][localName] : a[localName];
|
let val_a = field.oneof ? a[field.oneof][localName] : a[localName];
|
||||||
let val_b = field.oneof ? b[field.oneof][localName] : b[localName];
|
let val_b = field.oneof ? b[field.oneof][localName] : b[localName];
|
||||||
@@ -28045,12 +28045,12 @@ var HttpClient = class {
|
|||||||
throw new Error("Client has already been disposed.");
|
throw new Error("Client has already been disposed.");
|
||||||
}
|
}
|
||||||
const parsedUrl = new URL(requestUrl);
|
const parsedUrl = new URL(requestUrl);
|
||||||
let info3 = this._prepareRequest(verb, parsedUrl, headers);
|
let info2 = this._prepareRequest(verb, parsedUrl, headers);
|
||||||
const maxTries = this._allowRetries && RetryableHttpVerbs.includes(verb) ? this._maxRetries + 1 : 1;
|
const maxTries = this._allowRetries && RetryableHttpVerbs.includes(verb) ? this._maxRetries + 1 : 1;
|
||||||
let numTries = 0;
|
let numTries = 0;
|
||||||
let response;
|
let response;
|
||||||
do {
|
do {
|
||||||
response = yield this.requestRaw(info3, data);
|
response = yield this.requestRaw(info2, data);
|
||||||
if (response && response.message && response.message.statusCode === HttpCodes.Unauthorized) {
|
if (response && response.message && response.message.statusCode === HttpCodes.Unauthorized) {
|
||||||
let authenticationHandler;
|
let authenticationHandler;
|
||||||
for (const handler of this.handlers) {
|
for (const handler of this.handlers) {
|
||||||
@@ -28060,7 +28060,7 @@ var HttpClient = class {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (authenticationHandler) {
|
if (authenticationHandler) {
|
||||||
return authenticationHandler.handleAuthentication(this, info3, data);
|
return authenticationHandler.handleAuthentication(this, info2, data);
|
||||||
} else {
|
} else {
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
@@ -28083,8 +28083,8 @@ var HttpClient = class {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
info3 = this._prepareRequest(verb, parsedRedirectUrl, headers);
|
info2 = this._prepareRequest(verb, parsedRedirectUrl, headers);
|
||||||
response = yield this.requestRaw(info3, data);
|
response = yield this.requestRaw(info2, data);
|
||||||
redirectsRemaining--;
|
redirectsRemaining--;
|
||||||
}
|
}
|
||||||
if (!response.message.statusCode || !HttpResponseRetryCodes.includes(response.message.statusCode)) {
|
if (!response.message.statusCode || !HttpResponseRetryCodes.includes(response.message.statusCode)) {
|
||||||
@@ -28113,7 +28113,7 @@ var HttpClient = class {
|
|||||||
* @param info
|
* @param info
|
||||||
* @param data
|
* @param data
|
||||||
*/
|
*/
|
||||||
requestRaw(info3, data) {
|
requestRaw(info2, data) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
return new Promise((resolve2, reject) => {
|
return new Promise((resolve2, reject) => {
|
||||||
function callbackForResult(err, res) {
|
function callbackForResult(err, res) {
|
||||||
@@ -28125,7 +28125,7 @@ var HttpClient = class {
|
|||||||
resolve2(res);
|
resolve2(res);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.requestRawWithCallback(info3, data, callbackForResult);
|
this.requestRawWithCallback(info2, data, callbackForResult);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -28135,12 +28135,12 @@ var HttpClient = class {
|
|||||||
* @param data
|
* @param data
|
||||||
* @param onResult
|
* @param onResult
|
||||||
*/
|
*/
|
||||||
requestRawWithCallback(info3, data, onResult) {
|
requestRawWithCallback(info2, data, onResult) {
|
||||||
if (typeof data === "string") {
|
if (typeof data === "string") {
|
||||||
if (!info3.options.headers) {
|
if (!info2.options.headers) {
|
||||||
info3.options.headers = {};
|
info2.options.headers = {};
|
||||||
}
|
}
|
||||||
info3.options.headers["Content-Length"] = Buffer.byteLength(data, "utf8");
|
info2.options.headers["Content-Length"] = Buffer.byteLength(data, "utf8");
|
||||||
}
|
}
|
||||||
let callbackCalled = false;
|
let callbackCalled = false;
|
||||||
function handleResult(err, res) {
|
function handleResult(err, res) {
|
||||||
@@ -28149,7 +28149,7 @@ var HttpClient = class {
|
|||||||
onResult(err, res);
|
onResult(err, res);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const req = info3.httpModule.request(info3.options, (msg) => {
|
const req = info2.httpModule.request(info2.options, (msg) => {
|
||||||
const res = new HttpClientResponse(msg);
|
const res = new HttpClientResponse(msg);
|
||||||
handleResult(void 0, res);
|
handleResult(void 0, res);
|
||||||
});
|
});
|
||||||
@@ -28161,7 +28161,7 @@ var HttpClient = class {
|
|||||||
if (socket) {
|
if (socket) {
|
||||||
socket.end();
|
socket.end();
|
||||||
}
|
}
|
||||||
handleResult(new Error(`Request timeout: ${info3.options.path}`));
|
handleResult(new Error(`Request timeout: ${info2.options.path}`));
|
||||||
});
|
});
|
||||||
req.on("error", function(err) {
|
req.on("error", function(err) {
|
||||||
handleResult(err);
|
handleResult(err);
|
||||||
@@ -28197,27 +28197,27 @@ var HttpClient = class {
|
|||||||
return this._getProxyAgentDispatcher(parsedUrl, proxyUrl);
|
return this._getProxyAgentDispatcher(parsedUrl, proxyUrl);
|
||||||
}
|
}
|
||||||
_prepareRequest(method, requestUrl, headers) {
|
_prepareRequest(method, requestUrl, headers) {
|
||||||
const info3 = {};
|
const info2 = {};
|
||||||
info3.parsedUrl = requestUrl;
|
info2.parsedUrl = requestUrl;
|
||||||
const usingSsl = info3.parsedUrl.protocol === "https:";
|
const usingSsl = info2.parsedUrl.protocol === "https:";
|
||||||
info3.httpModule = usingSsl ? https : http;
|
info2.httpModule = usingSsl ? https : http;
|
||||||
const defaultPort = usingSsl ? 443 : 80;
|
const defaultPort = usingSsl ? 443 : 80;
|
||||||
info3.options = {};
|
info2.options = {};
|
||||||
info3.options.host = info3.parsedUrl.hostname;
|
info2.options.host = info2.parsedUrl.hostname;
|
||||||
info3.options.port = info3.parsedUrl.port ? parseInt(info3.parsedUrl.port) : defaultPort;
|
info2.options.port = info2.parsedUrl.port ? parseInt(info2.parsedUrl.port) : defaultPort;
|
||||||
info3.options.path = (info3.parsedUrl.pathname || "") + (info3.parsedUrl.search || "");
|
info2.options.path = (info2.parsedUrl.pathname || "") + (info2.parsedUrl.search || "");
|
||||||
info3.options.method = method;
|
info2.options.method = method;
|
||||||
info3.options.headers = this._mergeHeaders(headers);
|
info2.options.headers = this._mergeHeaders(headers);
|
||||||
if (this.userAgent != null) {
|
if (this.userAgent != null) {
|
||||||
info3.options.headers["user-agent"] = this.userAgent;
|
info2.options.headers["user-agent"] = this.userAgent;
|
||||||
}
|
}
|
||||||
info3.options.agent = this._getAgent(info3.parsedUrl);
|
info2.options.agent = this._getAgent(info2.parsedUrl);
|
||||||
if (this.handlers) {
|
if (this.handlers) {
|
||||||
for (const handler of this.handlers) {
|
for (const handler of this.handlers) {
|
||||||
handler.prepareRequest(info3.options);
|
handler.prepareRequest(info2.options);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return info3;
|
return info2;
|
||||||
}
|
}
|
||||||
_mergeHeaders(headers) {
|
_mergeHeaders(headers) {
|
||||||
if (this.requestOptions && this.requestOptions.headers) {
|
if (this.requestOptions && this.requestOptions.headers) {
|
||||||
@@ -30601,14 +30601,14 @@ function disable() {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
function createDebugger(namespace) {
|
function createDebugger(namespace) {
|
||||||
const newDebugger = Object.assign(debug3, {
|
const newDebugger = Object.assign(debug2, {
|
||||||
enabled: enabled(namespace),
|
enabled: enabled(namespace),
|
||||||
destroy,
|
destroy,
|
||||||
log: debugObj.log,
|
log: debugObj.log,
|
||||||
namespace,
|
namespace,
|
||||||
extend
|
extend
|
||||||
});
|
});
|
||||||
function debug3(...args) {
|
function debug2(...args) {
|
||||||
if (!newDebugger.enabled) {
|
if (!newDebugger.enabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -34098,12 +34098,12 @@ function getOperationRequestInfo(request) {
|
|||||||
if (hasOriginalRequest(request)) {
|
if (hasOriginalRequest(request)) {
|
||||||
return getOperationRequestInfo(request[originalRequestSymbol]);
|
return getOperationRequestInfo(request[originalRequestSymbol]);
|
||||||
}
|
}
|
||||||
let info3 = state2.operationRequestMap.get(request);
|
let info2 = state2.operationRequestMap.get(request);
|
||||||
if (!info3) {
|
if (!info2) {
|
||||||
info3 = {};
|
info2 = {};
|
||||||
state2.operationRequestMap.set(request, info3);
|
state2.operationRequestMap.set(request, info2);
|
||||||
}
|
}
|
||||||
return info3;
|
return info2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// node_modules/@azure/core-client/dist/esm/deserializationPolicy.js
|
// node_modules/@azure/core-client/dist/esm/deserializationPolicy.js
|
||||||
@@ -62241,21 +62241,6 @@ function saveCacheV2(paths_1, key_1, options_1) {
|
|||||||
// src/save-cache.ts
|
// src/save-cache.ts
|
||||||
var pep440 = __toESM(require_pep440(), 1);
|
var pep440 = __toESM(require_pep440(), 1);
|
||||||
|
|
||||||
// src/utils/logging.ts
|
|
||||||
var quiet;
|
|
||||||
function isQuiet() {
|
|
||||||
if (quiet === void 0) {
|
|
||||||
quiet = typeof getInput === "function" && getInput("quiet") === "true";
|
|
||||||
}
|
|
||||||
return quiet;
|
|
||||||
}
|
|
||||||
function info2(msg) {
|
|
||||||
if (!isQuiet()) {
|
|
||||||
info(msg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var warning2 = warning;
|
|
||||||
|
|
||||||
// src/cache/restore-cache.ts
|
// src/cache/restore-cache.ts
|
||||||
var STATE_CACHE_KEY = "cache-key";
|
var STATE_CACHE_KEY = "cache-key";
|
||||||
var STATE_CACHE_MATCHED_KEY = "cache-matched-key";
|
var STATE_CACHE_MATCHED_KEY = "cache-matched-key";
|
||||||
@@ -62342,14 +62327,9 @@ function skipComment(str, ptr) {
|
|||||||
}
|
}
|
||||||
function skipVoid(str, ptr, banNewLines, banComments) {
|
function skipVoid(str, ptr, banNewLines, banComments) {
|
||||||
let c;
|
let c;
|
||||||
while (1) {
|
|
||||||
while ((c = str[ptr]) === " " || c === " " || !banNewLines && (c === "\n" || c === "\r" && str[ptr + 1] === "\n"))
|
while ((c = str[ptr]) === " " || c === " " || !banNewLines && (c === "\n" || c === "\r" && str[ptr + 1] === "\n"))
|
||||||
ptr++;
|
ptr++;
|
||||||
if (banComments || c !== "#")
|
return banComments || c !== "#" ? ptr : skipVoid(str, skipComment(str, ptr), banNewLines);
|
||||||
break;
|
|
||||||
ptr = skipComment(str, ptr);
|
|
||||||
}
|
|
||||||
return ptr;
|
|
||||||
}
|
}
|
||||||
function skipUntil(str, ptr, sep7, end, banNewLines = false) {
|
function skipUntil(str, ptr, sep7, end, banNewLines = false) {
|
||||||
if (!end) {
|
if (!end) {
|
||||||
@@ -63010,9 +62990,7 @@ function loadInputs() {
|
|||||||
const pythonDir = getUvPythonDir();
|
const pythonDir = getUvPythonDir();
|
||||||
const githubToken = getInput("github-token");
|
const githubToken = getInput("github-token");
|
||||||
const manifestFile = getManifestFile();
|
const manifestFile = getManifestFile();
|
||||||
const downloadFromAstralMirror = getInput("download-from-astral-mirror") === "true";
|
|
||||||
const addProblemMatchers = getInput("add-problem-matchers") === "true";
|
const addProblemMatchers = getInput("add-problem-matchers") === "true";
|
||||||
const quiet2 = getInput("quiet") === "true";
|
|
||||||
const resolutionStrategy = getResolutionStrategy();
|
const resolutionStrategy = getResolutionStrategy();
|
||||||
return {
|
return {
|
||||||
activateEnvironment,
|
activateEnvironment,
|
||||||
@@ -63022,7 +63000,6 @@ function loadInputs() {
|
|||||||
cachePython,
|
cachePython,
|
||||||
cacheSuffix,
|
cacheSuffix,
|
||||||
checksum,
|
checksum,
|
||||||
downloadFromAstralMirror,
|
|
||||||
enableCache,
|
enableCache,
|
||||||
githubToken,
|
githubToken,
|
||||||
ignoreEmptyWorkdir,
|
ignoreEmptyWorkdir,
|
||||||
@@ -63032,7 +63009,6 @@ function loadInputs() {
|
|||||||
pruneCache: pruneCache2,
|
pruneCache: pruneCache2,
|
||||||
pythonDir,
|
pythonDir,
|
||||||
pythonVersion,
|
pythonVersion,
|
||||||
quiet: quiet2,
|
|
||||||
resolutionStrategy,
|
resolutionStrategy,
|
||||||
restoreCache: restoreCache2,
|
restoreCache: restoreCache2,
|
||||||
saveCache: saveCache4,
|
saveCache: saveCache4,
|
||||||
@@ -63056,7 +63032,7 @@ function getVenvPath(workingDirectory, activateEnvironment) {
|
|||||||
const venvPathInput = getInput("venv-path");
|
const venvPathInput = getInput("venv-path");
|
||||||
if (venvPathInput !== "") {
|
if (venvPathInput !== "") {
|
||||||
if (!activateEnvironment) {
|
if (!activateEnvironment) {
|
||||||
warning2("venv-path is only used when activate-environment is true");
|
warning("venv-path is only used when activate-environment is true");
|
||||||
}
|
}
|
||||||
const tildeExpanded = expandTilde(venvPathInput);
|
const tildeExpanded = expandTilde(venvPathInput);
|
||||||
return normalizePath(resolveRelativePath(workingDirectory, tildeExpanded));
|
return normalizePath(resolveRelativePath(workingDirectory, tildeExpanded));
|
||||||
@@ -63119,7 +63095,7 @@ function getCacheLocalPath(workingDirectory, versionFile, enableCache) {
|
|||||||
return { path: cacheDirFromConfig, source: 1 /* Config */ };
|
return { path: cacheDirFromConfig, source: 1 /* Config */ };
|
||||||
}
|
}
|
||||||
if (process.env.UV_CACHE_DIR !== void 0) {
|
if (process.env.UV_CACHE_DIR !== void 0) {
|
||||||
info2(`UV_CACHE_DIR is already set to ${process.env.UV_CACHE_DIR}`);
|
info(`UV_CACHE_DIR is already set to ${process.env.UV_CACHE_DIR}`);
|
||||||
return { path: process.env.UV_CACHE_DIR, source: 2 /* Env */ };
|
return { path: process.env.UV_CACHE_DIR, source: 2 /* Env */ };
|
||||||
}
|
}
|
||||||
if (enableCache) {
|
if (enableCache) {
|
||||||
@@ -63152,12 +63128,12 @@ function getCacheDirFromConfig(workingDirectory, versionFile) {
|
|||||||
try {
|
try {
|
||||||
const cacheDir = getConfigValueFromTomlFile(resolvedPath, "cache-dir");
|
const cacheDir = getConfigValueFromTomlFile(resolvedPath, "cache-dir");
|
||||||
if (cacheDir !== void 0) {
|
if (cacheDir !== void 0) {
|
||||||
info2(`Found cache-dir in ${resolvedPath}: ${cacheDir}`);
|
info(`Found cache-dir in ${resolvedPath}: ${cacheDir}`);
|
||||||
return cacheDir;
|
return cacheDir;
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
const message = err.message;
|
const message = err.message;
|
||||||
warning2(`Error while parsing ${filePath}: ${message}`);
|
warning(`Error while parsing ${filePath}: ${message}`);
|
||||||
return void 0;
|
return void 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -63165,7 +63141,7 @@ function getCacheDirFromConfig(workingDirectory, versionFile) {
|
|||||||
}
|
}
|
||||||
function getUvPythonDir() {
|
function getUvPythonDir() {
|
||||||
if (process.env.UV_PYTHON_INSTALL_DIR !== void 0) {
|
if (process.env.UV_PYTHON_INSTALL_DIR !== void 0) {
|
||||||
info2(
|
info(
|
||||||
`UV_PYTHON_INSTALL_DIR is already set to ${process.env.UV_PYTHON_INSTALL_DIR}`
|
`UV_PYTHON_INSTALL_DIR is already set to ${process.env.UV_PYTHON_INSTALL_DIR}`
|
||||||
);
|
);
|
||||||
return process.env.UV_PYTHON_INSTALL_DIR;
|
return process.env.UV_PYTHON_INSTALL_DIR;
|
||||||
@@ -63235,22 +63211,6 @@ function getResolutionStrategy() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// src/save-cache.ts
|
// src/save-cache.ts
|
||||||
function formatUnexpectedFailure(error2) {
|
|
||||||
if (error2 instanceof Error) {
|
|
||||||
return error2.stack ?? error2.message;
|
|
||||||
}
|
|
||||||
return String(error2);
|
|
||||||
}
|
|
||||||
function failUnexpectedly(event, error2) {
|
|
||||||
setFailed(`${event}: ${formatUnexpectedFailure(error2)}`);
|
|
||||||
process.exit(1);
|
|
||||||
}
|
|
||||||
process.on("uncaughtException", (error2) => {
|
|
||||||
failUnexpectedly("Uncaught exception", error2);
|
|
||||||
});
|
|
||||||
process.on("unhandledRejection", (reason) => {
|
|
||||||
failUnexpectedly("Unhandled promise rejection", reason);
|
|
||||||
});
|
|
||||||
async function run() {
|
async function run() {
|
||||||
try {
|
try {
|
||||||
const inputs = loadInputs();
|
const inputs = loadInputs();
|
||||||
@@ -63258,7 +63218,7 @@ async function run() {
|
|||||||
if (inputs.saveCache) {
|
if (inputs.saveCache) {
|
||||||
await saveCache3(inputs);
|
await saveCache3(inputs);
|
||||||
} else {
|
} else {
|
||||||
info2("save-cache is false. Skipping save cache step.");
|
info("save-cache is false. Skipping save cache step.");
|
||||||
}
|
}
|
||||||
await new Promise((resolve2) => setTimeout(resolve2, 100));
|
await new Promise((resolve2) => setTimeout(resolve2, 100));
|
||||||
process.exit(0);
|
process.exit(0);
|
||||||
@@ -63272,11 +63232,11 @@ async function saveCache3(inputs) {
|
|||||||
const cacheKey = getState(STATE_CACHE_KEY);
|
const cacheKey = getState(STATE_CACHE_KEY);
|
||||||
const matchedKey = getState(STATE_CACHE_MATCHED_KEY);
|
const matchedKey = getState(STATE_CACHE_MATCHED_KEY);
|
||||||
if (!cacheKey) {
|
if (!cacheKey) {
|
||||||
warning2("Error retrieving cache key from state.");
|
warning("Error retrieving cache key from state.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (matchedKey === cacheKey) {
|
if (matchedKey === cacheKey) {
|
||||||
info2(`Cache hit occurred on key ${cacheKey}, not saving cache.`);
|
info(`Cache hit occurred on key ${cacheKey}, not saving cache.`);
|
||||||
} else {
|
} else {
|
||||||
if (inputs.pruneCache) {
|
if (inputs.pruneCache) {
|
||||||
await pruneCache();
|
await pruneCache();
|
||||||
@@ -63284,7 +63244,7 @@ async function saveCache3(inputs) {
|
|||||||
const actualCachePath = getUvCachePath(inputs);
|
const actualCachePath = getUvCachePath(inputs);
|
||||||
if (!fs7.existsSync(actualCachePath)) {
|
if (!fs7.existsSync(actualCachePath)) {
|
||||||
if (inputs.ignoreNothingToCache) {
|
if (inputs.ignoreNothingToCache) {
|
||||||
info2(
|
info(
|
||||||
"No cacheable uv cache paths were found. Ignoring because ignore-nothing-to-cache is enabled."
|
"No cacheable uv cache paths were found. Ignoring because ignore-nothing-to-cache is enabled."
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
@@ -63303,7 +63263,7 @@ async function saveCache3(inputs) {
|
|||||||
}
|
}
|
||||||
if (inputs.cachePython) {
|
if (inputs.cachePython) {
|
||||||
if (!fs7.existsSync(inputs.pythonDir)) {
|
if (!fs7.existsSync(inputs.pythonDir)) {
|
||||||
warning2(
|
warning(
|
||||||
`Python cache path ${inputs.pythonDir} does not exist on disk. Skipping Python cache save because no managed Python installation was found. If you want uv to install managed Python instead of using a system interpreter, set UV_PYTHON_PREFERENCE=only-managed.`
|
`Python cache path ${inputs.pythonDir} does not exist on disk. Skipping Python cache save because no managed Python installation was found. If you want uv to install managed Python instead of using a system interpreter, set UV_PYTHON_PREFERENCE=only-managed.`
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
@@ -63326,7 +63286,7 @@ async function pruneCache() {
|
|||||||
if (forceSupported) {
|
if (forceSupported) {
|
||||||
execArgs.push("--force");
|
execArgs.push("--force");
|
||||||
}
|
}
|
||||||
info2("Pruning cache...");
|
info("Pruning cache...");
|
||||||
const uvPath = getState(STATE_UV_PATH);
|
const uvPath = getState(STATE_UV_PATH);
|
||||||
await exec(uvPath, execArgs, options);
|
await exec(uvPath, execArgs, options);
|
||||||
}
|
}
|
||||||
@@ -63337,7 +63297,7 @@ function getUvCachePath(inputs) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (process.env.UV_CACHE_DIR && process.env.UV_CACHE_DIR !== inputs.cacheLocalPath.path) {
|
if (process.env.UV_CACHE_DIR && process.env.UV_CACHE_DIR !== inputs.cacheLocalPath.path) {
|
||||||
warning2(
|
warning(
|
||||||
`The environment variable UV_CACHE_DIR has been changed to "${process.env.UV_CACHE_DIR}", by an action or step running after astral-sh/setup-uv. This can lead to unexpected behavior. If you expected this to happen set the cache-local-path input to "${process.env.UV_CACHE_DIR}" instead of "${inputs.cacheLocalPath.path}".`
|
`The environment variable UV_CACHE_DIR has been changed to "${process.env.UV_CACHE_DIR}", by an action or step running after astral-sh/setup-uv. This can lead to unexpected behavior. If you expected this to happen set the cache-local-path input to "${process.env.UV_CACHE_DIR}" instead of "${inputs.cacheLocalPath.path}".`
|
||||||
);
|
);
|
||||||
return process.env.UV_CACHE_DIR;
|
return process.env.UV_CACHE_DIR;
|
||||||
@@ -63347,12 +63307,14 @@ function getUvCachePath(inputs) {
|
|||||||
async function saveCacheToKey(cacheKey, cachePath, stateKey, cacheName) {
|
async function saveCacheToKey(cacheKey, cachePath, stateKey, cacheName) {
|
||||||
const matchedKey = getState(stateKey);
|
const matchedKey = getState(stateKey);
|
||||||
if (matchedKey === cacheKey) {
|
if (matchedKey === cacheKey) {
|
||||||
info2(`${cacheName} hit occurred on key ${cacheKey}, not saving cache.`);
|
info(
|
||||||
|
`${cacheName} hit occurred on key ${cacheKey}, not saving cache.`
|
||||||
|
);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
info2(`Including ${cacheName} path: ${cachePath}`);
|
info(`Including ${cacheName} path: ${cachePath}`);
|
||||||
await saveCache2([cachePath], cacheKey);
|
await saveCache2([cachePath], cacheKey);
|
||||||
info2(`${cacheName} saved with key: ${cacheKey}`);
|
info(`${cacheName} saved with key: ${cacheKey}`);
|
||||||
}
|
}
|
||||||
run();
|
run();
|
||||||
// Annotate the CommonJS export names for ESM import in node:
|
// Annotate the CommonJS export names for ESM import in node:
|
||||||
|
|||||||
+1433
-2257
File diff suppressed because one or more lines are too long
+1291
-2093
File diff suppressed because one or more lines are too long
Generated
+325
-325
File diff suppressed because it is too large
Load Diff
+5
-5
@@ -35,19 +35,19 @@
|
|||||||
"@actions/io": "^3.0.2",
|
"@actions/io": "^3.0.2",
|
||||||
"@actions/tool-cache": "^4.0.0",
|
"@actions/tool-cache": "^4.0.0",
|
||||||
"@renovatebot/pep440": "^4.2.2",
|
"@renovatebot/pep440": "^4.2.2",
|
||||||
"smol-toml": "^1.6.1",
|
"smol-toml": "^1.6.0",
|
||||||
"undici": "^8.3.0"
|
"undici": "^7.24.2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@biomejs/biome": "^2.4.15",
|
"@biomejs/biome": "^2.4.7",
|
||||||
"@types/js-yaml": "^4.0.9",
|
"@types/js-yaml": "^4.0.9",
|
||||||
"@types/node": "^25.5.0",
|
"@types/node": "^25.5.0",
|
||||||
"@types/semver": "^7.7.1",
|
"@types/semver": "^7.7.1",
|
||||||
"@vercel/ncc": "^0.38.4",
|
"@vercel/ncc": "^0.38.4",
|
||||||
"esbuild": "^0.28.0",
|
"esbuild": "^0.27.4",
|
||||||
"jest": "^30.3.0",
|
"jest": "^30.3.0",
|
||||||
"js-yaml": "^4.1.1",
|
"js-yaml": "^4.1.1",
|
||||||
"ts-jest": "^29.4.11",
|
"ts-jest": "^29.4.6",
|
||||||
"typescript": "^5.9.3"
|
"typescript": "^5.9.3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Vendored
+7
-8
@@ -2,7 +2,6 @@ import * as cache from "@actions/cache";
|
|||||||
import * as core from "@actions/core";
|
import * as core from "@actions/core";
|
||||||
import { hashFiles } from "../hash/hash-files";
|
import { hashFiles } from "../hash/hash-files";
|
||||||
import type { SetupInputs } from "../utils/inputs";
|
import type { SetupInputs } from "../utils/inputs";
|
||||||
import * as log from "../utils/logging";
|
|
||||||
import { getArch, getOSNameVersion, getPlatform } from "../utils/platforms";
|
import { getArch, getOSNameVersion, getPlatform } from "../utils/platforms";
|
||||||
|
|
||||||
export const STATE_CACHE_KEY = "cache-key";
|
export const STATE_CACHE_KEY = "cache-key";
|
||||||
@@ -20,7 +19,7 @@ export async function restoreCache(
|
|||||||
core.setOutput("cache-key", cacheKey);
|
core.setOutput("cache-key", cacheKey);
|
||||||
|
|
||||||
if (!inputs.restoreCache) {
|
if (!inputs.restoreCache) {
|
||||||
log.info("restore-cache is false. Skipping restore cache step.");
|
core.info("restore-cache is false. Skipping restore cache step.");
|
||||||
core.setOutput("python-cache-hit", false);
|
core.setOutput("python-cache-hit", false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -56,7 +55,7 @@ async function restoreCacheFromKey(
|
|||||||
stateKey: string,
|
stateKey: string,
|
||||||
outputKey: string,
|
outputKey: string,
|
||||||
): Promise<void> {
|
): Promise<void> {
|
||||||
log.info(
|
core.info(
|
||||||
`Trying to restore cache from GitHub Actions cache with key: ${cacheKey}`,
|
`Trying to restore cache from GitHub Actions cache with key: ${cacheKey}`,
|
||||||
);
|
);
|
||||||
let matchedKey: string | undefined;
|
let matchedKey: string | undefined;
|
||||||
@@ -64,7 +63,7 @@ async function restoreCacheFromKey(
|
|||||||
matchedKey = await cache.restoreCache([cachePath], cacheKey);
|
matchedKey = await cache.restoreCache([cachePath], cacheKey);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
const message = (err as Error).message;
|
const message = (err as Error).message;
|
||||||
log.warning(message);
|
core.warning(message);
|
||||||
core.setOutput(outputKey, false);
|
core.setOutput(outputKey, false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -78,7 +77,7 @@ async function computeKeys(
|
|||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
let cacheDependencyPathHash = "-";
|
let cacheDependencyPathHash = "-";
|
||||||
if (inputs.cacheDependencyGlob !== "") {
|
if (inputs.cacheDependencyGlob !== "") {
|
||||||
log.info(
|
core.info(
|
||||||
`Searching files using cache dependency glob: ${inputs.cacheDependencyGlob.split("\n").join(",")}`,
|
`Searching files using cache dependency glob: ${inputs.cacheDependencyGlob.split("\n").join(",")}`,
|
||||||
);
|
);
|
||||||
cacheDependencyPathHash += await hashFiles(
|
cacheDependencyPathHash += await hashFiles(
|
||||||
@@ -86,7 +85,7 @@ async function computeKeys(
|
|||||||
true,
|
true,
|
||||||
);
|
);
|
||||||
if (cacheDependencyPathHash === "-") {
|
if (cacheDependencyPathHash === "-") {
|
||||||
log.warning(
|
core.warning(
|
||||||
`No file matched to [${inputs.cacheDependencyGlob.split("\n").join(",")}]. The cache will never get invalidated. Make sure you have checked out the target repository and configured the cache-dependency-glob input correctly.`,
|
`No file matched to [${inputs.cacheDependencyGlob.split("\n").join(",")}]. The cache will never get invalidated. Make sure you have checked out the target repository and configured the cache-dependency-glob input correctly.`,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -110,12 +109,12 @@ function handleMatchResult(
|
|||||||
outputKey: string,
|
outputKey: string,
|
||||||
): void {
|
): void {
|
||||||
if (!matchedKey) {
|
if (!matchedKey) {
|
||||||
log.info(`No GitHub Actions cache found for key: ${primaryKey}`);
|
core.info(`No GitHub Actions cache found for key: ${primaryKey}`);
|
||||||
core.setOutput(outputKey, false);
|
core.setOutput(outputKey, false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
core.saveState(stateKey, matchedKey);
|
core.saveState(stateKey, matchedKey);
|
||||||
log.info(`cache restored from GitHub Actions cache with key: ${matchedKey}`);
|
core.info(`cache restored from GitHub Actions cache with key: ${matchedKey}`);
|
||||||
core.setOutput(outputKey, true);
|
core.setOutput(outputKey, true);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,77 +1,5 @@
|
|||||||
// AUTOGENERATED_DO_NOT_EDIT
|
// AUTOGENERATED_DO_NOT_EDIT
|
||||||
export const KNOWN_CHECKSUMS: { [key: string]: string } = {
|
export const KNOWN_CHECKSUMS: { [key: string]: string } = {
|
||||||
"aarch64-apple-darwin-0.11.19":
|
|
||||||
"d8f59c38e8c4168ee468d423cd63184be12fa6995a4283d41ee1a14d003c9453",
|
|
||||||
"aarch64-pc-windows-msvc-0.11.19":
|
|
||||||
"5592a990a9d9901fd0d23992d872f2ec3ca91b7bbd3d5f0bb5e6f42b851493d8",
|
|
||||||
"aarch64-unknown-linux-gnu-0.11.19":
|
|
||||||
"83b13ab184a45b7d9a3b0e4b10eaebd50ad41e66cb16dcce8e60aa7be13ae399",
|
|
||||||
"aarch64-unknown-linux-musl-0.11.19":
|
|
||||||
"767629b64cdf078c32e42819db28d5ca868b8dc7e3a879967fadc3e4f7f66be3",
|
|
||||||
"arm-unknown-linux-musleabihf-0.11.19":
|
|
||||||
"638bb5aac6419e062149b4600c0030e2203dfbb8bf6b0db740755bb19f458abf",
|
|
||||||
"armv7-unknown-linux-gnueabihf-0.11.19":
|
|
||||||
"56c307d18acadb1bee2b76bde39cedcf0d29f93102c52f39f8c0c8a42dffe96e",
|
|
||||||
"armv7-unknown-linux-musleabihf-0.11.19":
|
|
||||||
"d807c33e89c27430a68b7be52a8a0d39e08c91dba0fa295172c6ff2ce2d07a27",
|
|
||||||
"i686-pc-windows-msvc-0.11.19":
|
|
||||||
"e701a69f0ab192fde8ea3f4cfdedfa6cade0c92cea2e350613b6528e966b50c7",
|
|
||||||
"i686-unknown-linux-gnu-0.11.19":
|
|
||||||
"d0ef2e69c44a2763161d5b5f40b722fe81e0d16bed217cbc526fb5a3640802b3",
|
|
||||||
"i686-unknown-linux-musl-0.11.19":
|
|
||||||
"f58e41864cb91fbd2306a7b46718fdd0c1029169fe03347719771a1c68a527e6",
|
|
||||||
"powerpc64le-unknown-linux-gnu-0.11.19":
|
|
||||||
"b6dcd94b5c456d11787d1e6d01b5f9a34b456e22e2dde9bbae3531dc7676c0d8",
|
|
||||||
"riscv64gc-unknown-linux-gnu-0.11.19":
|
|
||||||
"4b9ca6bd2ed1e4c2658e5f85cf8a208c192490d9d24dbf2c36d61ea10a389778",
|
|
||||||
"riscv64gc-unknown-linux-musl-0.11.19":
|
|
||||||
"184232b4e0de4d6a674d57b1d6d8c39a3c5a5dbc27f95ed972c46974d21b0115",
|
|
||||||
"s390x-unknown-linux-gnu-0.11.19":
|
|
||||||
"c4535a5f9f27a94df384ea8140b78c3e7c083d4130cd341fd826b5ab343979fb",
|
|
||||||
"x86_64-apple-darwin-0.11.19":
|
|
||||||
"1585f415cade9f061e7f00fe5b00030a79ccfac60c650242ce639ba946138d40",
|
|
||||||
"x86_64-pc-windows-msvc-0.11.19":
|
|
||||||
"1665fc8e37b5d70a134820d6d7891747471a2ac8bc940ee7af0b69fd03b28d61",
|
|
||||||
"x86_64-unknown-linux-gnu-0.11.19":
|
|
||||||
"7035608168e106375b36d0c818d537a889c51a8625fe7f8f7cad5e62b947c368",
|
|
||||||
"x86_64-unknown-linux-musl-0.11.19":
|
|
||||||
"c4c0d0a383413261af5f0f0743e1292f4aafbe907987ed83bd0ac66f0a3d7e20",
|
|
||||||
"aarch64-apple-darwin-0.11.18":
|
|
||||||
"1a7adf8dadae3b55853115d13a8bf564d219597ad13824b93b213706933863e5",
|
|
||||||
"aarch64-pc-windows-msvc-0.11.18":
|
|
||||||
"0689e1a40d36b387522d2b1b865cd98a15ddd4a7507e256ad93be6f6a335fec1",
|
|
||||||
"aarch64-unknown-linux-gnu-0.11.18":
|
|
||||||
"0f03c6648df1c159557f4222c0f37250f84733fb88d6fc3c16770e17c177a8c9",
|
|
||||||
"aarch64-unknown-linux-musl-0.11.18":
|
|
||||||
"6d895725333680bf7633ad635baff8e49dc45d3b52e00b2b3adf6ced41f2ebe2",
|
|
||||||
"arm-unknown-linux-musleabihf-0.11.18":
|
|
||||||
"c4fe354b28c489fa6649531808076c43eb3a34122df49b0a3005bb75dbf101c3",
|
|
||||||
"armv7-unknown-linux-gnueabihf-0.11.18":
|
|
||||||
"a70a8b1124dc1fabcce9f2bbe6591c72a05d49df74125d1c327b5745f2becbb6",
|
|
||||||
"armv7-unknown-linux-musleabihf-0.11.18":
|
|
||||||
"f8b6f4df3ff9d142a25892be575ade438672a8353ad71997f7db88e9b9a1062d",
|
|
||||||
"i686-pc-windows-msvc-0.11.18":
|
|
||||||
"7505112a7bf72f50391c50f2aa07950b95b3c43c7d9fd4da5626876407d15dda",
|
|
||||||
"i686-unknown-linux-gnu-0.11.18":
|
|
||||||
"5f3df0d62af1d174a06b82a6faf1a5e9a1f729b87d11c7d9cd87d4241e04f23d",
|
|
||||||
"i686-unknown-linux-musl-0.11.18":
|
|
||||||
"4237cfcd03fb8767a7ec713ab3db14381d83bbd0bf5ccc88cd6f28ac8c2c616f",
|
|
||||||
"powerpc64le-unknown-linux-gnu-0.11.18":
|
|
||||||
"fc8f46a198e540ca2d89fd9480da0648d673ff3e25b4048c82ca5c292a478052",
|
|
||||||
"riscv64gc-unknown-linux-gnu-0.11.18":
|
|
||||||
"cdb0555db7828bbd1dc24e55171b8ac3dbbc24fe17b6a7387783cd4d543a1538",
|
|
||||||
"riscv64gc-unknown-linux-musl-0.11.18":
|
|
||||||
"3d5b533080bb593c82b281b8d289e29d51b97c0994655099845752e948181fe2",
|
|
||||||
"s390x-unknown-linux-gnu-0.11.18":
|
|
||||||
"7a91aa963680f2fe14ebf89291cf8eafcff634eccdeb6d301e0252b282171818",
|
|
||||||
"x86_64-apple-darwin-0.11.18":
|
|
||||||
"00a61e3db99b53c927a7e6c4ccdccb898aa3253d07928822211e9dc570a25661",
|
|
||||||
"x86_64-pc-windows-msvc-0.11.18":
|
|
||||||
"bf8e0021336b7c77bd80a078b612125f385b08f541437edaea8c8ca9e574db0d",
|
|
||||||
"x86_64-unknown-linux-gnu-0.11.18":
|
|
||||||
"588f3e360f69ce02b6982aa99f2240e803933a6b7e176ac01617830adf955add",
|
|
||||||
"x86_64-unknown-linux-musl-0.11.18":
|
|
||||||
"a095a969fc8357f42e35652e0554525a47a29010ddb814bd82650c2ffa7d6d62",
|
|
||||||
"aarch64-apple-darwin-0.11.17":
|
"aarch64-apple-darwin-0.11.17":
|
||||||
"2a162f6b90ff3691a2f9cae1622e066a3ce592e110f66670cdcc841324b28226",
|
"2a162f6b90ff3691a2f9cae1622e066a3ce592e110f66670cdcc841324b28226",
|
||||||
"aarch64-pc-windows-msvc-0.11.17":
|
"aarch64-pc-windows-msvc-0.11.17":
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ import {
|
|||||||
TOOL_CACHE_NAME,
|
TOOL_CACHE_NAME,
|
||||||
VERSIONS_MANIFEST_URL,
|
VERSIONS_MANIFEST_URL,
|
||||||
} from "../utils/constants";
|
} from "../utils/constants";
|
||||||
import * as log from "../utils/logging";
|
|
||||||
import type { Architecture, Platform } from "../utils/platforms";
|
import type { Architecture, Platform } from "../utils/platforms";
|
||||||
import { validateChecksum } from "./checksum/checksum";
|
import { validateChecksum } from "./checksum/checksum";
|
||||||
import { getArtifact } from "./manifest";
|
import { getArtifact } from "./manifest";
|
||||||
@@ -37,7 +36,6 @@ export async function downloadVersion(
|
|||||||
checksum: string | undefined,
|
checksum: string | undefined,
|
||||||
githubToken: string,
|
githubToken: string,
|
||||||
manifestUrl?: string,
|
manifestUrl?: string,
|
||||||
downloadFromAstralMirror = true,
|
|
||||||
): Promise<{ version: string; cachedToolDir: string }> {
|
): Promise<{ version: string; cachedToolDir: string }> {
|
||||||
const artifact = await getArtifact(version, arch, platform, manifestUrl);
|
const artifact = await getArtifact(version, arch, platform, manifestUrl);
|
||||||
|
|
||||||
@@ -54,9 +52,7 @@ export async function downloadVersion(
|
|||||||
? checksum
|
? checksum
|
||||||
: resolveChecksum(checksum, artifact.checksum);
|
: resolveChecksum(checksum, artifact.checksum);
|
||||||
|
|
||||||
const mirrorUrl = downloadFromAstralMirror
|
const mirrorUrl = rewriteToMirror(artifact.downloadUrl);
|
||||||
? rewriteToMirror(artifact.downloadUrl)
|
|
||||||
: undefined;
|
|
||||||
const downloadUrl = mirrorUrl ?? artifact.downloadUrl;
|
const downloadUrl = mirrorUrl ?? artifact.downloadUrl;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -74,7 +70,7 @@ export async function downloadVersion(
|
|||||||
throw err;
|
throw err;
|
||||||
}
|
}
|
||||||
|
|
||||||
log.warning(
|
core.warning(
|
||||||
`Failed to download from mirror, falling back to GitHub Releases: ${(err as Error).message}`,
|
`Failed to download from mirror, falling back to GitHub Releases: ${(err as Error).message}`,
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -124,7 +120,7 @@ async function downloadArtifact(
|
|||||||
checksum: string | undefined,
|
checksum: string | undefined,
|
||||||
githubToken: string | undefined,
|
githubToken: string | undefined,
|
||||||
): Promise<{ version: string; cachedToolDir: string }> {
|
): Promise<{ version: string; cachedToolDir: string }> {
|
||||||
log.info(`Downloading uv from "${downloadUrl}" ...`);
|
core.info(`Downloading uv from "${downloadUrl}" ...`);
|
||||||
const downloadPath = await tc.downloadTool(
|
const downloadPath = await tc.downloadTool(
|
||||||
downloadUrl,
|
downloadUrl,
|
||||||
undefined,
|
undefined,
|
||||||
@@ -140,7 +136,7 @@ async function downloadArtifact(
|
|||||||
// so this may fail if another tar, like gnu tar, ends up being used.
|
// so this may fail if another tar, like gnu tar, ends up being used.
|
||||||
uvDir = await tc.extractTar(downloadPath, undefined, "x");
|
uvDir = await tc.extractTar(downloadPath, undefined, "x");
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
log.info(
|
core.info(
|
||||||
`Extracting with tar failed, falling back to zip extraction: ${(err as Error).message}`,
|
`Extracting with tar failed, falling back to zip extraction: ${(err as Error).message}`,
|
||||||
);
|
);
|
||||||
const extension = getExtension(platform);
|
const extension = getExtension(platform);
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
import * as core from "@actions/core";
|
import * as core from "@actions/core";
|
||||||
import { VERSIONS_MANIFEST_URL } from "../utils/constants";
|
import { VERSIONS_MANIFEST_URL } from "../utils/constants";
|
||||||
import { fetch } from "../utils/fetch";
|
import { fetch } from "../utils/fetch";
|
||||||
import * as log from "../utils/logging";
|
|
||||||
import { selectDefaultVariant } from "./variant-selection";
|
import { selectDefaultVariant } from "./variant-selection";
|
||||||
|
|
||||||
export interface ManifestArtifact {
|
export interface ManifestArtifact {
|
||||||
@@ -34,7 +33,7 @@ export async function fetchManifest(
|
|||||||
return cachedVersions;
|
return cachedVersions;
|
||||||
}
|
}
|
||||||
|
|
||||||
log.info(`Fetching manifest data from ${manifestUrl} ...`);
|
core.info(`Fetching manifest data from ${manifestUrl} ...`);
|
||||||
const response = await fetch(manifestUrl, {});
|
const response = await fetch(manifestUrl, {});
|
||||||
if (!response.ok) {
|
if (!response.ok) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
@@ -112,7 +111,7 @@ export async function getLatestVersion(
|
|||||||
export async function getAllVersions(
|
export async function getAllVersions(
|
||||||
manifestUrl: string = VERSIONS_MANIFEST_URL,
|
manifestUrl: string = VERSIONS_MANIFEST_URL,
|
||||||
): Promise<string[]> {
|
): Promise<string[]> {
|
||||||
log.info(
|
core.info(
|
||||||
`Getting available versions from ${manifestSource(manifestUrl)} ...`,
|
`Getting available versions from ${manifestSource(manifestUrl)} ...`,
|
||||||
);
|
);
|
||||||
const versions = await fetchManifest(manifestUrl);
|
const versions = await fetchManifest(manifestUrl);
|
||||||
|
|||||||
@@ -2,8 +2,8 @@ import * as crypto from "node:crypto";
|
|||||||
import * as fs from "node:fs";
|
import * as fs from "node:fs";
|
||||||
import * as stream from "node:stream";
|
import * as stream from "node:stream";
|
||||||
import * as util from "node:util";
|
import * as util from "node:util";
|
||||||
|
import * as core from "@actions/core";
|
||||||
import { create } from "@actions/glob";
|
import { create } from "@actions/glob";
|
||||||
import * as log from "../utils/logging";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Hashes files matching the given glob pattern.
|
* Hashes files matching the given glob pattern.
|
||||||
@@ -19,7 +19,7 @@ export async function hashFiles(
|
|||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
const globber = await create(pattern);
|
const globber = await create(pattern);
|
||||||
let hasMatch = false;
|
let hasMatch = false;
|
||||||
const writeDelegate = verbose ? log.info : log.debug;
|
const writeDelegate = verbose ? core.info : core.debug;
|
||||||
const result = crypto.createHash("sha256");
|
const result = crypto.createHash("sha256");
|
||||||
let count = 0;
|
let count = 0;
|
||||||
for await (const file of globber.globGenerator()) {
|
for await (const file of globber.globGenerator()) {
|
||||||
|
|||||||
+12
-31
@@ -10,27 +10,6 @@ import {
|
|||||||
} from "./cache/restore-cache";
|
} from "./cache/restore-cache";
|
||||||
import { STATE_UV_PATH, STATE_UV_VERSION } from "./utils/constants";
|
import { STATE_UV_PATH, STATE_UV_VERSION } from "./utils/constants";
|
||||||
import { loadInputs, type SetupInputs } from "./utils/inputs";
|
import { loadInputs, type SetupInputs } from "./utils/inputs";
|
||||||
import * as log from "./utils/logging";
|
|
||||||
|
|
||||||
function formatUnexpectedFailure(error: unknown): string {
|
|
||||||
if (error instanceof Error) {
|
|
||||||
return error.stack ?? error.message;
|
|
||||||
}
|
|
||||||
return String(error);
|
|
||||||
}
|
|
||||||
|
|
||||||
function failUnexpectedly(event: string, error: unknown): never {
|
|
||||||
core.setFailed(`${event}: ${formatUnexpectedFailure(error)}`);
|
|
||||||
process.exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
process.on("uncaughtException", (error) => {
|
|
||||||
failUnexpectedly("Uncaught exception", error);
|
|
||||||
});
|
|
||||||
|
|
||||||
process.on("unhandledRejection", (reason) => {
|
|
||||||
failUnexpectedly("Unhandled promise rejection", reason);
|
|
||||||
});
|
|
||||||
|
|
||||||
export async function run(): Promise<void> {
|
export async function run(): Promise<void> {
|
||||||
try {
|
try {
|
||||||
@@ -39,7 +18,7 @@ export async function run(): Promise<void> {
|
|||||||
if (inputs.saveCache) {
|
if (inputs.saveCache) {
|
||||||
await saveCache(inputs);
|
await saveCache(inputs);
|
||||||
} else {
|
} else {
|
||||||
log.info("save-cache is false. Skipping save cache step.");
|
core.info("save-cache is false. Skipping save cache step.");
|
||||||
}
|
}
|
||||||
// https://github.com/nodejs/node/issues/56645#issuecomment-3924958861
|
// https://github.com/nodejs/node/issues/56645#issuecomment-3924958861
|
||||||
await new Promise((resolve) => setTimeout(resolve, 100));
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
||||||
@@ -62,11 +41,11 @@ async function saveCache(inputs: SetupInputs): Promise<void> {
|
|||||||
const matchedKey = core.getState(STATE_CACHE_MATCHED_KEY);
|
const matchedKey = core.getState(STATE_CACHE_MATCHED_KEY);
|
||||||
|
|
||||||
if (!cacheKey) {
|
if (!cacheKey) {
|
||||||
log.warning("Error retrieving cache key from state.");
|
core.warning("Error retrieving cache key from state.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (matchedKey === cacheKey) {
|
if (matchedKey === cacheKey) {
|
||||||
log.info(`Cache hit occurred on key ${cacheKey}, not saving cache.`);
|
core.info(`Cache hit occurred on key ${cacheKey}, not saving cache.`);
|
||||||
} else {
|
} else {
|
||||||
if (inputs.pruneCache) {
|
if (inputs.pruneCache) {
|
||||||
await pruneCache();
|
await pruneCache();
|
||||||
@@ -75,7 +54,7 @@ async function saveCache(inputs: SetupInputs): Promise<void> {
|
|||||||
const actualCachePath = getUvCachePath(inputs);
|
const actualCachePath = getUvCachePath(inputs);
|
||||||
if (!fs.existsSync(actualCachePath)) {
|
if (!fs.existsSync(actualCachePath)) {
|
||||||
if (inputs.ignoreNothingToCache) {
|
if (inputs.ignoreNothingToCache) {
|
||||||
log.info(
|
core.info(
|
||||||
"No cacheable uv cache paths were found. Ignoring because ignore-nothing-to-cache is enabled.",
|
"No cacheable uv cache paths were found. Ignoring because ignore-nothing-to-cache is enabled.",
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
@@ -95,7 +74,7 @@ async function saveCache(inputs: SetupInputs): Promise<void> {
|
|||||||
|
|
||||||
if (inputs.cachePython) {
|
if (inputs.cachePython) {
|
||||||
if (!fs.existsSync(inputs.pythonDir)) {
|
if (!fs.existsSync(inputs.pythonDir)) {
|
||||||
log.warning(
|
core.warning(
|
||||||
`Python cache path ${inputs.pythonDir} does not exist on disk. Skipping Python cache save because no managed Python installation was found. If you want uv to install managed Python instead of using a system interpreter, set UV_PYTHON_PREFERENCE=only-managed.`,
|
`Python cache path ${inputs.pythonDir} does not exist on disk. Skipping Python cache save because no managed Python installation was found. If you want uv to install managed Python instead of using a system interpreter, set UV_PYTHON_PREFERENCE=only-managed.`,
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
@@ -122,7 +101,7 @@ async function pruneCache(): Promise<void> {
|
|||||||
execArgs.push("--force");
|
execArgs.push("--force");
|
||||||
}
|
}
|
||||||
|
|
||||||
log.info("Pruning cache...");
|
core.info("Pruning cache...");
|
||||||
const uvPath = core.getState(STATE_UV_PATH);
|
const uvPath = core.getState(STATE_UV_PATH);
|
||||||
await exec.exec(uvPath, execArgs, options);
|
await exec.exec(uvPath, execArgs, options);
|
||||||
}
|
}
|
||||||
@@ -137,7 +116,7 @@ function getUvCachePath(inputs: SetupInputs): string {
|
|||||||
process.env.UV_CACHE_DIR &&
|
process.env.UV_CACHE_DIR &&
|
||||||
process.env.UV_CACHE_DIR !== inputs.cacheLocalPath.path
|
process.env.UV_CACHE_DIR !== inputs.cacheLocalPath.path
|
||||||
) {
|
) {
|
||||||
log.warning(
|
core.warning(
|
||||||
`The environment variable UV_CACHE_DIR has been changed to "${process.env.UV_CACHE_DIR}", by an action or step running after astral-sh/setup-uv. This can lead to unexpected behavior. If you expected this to happen set the cache-local-path input to "${process.env.UV_CACHE_DIR}" instead of "${inputs.cacheLocalPath.path}".`,
|
`The environment variable UV_CACHE_DIR has been changed to "${process.env.UV_CACHE_DIR}", by an action or step running after astral-sh/setup-uv. This can lead to unexpected behavior. If you expected this to happen set the cache-local-path input to "${process.env.UV_CACHE_DIR}" instead of "${inputs.cacheLocalPath.path}".`,
|
||||||
);
|
);
|
||||||
return process.env.UV_CACHE_DIR;
|
return process.env.UV_CACHE_DIR;
|
||||||
@@ -154,13 +133,15 @@ async function saveCacheToKey(
|
|||||||
const matchedKey = core.getState(stateKey);
|
const matchedKey = core.getState(stateKey);
|
||||||
|
|
||||||
if (matchedKey === cacheKey) {
|
if (matchedKey === cacheKey) {
|
||||||
log.info(`${cacheName} hit occurred on key ${cacheKey}, not saving cache.`);
|
core.info(
|
||||||
|
`${cacheName} hit occurred on key ${cacheKey}, not saving cache.`,
|
||||||
|
);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
log.info(`Including ${cacheName} path: ${cachePath}`);
|
core.info(`Including ${cacheName} path: ${cachePath}`);
|
||||||
await cache.saveCache([cachePath], cacheKey);
|
await cache.saveCache([cachePath], cacheKey);
|
||||||
log.info(`${cacheName} saved with key: ${cacheKey}`);
|
core.info(`${cacheName} saved with key: ${cacheKey}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
run();
|
run();
|
||||||
|
|||||||
+21
-43
@@ -9,7 +9,6 @@ import {
|
|||||||
} from "./download/download-version";
|
} from "./download/download-version";
|
||||||
import { STATE_UV_PATH, STATE_UV_VERSION } from "./utils/constants";
|
import { STATE_UV_PATH, STATE_UV_VERSION } from "./utils/constants";
|
||||||
import { CacheLocalSource, loadInputs, type SetupInputs } from "./utils/inputs";
|
import { CacheLocalSource, loadInputs, type SetupInputs } from "./utils/inputs";
|
||||||
import * as log from "./utils/logging";
|
|
||||||
import {
|
import {
|
||||||
type Architecture,
|
type Architecture,
|
||||||
getArch,
|
getArch,
|
||||||
@@ -20,26 +19,6 @@ import { resolveUvVersion } from "./version/resolve";
|
|||||||
|
|
||||||
const sourceDir = __dirname;
|
const sourceDir = __dirname;
|
||||||
|
|
||||||
function formatUnexpectedFailure(error: unknown): string {
|
|
||||||
if (error instanceof Error) {
|
|
||||||
return error.stack ?? error.message;
|
|
||||||
}
|
|
||||||
return String(error);
|
|
||||||
}
|
|
||||||
|
|
||||||
function failUnexpectedly(event: string, error: unknown): never {
|
|
||||||
core.setFailed(`${event}: ${formatUnexpectedFailure(error)}`);
|
|
||||||
process.exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
process.on("uncaughtException", (error) => {
|
|
||||||
failUnexpectedly("Uncaught exception", error);
|
|
||||||
});
|
|
||||||
|
|
||||||
process.on("unhandledRejection", (reason) => {
|
|
||||||
failUnexpectedly("Unhandled promise rejection", reason);
|
|
||||||
});
|
|
||||||
|
|
||||||
async function getPythonVersion(inputs: SetupInputs): Promise<string> {
|
async function getPythonVersion(inputs: SetupInputs): Promise<string> {
|
||||||
if (inputs.pythonVersion !== "") {
|
if (inputs.pythonVersion !== "") {
|
||||||
return inputs.pythonVersion;
|
return inputs.pythonVersion;
|
||||||
@@ -97,7 +76,7 @@ async function run(): Promise<void> {
|
|||||||
|
|
||||||
core.setOutput("uv-version", setupResult.version);
|
core.setOutput("uv-version", setupResult.version);
|
||||||
core.saveState(STATE_UV_VERSION, setupResult.version);
|
core.saveState(STATE_UV_VERSION, setupResult.version);
|
||||||
log.info(`Successfully installed uv version ${setupResult.version}`);
|
core.info(`Successfully installed uv version ${setupResult.version}`);
|
||||||
|
|
||||||
const detectedPythonVersion = await getPythonVersion(inputs);
|
const detectedPythonVersion = await getPythonVersion(inputs);
|
||||||
core.setOutput("python-version", detectedPythonVersion);
|
core.setOutput("python-version", detectedPythonVersion);
|
||||||
@@ -116,11 +95,11 @@ async function run(): Promise<void> {
|
|||||||
function detectEmptyWorkdir(inputs: SetupInputs): void {
|
function detectEmptyWorkdir(inputs: SetupInputs): void {
|
||||||
if (fs.readdirSync(inputs.workingDirectory).length === 0) {
|
if (fs.readdirSync(inputs.workingDirectory).length === 0) {
|
||||||
if (inputs.ignoreEmptyWorkdir) {
|
if (inputs.ignoreEmptyWorkdir) {
|
||||||
log.info(
|
core.info(
|
||||||
"Empty workdir detected. Ignoring because ignore-empty-workdir is enabled",
|
"Empty workdir detected. Ignoring because ignore-empty-workdir is enabled",
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
log.warning(
|
core.warning(
|
||||||
"Empty workdir detected. This may cause unexpected behavior. You can enable ignore-empty-workdir to mute this warning.",
|
"Empty workdir detected. This may cause unexpected behavior. You can enable ignore-empty-workdir to mute this warning.",
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -141,7 +120,7 @@ async function setupUv(
|
|||||||
});
|
});
|
||||||
const toolCacheResult = tryGetFromToolCache(arch, resolvedVersion);
|
const toolCacheResult = tryGetFromToolCache(arch, resolvedVersion);
|
||||||
if (toolCacheResult.installedPath) {
|
if (toolCacheResult.installedPath) {
|
||||||
log.info(`Found uv in tool-cache for ${toolCacheResult.version}`);
|
core.info(`Found uv in tool-cache for ${toolCacheResult.version}`);
|
||||||
return {
|
return {
|
||||||
uvDir: toolCacheResult.installedPath,
|
uvDir: toolCacheResult.installedPath,
|
||||||
version: toolCacheResult.version,
|
version: toolCacheResult.version,
|
||||||
@@ -155,7 +134,6 @@ async function setupUv(
|
|||||||
inputs.checksum,
|
inputs.checksum,
|
||||||
inputs.githubToken,
|
inputs.githubToken,
|
||||||
inputs.manifestFile,
|
inputs.manifestFile,
|
||||||
inputs.downloadFromAstralMirror,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
@@ -169,39 +147,39 @@ function addUvToPathAndOutput(cachedPath: string): void {
|
|||||||
core.saveState(STATE_UV_PATH, `${cachedPath}${path.sep}uv`);
|
core.saveState(STATE_UV_PATH, `${cachedPath}${path.sep}uv`);
|
||||||
core.setOutput("uvx-path", `${cachedPath}${path.sep}uvx`);
|
core.setOutput("uvx-path", `${cachedPath}${path.sep}uvx`);
|
||||||
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
||||||
log.info("UV_NO_MODIFY_PATH is set, not modifying PATH");
|
core.info("UV_NO_MODIFY_PATH is set, not modifying PATH");
|
||||||
} else {
|
} else {
|
||||||
core.addPath(cachedPath);
|
core.addPath(cachedPath);
|
||||||
log.info(`Added ${cachedPath} to the path`);
|
core.info(`Added ${cachedPath} to the path`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function addToolBinToPath(inputs: SetupInputs): void {
|
function addToolBinToPath(inputs: SetupInputs): void {
|
||||||
if (inputs.toolBinDir !== undefined) {
|
if (inputs.toolBinDir !== undefined) {
|
||||||
core.exportVariable("UV_TOOL_BIN_DIR", inputs.toolBinDir);
|
core.exportVariable("UV_TOOL_BIN_DIR", inputs.toolBinDir);
|
||||||
log.info(`Set UV_TOOL_BIN_DIR to ${inputs.toolBinDir}`);
|
core.info(`Set UV_TOOL_BIN_DIR to ${inputs.toolBinDir}`);
|
||||||
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
||||||
log.info(
|
core.info(
|
||||||
`UV_NO_MODIFY_PATH is set, not adding ${inputs.toolBinDir} to path`,
|
`UV_NO_MODIFY_PATH is set, not adding ${inputs.toolBinDir} to path`,
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
core.addPath(inputs.toolBinDir);
|
core.addPath(inputs.toolBinDir);
|
||||||
log.info(`Added ${inputs.toolBinDir} to the path`);
|
core.info(`Added ${inputs.toolBinDir} to the path`);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
||||||
log.info("UV_NO_MODIFY_PATH is set, not adding user local bin to path");
|
core.info("UV_NO_MODIFY_PATH is set, not adding user local bin to path");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (process.env.XDG_BIN_HOME !== undefined) {
|
if (process.env.XDG_BIN_HOME !== undefined) {
|
||||||
core.addPath(process.env.XDG_BIN_HOME);
|
core.addPath(process.env.XDG_BIN_HOME);
|
||||||
log.info(`Added ${process.env.XDG_BIN_HOME} to the path`);
|
core.info(`Added ${process.env.XDG_BIN_HOME} to the path`);
|
||||||
} else if (process.env.XDG_DATA_HOME !== undefined) {
|
} else if (process.env.XDG_DATA_HOME !== undefined) {
|
||||||
core.addPath(`${process.env.XDG_DATA_HOME}/../bin`);
|
core.addPath(`${process.env.XDG_DATA_HOME}/../bin`);
|
||||||
log.info(`Added ${process.env.XDG_DATA_HOME}/../bin to the path`);
|
core.info(`Added ${process.env.XDG_DATA_HOME}/../bin to the path`);
|
||||||
} else {
|
} else {
|
||||||
core.addPath(`${process.env.HOME}/.local/bin`);
|
core.addPath(`${process.env.HOME}/.local/bin`);
|
||||||
log.info(`Added ${process.env.HOME}/.local/bin to the path`);
|
core.info(`Added ${process.env.HOME}/.local/bin to the path`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -209,25 +187,25 @@ function addToolBinToPath(inputs: SetupInputs): void {
|
|||||||
function setToolDir(inputs: SetupInputs): void {
|
function setToolDir(inputs: SetupInputs): void {
|
||||||
if (inputs.toolDir !== undefined) {
|
if (inputs.toolDir !== undefined) {
|
||||||
core.exportVariable("UV_TOOL_DIR", inputs.toolDir);
|
core.exportVariable("UV_TOOL_DIR", inputs.toolDir);
|
||||||
log.info(`Set UV_TOOL_DIR to ${inputs.toolDir}`);
|
core.info(`Set UV_TOOL_DIR to ${inputs.toolDir}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function addPythonDirToPath(inputs: SetupInputs): void {
|
function addPythonDirToPath(inputs: SetupInputs): void {
|
||||||
core.exportVariable("UV_PYTHON_INSTALL_DIR", inputs.pythonDir);
|
core.exportVariable("UV_PYTHON_INSTALL_DIR", inputs.pythonDir);
|
||||||
log.info(`Set UV_PYTHON_INSTALL_DIR to ${inputs.pythonDir}`);
|
core.info(`Set UV_PYTHON_INSTALL_DIR to ${inputs.pythonDir}`);
|
||||||
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
if (process.env.UV_NO_MODIFY_PATH !== undefined) {
|
||||||
log.info("UV_NO_MODIFY_PATH is set, not adding python dir to path");
|
core.info("UV_NO_MODIFY_PATH is set, not adding python dir to path");
|
||||||
} else {
|
} else {
|
||||||
core.addPath(inputs.pythonDir);
|
core.addPath(inputs.pythonDir);
|
||||||
log.info(`Added ${inputs.pythonDir} to the path`);
|
core.info(`Added ${inputs.pythonDir} to the path`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function setupPython(inputs: SetupInputs): void {
|
function setupPython(inputs: SetupInputs): void {
|
||||||
if (inputs.pythonVersion !== "") {
|
if (inputs.pythonVersion !== "") {
|
||||||
core.exportVariable("UV_PYTHON", inputs.pythonVersion);
|
core.exportVariable("UV_PYTHON", inputs.pythonVersion);
|
||||||
log.info(`Set UV_PYTHON to ${inputs.pythonVersion}`);
|
core.info(`Set UV_PYTHON to ${inputs.pythonVersion}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -239,7 +217,7 @@ async function activateEnvironment(inputs: SetupInputs): Promise<void> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
log.info(`Creating and activating python venv at ${inputs.venvPath}...`);
|
core.info(`Creating and activating python venv at ${inputs.venvPath}...`);
|
||||||
const venvArgs = [
|
const venvArgs = [
|
||||||
"venv",
|
"venv",
|
||||||
inputs.venvPath,
|
inputs.venvPath,
|
||||||
@@ -265,13 +243,13 @@ async function activateEnvironment(inputs: SetupInputs): Promise<void> {
|
|||||||
function setCacheDir(inputs: SetupInputs): void {
|
function setCacheDir(inputs: SetupInputs): void {
|
||||||
if (inputs.cacheLocalPath !== undefined) {
|
if (inputs.cacheLocalPath !== undefined) {
|
||||||
if (inputs.cacheLocalPath.source === CacheLocalSource.Config) {
|
if (inputs.cacheLocalPath.source === CacheLocalSource.Config) {
|
||||||
log.info(
|
core.info(
|
||||||
"Using cache-dir from uv config file, not modifying UV_CACHE_DIR",
|
"Using cache-dir from uv config file, not modifying UV_CACHE_DIR",
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
core.exportVariable("UV_CACHE_DIR", inputs.cacheLocalPath.path);
|
core.exportVariable("UV_CACHE_DIR", inputs.cacheLocalPath.path);
|
||||||
log.info(`Set UV_CACHE_DIR to ${inputs.cacheLocalPath.path}`);
|
core.info(`Set UV_CACHE_DIR to ${inputs.cacheLocalPath.path}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ import {
|
|||||||
getLatestVersion,
|
getLatestVersion,
|
||||||
type ManifestVersion,
|
type ManifestVersion,
|
||||||
} from "./download/manifest";
|
} from "./download/manifest";
|
||||||
import * as log from "./utils/logging";
|
|
||||||
|
|
||||||
const VERSION_IN_CHECKSUM_KEY_PATTERN =
|
const VERSION_IN_CHECKSUM_KEY_PATTERN =
|
||||||
/-(\d+\.\d+\.\d+(?:[-+][0-9A-Za-z.-]+)?)$/;
|
/-(\d+\.\d+\.\d+(?:[-+][0-9A-Za-z.-]+)?)$/;
|
||||||
@@ -27,7 +26,7 @@ async function run(): Promise<void> {
|
|||||||
const latestKnownVersion = getLatestKnownVersionFromChecksums();
|
const latestKnownVersion = getLatestKnownVersionFromChecksums();
|
||||||
|
|
||||||
if (semver.lte(latestVersion, latestKnownVersion)) {
|
if (semver.lte(latestVersion, latestKnownVersion)) {
|
||||||
log.info(
|
core.info(
|
||||||
`Latest release (${latestVersion}) is not newer than the latest known version (${latestKnownVersion}). Skipping update.`,
|
`Latest release (${latestVersion}) is not newer than the latest known version (${latestKnownVersion}). Skipping update.`,
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
|
|||||||
+1
-1
@@ -16,7 +16,7 @@ export function getProxyAgent() {
|
|||||||
|
|
||||||
export const fetch = async (url: string, opts: RequestInit) => {
|
export const fetch = async (url: string, opts: RequestInit) => {
|
||||||
// Merge timeout signal with any existing signal from opts
|
// Merge timeout signal with any existing signal from opts
|
||||||
const timeoutSignal = AbortSignal.timeout(5_000);
|
const timeoutSignal = AbortSignal.timeout(30_000);
|
||||||
const existingSignal = opts.signal;
|
const existingSignal = opts.signal;
|
||||||
const mergedSignal = existingSignal
|
const mergedSignal = existingSignal
|
||||||
? AbortSignal.any([timeoutSignal, existingSignal])
|
? AbortSignal.any([timeoutSignal, existingSignal])
|
||||||
|
|||||||
+5
-13
@@ -1,7 +1,6 @@
|
|||||||
import path from "node:path";
|
import path from "node:path";
|
||||||
import * as core from "@actions/core";
|
import * as core from "@actions/core";
|
||||||
import { getConfigValueFromTomlFile } from "./config-file";
|
import { getConfigValueFromTomlFile } from "./config-file";
|
||||||
import * as log from "./logging";
|
|
||||||
|
|
||||||
export enum CacheLocalSource {
|
export enum CacheLocalSource {
|
||||||
Input,
|
Input,
|
||||||
@@ -41,9 +40,7 @@ export interface SetupInputs {
|
|||||||
pythonDir: string;
|
pythonDir: string;
|
||||||
githubToken: string;
|
githubToken: string;
|
||||||
manifestFile?: string;
|
manifestFile?: string;
|
||||||
downloadFromAstralMirror: boolean;
|
|
||||||
addProblemMatchers: boolean;
|
addProblemMatchers: boolean;
|
||||||
quiet: boolean;
|
|
||||||
resolutionStrategy: ResolutionStrategy;
|
resolutionStrategy: ResolutionStrategy;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -76,10 +73,7 @@ export function loadInputs(): SetupInputs {
|
|||||||
const pythonDir = getUvPythonDir();
|
const pythonDir = getUvPythonDir();
|
||||||
const githubToken = core.getInput("github-token");
|
const githubToken = core.getInput("github-token");
|
||||||
const manifestFile = getManifestFile();
|
const manifestFile = getManifestFile();
|
||||||
const downloadFromAstralMirror =
|
|
||||||
core.getInput("download-from-astral-mirror") === "true";
|
|
||||||
const addProblemMatchers = core.getInput("add-problem-matchers") === "true";
|
const addProblemMatchers = core.getInput("add-problem-matchers") === "true";
|
||||||
const quiet = core.getInput("quiet") === "true";
|
|
||||||
const resolutionStrategy = getResolutionStrategy();
|
const resolutionStrategy = getResolutionStrategy();
|
||||||
|
|
||||||
return {
|
return {
|
||||||
@@ -90,7 +84,6 @@ export function loadInputs(): SetupInputs {
|
|||||||
cachePython,
|
cachePython,
|
||||||
cacheSuffix,
|
cacheSuffix,
|
||||||
checksum,
|
checksum,
|
||||||
downloadFromAstralMirror,
|
|
||||||
enableCache,
|
enableCache,
|
||||||
githubToken,
|
githubToken,
|
||||||
ignoreEmptyWorkdir,
|
ignoreEmptyWorkdir,
|
||||||
@@ -100,7 +93,6 @@ export function loadInputs(): SetupInputs {
|
|||||||
pruneCache,
|
pruneCache,
|
||||||
pythonDir,
|
pythonDir,
|
||||||
pythonVersion,
|
pythonVersion,
|
||||||
quiet,
|
|
||||||
resolutionStrategy,
|
resolutionStrategy,
|
||||||
restoreCache,
|
restoreCache,
|
||||||
saveCache,
|
saveCache,
|
||||||
@@ -129,7 +121,7 @@ function getVenvPath(
|
|||||||
const venvPathInput = core.getInput("venv-path");
|
const venvPathInput = core.getInput("venv-path");
|
||||||
if (venvPathInput !== "") {
|
if (venvPathInput !== "") {
|
||||||
if (!activateEnvironment) {
|
if (!activateEnvironment) {
|
||||||
log.warning("venv-path is only used when activate-environment is true");
|
core.warning("venv-path is only used when activate-environment is true");
|
||||||
}
|
}
|
||||||
const tildeExpanded = expandTilde(venvPathInput);
|
const tildeExpanded = expandTilde(venvPathInput);
|
||||||
return normalizePath(resolveRelativePath(workingDirectory, tildeExpanded));
|
return normalizePath(resolveRelativePath(workingDirectory, tildeExpanded));
|
||||||
@@ -200,7 +192,7 @@ function getCacheLocalPath(
|
|||||||
return { path: cacheDirFromConfig, source: CacheLocalSource.Config };
|
return { path: cacheDirFromConfig, source: CacheLocalSource.Config };
|
||||||
}
|
}
|
||||||
if (process.env.UV_CACHE_DIR !== undefined) {
|
if (process.env.UV_CACHE_DIR !== undefined) {
|
||||||
log.info(`UV_CACHE_DIR is already set to ${process.env.UV_CACHE_DIR}`);
|
core.info(`UV_CACHE_DIR is already set to ${process.env.UV_CACHE_DIR}`);
|
||||||
return { path: process.env.UV_CACHE_DIR, source: CacheLocalSource.Env };
|
return { path: process.env.UV_CACHE_DIR, source: CacheLocalSource.Env };
|
||||||
}
|
}
|
||||||
if (enableCache) {
|
if (enableCache) {
|
||||||
@@ -237,12 +229,12 @@ function getCacheDirFromConfig(
|
|||||||
try {
|
try {
|
||||||
const cacheDir = getConfigValueFromTomlFile(resolvedPath, "cache-dir");
|
const cacheDir = getConfigValueFromTomlFile(resolvedPath, "cache-dir");
|
||||||
if (cacheDir !== undefined) {
|
if (cacheDir !== undefined) {
|
||||||
log.info(`Found cache-dir in ${resolvedPath}: ${cacheDir}`);
|
core.info(`Found cache-dir in ${resolvedPath}: ${cacheDir}`);
|
||||||
return cacheDir;
|
return cacheDir;
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
const message = (err as Error).message;
|
const message = (err as Error).message;
|
||||||
log.warning(`Error while parsing ${filePath}: ${message}`);
|
core.warning(`Error while parsing ${filePath}: ${message}`);
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -251,7 +243,7 @@ function getCacheDirFromConfig(
|
|||||||
|
|
||||||
export function getUvPythonDir(): string {
|
export function getUvPythonDir(): string {
|
||||||
if (process.env.UV_PYTHON_INSTALL_DIR !== undefined) {
|
if (process.env.UV_PYTHON_INSTALL_DIR !== undefined) {
|
||||||
log.info(
|
core.info(
|
||||||
`UV_PYTHON_INSTALL_DIR is already set to ${process.env.UV_PYTHON_INSTALL_DIR}`,
|
`UV_PYTHON_INSTALL_DIR is already set to ${process.env.UV_PYTHON_INSTALL_DIR}`,
|
||||||
);
|
);
|
||||||
return process.env.UV_PYTHON_INSTALL_DIR;
|
return process.env.UV_PYTHON_INSTALL_DIR;
|
||||||
|
|||||||
@@ -1,21 +0,0 @@
|
|||||||
import * as core from "@actions/core";
|
|
||||||
|
|
||||||
let quiet: boolean | undefined;
|
|
||||||
|
|
||||||
function isQuiet(): boolean {
|
|
||||||
if (quiet === undefined) {
|
|
||||||
quiet =
|
|
||||||
typeof core.getInput === "function" && core.getInput("quiet") === "true";
|
|
||||||
}
|
|
||||||
return quiet;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function info(msg: string): void {
|
|
||||||
if (!isQuiet()) {
|
|
||||||
core.info(msg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const warning = core.warning;
|
|
||||||
export const error = core.error;
|
|
||||||
export const debug = core.debug;
|
|
||||||
@@ -109,9 +109,8 @@ function getLinuxOSNameVersion(): string {
|
|||||||
const id = parseOsReleaseValue(content, "ID");
|
const id = parseOsReleaseValue(content, "ID");
|
||||||
const versionId = parseOsReleaseValue(content, "VERSION_ID");
|
const versionId = parseOsReleaseValue(content, "VERSION_ID");
|
||||||
// Fallback for rolling releases (debian:unstable/testing, arch, etc.)
|
// Fallback for rolling releases (debian:unstable/testing, arch, etc.)
|
||||||
// that don't have VERSION_ID but have VERSION_CODENAME or BUILD_ID
|
// that don't have VERSION_ID but have VERSION_CODENAME
|
||||||
const versionCodename = parseOsReleaseValue(content, "VERSION_CODENAME");
|
const versionCodename = parseOsReleaseValue(content, "VERSION_CODENAME");
|
||||||
const buildId = parseOsReleaseValue(content, "BUILD_ID");
|
|
||||||
|
|
||||||
if (id && versionId) {
|
if (id && versionId) {
|
||||||
return `${id}-${versionId}`;
|
return `${id}-${versionId}`;
|
||||||
@@ -119,9 +118,6 @@ function getLinuxOSNameVersion(): string {
|
|||||||
if (id && versionCodename) {
|
if (id && versionCodename) {
|
||||||
return `${id}-${versionCodename}`;
|
return `${id}-${versionCodename}`;
|
||||||
}
|
}
|
||||||
if (id && buildId) {
|
|
||||||
return `${id}-${buildId}`;
|
|
||||||
}
|
|
||||||
} catch {
|
} catch {
|
||||||
// Try next file
|
// Try next file
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import fs from "node:fs";
|
import fs from "node:fs";
|
||||||
|
import * as core from "@actions/core";
|
||||||
import { getConfigValueFromTomlContent } from "../utils/config-file";
|
import { getConfigValueFromTomlContent } from "../utils/config-file";
|
||||||
import * as log from "../utils/logging";
|
|
||||||
import {
|
import {
|
||||||
getUvVersionFromParsedPyproject,
|
getUvVersionFromParsedPyproject,
|
||||||
getUvVersionFromRequirementsText,
|
getUvVersionFromRequirementsText,
|
||||||
@@ -62,10 +62,10 @@ const VERSION_FILE_PARSERS: VersionFileParser[] = [
|
|||||||
export function getParsedVersionFile(
|
export function getParsedVersionFile(
|
||||||
filePath: string,
|
filePath: string,
|
||||||
): ParsedVersionFile | undefined {
|
): ParsedVersionFile | undefined {
|
||||||
log.info(`Trying to find version for uv in: ${filePath}`);
|
core.info(`Trying to find version for uv in: ${filePath}`);
|
||||||
|
|
||||||
if (!fs.existsSync(filePath)) {
|
if (!fs.existsSync(filePath)) {
|
||||||
log.info(`Could not find file: ${filePath}`);
|
core.info(`Could not find file: ${filePath}`);
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -81,13 +81,15 @@ export function getParsedVersionFile(
|
|||||||
}
|
}
|
||||||
|
|
||||||
const normalizedSpecifier = normalizeVersionSpecifier(specifier);
|
const normalizedSpecifier = normalizeVersionSpecifier(specifier);
|
||||||
log.info(`Found version for uv in ${filePath}: ${normalizedSpecifier}`);
|
core.info(`Found version for uv in ${filePath}: ${normalizedSpecifier}`);
|
||||||
return {
|
return {
|
||||||
format: parser.format,
|
format: parser.format,
|
||||||
specifier: normalizedSpecifier,
|
specifier: normalizedSpecifier,
|
||||||
};
|
};
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
log.warning(`Error while parsing ${filePath}: ${(error as Error).message}`);
|
core.warning(
|
||||||
|
`Error while parsing ${filePath}: ${(error as Error).message}`,
|
||||||
|
);
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import * as pep440 from "@renovatebot/pep440";
|
|||||||
import * as semver from "semver";
|
import * as semver from "semver";
|
||||||
import { getAllVersions, getLatestVersion } from "../download/manifest";
|
import { getAllVersions, getLatestVersion } from "../download/manifest";
|
||||||
import type { ResolutionStrategy } from "../utils/inputs";
|
import type { ResolutionStrategy } from "../utils/inputs";
|
||||||
import * as log from "../utils/logging";
|
|
||||||
import {
|
import {
|
||||||
type ParsedVersionSpecifier,
|
type ParsedVersionSpecifier,
|
||||||
parseVersionSpecifier,
|
parseVersionSpecifier,
|
||||||
@@ -57,7 +56,7 @@ class LatestVersionResolver implements ConcreteVersionResolver {
|
|||||||
context.parsedSpecifier.kind === "range" &&
|
context.parsedSpecifier.kind === "range" &&
|
||||||
context.parsedSpecifier.isSimpleMinimumVersionSpecifier
|
context.parsedSpecifier.isSimpleMinimumVersionSpecifier
|
||||||
) {
|
) {
|
||||||
log.info("Found minimum version specifier, using latest version");
|
core.info("Found minimum version specifier, using latest version");
|
||||||
}
|
}
|
||||||
|
|
||||||
const latestVersion = await getLatestVersion(context.manifestUrl);
|
const latestVersion = await getLatestVersion(context.manifestUrl);
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import * as path from "node:path";
|
import * as path from "node:path";
|
||||||
import * as log from "../utils/logging";
|
import * as core from "@actions/core";
|
||||||
import { getParsedVersionFile } from "./file-parser";
|
import { getParsedVersionFile } from "./file-parser";
|
||||||
import { normalizeVersionSpecifier } from "./specifier";
|
import { normalizeVersionSpecifier } from "./specifier";
|
||||||
import type {
|
import type {
|
||||||
@@ -111,7 +111,7 @@ export class WorkspaceVersionResolver implements VersionRequestResolver {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
log.info(
|
core.info(
|
||||||
"Could not determine uv version from uv.toml or pyproject.toml. Falling back to latest.",
|
"Could not determine uv version from uv.toml or pyproject.toml. Falling back to latest.",
|
||||||
);
|
);
|
||||||
return undefined;
|
return undefined;
|
||||||
|
|||||||
Reference in New Issue
Block a user