2017-07-27 23:23:20 +00:00
|
|
|
package transform
|
|
|
|
|
|
|
|
import (
|
2019-09-09 23:08:19 +00:00
|
|
|
"github.com/hashicorp/hcl/v2"
|
2017-07-27 23:23:20 +00:00
|
|
|
)
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
// NewErrorBody returns a hcl.Body that returns the given diagnostics whenever
|
2017-07-27 23:23:20 +00:00
|
|
|
// any of its content-access methods are called.
|
|
|
|
//
|
|
|
|
// The given diagnostics must have at least one diagnostic of severity
|
2017-09-11 23:40:37 +00:00
|
|
|
// hcl.DiagError, or this function will panic.
|
2017-07-27 23:23:20 +00:00
|
|
|
//
|
|
|
|
// This can be used to prepare a return value for a Transformer that
|
|
|
|
// can't complete due to an error. While the transform itself will succeed,
|
|
|
|
// the error will be returned as soon as a caller attempts to extract content
|
|
|
|
// from the resulting body.
|
2017-09-11 23:40:37 +00:00
|
|
|
func NewErrorBody(diags hcl.Diagnostics) hcl.Body {
|
2017-07-27 23:23:20 +00:00
|
|
|
if !diags.HasErrors() {
|
|
|
|
panic("NewErrorBody called without any error diagnostics")
|
|
|
|
}
|
|
|
|
return diagBody{
|
|
|
|
Diags: diags,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
// BodyWithDiagnostics returns a hcl.Body that wraps another hcl.Body
|
2017-07-27 23:23:20 +00:00
|
|
|
// and emits the given diagnostics for any content-extraction method.
|
|
|
|
//
|
|
|
|
// Unlike the result of NewErrorBody, a body with diagnostics still runs
|
|
|
|
// the extraction actions on the underlying body if (and only if) the given
|
|
|
|
// diagnostics do not contain errors, but prepends the given diagnostics with
|
|
|
|
// any diagnostics produced by the action.
|
|
|
|
//
|
|
|
|
// If the given diagnostics is empty, the given body is returned verbatim.
|
|
|
|
//
|
|
|
|
// This function is intended for conveniently reporting errors and/or warnings
|
|
|
|
// produced during a transform, ensuring that they will be seen when the
|
|
|
|
// caller eventually extracts content from the returned body.
|
2017-09-11 23:40:37 +00:00
|
|
|
func BodyWithDiagnostics(body hcl.Body, diags hcl.Diagnostics) hcl.Body {
|
2017-07-27 23:23:20 +00:00
|
|
|
if len(diags) == 0 {
|
|
|
|
// nothing to do!
|
|
|
|
return body
|
|
|
|
}
|
|
|
|
|
|
|
|
return diagBody{
|
|
|
|
Diags: diags,
|
|
|
|
Wrapped: body,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type diagBody struct {
|
2017-09-11 23:40:37 +00:00
|
|
|
Diags hcl.Diagnostics
|
|
|
|
Wrapped hcl.Body
|
2017-07-27 23:23:20 +00:00
|
|
|
}
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
func (b diagBody) Content(schema *hcl.BodySchema) (*hcl.BodyContent, hcl.Diagnostics) {
|
2017-07-27 23:23:20 +00:00
|
|
|
if b.Diags.HasErrors() {
|
|
|
|
return b.emptyContent(), b.Diags
|
|
|
|
}
|
|
|
|
|
|
|
|
content, wrappedDiags := b.Wrapped.Content(schema)
|
2017-09-11 23:40:37 +00:00
|
|
|
diags := make(hcl.Diagnostics, 0, len(b.Diags)+len(wrappedDiags))
|
2017-07-27 23:23:20 +00:00
|
|
|
diags = append(diags, b.Diags...)
|
|
|
|
diags = append(diags, wrappedDiags...)
|
|
|
|
return content, diags
|
|
|
|
}
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
func (b diagBody) PartialContent(schema *hcl.BodySchema) (*hcl.BodyContent, hcl.Body, hcl.Diagnostics) {
|
2017-07-27 23:23:20 +00:00
|
|
|
if b.Diags.HasErrors() {
|
|
|
|
return b.emptyContent(), b.Wrapped, b.Diags
|
|
|
|
}
|
|
|
|
|
|
|
|
content, remain, wrappedDiags := b.Wrapped.PartialContent(schema)
|
2017-09-11 23:40:37 +00:00
|
|
|
diags := make(hcl.Diagnostics, 0, len(b.Diags)+len(wrappedDiags))
|
2017-07-27 23:23:20 +00:00
|
|
|
diags = append(diags, b.Diags...)
|
|
|
|
diags = append(diags, wrappedDiags...)
|
|
|
|
return content, remain, diags
|
|
|
|
}
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
func (b diagBody) JustAttributes() (hcl.Attributes, hcl.Diagnostics) {
|
2017-07-27 23:23:20 +00:00
|
|
|
if b.Diags.HasErrors() {
|
|
|
|
return nil, b.Diags
|
|
|
|
}
|
|
|
|
|
|
|
|
attributes, wrappedDiags := b.Wrapped.JustAttributes()
|
2017-09-11 23:40:37 +00:00
|
|
|
diags := make(hcl.Diagnostics, 0, len(b.Diags)+len(wrappedDiags))
|
2017-07-27 23:23:20 +00:00
|
|
|
diags = append(diags, b.Diags...)
|
|
|
|
diags = append(diags, wrappedDiags...)
|
|
|
|
return attributes, diags
|
|
|
|
}
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
func (b diagBody) MissingItemRange() hcl.Range {
|
2017-07-27 23:23:20 +00:00
|
|
|
if b.Wrapped != nil {
|
|
|
|
return b.Wrapped.MissingItemRange()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Placeholder. This should never be seen in practice because decoding
|
|
|
|
// a diagBody without a wrapped body should always produce an error.
|
2017-09-11 23:40:37 +00:00
|
|
|
return hcl.Range{
|
2017-07-27 23:23:20 +00:00
|
|
|
Filename: "<empty>",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-11 23:40:37 +00:00
|
|
|
func (b diagBody) emptyContent() *hcl.BodyContent {
|
|
|
|
return &hcl.BodyContent{
|
2017-07-27 23:23:20 +00:00
|
|
|
MissingItemRange: b.MissingItemRange(),
|
|
|
|
}
|
|
|
|
}
|