]> git.tdb.fi Git - libs/gl.git/blobdiff - source/pipeline.h
Process MemberAccess nodes in FunctionInliner
[libs/gl.git] / source / pipeline.h
index 35d10a41c6f5a6f3521ade05f0066a4218bebbb3..0d38aaec40181ca402b896c1bf5a4530cb266fb7 100644 (file)
@@ -76,7 +76,7 @@ private:
        PassList passes;
        const Camera *camera;
        std::vector<Slot> renderables;
-       std::vector<PostProcessor *> postproc;
+       std::vector<RefPtr<PostProcessor> > postproc;
        unsigned width;
        unsigned height;
        bool hdr;
@@ -87,6 +87,7 @@ private:
 public:
        Pipeline(unsigned, unsigned, bool = false);
        Pipeline(const View &);
+       Pipeline(const Framebuffer &);
 private:
        void init(unsigned, unsigned);
 public:
@@ -98,6 +99,11 @@ public:
 
        void set_multisample(unsigned);
 
+       unsigned get_width() const { return width; }
+       unsigned get_height() const { return height; }
+       bool get_hdr() const { return hdr; }
+       unsigned get_multisample() const { return samples; }
+
        // Deprecated
        void set_camera(const Camera *);
        Pass &add_pass(const Tag &tag);
@@ -112,6 +118,15 @@ public:
        /** Adds a postprocessor to the pipeline. */
        void add_postprocessor(PostProcessor &);
 
+       /** Adds a postprocessor to the pipeline, transferring ownership.  The
+       postprocessor will be deleted together with with pipeline.  It is also
+       deleted if this call throws an exception. */
+       void add_postprocessor_owned(PostProcessor *);
+
+private:
+       void add_postprocessor(PostProcessor *, bool);
+
+public:
        virtual void setup_frame(Renderer &);
        virtual void finish_frame();