blob: 0de6056decb017452aa9a8df133e049f0e67d24c [file] [log] [blame]
Kevin Rocard93250d12012-07-19 17:48:30 +02001/*
Patrick Benavoli68a91282011-08-31 11:23:23 +02002 * INTEL CONFIDENTIAL
3 * Copyright © 2011 Intel
4 * Corporation All Rights Reserved.
5 *
6 * The source code contained or described herein and all documents related to
7 * the source code ("Material") are owned by Intel Corporation or its suppliers
8 * or licensors. Title to the Material remains with Intel Corporation or its
9 * suppliers and licensors. The Material contains trade secrets and proprietary
10 * and confidential information of Intel or its suppliers and licensors. The
11 * Material is protected by worldwide copyright and trade secret laws and
12 * treaty provisions. No part of the Material may be used, copied, reproduced,
13 * modified, published, uploaded, posted, transmitted, distributed, or
14 * disclosed in any way without Intel’s prior express written permission.
15 *
16 * No license under any patent, copyright, trade secret or other intellectual
17 * property right is granted to or conferred upon you by disclosure or delivery
18 * of the Materials, either expressly, by implication, inducement, estoppel or
19 * otherwise. Any license under such intellectual property rights must be
20 * express and approved by Intel in writing.
21 *
Patrick Benavoli68a91282011-08-31 11:23:23 +020022 * CREATED: 2011-06-01
23 * UPDATED: 2011-07-27
Patrick Benavoli68a91282011-08-31 11:23:23 +020024 */
25#pragma once
26
27#include <map>
28#include <string>
29
30#include "Element.h"
31
32using namespace std;
33
34class CElementBuilder;
35
36class CElementLibrary
37{
Kevin Rocarda7b69602013-08-07 16:15:33 +020038 typedef map<string, const CElementBuilder*> ElementBuilderMap;
39 typedef ElementBuilderMap::iterator ElementBuilderMapIterator;
40 typedef ElementBuilderMap::const_iterator ElementBuilderMapConstIterator;
Patrick Benavoli68a91282011-08-31 11:23:23 +020041
42public:
43 CElementLibrary();
44 virtual ~CElementLibrary();
45
Kevin Rocarda7b69602013-08-07 16:15:33 +020046 /** Add a xml tag and it's corresponding builder in the library.
47 *
48 * @param[in] xmlTag is the tag of an xml element that can be given to the builder to
49 * create a new element.
50 * @param[in] pElementBuilder is the tag associated element builder.
51 */
52 void addElementBuilder(string type, const CElementBuilder *pElementBuilder);
Patrick Benavoli68a91282011-08-31 11:23:23 +020053 void clean();
54
55 // Instantiation
56 CElement* createElement(const CXmlElement& xmlElement) const;
57
58private:
59 // Builder type
60 virtual string getBuilderType(const CXmlElement& xmlElement) const;
61
62 // Builders
Kevin Rocarda7b69602013-08-07 16:15:33 +020063 ElementBuilderMap _elementBuilderMap;
Patrick Benavoli68a91282011-08-31 11:23:23 +020064};