1 /*
2  * This source file is part of libRocket, the HTML/CSS Interface Middleware
3  *
4  * For the latest information, see http://www.librocket.com
5  *
6  * Copyright (c) 2008-2010 CodePoint Ltd, Shift Technology Ltd
7  *
8  * Permission is hereby granted, free of charge, to any person obtaining a copy
9  * of this software and associated documentation files (the "Software"), to deal
10  * in the Software without restriction, including without limitation the rights
11  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12  * copies of the Software, and to permit persons to whom the Software is
13  * furnished to do so, subject to the following conditions:
14  *
15  * The above copyright notice and this permission notice shall be included in
16  * all copies or substantial portions of the Software.
17  *
18  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24  * THE SOFTWARE.
25  *
26  */
27 
28 #ifndef ROCKETINVADERSDECORATORINSTANCERDEFENDER_H
29 #define ROCKETINVADERSDECORATORINSTANCERDEFENDER_H
30 
31 #include <Rocket/Core/DecoratorInstancer.h>
32 
33 /**
34 	@author Robert Curry
35  */
36 
37 class DecoratorInstancerDefender : public Rocket::Core::DecoratorInstancer
38 {
39 public:
40 	DecoratorInstancerDefender();
41 	virtual ~DecoratorInstancerDefender();
42 
43 	/// Instances a decorator given the property tag and attributes from the RCSS file.
44 	/// @param[in] name The type of decorator desired. For example, "background-decorator: simple;" is declared as type "simple".
45 	/// @param[in] properties All RCSS properties associated with the decorator.
46 	/// @return The decorator if it was instanced successful, NULL if an error occured.
47 	Rocket::Core::Decorator* InstanceDecorator(const Rocket::Core::String& name, const Rocket::Core::PropertyDictionary& properties);
48 	/// Releases the given decorator.
49 	/// @param[in] decorator Decorator to release. This is guaranteed to have been constructed by this instancer.
50 	void ReleaseDecorator(Rocket::Core::Decorator* decorator);
51 
52 	/// Releases the instancer.
53 	void Release();
54 };
55 
56 #endif
57