blob: 544d4a36c228499cc1a01260c77951726b082602 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
/***************************************************************************
* value.h
* This file is part of the KDE project
* copyright (C)2004-2005 by Sebastian Sauer (mail@dipe.org)
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library 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 Library General Public License
* along with this program; see the file COPYING. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
***************************************************************************/
#ifndef KROSS_API_VALUE_H
#define KROSS_API_VALUE_H
#include <qstring.h>
#include <qvariant.h>
#include "object.h"
namespace Kross { namespace Api {
/**
* Template class to represent values.
*
* Classes like \a Variant or \a List are implementing this
* class. That way we have a common base for all kind of
* values.
*/
template<class T, class V>
class Value : public Object
{
public:
/**
* Constructor.
*
* \param value The initial value this
* Value has.
*/
Value(V value)
: Object()
, m_value(value) {}
/**
* Destructor.
*/
virtual ~Value() {}
//operator V&() const { return m_value; }
/**
* Return the value.
*
* \return The value this Value-class holds.
*/
V& getValue() { return m_value; }
//operator V& () { return m_value; }
template<typename TYPE>
static Object::Ptr toObject(TYPE t) { return new T(t); }
#if 0
//do we need it anyway?
/**
* Set the value.
* The value is call-by-value cause it may
* contain some KShared and therefore
* we need to keep a local copy to keep
* it from disappearing.
*
* \param value The value to set.
*/
void setValue(V& value) { m_value = value; }
#endif
private:
V m_value;
};
}}
#endif
|