1
0
mirror of https://github.com/OpenNebula/one.git synced 2024-12-23 17:33:56 +03:00
one/include/Attribute.h
Constantino Vázquez Blanco ee411e7963 Merged TransferManager and VirtualNetworkManager branches.
git-svn-id: http://svn.opennebula.org/one/trunk@230 3034c82b-c49b-4eb3-8279-a7acafdc01c0
2008-11-13 16:21:17 +00:00

238 lines
6.0 KiB
C++

/* -------------------------------------------------------------------------- */
/* Copyright 2002-2008, Distributed Systems Architecture Group, Universidad */
/* Complutense de Madrid (dsa-research.org) */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
#ifndef ATTRIBUTE_H_
#define ATTRIBUTE_H_
#include <string>
#include <map>
#include <sstream>
#include <algorithm>
using namespace std;
/**
* Attribute base class for name-value pairs. This class provides a generic
* interface to implement
*/
class Attribute
{
public:
Attribute(const string& aname):attribute_name(aname)
{
transform (
attribute_name.begin(),
attribute_name.end(),
attribute_name.begin(),
(int(*)(int))toupper);
};
Attribute(const char * aname)
{
ostringstream name;
name << uppercase << aname;
attribute_name = name.str();
};
virtual ~Attribute(){};
enum AttributeType
{
SIMPLE = 0,
VECTOR = 1
};
/**
* Gets the name of the attribute.
* @return the attribute name
*/
const string& name() const
{
return attribute_name;
};
/**
* Marshall the attribute in a single string. The string MUST be freed
* by the calling function.
* @return a string (allocated in the heap) holding the attribute value.
*/
virtual string * marshall() = 0;
/**
* Builds a new attribute from a string.
*/
virtual void unmarshall(const string& sattr) = 0;
/**
* Returns the attribute type
*/
virtual AttributeType type() = 0;
private:
/**
* The attribute name.
*/
string attribute_name;
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/**
* The SingleAttribute class represents a simple attribute in the form
* NAME = VALUE.
*/
class SingleAttribute : public Attribute
{
public:
SingleAttribute(const string& name):Attribute(name){};
SingleAttribute(const string& name, const string& value):
Attribute(name),attribute_value(value){};
SingleAttribute(const char * name, const string& value):
Attribute(name),attribute_value(value){};
~SingleAttribute(){};
/**
* Returns the attribute value, a string.
*/
const string& value() const
{
return attribute_value;
};
/**
* Marshall the attribute in a single string. The string MUST be freed
* by the calling function.
* @return a string (allocated in the heap) holding the attribute value.
*/
string * marshall()
{
string * rs = new string;
*rs = attribute_value;
return rs;
};
/**
* Builds a new attribute from a string.
*/
void unmarshall(const string& sattr)
{
attribute_value = sattr;
};
/**
* Replaces the attribute value from a string.
*/
void replace(const string& sattr)
{
attribute_value = sattr;
};
/**
* Returns the attribute type
*/
AttributeType type()
{
return SIMPLE;
};
private:
string attribute_value;
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/**
* The VectorAttribute class represents an array attribute in the form
* NAME = [ VAL_NAME_1=VAL_VALUE_1,...,VAL_NAME_N=VAL_VALUE_N].
*/
class VectorAttribute : public Attribute
{
public:
VectorAttribute(const string& name):Attribute(name){};
VectorAttribute(const string& name,const map<string,string>& value):
Attribute(name),attribute_value(value){};
~VectorAttribute(){};
/**
* Returns the attribute value, a string.
*/
const map<string,string>& value() const
{
return attribute_value;
};
/**
*
*/
string vector_value(const char *name) const;
/**
* Marshall the attribute in a single string. The string MUST be freed
* by the calling function. The string is in the form:
* "VAL_NAME_1=VAL_VALUE_1,...,VAL_NAME_N=VAL_VALUE_N".
* @return a string (allocated in the heap) holding the attribute value.
*/
string * marshall();
/**
* Builds a new attribute from a string of the form:
* "VAL_NAME_1=VAL_VALUE_1,...,VAL_NAME_N=VAL_VALUE_N".
*/
void unmarshall(const string& sattr);
/**
* Replace the value of the given attribute with the provided map
*/
void replace(const map<string,string>& attr);
/**
* Returns the attribute type
*/
AttributeType type()
{
return VECTOR;
};
private:
static const char * magic_sep;
static const int magic_sep_size;
map<string,string> attribute_value;
};
#endif /*ATTRIBUTE_H_*/