deno: update update script to changed deno

This commit is contained in:
06kellyjac 2021-03-12 19:14:19 +00:00
parent 9611f03177
commit c034a1412b
5 changed files with 113 additions and 118 deletions

View File

@ -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;

View File

@ -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 {
librusty_v8 = {
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 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(archShaTasks(version, arches));
await write(filePath, templateDeps(version, archShaResults));
log("Finished deps update");
}

View 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");
}

View File

@ -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);

View File

@ -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,7 +14,7 @@ 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" },
@ -42,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");