|
@@ -39,33 +39,13 @@ func (i *TemplateInspector) Inspect(typedElement interface{}, rawElement []byte)
|
|
if rawElement == nil {
|
|
if rawElement == nil {
|
|
return fmt.Errorf("Template parsing error: %v", err)
|
|
return fmt.Errorf("Template parsing error: %v", err)
|
|
}
|
|
}
|
|
- return i.tryRawInspectFallback(rawElement)
|
|
|
|
|
|
+ return i.tryRawInspectFallback(rawElement, err)
|
|
}
|
|
}
|
|
i.buffer.Write(buffer.Bytes())
|
|
i.buffer.Write(buffer.Bytes())
|
|
i.buffer.WriteByte('\n')
|
|
i.buffer.WriteByte('\n')
|
|
return nil
|
|
return nil
|
|
}
|
|
}
|
|
|
|
|
|
-func (i *TemplateInspector) tryRawInspectFallback(rawElement []byte) error {
|
|
|
|
- var raw interface{}
|
|
|
|
- buffer := new(bytes.Buffer)
|
|
|
|
- rdr := bytes.NewReader(rawElement)
|
|
|
|
- dec := json.NewDecoder(rdr)
|
|
|
|
-
|
|
|
|
- if rawErr := dec.Decode(&raw); rawErr != nil {
|
|
|
|
- return fmt.Errorf("unable to read inspect data: %v", rawErr)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- tmplMissingKey := i.tmpl.Option("missingkey=error")
|
|
|
|
- if rawErr := tmplMissingKey.Execute(buffer, raw); rawErr != nil {
|
|
|
|
- return fmt.Errorf("Template parsing error: %v", rawErr)
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- i.buffer.Write(buffer.Bytes())
|
|
|
|
- i.buffer.WriteByte('\n')
|
|
|
|
- return nil
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
// Flush write the result of inspecting all elements into the output stream.
|
|
// Flush write the result of inspecting all elements into the output stream.
|
|
func (i *TemplateInspector) Flush() error {
|
|
func (i *TemplateInspector) Flush() error {
|
|
_, err := io.Copy(i.outputStream, i.buffer)
|
|
_, err := io.Copy(i.outputStream, i.buffer)
|