mirror of
https://github.com/DeterminateSystems/update-flake-lock.git
synced 2025-01-11 06:42:41 +01:00
Make a single dir a special case
This commit is contained in:
parent
dccc3175bf
commit
5d30a7794a
3 changed files with 33 additions and 43 deletions
29
dist/index.js
vendored
29
dist/index.js
vendored
|
@ -94777,6 +94777,7 @@ function makeNixCommandArgs(nixOptions, flakeInputs, commitMessage) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var DEFAULT_FLAKE_DIR = ".";
|
||||||
var EVENT_EXECUTION_FAILURE = "execution_failure";
|
var EVENT_EXECUTION_FAILURE = "execution_failure";
|
||||||
var UpdateFlakeLockAction = class extends DetSysAction {
|
var UpdateFlakeLockAction = class extends DetSysAction {
|
||||||
constructor() {
|
constructor() {
|
||||||
|
@ -94789,27 +94790,21 @@ var UpdateFlakeLockAction = class extends DetSysAction {
|
||||||
this.flakeInputs = inputs_exports.getArrayOfStrings("inputs", "space");
|
this.flakeInputs = inputs_exports.getArrayOfStrings("inputs", "space");
|
||||||
this.nixOptions = inputs_exports.getArrayOfStrings("nix-options", "space");
|
this.nixOptions = inputs_exports.getArrayOfStrings("nix-options", "space");
|
||||||
this.pathToFlakeDir = inputs_exports.getStringOrNull("path-to-flake-dir");
|
this.pathToFlakeDir = inputs_exports.getStringOrNull("path-to-flake-dir");
|
||||||
this.flakeDirs = inputs_exports.getArrayOfStringsOrNull("flake-dirs", "space");
|
this.flakeDirsInput = inputs_exports.getArrayOfStringsOrNull("flake-dirs", "space");
|
||||||
this.validateInputs();
|
this.validateInputs();
|
||||||
|
if (this.flakeDirsInput !== null && this.flakeDirsInput.length > 0) {
|
||||||
|
this.flakeDirs = this.flakeDirsInput;
|
||||||
|
} else {
|
||||||
|
this.flakeDirs = [this.pathToFlakeDir ?? DEFAULT_FLAKE_DIR];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
async main() {
|
async main() {
|
||||||
await this.updateFlakeLock();
|
|
||||||
}
|
|
||||||
// No post phase
|
|
||||||
async post() {
|
|
||||||
}
|
|
||||||
async updateFlakeLock() {
|
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
|
||||||
core.debug(
|
|
||||||
`Running flake lock update in multiple directories: ${this.flakeDirs.map((dir) => `\`${dir}\``).join(" ")}`
|
|
||||||
);
|
|
||||||
for (const directory of this.flakeDirs) {
|
for (const directory of this.flakeDirs) {
|
||||||
await this.updateFlakeInDirectory(directory);
|
await this.updateFlakeInDirectory(directory);
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
const flakeDir = this.pathToFlakeDir ?? ".";
|
|
||||||
await this.updateFlakeInDirectory(flakeDir);
|
|
||||||
}
|
}
|
||||||
|
// No post phase
|
||||||
|
async post() {
|
||||||
}
|
}
|
||||||
async updateFlakeInDirectory(flakeDir) {
|
async updateFlakeInDirectory(flakeDir) {
|
||||||
this.ensureDirectoryExists(flakeDir);
|
this.ensureDirectoryExists(flakeDir);
|
||||||
|
@ -94847,17 +94842,17 @@ var UpdateFlakeLockAction = class extends DetSysAction {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
validateInputs() {
|
validateInputs() {
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0 && this.pathToFlakeDir !== null && this.pathToFlakeDir !== "") {
|
if (this.flakeDirsInput !== null && this.flakeDirsInput.length > 0 && this.pathToFlakeDir !== null && this.pathToFlakeDir !== "") {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
"Both `path-to-flake-dir` and `flake-dirs` are set, whereas only one can be"
|
"Both `path-to-flake-dir` and `flake-dirs` are set, whereas only one can be"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length === 0) {
|
if (this.flakeDirsInput !== null && this.flakeDirsInput.length === 0) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
"The `flake-dirs` input is set to an empty array; it must contain at least one directory"
|
"The `flake-dirs` input is set to an empty array; it must contain at least one directory"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0 && this.flakeInputs.length > 0) {
|
if (this.flakeDirsInput !== null && this.flakeDirsInput.length > 0 && this.flakeInputs.length > 0) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
`You've set both \`flake-dirs\` and \`inputs\` but you can only set one`
|
`You've set both \`flake-dirs\` and \`inputs\` but you can only set one`
|
||||||
);
|
);
|
||||||
|
|
2
dist/index.js.map
vendored
2
dist/index.js.map
vendored
File diff suppressed because one or more lines are too long
43
src/index.ts
43
src/index.ts
|
@ -4,6 +4,8 @@ import * as actionsExec from "@actions/exec";
|
||||||
import { DetSysAction, inputs } from "detsys-ts";
|
import { DetSysAction, inputs } from "detsys-ts";
|
||||||
import * as fs from "fs";
|
import * as fs from "fs";
|
||||||
|
|
||||||
|
const DEFAULT_FLAKE_DIR = ".";
|
||||||
|
|
||||||
const EVENT_EXECUTION_FAILURE = "execution_failure";
|
const EVENT_EXECUTION_FAILURE = "execution_failure";
|
||||||
|
|
||||||
class UpdateFlakeLockAction extends DetSysAction {
|
class UpdateFlakeLockAction extends DetSysAction {
|
||||||
|
@ -11,7 +13,8 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
private nixOptions: string[];
|
private nixOptions: string[];
|
||||||
private flakeInputs: string[];
|
private flakeInputs: string[];
|
||||||
private pathToFlakeDir: string | null;
|
private pathToFlakeDir: string | null;
|
||||||
private flakeDirs: string[] | null;
|
private flakeDirsInput: string[] | null;
|
||||||
|
private flakeDirs: string[];
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super({
|
super({
|
||||||
|
@ -24,34 +27,26 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
this.flakeInputs = inputs.getArrayOfStrings("inputs", "space");
|
this.flakeInputs = inputs.getArrayOfStrings("inputs", "space");
|
||||||
this.nixOptions = inputs.getArrayOfStrings("nix-options", "space");
|
this.nixOptions = inputs.getArrayOfStrings("nix-options", "space");
|
||||||
this.pathToFlakeDir = inputs.getStringOrNull("path-to-flake-dir");
|
this.pathToFlakeDir = inputs.getStringOrNull("path-to-flake-dir");
|
||||||
this.flakeDirs = inputs.getArrayOfStringsOrNull("flake-dirs", "space");
|
this.flakeDirsInput = inputs.getArrayOfStringsOrNull("flake-dirs", "space");
|
||||||
|
|
||||||
this.validateInputs();
|
this.validateInputs();
|
||||||
|
|
||||||
|
if (this.flakeDirsInput !== null && this.flakeDirsInput.length > 0) {
|
||||||
|
this.flakeDirs = this.flakeDirsInput;
|
||||||
|
} else {
|
||||||
|
this.flakeDirs = [this.pathToFlakeDir ?? DEFAULT_FLAKE_DIR];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async main(): Promise<void> {
|
async main(): Promise<void> {
|
||||||
await this.updateFlakeLock();
|
for (const directory of this.flakeDirs) {
|
||||||
|
await this.updateFlakeInDirectory(directory);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// No post phase
|
// No post phase
|
||||||
async post(): Promise<void> {}
|
async post(): Promise<void> {}
|
||||||
|
|
||||||
async updateFlakeLock(): Promise<void> {
|
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
|
||||||
actionsCore.debug(
|
|
||||||
`Running flake lock update in multiple directories: ${this.flakeDirs.map((dir) => `\`${dir}\``).join(" ")}`,
|
|
||||||
);
|
|
||||||
|
|
||||||
for (const directory of this.flakeDirs) {
|
|
||||||
await this.updateFlakeInDirectory(directory);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Set directory to root if not specified
|
|
||||||
const flakeDir = this.pathToFlakeDir ?? ".";
|
|
||||||
await this.updateFlakeInDirectory(flakeDir);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private async updateFlakeInDirectory(flakeDir: string): Promise<void> {
|
private async updateFlakeInDirectory(flakeDir: string): Promise<void> {
|
||||||
this.ensureDirectoryExists(flakeDir);
|
this.ensureDirectoryExists(flakeDir);
|
||||||
this.ensureDirectoryIsFlake(flakeDir);
|
this.ensureDirectoryIsFlake(flakeDir);
|
||||||
|
@ -102,8 +97,8 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
private validateInputs(): void {
|
private validateInputs(): void {
|
||||||
// Ensure that either `path-to-flake-dir` or `flake-dirs` is set to a meaningful value but not both
|
// Ensure that either `path-to-flake-dir` or `flake-dirs` is set to a meaningful value but not both
|
||||||
if (
|
if (
|
||||||
this.flakeDirs !== null &&
|
this.flakeDirsInput !== null &&
|
||||||
this.flakeDirs.length > 0 &&
|
this.flakeDirsInput.length > 0 &&
|
||||||
this.pathToFlakeDir !== null &&
|
this.pathToFlakeDir !== null &&
|
||||||
this.pathToFlakeDir !== ""
|
this.pathToFlakeDir !== ""
|
||||||
) {
|
) {
|
||||||
|
@ -113,7 +108,7 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure that `flake-dirs` isn't an empty array if set
|
// Ensure that `flake-dirs` isn't an empty array if set
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length === 0) {
|
if (this.flakeDirsInput !== null && this.flakeDirsInput.length === 0) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
"The `flake-dirs` input is set to an empty array; it must contain at least one directory",
|
"The `flake-dirs` input is set to an empty array; it must contain at least one directory",
|
||||||
);
|
);
|
||||||
|
@ -121,8 +116,8 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
|
|
||||||
// Ensure that both `flake-dirs` and `inputs` aren't set at the same time
|
// Ensure that both `flake-dirs` and `inputs` aren't set at the same time
|
||||||
if (
|
if (
|
||||||
this.flakeDirs !== null &&
|
this.flakeDirsInput !== null &&
|
||||||
this.flakeDirs.length > 0 &&
|
this.flakeDirsInput.length > 0 &&
|
||||||
this.flakeInputs.length > 0
|
this.flakeInputs.length > 0
|
||||||
) {
|
) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
|
|
Loading…
Reference in a new issue