X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Flayer_pastecanvas.h;h=2d4714cb9b5abfdf36c1facc91ea232772217657;hb=9459638ad6797b8139f1e9f0715c96076dbf0890;hp=82cd32dfc9660ffd652a0e094f9c7275700bf715;hpb=cc54c38609ee9745ad678e5e9b9d7d2912be9c95;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/layer_pastecanvas.h b/synfig-core/trunk/src/synfig/layer_pastecanvas.h index 82cd32d..2d4714c 100644 --- a/synfig-core/trunk/src/synfig/layer_pastecanvas.h +++ b/synfig-core/trunk/src/synfig/layer_pastecanvas.h @@ -1,11 +1,12 @@ /* === S Y N F I G ========================================================= */ /*! \file layer_pastecanvas.h -** \brief Template Header +** \brief Header file for implementation of the "Paste Canvas" layer ** ** $Id$ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007, 2008 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -50,6 +51,7 @@ class Layer_PasteCanvas : public Layer_Composite, public Layer_NoDeform private: Vector origin; + Vector focus; etl::loose_handle canvas; @@ -62,20 +64,64 @@ private: mutable Time curr_time; - bool optimize_layers(synfig::Context context,synfig::CanvasBase&)const; - - bool do_not_muck_with_time_; + bool muck_with_time_; bool children_lock; mutable Rect bounds; sigc::connection child_changed_connection; + + // Nasty hack: Remember whether we called an extra ref() when + // setting the canvas, so we know whether to call an extra unref() + // when finished with the canvas. + // + // Here's the story: + // + // The root canvas is destructed first. That sets the + // Layer::canvas_ (the parent canvas) of any PasteCanvas layer it + // contains to nil, due to a call to Layer::set_canvas(0), + // triggered by the connection made when Layer::set_canvas + // originally set its canvas_ member to point to the root canvas. + // ~Canvas does begin_delete() which triggers that connection. + // + // After ~Canvas has run, the members of the root canvas are + // freed, including its children_ list. If this was the last + // reference to the child canvas that the pastecanvas uses, that + // child canvas will Layer_PasteCanvas::set_sub_canvas(0) on the + // PasteCanvas layer to set its canvas (the child, pasted canvas) + // not to refer to the soon-to-be destroys child canvas. But + // set_sub_canvas() originally looked at the value of + // Layer::canvas_ (the parent canvas, obtained via + // Layer::get_canvas()) to decide whether to do an extra ref() on + // canvas (the child canvas). We need to unref() it now if we + // did, but we've forgotten whether we did. So we use this + // 'extra_reference' member to store that decision. + bool extra_reference; + + /* + -- ** -- S I G N A L S ------------------------------------------------------- + */ + +private: + + sigc::signal signal_subcanvas_changed_; + + /* + -- ** -- S I G N A L I N T E R F A C E ------------------------------------- + */ + public: + sigc::signal& signal_subcanvas_changed() { return signal_subcanvas_changed_; } + +public: + + void update_renddesc(); + virtual void on_canvas_set(); - void set_do_not_muck_with_time(bool x=true) { do_not_muck_with_time_=true; } + void set_muck_with_time(bool x=false) { muck_with_time_=x; } etl::handle get_sub_canvas()const { return canvas; } void set_sub_canvas(etl::handle x);