Teuchos Package Browser (Single Doxygen Collection) Version of the Day
Loading...
Searching...
No Matches
Teuchos_XMLParameterListWriter.cpp
Go to the documentation of this file.
1// @HEADER
2// ***********************************************************************
3//
4// Teuchos: Common Tools Package
5// Copyright (2004) Sandia Corporation
6//
7// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
8// license for use of this work by or on behalf of the U.S. Government.
9//
10// Redistribution and use in source and binary forms, with or without
11// modification, are permitted provided that the following conditions are
12// met:
13//
14// 1. Redistributions of source code must retain the above copyright
15// notice, this list of conditions and the following disclaimer.
16//
17// 2. Redistributions in binary form must reproduce the above copyright
18// notice, this list of conditions and the following disclaimer in the
19// documentation and/or other materials provided with the distribution.
20//
21// 3. Neither the name of the Corporation nor the names of the
22// contributors may be used to endorse or promote products derived from
23// this software without specific prior written permission.
24//
25// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
26// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
29// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36//
37// Questions? Contact Michael A. Heroux (maherou@sandia.gov)
38//
39// ***********************************************************************
40// @HEADER
41
47
48
49namespace Teuchos{
50
51
54
55
58 const ParameterList& p,
60{
64
65 //We build an initial map full of validators that are located in the
66 //parameter list. That way we can convert the parameter entries.
68
71 toReturn.addAttribute(getNameAttributeName(), p.name());
72
73 if(!depSheet.is_null()){
76 toReturn.addChild(deps);
77 }
78
79 //Validators must be done after depencneies because dependencies might add
80 //entries to the validator map. KLN 09/20/2010
82 toReturn.addChild(validators);
83
84 return toReturn;
85}
86
88 const ParameterList& p,
90{
91 for (ParameterList::ConstIterator i=p.begin(); i!=p.end(); ++i) {
92 const ParameterEntry& entry = p.entry(i);
93 if(entry.isList()){
97 }
98 else if(nonnull(entry.validator())){
99 validatorIDsMap.insert(entry.validator());
100 }
101 }
102}
103
104
119
120
122 const ParameterList& p,
126{
128
129 for (ParameterList::ConstIterator i=p.begin(); i!=p.end(); ++i){
130 RCP<const ParameterEntry> entry = p.getEntryRCP(i->first);
131 if(entry->isList()){
134 idCounter,
137 newPL.addAttribute(
138 getNameAttributeName(), p.name(i));
139 newPL.addAttribute(
141 entryIDsMap.insert(EntryIDsMap::value_type(entry, idCounter));
142 rtn.addChild(newPL);
143 ++idCounter;
144 }
145 else{
147 entry, p.name(i), idCounter, validatorIDsMap));
148 entryIDsMap.insert(EntryIDsMap::value_type(entry, idCounter));
149 ++idCounter;
150 }
151 }
152 return rtn;
153}
154
160{
162 toReturn.addAttribute(
164 depSheet->getName()
165 );
166
167 for(
168 DependencySheet::DepSet::const_iterator it = depSheet->depBegin();
169 it != depSheet->depEnd();
170 ++it)
171 {
174 }
175 return toReturn;
176}
177
178
179} // namespace Teuchos
180
A database for DependencyXMLConverters.
A database for ValidatorXMLConverters.
A collection of Exceptions that can be potentially thrown when converting a ParameterList to and from...
Writes a ParameterList to an XML object.
static const std::string & getNameAttributeName()
When serializing to XML, this string should be used as the name of the name attribute.
static XMLObject convertDependency(RCP< const Dependency > dependency, const XMLParameterListWriter::EntryIDsMap &entryIDsMap, ValidatortoIDMap &validatorIDsMap)
Given a dependency converts the dependency to XML.
static XMLObject convertEntry(RCP< const ParameterEntry > entry, const std::string &name, const ParameterEntry::ParameterEntryID &id, const ValidatortoIDMap &validatorIDsMap)
Converts the given ParameterEntry to XML.
This object is held as the "value" in the Teuchos::ParameterList std::map.
RCP< const ParameterEntryValidator > validator() const
Return the (optional) validator object.
bool isList() const
Return whether or not the value itself is a list.
A list of parameters of arbitrary type.
Concrete serial communicator subclass.
static XMLObject convertValidator(RCP< const ParameterEntryValidator > validator, const ValidatortoIDMap &validatorIDsMap, bool assignedID=true)
Given a validator converts the validator to XML.
A class for mapping validators to integers.
ValidatorMap::const_iterator const_iterator
Representation of an XML data tree. XMLObject is a ref-counted handle to a XMLObjectImplem object,...
std::map< RCP< const ParameterEntry >, ParameterEntry::ParameterEntryID, RCPConstComp > EntryIDsMap
static const std::string & getDependenciesTagName()
static const std::string & getParameterListTagName()
XMLObject convertDependencies(RCP< const DependencySheet > depSheet, const EntryIDsMap &entryIDsMap, ValidatortoIDMap &validatorIDsMap) const
Convert all the dependencies.
void buildInitialValidatorMap(const ParameterList &p, ValidatortoIDMap &validatorIDsMap) const
Builds up the list of validators to be converted.
XMLObject convertValidators(const ParameterList &p, ValidatortoIDMap &validatorIDsMap) const
Convert all the validators.
static const std::string & getNameAttributeName()
XMLObject convertParameterList(const ParameterList &p, ParameterEntry::ParameterEntryID &idCounter, EntryIDsMap &entryIDsMap, const ValidatortoIDMap &validatorIDsMap) const
Write the given list to an XML object.
XMLObject toXML(const ParameterList &p, RCP< const DependencySheet > depSheet=null) const
bool nonnull(const std::shared_ptr< T > &p)
Returns true if p.get()!=NULL.