From 7edbd9edb57a0da796346965de9207d0f9164523 Mon Sep 17 00:00:00 2001 From: jeffail Date: Thu, 18 Jan 2018 10:45:02 +0000 Subject: [PATCH] Wrap with pipelines should return pipe type --- lib/input/wrap_with_pipeline.go | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/lib/input/wrap_with_pipeline.go b/lib/input/wrap_with_pipeline.go index a7fe165a5e..2601e5d877 100644 --- a/lib/input/wrap_with_pipeline.go +++ b/lib/input/wrap_with_pipeline.go @@ -55,14 +55,19 @@ func WrapWithPipeline(in Type, pipeConstructor pipeline.ConstructorFunc) (*WithP } // WrapWithPipelines wraps an input with a variadic number of pipelines. -func WrapWithPipelines(in Type, pipeConstructors ...pipeline.ConstructorFunc) (Type, error) { +func WrapWithPipelines(in Type, pipeConstructors ...pipeline.ConstructorFunc) (*WithPipeline, error) { var err error - for _, ctor := range pipeConstructors { - if in, err = WrapWithPipeline(in, ctor); err != nil { + var pipe *WithPipeline + for i, ctor := range pipeConstructors { + if i == 0 { + if pipe, err = WrapWithPipeline(in, ctor); err != nil { + return nil, err + } + } else if pipe, err = WrapWithPipeline(pipe, ctor); err != nil { return nil, err } } - return in, nil + return pipe, nil } //------------------------------------------------------------------------------