syndilights/open-lighting-architecture/ola-0.8.4/common/export_map/ExportMap.cpp

206 lines
5.6 KiB
C++
Raw Normal View History

2010-10-31 17:32:25 +01:00
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* ExportMap.cpp
* Exported Variables
* Copyright (C) 2005-2008 Simon Newton
*/
#include <algorithm>
#include <string>
#include <map>
#include <vector>
#include <iostream>
#include "ola/ExportMap.h"
#include "ola/StringUtils.h"
namespace ola {
using std::string;
using std::stringstream;
/*
* Return the string representation of this map variable.
* The form is:
* var_name map:label_name key1:value1 key2:value2
* @return the string representation of the variable.
*/
template<typename Type>
const string MapVariable<Type>::Value() const {
stringstream value;
value << "map:" << m_label;
typename map<string, Type>::const_iterator iter;
for (iter = m_variables.begin(); iter != m_variables.end(); ++iter)
value << " " << iter->first << ":" << iter->second;
return value.str();
}
/*
* Strings need to be quoted
*/
template<>
const string MapVariable<string>::Value() const {
stringstream value;
value << "map:" << m_label;
map<string, string>::const_iterator iter;
for (iter = m_variables.begin(); iter != m_variables.end(); ++iter) {
std::string var = iter->second;
Escape(&var);
value << " " << iter->first << ":\"" << var << "\"";
}
return value.str();
}
ExportMap::~ExportMap() {
DeleteVariables(&m_int_variables);
DeleteVariables(&m_counter_variables);
DeleteVariables(&m_string_variables);
DeleteVariables(&m_str_map_variables);
DeleteVariables(&m_uint_map_variables);
DeleteVariables(&m_int_map_variables);
}
/*
* Lookup or create an integer variable.
* @param name the name of this variable.
* @return an IntergerVariable
*/
IntegerVariable *ExportMap::GetIntegerVar(const string &name) {
return GetVar(&m_int_variables, name);
}
/*
* Lookup or create a counter variable.
* @param name the name of the variable.
* @return a CounterVariable.
*/
CounterVariable *ExportMap::GetCounterVar(const string &name) {
return GetVar(&m_counter_variables, name);
}
/*
* Lookup or create a string variable.
* @param name the name of the variable.
* @return a StringVariable.
*/
StringVariable *ExportMap::GetStringVar(const string &name) {
return GetVar(&m_string_variables, name);
}
/*
* Lookup or create a string map variable
* @param name the name of the variable
* @param label the label to use for the map (optional)
* @return a MapVariable
*/
StringMap *ExportMap::GetStringMapVar(const string &name, const string &label) {
return GetMapVar(&m_str_map_variables, name, label);
}
/*
* Lookup or create an int map variable
* @param name the name of the variable
* @param label the label to use for the map (optional)
* @return a MapVariable
*/
IntMap *ExportMap::GetIntMapVar(const string &name, const string &label) {
return GetMapVar(&m_int_map_variables, name, label);
}
/*
* Lookup or create an unsigned int map variable
* @param name the name of the variable
* @param label the label to use for the map (optional)
* @return a MapVariable
*/
UIntMap *ExportMap::GetUIntMapVar(const string &name, const string &label) {
return GetMapVar(&m_uint_map_variables, name, label);
}
/*
* Return a list of all variables.
* @return a vector of all variables.
*/
vector<BaseVariable*> ExportMap::AllVariables() const {
vector<BaseVariable*> variables;
AddVariablesToVector(&variables, m_int_variables);
AddVariablesToVector(&variables, m_counter_variables);
AddVariablesToVector(&variables, m_string_variables);
AddVariablesToVector(&variables, m_str_map_variables);
AddVariablesToVector(&variables, m_int_map_variables);
AddVariablesToVector(&variables, m_uint_map_variables);
sort(variables.begin(), variables.end(), VariableLessThan());
return variables;
}
template<typename Type>
Type *ExportMap::GetVar(map<string, Type*> *var_map, const string &name) {
typename map<string, Type*>::iterator iter;
iter = var_map->find(name);
if (iter == var_map->end()) {
Type *var = new Type(name);
(*var_map)[name] = var;
return var;
}
return iter->second;
}
template<typename Type>
Type *ExportMap::GetMapVar(map<string, Type*> *var_map,
const string &name,
const string &label) {
typename map<string, Type*>::iterator iter;
iter = var_map->find(name);
if (iter == var_map->end()) {
Type *var = new Type(name, label);
(*var_map)[name] = var;
return var;
}
return iter->second;
}
template<typename Type>
void ExportMap::AddVariablesToVector(vector<BaseVariable*> *variables,
const Type &var_map) const {
typename Type::const_iterator iter;
for (iter = var_map.begin(); iter != var_map.end(); ++iter)
variables->push_back(iter->second);
}
template<typename Type>
void ExportMap::DeleteVariables(Type *var_map) const {
typename Type::const_iterator iter;
for (iter = var_map->begin(); iter != var_map->end(); iter++)
delete iter->second;
var_map->clear();
}
} // ola