]> git.sesse.net Git - movit/blobdiff - diffusion_effect.cpp
Check for __APPLE__ instead of __DARWIN__.
[movit] / diffusion_effect.cpp
index fb78bb76a4cadfe6b4609a1f4fcddaacc565bc23..afec9c80805490a97404d6e0c6e118759982dd9b 100644 (file)
@@ -8,10 +8,20 @@
 
 using namespace std;
 
+namespace movit {
+
 DiffusionEffect::DiffusionEffect()
        : blur(new BlurEffect),
-         overlay_matte(new OverlayMatteEffect)
+         overlay_matte(new OverlayMatteEffect),
+         owns_overlay_matte(true)
+{
+}
+
+DiffusionEffect::~DiffusionEffect()
 {
+       if (owns_overlay_matte) {
+               delete overlay_matte;
+       }
 }
 
 void DiffusionEffect::rewrite_graph(EffectChain *graph, Node *self)
@@ -21,6 +31,7 @@ void DiffusionEffect::rewrite_graph(EffectChain *graph, Node *self)
 
        Node *blur_node = graph->add_node(blur);
        Node *overlay_matte_node = graph->add_node(overlay_matte);
+       owns_overlay_matte = false;
        graph->replace_receiver(self, overlay_matte_node);
        graph->connect_nodes(input, blur_node);
        graph->connect_nodes(blur_node, overlay_matte_node);
@@ -46,3 +57,5 @@ string OverlayMatteEffect::output_fragment_shader()
 {
        return read_file("overlay_matte_effect.frag");
 }
+
+}  // namespace movit