# HG changeset patch # User John Kern # Date 1281739026 25200 # Node ID 7140311376c0097d6499094fb3f0851cbd716b6f # Parent 33e489bb74879022f973bb2bca633a15de89818c created in memory contact mgr; populateAddress populates it diff -r 33e489bb7487 -r 7140311376c0 contactengine/contactsengine.cpp --- a/contactengine/contactsengine.cpp Fri Aug 13 15:33:51 2010 -0700 +++ b/contactengine/contactsengine.cpp Fri Aug 13 15:37:06 2010 -0700 @@ -22,12 +22,71 @@ } -//void ContactsEngine::createManager() -//{ -// // this->m_manager = new QContactManager("symbian"); -// // let's try the default. -// this->m_manager = new QContactManager(); -//} +void ContactsEngine::createManagerSF() +{ + // let's try the default. + this->m_manager_sf = new QContactManager("memory"); + // Debugger confirms this is hit, Qt Simulator doesn't display QMessageBox but + // the associated control window shows it is the top level window. + // emit this->errorOccurred(this->errorString(this->m_manager_sf->error())); +} + +QString ContactsEngine::errorString(QContactManager::Error aErr) +{ + QString err; + switch(aErr) + { + case QContactManager::NoError: + err = "No Error"; + break; + case QContactManager::DoesNotExistError: + err = "Does Not Exist Error "; + break; + case QContactManager::AlreadyExistsError: + err = "Already Exists Error"; + break; + case QContactManager::InvalidDetailError: + err = "Invalid Detail Error"; + break; + case QContactManager::InvalidRelationshipError: + err = "Invalid Relationship Error"; + break; + case QContactManager::LockedError: + err = "Locked Error"; + break; + case QContactManager::DetailAccessError: + err = "Detail Access Error"; + break; + case QContactManager::PermissionsError: + err = "Permissions Error"; + break; + case QContactManager::OutOfMemoryError: + err = "Out Of Memory Error"; + break; + case QContactManager::NotSupportedError: + err = "Not Supported Error"; + break; + case QContactManager::BadArgumentError: + err = "Bad Argument Error"; + break; + case QContactManager::UnspecifiedError: + err = "Unspecified Error"; + break; + case QContactManager::VersionMismatchError: + err = "Version Mismatch Error"; + break; + case QContactManager::LimitReachedError: + err = "Limit Reached Error"; + break; + case QContactManager::InvalidContactTypeError: + err = "Invalid Contact Type Error"; + break; + default: + err = "Unknown Error"; + break; + } + return err; +} void ContactsEngine::createManager() { @@ -109,7 +168,9 @@ address->setPostcode("94404"); contact->saveDetail(address); - this->m_manager->saveContact(contact); + this->m_manager_sf->saveContact(contact); + qDebug() << "cm sf status: " << this->errorString(this->m_manager_sf->error()); + // Note that the caller retains ownership of the detail. delete dept; while (!departmentName.isEmpty()) @@ -141,7 +202,9 @@ address->setPostcode("94404"); contact->saveDetail(address); - this->m_manager->saveContact(contact); + this->m_manager_sf->saveContact(contact); + qDebug() << "cm sf status: " << this->errorString(this->m_manager_sf->error()); + delete dept; while (!departmentName.isEmpty()) departmentName.takeFirst(); @@ -171,7 +234,9 @@ address->setPostcode("94404"); contact->saveDetail(address); - this->m_manager->saveContact(contact); + this->m_manager_sf->saveContact(contact); + qDebug() << "cm sf status: " << this->errorString(this->m_manager_sf->error()); + delete dept; while (!departmentName.isEmpty()) departmentName.takeFirst(); @@ -201,7 +266,9 @@ address->setPostcode("94025"); contact->saveDetail(address); - this->m_manager->saveContact(contact); + this->m_manager_sf->saveContact(contact); + qDebug() << "cm sf status: " << this->errorString(this->m_manager_sf->error()); + delete dept; while (!departmentName.isEmpty()) departmentName.takeFirst(); @@ -232,7 +299,9 @@ address->setPostcode("94025"); contact->saveDetail(address); - this->m_manager->saveContact(contact); + this->m_manager_sf->saveContact(contact); + qDebug() << "cm sf status: " << this->errorString(this->m_manager_sf->error()); + delete dept; while (!departmentName.isEmpty()) departmentName.takeFirst(); @@ -302,7 +371,6 @@ foreach(QString m, mgrs) { qDebug() << "\tmgr: " << m << endl; - this->dumpContactMgr(); } qDebug() << endl; } @@ -310,14 +378,24 @@ // dump the current contact manager. void ContactsEngine::dumpContactMgr() { - qDebug() << "Dump Contact Manager:" << endl; + qDebug() << "Dump Contact Manager(default):" << endl; if (this->m_manager) { qDebug() << "\tname: " << this->m_manager->managerName() << endl; qDebug() << "\tURI: " << this->m_manager->managerUri() << endl; qDebug() << "\tVersion: " << this->m_manager->managerVersion() << endl; qDebug() << "\tCount:" << this->m_manager->contacts().count() << endl; } else { - qDebug() << "\t Contact Manager set to zero." << endl; + qDebug() << "\t Contact Manager(default) set to zero." << endl; + } + qDebug() << endl; + qDebug() << "Dump Contact Manager(SF Staff):" << endl; + if (this->m_manager_sf) { + qDebug() << "\tname: " << this->m_manager_sf->managerName() << endl; + qDebug() << "\tURI: " << this->m_manager_sf->managerUri() << endl; + qDebug() << "\tVersion: " << this->m_manager_sf->managerVersion() << endl; + qDebug() << "\tCount:" << this->m_manager_sf->contacts().count() << endl; + } else { + qDebug() << "\t Contact Manager(SF Staff) set to zero." << endl; } qDebug() << endl; } diff -r 33e489bb7487 -r 7140311376c0 contactengine/contactsengine.h --- a/contactengine/contactsengine.h Fri Aug 13 15:33:51 2010 -0700 +++ b/contactengine/contactsengine.h Fri Aug 13 15:37:06 2010 -0700 @@ -29,6 +29,7 @@ void dumpContactMgr(); // use for debugging. Hard to inspect it via Qt Creator. void enumerateMgrs(); void createManager(); + void createManagerSF(); signals: void errorOccurred(QString errMsg); // when a error message @@ -37,8 +38,12 @@ void setManager(const QString &aMgr); private: + QString errorString(QContactManager::Error); + +private: QMap m_availableManagers; QPointer m_manager; + QPointer m_manager_sf; }; #endif // CONTACTSENGINE_H