create-astro 0.7.0 → 0.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -43,4 +43,19 @@ May be provided in place of prompts
43
43
  | `--template` | Specify the template name ([list][examples]) |
44
44
  | `--commit` | Specify a specific Git commit or branch to use from this repo (by default, `main` branch of this repo will be used) |
45
45
 
46
+ ### Debugging
47
+
48
+ To debug `create-astro`, you can use the `--verbose` flag which will log the output of degit and some more information about the command, this can be useful when you encounter an error and want to report it.
49
+
50
+ ```bash
51
+ # npm 6.x
52
+ npm init astro my-astro-project --verbose
53
+
54
+ # npm 7+, extra double-dash is needed:
55
+ npm init astro my-astro-project -- --verbose
56
+
57
+ # yarn
58
+ yarn create astro my-astro-project --verbose
59
+ ```
60
+
46
61
  [examples]: https://github.com/withastro/astro/tree/main/examples
package/dist/index.js CHANGED
@@ -24,6 +24,7 @@ import yargs from "yargs-parser";
24
24
  import { FRAMEWORKS, COUNTER_COMPONENTS } from "./frameworks.js";
25
25
  import { TEMPLATES } from "./templates.js";
26
26
  import { createConfig } from "./config.js";
27
+ import { logger, defaultLogLevel } from "./logger.js";
27
28
  const cleanArgv = process.argv.filter((arg) => arg !== "--");
28
29
  const args = yargs(cleanArgv, { array: ["renderers"] });
29
30
  prompts.override(args);
@@ -39,6 +40,7 @@ function mkdirp(dir) {
39
40
  const { version } = JSON.parse(fs.readFileSync(new URL("../package.json", import.meta.url), "utf-8"));
40
41
  const POSTPROCESS_FILES = ["package.json", "astro.config.mjs", "CHANGELOG.md"];
41
42
  async function main() {
43
+ logger.debug("Verbose logging turned on");
42
44
  console.log(`
43
45
  ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
44
46
  console.log(`If you encounter a problem, visit ${cyan("https://github.com/withastro/astro/issues")} to search or file a new issue.
@@ -78,7 +80,12 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
78
80
  const emitter = degit(`${templateTarget}${hash}`, {
79
81
  cache: false,
80
82
  force: true,
81
- verbose: false
83
+ verbose: defaultLogLevel === "debug" ? true : false
84
+ });
85
+ logger.debug("Initialized degit with following config:", `${templateTarget}${hash}`, {
86
+ cache: false,
87
+ force: true,
88
+ verbose: defaultLogLevel === "debug" ? true : false
82
89
  });
83
90
  const selectedTemplate = TEMPLATES.find((template) => template.value === options.template);
84
91
  let renderers = [];
@@ -101,17 +108,21 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
101
108
  console.log(`${green(`\u2714`)} ${bold(`Using template's default renderers`)} ${gray("\u203A")} ${titles}`);
102
109
  }
103
110
  try {
111
+ emitter.on("info", (info) => {
112
+ logger.debug(info.message);
113
+ });
104
114
  console.log(`${green(`>`)} ${gray(`Copying project files...`)}`);
105
115
  await emitter.clone(cwd);
106
116
  } catch (err) {
117
+ logger.debug(err);
107
118
  console.error(red(err.message));
108
119
  if (err.message === "zlib: unexpected end of file") {
109
- console.log(yellow("This seems to be a cache related problem. Remove the folder '~/.degit/github/snowpackjs' to fix this error."));
120
+ console.log(yellow("This seems to be a cache related problem. Remove the folder '~/.degit/github/withastro' to fix this error."));
110
121
  console.log(yellow("For more information check out this issue: https://github.com/withastro/astro/issues/655"));
111
122
  }
112
123
  if (err.code === "MISSING_REF") {
113
124
  console.log(yellow("This seems to be an issue with degit. Please check if you have 'git' installed on your system, and install it if you don't have (https://git-scm.com)."));
114
- console.log(yellow("If you do have 'git' installed, please file a new issue here: https://github.com/withastro/astro/issues"));
125
+ console.log(yellow("If you do have 'git' installed, please run this command with the --verbose flag and file a new issue with the command output here: https://github.com/withastro/astro/issues"));
115
126
  }
116
127
  process.exit(1);
117
128
  }
@@ -182,4 +193,4 @@ export {
182
193
  main,
183
194
  mkdirp
184
195
  };
185
- //# sourceMappingURL=data:application/json;base64,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
196
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFNQSxNQUFNLFlBQVksUUFBUSxLQUFLLE9BQU8sQ0FBQyxRQUFRLFFBQVE7QUFDdkQsTUFBTSxPQUFPLE1BQU0sV0FBVyxFQUFFLE9BQU8sQ0FBQztBQUN4QyxRQUFRLFNBQVM7QUFFVixnQkFBZ0IsS0FBYTtBQUNuQyxNQUFJO0FBQ0gsT0FBRyxVQUFVLEtBQUssRUFBRSxXQUFXO0FBQUEsV0FDdkIsR0FBUDtBQUNELFFBQUksRUFBRSxTQUFTO0FBQVU7QUFDekIsVUFBTTtBQUFBO0FBQUE7QUFJUixNQUFNLEVBQUUsWUFBWSxLQUFLLE1BQU0sR0FBRyxhQUFhLElBQUksSUFBSSxtQkFBbUIsWUFBWSxNQUFNO0FBRTVGLE1BQU0sb0JBQW9CLENBQUMsZ0JBQWdCLG9CQUFvQjtBQUUvRCxzQkFBNkI7QUFDNUIsU0FBTyxNQUFNO0FBQ2IsVUFBUSxJQUFJO0FBQUEsRUFBSyxLQUFLLHdCQUF3QixLQUFLLGtCQUFrQjtBQUNyRSxVQUFRLElBQUkscUNBQXFDLEtBQUs7QUFBQTtBQUV0RCxVQUFRLElBQUksR0FBRyxNQUFNLFFBQVEsS0FBSztBQUNsQyxVQUFRLElBQUksR0FBRyxNQUFNLFFBQVEsS0FBSztBQUVsQyxRQUFNLE1BQU0sS0FBSyxLQUFLLE1BQU07QUFDNUIsTUFBSSxHQUFHLFdBQVcsTUFBTTtBQUN2QixRQUFJLEdBQUcsWUFBWSxLQUFLLFNBQVMsR0FBRztBQUNuQyxZQUFNLFdBQVcsTUFBTSxRQUFRO0FBQUEsUUFDOUIsTUFBTTtBQUFBLFFBQ04sTUFBTTtBQUFBLFFBQ04sU0FBUztBQUFBLFFBQ1QsU0FBUztBQUFBO0FBRVYsVUFBSSxDQUFDLFNBQVMsZ0JBQWdCO0FBQzdCLGdCQUFRLEtBQUs7QUFBQTtBQUVkLGFBQU87QUFBQTtBQUFBLFNBRUY7QUFDTixXQUFPO0FBQUE7QUFHUixRQUFNLFVBQTRELE1BQU0sUUFBUTtBQUFBLElBQy9FO0FBQUEsTUFDQyxNQUFNO0FBQUEsTUFDTixNQUFNO0FBQUEsTUFDTixTQUFTO0FBQUEsTUFDVCxTQUFTO0FBQUE7QUFBQTtBQUlYLE1BQUksQ0FBQyxRQUFRLFVBQVU7QUFDdEIsWUFBUSxLQUFLO0FBQUE7QUFHZCxRQUFNLE9BQU8sS0FBSyxTQUFTLElBQUksS0FBSyxXQUFXO0FBRS9DLFFBQU0saUJBQWlCLFFBQVEsU0FBUyxTQUFTLE9BQU8sUUFBUSxXQUFXLDRCQUE0QixRQUFRO0FBRS9HLFFBQU0sVUFBVSxNQUFNLEdBQUcsaUJBQWlCLFFBQVE7QUFBQSxJQUNqRCxPQUFPO0FBQUEsSUFDUCxPQUFPO0FBQUEsSUFDUCxTQUFTLG9CQUFvQixVQUFVLE9BQU87QUFBQTtBQUcvQyxTQUFPLE1BQU0sNENBQTRDLEdBQUcsaUJBQWlCLFFBQVE7QUFBQSxJQUNwRixPQUFPO0FBQUEsSUFDUCxPQUFPO0FBQUEsSUFDUCxTQUFTLG9CQUFvQixVQUFVLE9BQU87QUFBQTtBQUcvQyxRQUFNLG1CQUFtQixVQUFVLEtBQUssQ0FBQyxhQUFhLFNBQVMsVUFBVSxRQUFRO0FBQ2pGLE1BQUksWUFBc0I7QUFFMUIsTUFBSSxzREFBa0IsZUFBYyxNQUFNO0FBQ3pDLFVBQU0sU0FBMkQsTUFBTSxRQUFRO0FBQUEsTUFDOUU7QUFBQSxRQUNDLE1BQU07QUFBQSxRQUNOLE1BQU07QUFBQSxRQUNOLFNBQVM7QUFBQSxRQUNULFNBQVM7QUFBQTtBQUFBO0FBR1gsZ0JBQVksT0FBTztBQUFBLGFBQ1Qsc0RBQWtCLGNBQWEsTUFBTSxRQUFRLGlCQUFpQixjQUFjLGlCQUFpQixVQUFVLFFBQVE7QUFDekgsZ0JBQVksaUJBQWlCO0FBQzdCLFVBQU0sU0FBUyxVQUFVLElBQUksQ0FBQyxhQUFVO0FBdkcxQztBQXVHNkMsOEJBQVcsS0FBSyxDQUFDLFNBQVMsS0FBSyxVQUFVLGNBQXpDLG1CQUFvRDtBQUFBLE9BQU8sS0FBSztBQUMzRyxZQUFRLElBQUksR0FBRyxNQUFNLGFBQVEsS0FBSyx5Q0FBeUMsS0FBSyxhQUFRO0FBQUE7QUFJekYsTUFBSTtBQUNILFlBQVEsR0FBRyxRQUFRLENBQUMsU0FBUztBQUM1QixhQUFPLE1BQU0sS0FBSztBQUFBO0FBRW5CLFlBQVEsSUFBSSxHQUFHLE1BQU0sUUFBUSxLQUFLO0FBQ2xDLFVBQU0sUUFBUSxNQUFNO0FBQUEsV0FDWixLQUFQO0FBRUQsV0FBTyxNQUFNO0FBQ2IsWUFBUSxNQUFNLElBQUksSUFBSTtBQUd0QixRQUFJLElBQUksWUFBWSxnQ0FBZ0M7QUFDbkQsY0FBUSxJQUFJLE9BQU87QUFDbkIsY0FBUSxJQUFJLE9BQU87QUFBQTtBQUlwQixRQUFJLElBQUksU0FBUyxlQUFlO0FBQy9CLGNBQVEsSUFBSSxPQUFPO0FBQ25CLGNBQVEsSUFDUCxPQUNDO0FBQUE7QUFJSCxZQUFRLEtBQUs7QUFBQTtBQUlkLFFBQU0sUUFBUSxJQUNiLGtCQUFrQixJQUFJLE9BQU8sU0FBUztBQTNJeEM7QUE0SUcsVUFBTSxVQUFVLEtBQUssUUFBUSxLQUFLLEtBQUssS0FBSztBQUU1QyxZQUFRO0FBQUEsV0FDRixnQkFBZ0I7QUFDcEIsWUFBSSxHQUFHLFdBQVcsVUFBVTtBQUMzQixnQkFBTSxHQUFHLFNBQVMsT0FBTztBQUFBO0FBRTFCO0FBQUE7QUFBQSxXQUVJLG9CQUFvQjtBQUN4QixZQUFJLHNEQUFrQixlQUFjLE1BQU07QUFDekM7QUFBQTtBQUVELGNBQU0sR0FBRyxTQUFTLFVBQVUsU0FBUyxhQUFhLEVBQUU7QUFDcEQ7QUFBQTtBQUFBLFdBRUksZ0JBQWdCO0FBQ3BCLGNBQU0sY0FBYyxLQUFLLE1BQU0sTUFBTSxHQUFHLFNBQVMsU0FBUyxTQUFTO0FBQ25FLGVBQU8sWUFBWTtBQUVuQixjQUFNLGtCQUFtQixNQUFNLFFBQVEsSUFDdEMsQ0FBQyxTQUFTLEdBQUcsV0FBVyxJQUFJLENBQUMsYUFDNUIsTUFBTSw4QkFBOEIsbUJBQ2xDLEtBQUssQ0FBQyxRQUFhLElBQUksUUFDdkIsS0FBSyxDQUFDLFFBQWEsQ0FBQyxVQUFVLElBQUksSUFBSTtBQUcxQyxvQkFBWSxrQkFBa0Isa0NBQU0sa0JBQVksb0JBQVosWUFBK0IsS0FBUSxPQUFPLFlBQVk7QUFDOUYsY0FBTSxHQUFHLFNBQVMsVUFBVSxTQUFTLEtBQUssVUFBVSxhQUFhLFFBQVc7QUFDNUU7QUFBQTtBQUFBO0FBQUE7QUFPSixNQUFJLHNEQUFrQixXQUFVLFdBQVc7QUFDMUMsUUFBSSxtQkFBNkI7QUFDakMsUUFBSSxhQUF1QjtBQUMzQixVQUFNLFFBQVEsSUFDYixVQUFVLElBQUksT0FBTyxhQUFhO0FBQ2pDLFlBQU0sWUFBWSxtQkFBbUI7QUFDckMsWUFBTSxnQkFBZ0IsS0FBSyxTQUFTLFVBQVUsVUFBVSxLQUFLLFFBQVEsVUFBVTtBQUMvRSxZQUFNLGFBQWEsS0FBSyxRQUFRLEtBQUssVUFBVTtBQUMvQyx1QkFBaUIsS0FBSyxVQUFVLHVCQUF1QixVQUFVLFNBQVMsUUFBUSxRQUFRO0FBQzFGLGlCQUFXLEtBQUssSUFBSTtBQUNwQixZQUFNLEdBQUcsU0FBUyxVQUFVLFlBQVksVUFBVTtBQUFBO0FBSXBELFVBQU0sY0FBYyxLQUFLLFFBQVEsS0FBSyxLQUFLLEtBQUssT0FBTyxTQUFTO0FBQ2hFLFVBQU0sVUFBVyxPQUFNLEdBQUcsU0FBUyxTQUFTLGNBQWM7QUFDMUQsVUFBTSxhQUFhLFFBQ2pCLFFBQVEsOENBQThDLENBQUMsR0FBRyxXQUFXO0FBQ3JFLGFBQU8sU0FBUyxpQkFBaUIsS0FBSztBQUFBLE9BRXRDLFFBQVEsMkNBQTJDLENBQUMsR0FBRyxXQUFXO0FBQ2xFLGFBQU8sV0FBVyxJQUFJLENBQUMsT0FBTyxTQUFTLElBQUksS0FBSztBQUFBO0FBRWxELFVBQU0sR0FBRyxTQUFTLFVBQVUsYUFBYTtBQUFBO0FBRzFDLFVBQVEsSUFBSSxLQUFLLE1BQU0sWUFBTztBQUU5QixVQUFRLElBQUk7QUFDWixNQUFJLElBQUk7QUFFUixRQUFNLFdBQVcsS0FBSyxTQUFTLFFBQVEsT0FBTztBQUM5QyxNQUFJLGFBQWEsSUFBSTtBQUNwQixZQUFRLElBQUksS0FBSyxRQUFRLEtBQUssS0FBSyxNQUFNO0FBQUE7QUFHMUMsVUFBUSxJQUFJLEtBQUssUUFBUSxLQUFLLEtBQUs7QUFDbkMsVUFBUSxJQUFJLEtBQUssUUFBUSxLQUFLLEtBQUs7QUFDbkMsVUFBUSxJQUFJLEtBQUssUUFBUSxLQUFLLEtBQUs7QUFFbkMsVUFBUSxJQUFJO0FBQUEsK0JBQWtDLEtBQUssS0FBSztBQUN4RCxVQUFRLElBQUk7QUFBQSxxQkFBd0IsS0FBSztBQUFBO0FBQUE7IiwKICAibmFtZXMiOiBbXQp9Cg==
package/dist/logger.js ADDED
@@ -0,0 +1,110 @@
1
+ import { bold, blue, dim, red, yellow } from "kleur/colors";
2
+ import { Writable } from "stream";
3
+ import { format as utilFormat } from "util";
4
+ function getLoggerLocale() {
5
+ const defaultLocale = "en-US";
6
+ if (process.env.LANG) {
7
+ const extractedLocale = process.env.LANG.split(".")[0].replace(/_/g, "-");
8
+ if (extractedLocale.length < 2)
9
+ return defaultLocale;
10
+ else
11
+ return extractedLocale;
12
+ } else
13
+ return defaultLocale;
14
+ }
15
+ const dt = new Intl.DateTimeFormat(getLoggerLocale(), {
16
+ hour: "2-digit",
17
+ minute: "2-digit"
18
+ });
19
+ const defaultLogDestination = new Writable({
20
+ objectMode: true,
21
+ write(event, _, callback) {
22
+ let dest = process.stderr;
23
+ if (levels[event.level] < levels["error"])
24
+ dest = process.stdout;
25
+ dest.write(dim(dt.format(new Date()) + " "));
26
+ let type = event.type;
27
+ if (type) {
28
+ switch (event.level) {
29
+ case "info":
30
+ type = bold(blue(type));
31
+ break;
32
+ case "warn":
33
+ type = bold(yellow(type));
34
+ break;
35
+ case "error":
36
+ type = bold(red(type));
37
+ break;
38
+ }
39
+ dest.write(`[${type}] `);
40
+ }
41
+ dest.write(utilFormat(...event.args));
42
+ dest.write("\n");
43
+ callback();
44
+ }
45
+ });
46
+ let defaultLogLevel;
47
+ if (process.argv.includes("--verbose")) {
48
+ defaultLogLevel = "debug";
49
+ } else if (process.argv.includes("--silent")) {
50
+ defaultLogLevel = "silent";
51
+ } else {
52
+ defaultLogLevel = "info";
53
+ }
54
+ const defaultLogOptions = {
55
+ dest: defaultLogDestination,
56
+ level: defaultLogLevel
57
+ };
58
+ const levels = {
59
+ debug: 20,
60
+ info: 30,
61
+ warn: 40,
62
+ error: 50,
63
+ silent: 90
64
+ };
65
+ function log(opts = {}, level, type, ...args) {
66
+ var _a, _b;
67
+ const logLevel = (_a = opts.level) != null ? _a : defaultLogOptions.level;
68
+ const dest = (_b = opts.dest) != null ? _b : defaultLogOptions.dest;
69
+ const event = {
70
+ type,
71
+ level,
72
+ args,
73
+ message: ""
74
+ };
75
+ if (levels[logLevel] > levels[level]) {
76
+ return;
77
+ }
78
+ dest.write(event);
79
+ }
80
+ function debug(opts, type, ...messages) {
81
+ return log(opts, "debug", type, ...messages);
82
+ }
83
+ function info(opts, type, ...messages) {
84
+ return log(opts, "info", type, ...messages);
85
+ }
86
+ function warn(opts, type, ...messages) {
87
+ return log(opts, "warn", type, ...messages);
88
+ }
89
+ function error(opts, type, ...messages) {
90
+ return log(opts, "error", type, ...messages);
91
+ }
92
+ const logger = {
93
+ debug: debug.bind(null, defaultLogOptions, "debug"),
94
+ info: info.bind(null, defaultLogOptions, "info"),
95
+ warn: warn.bind(null, defaultLogOptions, "warn"),
96
+ error: error.bind(null, defaultLogOptions, "error")
97
+ };
98
+ export {
99
+ debug,
100
+ defaultLogDestination,
101
+ defaultLogLevel,
102
+ defaultLogOptions,
103
+ error,
104
+ info,
105
+ levels,
106
+ log,
107
+ logger,
108
+ warn
109
+ };
110
+ //# sourceMappingURL=data:application/json;base64,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
@@ -0,0 +1,38 @@
1
+ /// <reference types="node" />
2
+ import { Writable } from 'stream';
3
+ export declare const defaultLogDestination: Writable;
4
+ interface LogWritable<T> extends Writable {
5
+ write: (chunk: T) => boolean;
6
+ }
7
+ export declare type LoggerLevel = 'debug' | 'info' | 'warn' | 'error' | 'silent';
8
+ export declare type LoggerEvent = 'debug' | 'info' | 'warn' | 'error';
9
+ export declare let defaultLogLevel: LoggerLevel;
10
+ export interface LogOptions {
11
+ dest?: LogWritable<LogMessage>;
12
+ level?: LoggerLevel;
13
+ }
14
+ export declare const defaultLogOptions: Required<LogOptions>;
15
+ export interface LogMessage {
16
+ type: string | null;
17
+ level: LoggerLevel;
18
+ message: string;
19
+ args: Array<any>;
20
+ }
21
+ export declare const levels: Record<LoggerLevel, number>;
22
+ /** Full logging API */
23
+ export declare function log(opts: LogOptions | undefined, level: LoggerLevel, type: string | null, ...args: Array<any>): void;
24
+ /** Emit a message only shown in debug mode */
25
+ export declare function debug(opts: LogOptions, type: string | null, ...messages: Array<any>): void;
26
+ /** Emit a general info message (be careful using this too much!) */
27
+ export declare function info(opts: LogOptions, type: string | null, ...messages: Array<any>): void;
28
+ /** Emit a warning a user should be aware of */
29
+ export declare function warn(opts: LogOptions, type: string | null, ...messages: Array<any>): void;
30
+ /** Emit a fatal error message the user should address. */
31
+ export declare function error(opts: LogOptions, type: string | null, ...messages: Array<any>): void;
32
+ export declare const logger: {
33
+ debug: (...args: any[]) => void;
34
+ info: (...args: any[]) => void;
35
+ warn: (...args: any[]) => void;
36
+ error: (...args: any[]) => void;
37
+ };
38
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-astro",
3
- "version": "0.7.0",
3
+ "version": "0.7.1",
4
4
  "type": "module",
5
5
  "author": "withastro",
6
6
  "license": "MIT",