Projekt

Allgemein

Profil

Herunterladen als
Herunterladen (6,76 KB) Statistiken
| Zweig: | Revision:
/*
* Copyright (C) 2015 Christian Ehringfeld <c.ehringfeld@t-online.de>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation.
*
* 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 General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, see <http://www.gnu.org/licenses/>.
*/

#include "entity.h"

using namespace CuteEntityManager;

Entity::Entity(QObject *parent) : QObject(parent) {
this->id = -1;
}

QString Entity::toString() const {
QString r = "";
r.append(this->getClassname());
r.append(": {");
auto properties = this->getMetaProperties();
for (auto var = properties.constBegin(); var != properties.constEnd(); ++var) {
QString val = "";
auto value = var.value().read(this);
if (var.value().isEnumType()) {
val = var.value().enumerator().valueToKey(var.value().read(this).toInt());
} else if (value.canConvert<QList<QVariant>>()) {
auto list = value.toList();
val.append("[");
for (int var = 0; var < list.size(); ++var) {
val = list.at(var).toString();
}
val.append("]");
} else {
val = value.toString();
}
r.append(var.key() + ": " + val + ", ");
}
r.append("}");
return r;
}

QString Entity::slimToString() const {
QString r = "";
r.append(this->getClassname());
r.append(": {");
r.append("id: ") + this->getId() + "}";
return r;
}

Entity::~Entity() {

}

QString Entity::getTablename() const {
return QString(this->metaObject()->className()).toLower();
}

const QHash<QString, Relation> Entity::getRelations() const {
return QHash<QString, Relation>();
}

const QHash<QString, Relation> Entity::getNonInheritedRelations() const {
auto relations = this->getRelations();
auto superObject = EntityInstanceFactory::newSuperClassInstance(this);
if (superObject) {
auto superRelations = superObject->getRelations();
auto iterator = superRelations.constBegin();
while (iterator != relations.constEnd()) {
if (relations.contains(iterator.key())) {
relations.remove(iterator.key());
}
++iterator;
}
delete superObject;
superObject = nullptr;
}
return relations;
}

const QStringList Entity::getTransientAttributes() const {
return QStringList();
}

const QStringList Entity::getBLOBColumns() const {
return QStringList();
}

InheritanceStrategy Entity::getInheritanceStrategy() const {
return JOINED_TABLE;
}

bool Entity::isInheritanceCascaded() const {
return true;
}

QString Entity::getPrimaryKey() const {
return "id";
}

const QList<const QMetaObject *> Entity::superClasses(bool
stopAtSingleTableInheritance) const {
QList<const QMetaObject *> classes = QList<const QMetaObject *>();
auto superMetaObject = this->metaObject()->superClass();
if (this->getInheritanceStrategy() == JOINED_TABLE) {
Entity *e = nullptr;
while (superMetaObject && QString(superMetaObject->className()) !=
QString("CuteEntityManager::Entity")) {
e = EntityInstanceFactory::createInstance(superMetaObject->className());
if (e) {
classes.append(superMetaObject);
superMetaObject = superMetaObject->superClass();
quint8 s = e->getInheritanceStrategy();
delete e;
e = nullptr;
if (stopAtSingleTableInheritance && s == PER_CLASS_TABLE) {
break;
}
} else {
break;
}
}
}
return classes;
}

const QHash<QString, QMetaProperty> Entity::getMetaProperties() const {
return Entity::getMetaProperties(this->metaObject());
}

const QHash<QString, QMetaProperty> Entity::getSuperMetaProperties() const {
auto superMetaObjectPropertyMap = QHash<QString, QMetaProperty>();
auto superMeta = this->metaObject()->superClass();
if (QString(superMeta->className()) != QString("CuteEntityManager::Entity")
&& this->getInheritanceStrategy() == JOINED_TABLE) {
for (int var = 0; var < superMeta->propertyCount(); ++var) {
QMetaProperty prop = superMeta->property(var);
if (prop.isReadable() && prop.isWritable()) {
superMetaObjectPropertyMap.insert(QString(prop.name()), prop);
}
}
}
return superMetaObjectPropertyMap;
}

const QHash<QString, QMetaProperty> Entity::getMetaProperties(
const QMetaObject *object) {
auto h = QHash<QString, QMetaProperty>();
for (int var = 0; var < object->propertyCount(); ++var) {
QMetaProperty m = object->property(var);
if (m.isValid() && m.name() != QString("objectName")) {
h.insert(m.name(), m);
}
}
return h;
}

const QHash<QString, QMetaProperty> Entity::getInheritedMetaProperties() const {
auto classes = this->superClasses();
auto wholeProperties = QHash<QString, QMetaProperty>();
for (int var = classes.size() - 1; var >= 0; --var) {
auto metaObject = classes.at(var);
auto properties = Entity::getMetaProperties(metaObject);
auto iterator = properties.constBegin();
while (iterator != properties.constEnd()) {
wholeProperties.insert(iterator.key(), iterator.value());
++iterator;
}
}
return wholeProperties;
}

const QHash<Relation, QMetaProperty> Entity::getRelationProperties() const {
auto h = QHash<Relation, QMetaProperty>();
auto relations = this->getRelations();
for (int var = 0; var < this->metaObject()->propertyCount(); ++var) {
QMetaProperty m = this->metaObject()->property(var);
if (m.isValid() && relations.contains(QString(m.name()))) {
h.insert(relations.value(m.name()), m);
}
}
return h;
}

const char *Entity::getClassname() const {
return this->metaObject()->className();
}

QVariant Entity::getProperty(const QString &name) const {
if (!name.isEmpty()) {
return QObject::property(name.toLatin1().constData());
}
return QVariant();
}

bool Entity::setProperty(const QString &name, const QVariant &value) {
return QObject::setProperty(name.toLatin1().constData(), value);
}

qint64 Entity::getId() const {
return id;
}

void Entity::setId(const qint64 &value) {
if (value != this->id) {
id = value;
emit idChanged();
}
}
(9-9/22)