diff --git a/packages/gatsby/src/bootstrap/index.js b/packages/gatsby/src/bootstrap/index.js index 45f17fd6c2dab..56dd5aa9754c9 100644 --- a/packages/gatsby/src/bootstrap/index.js +++ b/packages/gatsby/src/bootstrap/index.js @@ -21,7 +21,7 @@ const loadThemes = require(`./load-themes`) const report = require(`gatsby-cli/lib/reporter`) import { getConfigFile } from "./get-config-file" const tracer = require(`opentracing`).globalTracer() -const preferDefault = require(`./prefer-default`) +import { preferDefault } from "./prefer-default" import { removeStaleJobs } from "./remove-stale-jobs" // Show stack trace on unhandled promises. @@ -37,7 +37,7 @@ import { writeRedirects, startRedirectListener } from "./redirects-writer" // Override console.log to add the source file + line number. // Useful for debugging if you lose a console.log somewhere. // Otherwise leave commented out. -// require(`./log-line-function`) +// import "./log-line-function" type BootstrapArgs = { directory: string, diff --git a/packages/gatsby/src/bootstrap/load-themes/index.js b/packages/gatsby/src/bootstrap/load-themes/index.js index 3ce77bd406896..94e909e6e6ee3 100644 --- a/packages/gatsby/src/bootstrap/load-themes/index.js +++ b/packages/gatsby/src/bootstrap/load-themes/index.js @@ -3,7 +3,7 @@ const mergeGatsbyConfig = require(`../../utils/merge-gatsby-config`) const Promise = require(`bluebird`) const _ = require(`lodash`) const debug = require(`debug`)(`gatsby:load-themes`) -const preferDefault = require(`../prefer-default`) +import { preferDefault } from "../prefer-default" import { getConfigFile } from "../get-config-file" const { resolvePlugin } = require(`../load-plugins/load`) const reporter = require(`gatsby-cli/lib/reporter`) diff --git a/packages/gatsby/src/bootstrap/log-line-function.js b/packages/gatsby/src/bootstrap/log-line-function.js deleted file mode 100644 index b6e8ee936d8f0..0000000000000 --- a/packages/gatsby/src/bootstrap/log-line-function.js +++ /dev/null @@ -1,12 +0,0 @@ -;[`log`, `warn`].forEach(function (method) { - var old = console[method] - console[method] = function () { - var stack = new Error().stack.split(/\n/) - // Chrome includes a single "Error" line, FF doesn't. - if (stack[0].indexOf(`Error`) === 0) { - stack = stack.slice(1) - } - var args = [].slice.apply(arguments).concat([stack[1].trim()]) - return old.apply(console, args) - } -}) diff --git a/packages/gatsby/src/bootstrap/log-line-function.ts b/packages/gatsby/src/bootstrap/log-line-function.ts new file mode 100644 index 0000000000000..44efb53f99b25 --- /dev/null +++ b/packages/gatsby/src/bootstrap/log-line-function.ts @@ -0,0 +1,20 @@ +;[`log`, `warn`].forEach((method: string): void => { + const old = console[method] + + console[method] = (...methodArgs: []): void => { + const error: Error = new Error() + let stack = error.stack ? error.stack.split(/\n/) : [] + + // Chrome includes a single "Error" line, FF doesn't. + if (stack[0].indexOf(`Error`) === 0) { + stack = stack.slice(1) + } + + const [, trace] = stack[1] || `` + const args: string[] = ([] as string[]).slice + .apply(methodArgs) + .concat([trace.trim()]) + + return old.apply(console, args) + } +}) diff --git a/packages/gatsby/src/bootstrap/prefer-default.js b/packages/gatsby/src/bootstrap/prefer-default.js deleted file mode 100644 index 13b0f0fcede97..0000000000000 --- a/packages/gatsby/src/bootstrap/prefer-default.js +++ /dev/null @@ -1 +0,0 @@ -module.exports = m => (m && m.default) || m diff --git a/packages/gatsby/src/bootstrap/prefer-default.ts b/packages/gatsby/src/bootstrap/prefer-default.ts new file mode 100644 index 0000000000000..603441436b008 --- /dev/null +++ b/packages/gatsby/src/bootstrap/prefer-default.ts @@ -0,0 +1 @@ +export const preferDefault = (m: any): any => (m && m.default) || m diff --git a/packages/gatsby/src/commands/serve.ts b/packages/gatsby/src/commands/serve.ts index 9189c6fe9a4c9..76b8f76e840b6 100644 --- a/packages/gatsby/src/commands/serve.ts +++ b/packages/gatsby/src/commands/serve.ts @@ -12,7 +12,7 @@ import telemetry from "gatsby-telemetry" import { detectPortInUseAndPrompt } from "../utils/detect-port-in-use-and-prompt" import { getConfigFile } from "../bootstrap/get-config-file" -import preferDefault from "../bootstrap/prefer-default" +import { preferDefault } from "../bootstrap/prefer-default" import { IProgram } from "./types" interface IMatchPath {