forked from mirrors/nixpkgs
Merge pull request #110156 from 06kellyjac/deno
deno: 1.6.3 -> 1.8.0 -> 1.8.1
This commit is contained in:
commit
acb2a83018
|
@ -1,52 +1,49 @@
|
||||||
{ lib, stdenv
|
{ stdenv
|
||||||
, fetchurl
|
, lib
|
||||||
|
, callPackage
|
||||||
, fetchFromGitHub
|
, fetchFromGitHub
|
||||||
, rust
|
, rust
|
||||||
, rustPlatform
|
, rustPlatform
|
||||||
, installShellFiles
|
, installShellFiles
|
||||||
|
, libobjc
|
||||||
, Security
|
, Security
|
||||||
, CoreServices
|
, CoreServices
|
||||||
|
, Metal
|
||||||
|
, Foundation
|
||||||
|
, librusty_v8 ? callPackage ./librusty_v8.nix { }
|
||||||
}:
|
}:
|
||||||
let
|
|
||||||
deps = import ./deps.nix { };
|
|
||||||
arch = rust.toRustTarget stdenv.hostPlatform;
|
|
||||||
rustyV8Lib = with deps.rustyV8Lib; fetchurl {
|
|
||||||
url = "https://github.com/denoland/rusty_v8/releases/download/v${version}/librusty_v8_release_${arch}.a";
|
|
||||||
sha256 = sha256s."${stdenv.hostPlatform.system}";
|
|
||||||
meta = { inherit version; };
|
|
||||||
};
|
|
||||||
in
|
|
||||||
rustPlatform.buildRustPackage rec {
|
rustPlatform.buildRustPackage rec {
|
||||||
pname = "deno";
|
pname = "deno";
|
||||||
version = "1.6.3";
|
version = "1.8.1";
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "denoland";
|
owner = "denoland";
|
||||||
repo = pname;
|
repo = pname;
|
||||||
rev = "v${version}";
|
rev = "v${version}";
|
||||||
sha256 = "1wmkx458fpsfw57ysawxc0ghxag8v051hiyswm7nnb7gckrm6j8z";
|
sha256 = "sha256-tyqZ/vjQ9gjLoK+Juj30It3H6+2sT9Fj/s0kEv0HRwI=";
|
||||||
fetchSubmodules = true;
|
|
||||||
};
|
};
|
||||||
cargoSha256 = "08vzsp53019gmxkn8lpa6l84w3fvbrnr11lzrfgf99nmii6l2hq5";
|
cargoSha256 = "sha256-LpBQztMqw7IbgTJkfiD+6Fcy5XXmN58HO/zhVen3oCI=";
|
||||||
|
|
||||||
# Install completions post-install
|
# Install completions post-install
|
||||||
nativeBuildInputs = [ installShellFiles ];
|
nativeBuildInputs = [ installShellFiles ];
|
||||||
|
|
||||||
buildInputs = lib.optionals stdenv.isDarwin [ Security CoreServices ];
|
buildInputs = lib.optionals stdenv.isDarwin [ libobjc Security CoreServices Metal Foundation ];
|
||||||
|
|
||||||
# The rusty_v8 package will try to download a `librusty_v8.a` release at build time to our read-only filesystem
|
# The rusty_v8 package will try to download a `librusty_v8.a` release at build time to our read-only filesystem
|
||||||
# To avoid this we pre-download the file and place it in the locations it will require it in advance
|
# To avoid this we pre-download the file and place it in the locations it will require it in advance
|
||||||
preBuild = ''
|
preBuild =
|
||||||
_rusty_v8_setup() {
|
let arch = rust.toRustTarget stdenv.hostPlatform; in
|
||||||
for v in "$@"; do
|
''
|
||||||
dir="target/$v/gn_out/obj"
|
_librusty_v8_setup() {
|
||||||
mkdir -p "$dir" && cp "${rustyV8Lib}" "$dir/librusty_v8.a"
|
for v in "$@"; do
|
||||||
done
|
install -D ${librusty_v8} "target/$v/gn_out/obj/librusty_v8.a"
|
||||||
}
|
done
|
||||||
|
}
|
||||||
|
|
||||||
# Copy over the `librusty_v8.a` file inside target/XYZ/gn_out/obj, symlink not allowed
|
# Copy over the `librusty_v8.a` file inside target/XYZ/gn_out/obj, symlink not allowed
|
||||||
_rusty_v8_setup "debug" "release" "${arch}/release"
|
_librusty_v8_setup "debug" "release" "${arch}/release"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# Tests have some inconsistencies between runs with output integration tests
|
# Tests have some inconsistencies between runs with output integration tests
|
||||||
# Skipping until resolved
|
# Skipping until resolved
|
||||||
|
@ -54,7 +51,7 @@ rustPlatform.buildRustPackage rec {
|
||||||
|
|
||||||
postInstall = ''
|
postInstall = ''
|
||||||
# remove test plugin and test server
|
# remove test plugin and test server
|
||||||
rm -rf $out/lib $out/bin/test_server
|
rm -r $out/lib $out/bin/test_server $out/bin/denort
|
||||||
|
|
||||||
installShellCompletion --cmd deno \
|
installShellCompletion --cmd deno \
|
||||||
--bash <($out/bin/deno completions bash) \
|
--bash <($out/bin/deno completions bash) \
|
||||||
|
@ -62,11 +59,19 @@ rustPlatform.buildRustPackage rec {
|
||||||
--zsh <($out/bin/deno completions zsh)
|
--zsh <($out/bin/deno completions zsh)
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
doInstallCheck = true;
|
||||||
|
installCheckPhase = ''
|
||||||
|
runHook preInstallCheck
|
||||||
|
$out/bin/deno --help
|
||||||
|
$out/bin/deno --version | grep "deno ${version}"
|
||||||
|
runHook postInstallCheck
|
||||||
|
'';
|
||||||
|
|
||||||
passthru.updateScript = ./update/update.ts;
|
passthru.updateScript = ./update/update.ts;
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
homepage = "https://deno.land/";
|
homepage = "https://deno.land/";
|
||||||
changelog = "${src.meta.homepage}/releases/tag/v${version}";
|
changelog = "https://github.com/denoland/deno/releases/tag/v${version}";
|
||||||
description = "A secure runtime for JavaScript and TypeScript";
|
description = "A secure runtime for JavaScript and TypeScript";
|
||||||
longDescription = ''
|
longDescription = ''
|
||||||
Deno aims to be a productive and secure scripting environment for the modern programmer.
|
Deno aims to be a productive and secure scripting environment for the modern programmer.
|
||||||
|
@ -79,6 +84,6 @@ rustPlatform.buildRustPackage rec {
|
||||||
'';
|
'';
|
||||||
license = licenses.mit;
|
license = licenses.mit;
|
||||||
maintainers = with maintainers; [ jk ];
|
maintainers = with maintainers; [ jk ];
|
||||||
platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ];
|
platforms = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
12
pkgs/development/web/deno/deps.nix
generated
12
pkgs/development/web/deno/deps.nix
generated
|
@ -1,12 +0,0 @@
|
||||||
# auto-generated file -- DO NOT EDIT!
|
|
||||||
{}:
|
|
||||||
rec {
|
|
||||||
rustyV8Lib = {
|
|
||||||
version = "0.15.0";
|
|
||||||
sha256s = {
|
|
||||||
x86_64-linux = "1j789pvqh44vsffzl5wg3pp3awrlixjrhbnjx2klsml7jv0lp0mq";
|
|
||||||
aarch64-linux = "13srja4vc275ygm806hcsr8mxjnd9qkzaqs58lxnp0702qs5xls6";
|
|
||||||
x86_64-darwin = "0aij9yb5i1r3pz0pyl51qdbgfspfdngwbk1qgkp4gxzl3cbnysx1";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
21
pkgs/development/web/deno/librusty_v8.nix
Normal file
21
pkgs/development/web/deno/librusty_v8.nix
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
# auto-generated file -- DO NOT EDIT!
|
||||||
|
{ rust, stdenv, fetchurl }:
|
||||||
|
|
||||||
|
let
|
||||||
|
arch = rust.toRustTarget stdenv.hostPlatform;
|
||||||
|
fetch_librusty_v8 = args: fetchurl {
|
||||||
|
name = "librusty_v8-${args.version}";
|
||||||
|
url = "https://github.com/denoland/rusty_v8/releases/download/v${args.version}/librusty_v8_release_${arch}.a";
|
||||||
|
sha256 = args.shas.${stdenv.hostPlatform.system};
|
||||||
|
meta = { inherit (args) version; };
|
||||||
|
};
|
||||||
|
in
|
||||||
|
fetch_librusty_v8 {
|
||||||
|
version = "0.20.0";
|
||||||
|
shas = {
|
||||||
|
x86_64-linux = "sha256-pTWNYQzChyYJh+afn1AMw/MxUE+Cv4k2FnM3+KDYCvg=";
|
||||||
|
aarch64-linux = "sha256-SPRtQO0tnuEf49GuSsuo403QO0Y6ioRkOp4cjohXRhw=";
|
||||||
|
x86_64-darwin = "sha256-k0kS5NiITqW/WEFWe/Bnt7Z9HZp2YN19L7DvVlptrj4=";
|
||||||
|
aarch64-darwin = "sha256-CDGxSv7fPR+5kF3+5NVTOH8ugLaM07Kv5mjoEW6/g/8=";
|
||||||
|
};
|
||||||
|
}
|
|
@ -3,12 +3,15 @@ interface GHRelease {
|
||||||
}
|
}
|
||||||
|
|
||||||
const decode = (buffer: Uint8Array) => new TextDecoder("utf-8").decode(buffer);
|
const decode = (buffer: Uint8Array) => new TextDecoder("utf-8").decode(buffer);
|
||||||
const run = async (command: string, args: string[]) => {
|
const decodeTrim = (b: Uint8Array) => decode(b).trimEnd();
|
||||||
const cmd = Deno.run(
|
export const run = async (command: string, args: string[]) => {
|
||||||
{ cmd: [command, ...args], stdout: "piped", stderr: "piped" },
|
const cmd = Deno.run({
|
||||||
);
|
cmd: [command, ...args],
|
||||||
|
stdout: "piped",
|
||||||
|
stderr: "piped",
|
||||||
|
});
|
||||||
if (!(await cmd.status()).success) {
|
if (!(await cmd.status()).success) {
|
||||||
const error = await cmd.stderrOutput().then((b) => decode(b).trimEnd());
|
const error = await cmd.stderrOutput().then(decodeTrim);
|
||||||
// Known error we can ignore
|
// Known error we can ignore
|
||||||
if (error.includes("'allow-unsafe-native-code-during-evaluation'")) {
|
if (error.includes("'allow-unsafe-native-code-during-evaluation'")) {
|
||||||
// Extract the target sha256 out of the error
|
// Extract the target sha256 out of the error
|
||||||
|
@ -23,26 +26,16 @@ const run = async (command: string, args: string[]) => {
|
||||||
}
|
}
|
||||||
throw new Error(error);
|
throw new Error(error);
|
||||||
}
|
}
|
||||||
return cmd.output().then((b) => decode(b).trimEnd());
|
return cmd.output().then(decodeTrim);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Exports
|
// Exports
|
||||||
export const versionRegExp = /\d+\.\d+\.\d+/;
|
export const versionRegExp = /\d+\.\d+\.\d+/;
|
||||||
export const sha256RegExp = /[a-z0-9]{52}/;
|
export const sha256RegExp = /[a-z0-9]{52}|sha256-.{44}/;
|
||||||
|
|
||||||
export async function commit(
|
|
||||||
name: string,
|
|
||||||
oldVer: string,
|
|
||||||
newVer: string,
|
|
||||||
files: string[],
|
|
||||||
) {
|
|
||||||
await run("git", ["add", ...files]);
|
|
||||||
await run("git", ["commit", "-m", `${name}: ${oldVer} -> ${newVer}`]);
|
|
||||||
}
|
|
||||||
|
|
||||||
export const getExistingVersion = async (filePath: string) =>
|
export const getExistingVersion = async (filePath: string) =>
|
||||||
read(filePath).then((s) =>
|
read(filePath).then(
|
||||||
s.match(genValueRegExp("version", versionRegExp))?.shift() || ""
|
(s) => s.match(genValueRegExp("version", versionRegExp))?.shift() || "",
|
||||||
);
|
);
|
||||||
|
|
||||||
export const getLatestVersion = (owner: string, repo: string) =>
|
export const getLatestVersion = (owner: string, repo: string) =>
|
||||||
|
@ -58,8 +51,5 @@ export const genValueRegExp = (key: string, regex: RegExp) =>
|
||||||
export const logger = (name: string) =>
|
export const logger = (name: string) =>
|
||||||
(...a: any) => console.log(`[${name}]`, ...a);
|
(...a: any) => console.log(`[${name}]`, ...a);
|
||||||
|
|
||||||
export const nixPrefetch = (args: string[]) => run("nix-prefetch", args);
|
|
||||||
export const nixPrefetchURL = (args: string[]) => run("nix-prefetch-url", args);
|
|
||||||
|
|
||||||
export const read = Deno.readTextFile;
|
export const read = Deno.readTextFile;
|
||||||
export const write = Deno.writeTextFile;
|
export const write = Deno.writeTextFile;
|
||||||
|
|
|
@ -1,79 +0,0 @@
|
||||||
import {
|
|
||||||
getExistingVersion,
|
|
||||||
genValueRegExp,
|
|
||||||
logger,
|
|
||||||
nixPrefetchURL,
|
|
||||||
versionRegExp,
|
|
||||||
write,
|
|
||||||
} from "./common.ts";
|
|
||||||
|
|
||||||
const log = logger("deps");
|
|
||||||
|
|
||||||
export interface Architecture {
|
|
||||||
nix: string;
|
|
||||||
rust: string;
|
|
||||||
}
|
|
||||||
interface PrefetchResult {
|
|
||||||
arch: Architecture;
|
|
||||||
sha256: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
const getRustyV8Version = async (
|
|
||||||
owner: string,
|
|
||||||
repo: string,
|
|
||||||
version: string,
|
|
||||||
) =>
|
|
||||||
fetch(
|
|
||||||
`https://github.com/${owner}/${repo}/raw/${version}/core/Cargo.toml`,
|
|
||||||
)
|
|
||||||
.then((res) => res.text())
|
|
||||||
.then((txt) =>
|
|
||||||
txt.match(genValueRegExp("rusty_v8", versionRegExp))?.shift()
|
|
||||||
);
|
|
||||||
|
|
||||||
const archShaTasks = (version: string, arches: Architecture[]) =>
|
|
||||||
arches.map(async (arch: Architecture): Promise<PrefetchResult> => {
|
|
||||||
log("Fetching:", arch.nix);
|
|
||||||
const sha256 = await nixPrefetchURL(
|
|
||||||
[`https://github.com/denoland/rusty_v8/releases/download/v${version}/librusty_v8_release_${arch.rust}.a`],
|
|
||||||
);
|
|
||||||
log("Done: ", arch.nix);
|
|
||||||
return { arch, sha256 };
|
|
||||||
});
|
|
||||||
|
|
||||||
const templateDeps = (version: string, deps: PrefetchResult[]) =>
|
|
||||||
`# auto-generated file -- DO NOT EDIT!
|
|
||||||
{}:
|
|
||||||
rec {
|
|
||||||
rustyV8Lib = {
|
|
||||||
version = "${version}";
|
|
||||||
sha256s = {
|
|
||||||
${deps.map((d) => ` ${d.arch.nix} = "${d.sha256}";`).join("\n")}
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
||||||
export async function updateDeps(
|
|
||||||
filePath: string,
|
|
||||||
owner: string,
|
|
||||||
repo: string,
|
|
||||||
denoVersion: string,
|
|
||||||
arches: Architecture[],
|
|
||||||
) {
|
|
||||||
log("Starting deps update");
|
|
||||||
// 0.0.0
|
|
||||||
const version = await getRustyV8Version(owner, repo, denoVersion);
|
|
||||||
if (typeof version !== "string") {
|
|
||||||
throw "no rusty_v8 version";
|
|
||||||
}
|
|
||||||
log("rusty_v8 version:", version);
|
|
||||||
const existingVersion = await getExistingVersion(filePath);
|
|
||||||
if (version === existingVersion) {
|
|
||||||
log("Version already matches latest, skipping...");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const archShaResults = await Promise.all(archShaTasks(version, arches));
|
|
||||||
await write(filePath, templateDeps(version, archShaResults));
|
|
||||||
log("Finished deps update");
|
|
||||||
}
|
|
92
pkgs/development/web/deno/update/librusty_v8.ts
Normal file
92
pkgs/development/web/deno/update/librusty_v8.ts
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
import {
|
||||||
|
genValueRegExp,
|
||||||
|
getExistingVersion,
|
||||||
|
logger,
|
||||||
|
run,
|
||||||
|
versionRegExp,
|
||||||
|
write,
|
||||||
|
} from "./common.ts";
|
||||||
|
|
||||||
|
const log = logger("librusty_v8");
|
||||||
|
|
||||||
|
export interface Architecture {
|
||||||
|
nix: string;
|
||||||
|
rust: string;
|
||||||
|
}
|
||||||
|
interface PrefetchResult {
|
||||||
|
arch: Architecture;
|
||||||
|
sha256: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
const getLibrustyV8Version = async (
|
||||||
|
owner: string,
|
||||||
|
repo: string,
|
||||||
|
version: string,
|
||||||
|
) =>
|
||||||
|
fetch(`https://github.com/${owner}/${repo}/raw/${version}/core/Cargo.toml`)
|
||||||
|
.then((res) => res.text())
|
||||||
|
.then((txt) =>
|
||||||
|
txt.match(genValueRegExp("rusty_v8", versionRegExp))?.shift()
|
||||||
|
);
|
||||||
|
|
||||||
|
const fetchArchShaTasks = (version: string, arches: Architecture[]) =>
|
||||||
|
arches.map(
|
||||||
|
async (arch: Architecture): Promise<PrefetchResult> => {
|
||||||
|
log("Fetching:", arch.nix);
|
||||||
|
const sha256 = await run("nix-prefetch", [
|
||||||
|
`
|
||||||
|
{ fetchurl }:
|
||||||
|
fetchurl {
|
||||||
|
url = "https://github.com/denoland/rusty_v8/releases/download/v${version}/librusty_v8_release_${arch.rust}.a";
|
||||||
|
}
|
||||||
|
`,
|
||||||
|
]);
|
||||||
|
log("Done: ", arch.nix);
|
||||||
|
return { arch, sha256 };
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
const templateDeps = (version: string, deps: PrefetchResult[]) =>
|
||||||
|
`# auto-generated file -- DO NOT EDIT!
|
||||||
|
{ rust, stdenv, fetchurl }:
|
||||||
|
|
||||||
|
let
|
||||||
|
arch = rust.toRustTarget stdenv.hostPlatform;
|
||||||
|
fetch_librusty_v8 = args: fetchurl {
|
||||||
|
name = "librusty_v8-\${args.version}";
|
||||||
|
url = "https://github.com/denoland/rusty_v8/releases/download/v\${args.version}/librusty_v8_release_\${arch}.a";
|
||||||
|
sha256 = args.shas.\${stdenv.hostPlatform.system};
|
||||||
|
meta = { inherit (args) version; };
|
||||||
|
};
|
||||||
|
in
|
||||||
|
fetch_librusty_v8 {
|
||||||
|
version = "${version}";
|
||||||
|
shas = {
|
||||||
|
${deps.map(({ arch, sha256 }) => ` ${arch.nix} = "${sha256}";`).join("\n")}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
export async function updateLibrustyV8(
|
||||||
|
filePath: string,
|
||||||
|
owner: string,
|
||||||
|
repo: string,
|
||||||
|
denoVersion: string,
|
||||||
|
arches: Architecture[],
|
||||||
|
) {
|
||||||
|
log("Starting librusty_v8 update");
|
||||||
|
// 0.0.0
|
||||||
|
const version = await getLibrustyV8Version(owner, repo, denoVersion);
|
||||||
|
if (typeof version !== "string") {
|
||||||
|
throw "no librusty_v8 version";
|
||||||
|
}
|
||||||
|
log("librusty_v8 version:", version);
|
||||||
|
const existingVersion = await getExistingVersion(filePath);
|
||||||
|
if (version === existingVersion) {
|
||||||
|
log("Version already matches latest, skipping...");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const archShaResults = await Promise.all(fetchArchShaTasks(version, arches));
|
||||||
|
await write(filePath, templateDeps(version, archShaResults));
|
||||||
|
log("Finished deps update");
|
||||||
|
}
|
|
@ -1,8 +1,8 @@
|
||||||
import {
|
import {
|
||||||
genValueRegExp,
|
genValueRegExp,
|
||||||
logger,
|
logger,
|
||||||
nixPrefetch,
|
|
||||||
read,
|
read,
|
||||||
|
run,
|
||||||
sha256RegExp,
|
sha256RegExp,
|
||||||
versionRegExp,
|
versionRegExp,
|
||||||
write,
|
write,
|
||||||
|
@ -16,10 +16,11 @@ interface Replacer {
|
||||||
const log = logger("src");
|
const log = logger("src");
|
||||||
|
|
||||||
const prefetchSha256 = (nixpkgs: string, version: string) =>
|
const prefetchSha256 = (nixpkgs: string, version: string) =>
|
||||||
nixPrefetch(["-f", nixpkgs, "deno.src", "--rev", version]);
|
run("nix-prefetch", ["-f", nixpkgs, "deno.src", "--rev", version]);
|
||||||
const prefetchCargoSha256 = (nixpkgs: string) =>
|
const prefetchCargoSha256 = (nixpkgs: string) =>
|
||||||
nixPrefetch(
|
run(
|
||||||
[`{ sha256 }: (import ${nixpkgs} {}).deno.cargoDeps.overrideAttrs (_: { outputHash = sha256; })`],
|
"nix-prefetch",
|
||||||
|
[`{ sha256 }: (import ${nixpkgs} {}).deno.cargoDeps.overrideAttrs (_: { inherit sha256; })`],
|
||||||
);
|
);
|
||||||
|
|
||||||
const replace = (str: string, replacers: Replacer[]) =>
|
const replace = (str: string, replacers: Replacer[]) =>
|
||||||
|
@ -53,7 +54,6 @@ export async function updateSrc(
|
||||||
[
|
[
|
||||||
genVerReplacer("version", trimVersion),
|
genVerReplacer("version", trimVersion),
|
||||||
genShaReplacer("sha256", sha256),
|
genShaReplacer("sha256", sha256),
|
||||||
genShaReplacer("cargoSha256", ""), // Empty ready for prefetchCargoSha256
|
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
log("Fetching cargoSha256 for:", sha256);
|
log("Fetching cargoSha256 for:", sha256);
|
||||||
|
|
|
@ -2,13 +2,8 @@
|
||||||
/*
|
/*
|
||||||
#!nix-shell -i "deno run --allow-net --allow-run --allow-read --allow-write" -p deno git nix-prefetch
|
#!nix-shell -i "deno run --allow-net --allow-run --allow-read --allow-write" -p deno git nix-prefetch
|
||||||
*/
|
*/
|
||||||
import {
|
import { getExistingVersion, getLatestVersion, logger } from "./common.ts";
|
||||||
commit,
|
import { Architecture, updateLibrustyV8 } from "./librusty_v8.ts";
|
||||||
getExistingVersion,
|
|
||||||
getLatestVersion,
|
|
||||||
logger,
|
|
||||||
} from "./common.ts";
|
|
||||||
import { Architecture, updateDeps } from "./deps.ts";
|
|
||||||
import { updateSrc } from "./src.ts";
|
import { updateSrc } from "./src.ts";
|
||||||
|
|
||||||
const log = logger("update");
|
const log = logger("update");
|
||||||
|
@ -19,11 +14,12 @@ const owner = "denoland";
|
||||||
const repo = "deno";
|
const repo = "deno";
|
||||||
const denoDir = `${nixpkgs}/pkgs/development/web/${repo}`;
|
const denoDir = `${nixpkgs}/pkgs/development/web/${repo}`;
|
||||||
const src = `${denoDir}/default.nix`;
|
const src = `${denoDir}/default.nix`;
|
||||||
const deps = `${denoDir}/deps.nix`;
|
const librusty_v8 = `${denoDir}/librusty_v8.nix`;
|
||||||
const architectures: Architecture[] = [
|
const architectures: Architecture[] = [
|
||||||
{ nix: "x86_64-linux", rust: "x86_64-unknown-linux-gnu" },
|
{ nix: "x86_64-linux", rust: "x86_64-unknown-linux-gnu" },
|
||||||
{ nix: "aarch64-linux", rust: "aarch64-unknown-linux-gnu" },
|
{ nix: "aarch64-linux", rust: "aarch64-unknown-linux-gnu" },
|
||||||
{ nix: "x86_64-darwin", rust: "x86_64-apple-darwin" },
|
{ nix: "x86_64-darwin", rust: "x86_64-apple-darwin" },
|
||||||
|
{ nix: "aarch64-darwin", rust: "aarch64-apple-darwin" },
|
||||||
];
|
];
|
||||||
|
|
||||||
log("Updating deno");
|
log("Updating deno");
|
||||||
|
@ -41,10 +37,7 @@ if (trimVersion === existingVersion) {
|
||||||
|
|
||||||
const tasks = [
|
const tasks = [
|
||||||
updateSrc(src, nixpkgs, version),
|
updateSrc(src, nixpkgs, version),
|
||||||
updateDeps(deps, owner, repo, version, architectures),
|
updateLibrustyV8(librusty_v8, owner, repo, version, architectures),
|
||||||
];
|
];
|
||||||
await Promise.all(tasks);
|
await Promise.all(tasks);
|
||||||
log("Updating deno complete");
|
log("Updating deno complete");
|
||||||
log("Commiting");
|
|
||||||
await commit(repo, existingVersion, trimVersion, [src, deps]);
|
|
||||||
log("Done");
|
|
||||||
|
|
|
@ -3618,7 +3618,8 @@ in
|
||||||
};
|
};
|
||||||
|
|
||||||
deno = callPackage ../development/web/deno {
|
deno = callPackage ../development/web/deno {
|
||||||
inherit (darwin.apple_sdk.frameworks) Security CoreServices;
|
inherit (darwin) libobjc;
|
||||||
|
inherit (darwin.apple_sdk.frameworks) Security CoreServices Metal Foundation;
|
||||||
};
|
};
|
||||||
|
|
||||||
detox = callPackage ../tools/misc/detox { };
|
detox = callPackage ../tools/misc/detox { };
|
||||||
|
|
Loading…
Reference in a new issue