aboutsummaryrefslogtreecommitdiff
path: root/packages/bun-release/src/console.ts
blob: 5c9db88728ed2dce21c6d83d1dcad5681305758c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
import { isatty } from "tty";
import { createInterface } from "readline";

export const isAction = !!process.env["GITHUB_ACTION"];

export const isDebug =
  process.env["DEBUG"] === "1" || process.env["LOG_LEVEL"] === "debug" || process.env["RUNNER_DEBUG"] === "1";

export function debug(...message: any[]): void {
  if (isAction) {
    console.debug("::debug::", ...message);
  } else if (isDebug) {
    console.debug(...message);
  }
}

export function log(...message: any[]): void {
  console.log(...message);
}

export function warn(...message: any[]): void {
  if (isAction) {
    console.warn("::warning::", ...message);
  } else {
    console.warn(...message);
  }
}

export function error(...message: any[]): void {
  if (isAction) {
    console.error("::error::", ...message);
  } else {
    console.error(...message);
  }
}

export function exit(...message: any[]): never {
  error(...message);
  process.exit(1);
}

export function isTty(): boolean {
  return isatty(process.stdout.fd);
}

export async function stdin(question: string): Promise<string> {
  if (isTty()) {
    return prompt(question) || "";
  }
  const reader = createInterface({
    input: process.stdin,
    terminal: false,
  });
  let buffer = "";
  reader.on("line", line => {
    buffer += line;
  });
  return new Promise(resolve => {
    reader.once("close", () => resolve(buffer));
  });
}

export async function confirm(message?: string): Promise<void> {
  if (!isTty()) {
    return;
  }
  const question = message ?? "Confirm?";
  switch (prompt(`${question} [y/n]`)) {
    case "y":
    case "Y":
      log();
      return;
  }
  exit();
}