Skip to content

Commit

Permalink
Handle .gql/.graphql files smartly
Browse files Browse the repository at this point in the history
  • Loading branch information
ewen-lbh committed Nov 10, 2024
1 parent ebd937b commit 01786e8
Showing 1 changed file with 14 additions and 6 deletions.
20 changes: 14 additions & 6 deletions packages/houdini/src/vite/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,15 +47,26 @@ export default function (opts?: PluginConfig): Plugin[] {
// make sure we behave as if we're generating from inside the plugin (changes logging behavior)
config.pluginMode = true

// .gql files always trigger a reload
if (opts?.autoCodeGen === 'smart' && absolutePath && !absolutePath.endsWith('.gql')) {
if (opts?.autoCodeGen === 'smart' && absolutePath) {
const isGraphQLFile = /\.g(raph)?ql$/.test(absolutePath)
const fileContents = await readFile(absolutePath).then((buf) => buf.toString('utf8'))
if (fileContents) {
if (fileContents && isGraphQLFile) {
// For graphql files, the extractedDocuments entry contains a single graphql "document" (which does not have to be an actual document) named '_' which is the entire file contents
// This allows us to only reload .gql files when their content actually changes. Writes to .gql files could not actually change their content, especially when the write was triggered by a write to the schema.graphql from the api server development workflow just because resolver implementation code was tweaked, but actual schema content was left unchanged.
const previousContent = extractedDocuments[absolutePath]?._.trim() ?? ''
// If the file is empty, don't assume anything changed
if (fileContents !== "" && previousContent !== fileContents) {
extractedDocuments[absolutePath] = { _: fileContents }
} else {
return
}
} else if (fileContents) {
const previousDocuments = extractedDocuments[absolutePath]
if (!previousDocuments) {
// To prevent full-page reloads every time we change something in a new document, just don't reload.
// Second change of the same document will trigger a reload
// It's better that way since most non-.gql files are modified for non-gql reasons most of the time
// This logic is reversed for .gql documents: reload on first change encountered since writes to graphql files are much more likely to cause a change in the graphql document
const [_, documents] = graphQLDocumentsChanged(fileContents, {})
extractedDocuments[absolutePath] = documents
return
Expand All @@ -69,9 +80,6 @@ export default function (opts?: PluginConfig): Plugin[] {
if (documentsChanged) {
extractedDocuments[absolutePath] = documents
} else {
console.debug(
`Skipped codegen for ${absolutePath} since graphql documents did not change`
)
return
}
}
Expand Down

0 comments on commit 01786e8

Please sign in to comment.