When a .sif file fails to load, display the error messages in the studio GUI, not...
[synfig.git] / synfig-core / trunk / src / synfig / loadcanvas.h
1 /* === S Y N F I G ========================================================= */
2 /*!     \file loadcanvas.h
3 **      \brief writeme
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **      Copyright (c) 2007, 2008 Chris Moore
10 **
11 **      This package is free software; you can redistribute it and/or
12 **      modify it under the terms of the GNU General Public License as
13 **      published by the Free Software Foundation; either version 2 of
14 **      the License, or (at your option) any later version.
15 **
16 **      This package is distributed in the hope that it will be useful,
17 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
18 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 **      General Public License for more details.
20 **      \endlegal
21 */
22 /* ========================================================================= */
23
24 /* === S T A R T =========================================================== */
25
26 #ifndef __SYNFIG_LOADCANVAS_H
27 #define __SYNFIG_LOADCANVAS_H
28
29 /* === H E A D E R S ======================================================= */
30
31 #include "string.h"
32 #include "canvas.h"
33 #include "valuenode.h"
34 #include "vector.h"
35 #include "value.h"
36 #include "valuenode_subtract.h"
37 #include "valuenode_animated.h"
38 #include "valuenode_composite.h"
39 #include "valuenode_dynamiclist.h"
40 #include "keyframe.h"
41 #include "guid.h"
42
43 /* === M A C R O S ========================================================= */
44
45 /* === T Y P E D E F S ===================================================== */
46
47 /* === C L A S S E S & S T R U C T S ======================================= */
48
49 namespace xmlpp { class Node; class Element; };
50
51 namespace synfig {
52
53 /*!     \class CanvasParser
54 **      \todo writeme
55 */
56 class CanvasParser
57 {
58         /*
59  --     ** -- D A T A -------------------------------------------------------------
60         */
61
62 private:
63
64         int max_warnings_;
65
66     int total_warnings_;
67
68     int total_errors_;
69
70         bool allow_errors_;
71
72         String filename;
73
74         String path;
75
76         String errors_text;
77
78         GUID guid_;
79
80         /*
81  --     ** -- C O N S T R U C T O R S ---------------------------------------------
82         */
83
84 public:
85
86         CanvasParser():
87                 max_warnings_   (1000),
88                 total_warnings_ (0),
89                 total_errors_   (0),
90                 allow_errors_   (false)
91         { }
92
93         /*
94  --     ** -- M E M B E R   F U N C T I O N S -------------------------------------
95         */
96
97 public:
98
99         //! \todo writeme
100         CanvasParser &set_allow_errors(bool x) { allow_errors_=x; return *this; }
101
102         //! Sets the maximum number of warnings before a fatal error is thrown
103         CanvasParser &set_max_warnings(int i) { max_warnings_=i; return *this; }
104
105         //! Returns the maximum number of warnings before a fatal_error is thrown
106         int get_max_warnings() { return max_warnings_; }
107
108         //! Returns the number of errors in the last parse
109         int error_count()const { return total_errors_; }
110
111         //! Returns the number of warnings in the last parse
112         int warning_count()const { return total_warnings_; }
113
114         void set_path(const synfig::String& x) { path=x; }
115
116         const synfig::String& get_path()const { return path; }
117
118         const synfig::String& get_errors_text()const { return errors_text; }
119
120         //! \todo writeme
121         Canvas::Handle parse_from_file_as(const String &filename,const String &as,String &errors);
122
123         //! \todo writeme
124         Canvas::Handle parse_from_string(const String &data);
125
126 private:
127
128         // Error/Warning handling functions
129
130         void error(xmlpp::Node *node,const String &text);
131         void fatal_error(xmlpp::Node *node,const String &text);
132         void warning(xmlpp::Node *node,const String &text);
133         void error_unexpected_element(xmlpp::Node *node,const String &got, const String &expected);
134         void error_unexpected_element(xmlpp::Node *node,const String &got);
135
136         // Parsing Functions
137
138         Canvas::Handle parse_canvas(xmlpp::Element *node,Canvas::Handle parent=0,bool inline_=false, String path=".");
139         void parse_canvas_defs(xmlpp::Element *node,Canvas::Handle canvas);
140         etl::handle<Layer> parse_layer(xmlpp::Element *node,Canvas::Handle canvas);
141         ValueBase parse_value(xmlpp::Element *node,Canvas::Handle canvas);
142         etl::handle<ValueNode> parse_value_node(xmlpp::Element *node,Canvas::Handle canvas);
143
144         // ValueBase Parsing Functions
145
146         Real parse_real(xmlpp::Element *node);
147         Time parse_time(xmlpp::Element *node,Canvas::Handle canvas);
148         int parse_integer(xmlpp::Element *node);
149         Vector parse_vector(xmlpp::Element *node);
150         Color parse_color(xmlpp::Element *node);
151         Angle parse_angle(xmlpp::Element *node);
152         String parse_string(xmlpp::Element *node);
153         bool parse_bool(xmlpp::Element *node);
154         Segment parse_segment(xmlpp::Element *node);
155         ValueBase parse_list(xmlpp::Element *node,Canvas::Handle canvas);
156         Gradient parse_gradient(xmlpp::Element *node);
157         BLinePoint parse_bline_point(xmlpp::Element *node);
158
159         Keyframe parse_keyframe(xmlpp::Element *node,Canvas::Handle canvas);
160
161         // ValueNode Parsing Functions
162
163         etl::handle<ValueNode_Animated> parse_animated(xmlpp::Element *node,Canvas::Handle canvas);
164         etl::handle<ValueNode_Subtract> parse_subtract(xmlpp::Element *node,Canvas::Handle canvas);
165         etl::handle<LinkableValueNode> parse_linkable_value_node(xmlpp::Element *node,Canvas::Handle canvas);
166         etl::handle<ValueNode_DynamicList> parse_dynamic_list(xmlpp::Element *node,Canvas::Handle canvas);
167
168 }; // END of CanvasParser
169
170 /* === E X T E R N S ======================================================= */
171
172 //!     Loads a canvas from \a filename
173 /*!     \return The Canvas's handle on success, an empty handle on failure */
174 extern Canvas::Handle open_canvas(const String &filename,String &errors);
175 extern Canvas::Handle open_canvas_as(const String &filename,const String &as,String &errors);
176
177 //! Retrieves a Canvas from a string in XML format
178 extern Canvas::Handle string_to_canvas(const String &data);
179
180 std::map<synfig::String, etl::loose_handle<Canvas> >& get_open_canvas_map();
181
182 }; // END of namespace synfig
183
184 /* === E N D =============================================================== */
185
186 #endif