Skip to content

Commit

Permalink
Add newline to body only on well-known error
Browse files Browse the repository at this point in the history
  • Loading branch information
syndicut committed Jan 24, 2021
1 parent 49b8284 commit 3b4dc57
Showing 1 changed file with 31 additions and 4 deletions.
35 changes: 31 additions & 4 deletions tflint/client/decode.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,12 +62,39 @@ func decodeBlock(block *Block) (*hcl.Block, hcl.Diagnostics) {
}, nil
}

func hasUnterminatedTemplateString(diags []*hcl.Diagnostic) bool {
for _, diag := range diags {
return diag.Summary == "Unterminated template string" &&
diag.Detail == "No closing marker was found for the string."
}
}

func onUnterminatedTemplateStringDiag(diags []*hcl.Diagnostic, action func() ) {
for _, diag := range diags {
if isUnterminatedTemplateStringDiag(diag) {
return action()
}
}
}

func parseExpression(src []byte, filename string, start hcl.Pos) (hcl.Expression, hcl.Diagnostics) {
if strings.HasSuffix(filename, ".tf") {
// HACK: Always add a newline to avoid heredoc parse errors.
// @see https://github.com/hashicorp/hcl/issues/441
src = []byte(string(src) + "\n")
return hclsyntax.ParseExpression(src, filename, start)
expr, diags := hclsyntax.ParseExpression(src, filename, start)
if hasUnterminatedTemplateString(diags) {
// HACK: Add a newline to avoid heredoc parse errors.
// @see https://github.com/hashicorp/hcl/issues/441
src = []byte(string(src) + "\n")
fixedExpr, fixedDiags := hclsyntax.ParseExpression(src, filename, start)

// Still has error? Return first result
if hasUnterminatedTemplateString(fixedDiags) {
return expr, diags
}

return fixedExpr, fixedDiags
}

return expr, diags
}

if strings.HasSuffix(filename, ".tf.json") {
Expand Down

0 comments on commit 3b4dc57

Please sign in to comment.