Using mutexes around accesses to refcounts seems to make the Windows build much less...
[synfig.git] / synfig-core / trunk / src / synfig / transform.cpp
1 /* === S Y N F I G ========================================================= */
2 /*!     \file transform.cpp
3 **      \brief Template File
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **
10 **      This package is free software; you can redistribute it and/or
11 **      modify it under the terms of the GNU General Public License as
12 **      published by the Free Software Foundation; either version 2 of
13 **      the License, or (at your option) any later version.
14 **
15 **      This package is distributed in the hope that it will be useful,
16 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
17 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 **      General Public License for more details.
19 **      \endlegal
20 */
21 /* ========================================================================= */
22
23 /* === H E A D E R S ======================================================= */
24
25 #ifdef USING_PCH
26 #       include "pch.h"
27 #else
28 #ifdef HAVE_CONFIG_H
29 #       include <config.h>
30 #endif
31
32 #include "transform.h"
33 #include <algorithm>
34
35 #endif
36
37 /* === U S I N G =========================================================== */
38
39 using namespace std;
40 using namespace etl;
41 using namespace synfig;
42
43 /* === M A C R O S ========================================================= */
44
45 /* === G L O B A L S ======================================================= */
46
47 /* === P R O C E D U R E S ================================================= */
48
49 /* === M E T H O D S ======================================================= */
50
51 synfig::GUID
52 TransformStack::get_guid()const
53 {
54         GUID ret(0);
55
56         for(const_iterator iter(begin());iter!=end();++iter)
57                 ret%=(*iter)->get_guid();
58         return ret;
59 }
60
61 synfig::Vector
62 TransformStack::perform(const synfig::Vector& x)const
63 {
64         synfig::Vector ret(x);
65
66         for(const_reverse_iterator iter(rbegin());iter!=rend();++iter)
67                 ret=(*iter)->perform(ret);
68
69         return ret;
70 }
71
72 synfig::Vector
73 TransformStack::unperform(const synfig::Vector& x)const
74 {
75         synfig::Vector ret(x);
76
77         for(const_iterator iter(begin());iter!=end();++iter)
78                 ret=(*iter)->unperform(ret);
79
80         return ret;
81 }
82
83 synfig::Rect
84 TransformStack::perform(const synfig::Rect& x)const
85 {
86         Point min(x.get_min());
87         Point max(x.get_max());
88         Rect ret(perform(min),perform(max));
89
90         std::swap(min[1],max[1]);
91         ret
92                 .expand(perform(min))
93                 .expand(perform(max))
94         ;
95         return ret;
96 }
97
98 synfig::Rect
99 TransformStack::unperform(const synfig::Rect& x)const
100 {
101         Point min(x.get_min());
102         Point max(x.get_max());
103         Rect ret(unperform(min),unperform(max));
104
105         std::swap(min[1],max[1]);
106         ret
107                 .expand(unperform(min))
108                 .expand(unperform(max))
109         ;
110         return ret;
111 }
112
113 synfig::Rect
114 Transform::perform(const synfig::Rect& x)const
115 {
116         if(x.area()>1000000000000.0)
117                 return Rect::full_plane();
118
119         Point min(x.get_min());
120         Point max(x.get_max());
121
122         Rect ret(perform(min),perform(max));
123
124         std::swap(min[1],max[1]);
125         ret
126                 .expand(perform(min))
127                 .expand(perform(max))
128         ;
129         return ret;
130 }
131
132 synfig::Rect
133 Transform::unperform(const synfig::Rect& x)const
134 {
135         if(x.area()>1000000000000.0)
136                 return Rect::full_plane();
137
138         Point min(x.get_min());
139         Point max(x.get_max());
140
141         Rect ret(unperform(min),unperform(max));
142
143         std::swap(min[1],max[1]);
144         ret
145                 .expand(unperform(min))
146                 .expand(unperform(max))
147         ;
148         return ret;
149 }