Skip to content

Commit

Permalink
fix(gatsby-source-filesystem,gatsby-transformer-sharp): Use custom er…
Browse files Browse the repository at this point in the history
…rors (gatsbyjs#27576)
  • Loading branch information
ax-vasquez authored Oct 26, 2020
1 parent 6a20a50 commit 5935379
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 3 deletions.
26 changes: 26 additions & 0 deletions src/error-utils.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
export const CODES = {
Generic: `10000`,
MissingResource: `10001`,
}

export const pluginPrefix = `gatsby-source-filesystem`

export function prefixId(id) {
return `${pluginPrefix}_${id}`
}

// TODO: Refactor to use contextual data instead of only context.sourceMessage
// once reporter.setErrorMap is guaranteed to be available
export const ERROR_MAP = {
[CODES.Generic]: {
text: context => context.sourceMessage,
level: `ERROR`,
type: `PLUGIN`,
},
[CODES.MissingResource]: {
text: context => context.sourceMessage,
level: `ERROR`,
type: `PLUGIN`,
category: `USER`,
},
}
17 changes: 14 additions & 3 deletions src/extend-file-node.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,14 @@
const { GraphQLString } = require(`gatsby/graphql`)
const fs = require(`fs-extra`)
const path = require(`path`)
const { prefixId, CODES } = require(`./error-utils`)

module.exports = ({ type, getNodeAndSavePathDependency, pathPrefix = `` }) => {
module.exports = ({
type,
getNodeAndSavePathDependency,
pathPrefix = ``,
reporter,
}) => {
if (type.name !== `File`) {
return {}
}
Expand Down Expand Up @@ -30,8 +36,13 @@ module.exports = ({ type, getNodeAndSavePathDependency, pathPrefix = `` }) => {
{ dereference: true },
err => {
if (err) {
console.error(
`error copying file from ${details.absolutePath} to ${publicPath}`,
reporter.panic(
{
id: prefixId(CODES.MissingResource),
context: {
sourceMessage: `error copying file from ${details.absolutePath} to ${publicPath}`,
},
},
err
)
}
Expand Down
7 changes: 7 additions & 0 deletions src/gatsby-node.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,13 @@ const path = require(`path`)
const { Machine, interpret } = require(`xstate`)

const { createFileNode } = require(`./create-file-node`)
const { ERROR_MAP } = require(`./error-utils`)

exports.onPreInit = ({ reporter }) => {
if (reporter.setErrorMap) {
reporter.setErrorMap(ERROR_MAP)
}
}

/**
* Create a state machine to manage Chokidar's not-ready/ready states.
Expand Down

0 comments on commit 5935379

Please sign in to comment.