Initial import from the monolithic Qt.
[profile/ivi/qtdeclarative.git] / src / declarative / util / qdeclarativelistaccessor.cpp
1 /****************************************************************************
2 **
3 ** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
6 **
7 ** This file is part of the QtDeclarative module of the Qt Toolkit.
8 **
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** No Commercial Usage
11 ** This file contains pre-release code and may not be distributed.
12 ** You may use this file in accordance with the terms and conditions
13 ** contained in the Technology Preview License Agreement accompanying
14 ** this package.
15 **
16 ** GNU Lesser General Public License Usage
17 ** Alternatively, this file may be used under the terms of the GNU Lesser
18 ** General Public License version 2.1 as published by the Free Software
19 ** Foundation and appearing in the file LICENSE.LGPL included in the
20 ** packaging of this file.  Please review the following information to
21 ** ensure the GNU Lesser General Public License version 2.1 requirements
22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23 **
24 ** In addition, as a special exception, Nokia gives you certain additional
25 ** rights.  These rights are described in the Nokia Qt LGPL Exception
26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27 **
28 ** If you have questions regarding the use of this file, please contact
29 ** Nokia at qt-info@nokia.com.
30 **
31 **
32 **
33 **
34 **
35 **
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 #include "private/qdeclarativelistaccessor_p.h"
43
44 #include <qdeclarativemetatype_p.h>
45
46 #include <QtCore/qstringlist.h>
47 #include <QtCore/qdebug.h>
48
49 // ### Remove me
50 #include <qdeclarativeengine_p.h>
51
52 QT_BEGIN_NAMESPACE
53
54 QDeclarativeListAccessor::QDeclarativeListAccessor()
55 : m_type(Invalid)
56 {
57 }
58
59 QDeclarativeListAccessor::~QDeclarativeListAccessor()
60 {
61 }
62
63 QVariant QDeclarativeListAccessor::list() const
64 {
65     return d;
66 }
67
68 void QDeclarativeListAccessor::setList(const QVariant &v, QDeclarativeEngine *engine)
69 {
70     d = v;
71
72     QDeclarativeEnginePrivate *enginePrivate = engine?QDeclarativeEnginePrivate::get(engine):0;
73
74     if (!d.isValid()) {
75         m_type = Invalid;
76     } else if (d.userType() == QVariant::StringList) {
77         m_type = StringList;
78     } else if (d.userType() == QMetaType::QVariantList) {
79         m_type = VariantList;
80     } else if (d.canConvert(QVariant::Int)) {
81         m_type = Integer;
82     } else if ((!enginePrivate && QDeclarativeMetaType::isQObject(d.userType())) ||
83                (enginePrivate && enginePrivate->isQObject(d.userType()))) {
84         QObject *data = enginePrivate?enginePrivate->toQObject(v):QDeclarativeMetaType::toQObject(v);
85         d = QVariant::fromValue(data);
86         m_type = Instance;
87     } else if (d.userType() == qMetaTypeId<QDeclarativeListReference>()) {
88         m_type = ListProperty;
89     } else {
90         m_type = Instance;
91     }
92 }
93
94 int QDeclarativeListAccessor::count() const
95 {
96     switch(m_type) {
97     case StringList:
98         return qvariant_cast<QStringList>(d).count();
99     case VariantList:
100         return qvariant_cast<QVariantList>(d).count();
101     case ListProperty:
102         return ((QDeclarativeListReference *)d.constData())->count();
103     case Instance:
104         return 1;
105     case Integer:
106         return d.toInt();
107     default:
108     case Invalid:
109         return 0;
110     }
111 }
112
113 QVariant QDeclarativeListAccessor::at(int idx) const
114 {
115     Q_ASSERT(idx >= 0 && idx < count());
116     switch(m_type) {
117     case StringList:
118         return QVariant::fromValue(qvariant_cast<QStringList>(d).at(idx));
119     case VariantList:
120         return qvariant_cast<QVariantList>(d).at(idx);
121     case ListProperty:
122         return QVariant::fromValue(((QDeclarativeListReference *)d.constData())->at(idx));
123     case Instance:
124         return d;
125     case Integer:
126         return QVariant(idx);
127     default:
128     case Invalid:
129         return QVariant();
130     }
131 }
132
133 bool QDeclarativeListAccessor::isValid() const
134 {
135     return m_type != Invalid;
136 }
137
138 QT_END_NAMESPACE