summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiepim/backend/obackendfactory.h30
-rw-r--r--libopie2/opiepim/core/opimaccessfactory.h18
2 files changed, 38 insertions, 10 deletions
diff --git a/libopie2/opiepim/backend/obackendfactory.h b/libopie2/opiepim/backend/obackendfactory.h
index d8caa80..993ecb4 100644
--- a/libopie2/opiepim/backend/obackendfactory.h
+++ b/libopie2/opiepim/backend/obackendfactory.h
@@ -87,3 +87,9 @@ class OBackendFactory
const QString& appName ){
- qWarning("Selected backend for %d is: %d", type, database );
+ qWarning("Selected backend for %d is: %d", type, database );
+ // If we should use the dafult database style, we have to request it
+ OPimGlobal::DatabaseStyle used_database = database;
+ if ( database == OPimGlobal::DEFAULT ){
+ used_database = defaultDB( type );
+ }
+
@@ -92,6 +98,6 @@ class OBackendFactory
#ifdef __USE_SQL
- if ( database == OPimGlobal::SQL )
+ if ( used_database == OPimGlobal::SQL )
return (T*) new OPimTodoAccessBackendSQL("");
#else
- if ( database == OPimGlobal::SQL )
+ if ( used_database == OPimGlobal::SQL )
qWarning ("OBackendFactory:: sql Backend for TODO not implemented! Using XML instead!");
@@ -102,6 +108,6 @@ class OBackendFactory
#ifdef __USE_SQL
- if ( database == OPimGlobal::SQL )
+ if ( used_database == OPimGlobal::SQL )
return (T*) new OPimContactAccessBackend_SQL("");
#else
- if ( database == OPimGlobal::SQL )
+ if ( used_database == OPimGlobal::SQL )
qWarning ("OBackendFactory:: sql Backend for CONTACT not implemented! Using XML instead!");
@@ -112,6 +118,6 @@ class OBackendFactory
#ifdef __USE_SQL
- if ( database == OPimGlobal::SQL )
+ if ( used_database == OPimGlobal::SQL )
return (T*) new ODateBookAccessBackend_SQL("");
#else
- if ( database == OPimGlobal::SQL )
+ if ( used_database == OPimGlobal::SQL )
qWarning("OBackendFactory:: sql Backend for DATEBOOK not implemented! Using XML instead!");
@@ -127,6 +133,10 @@ class OBackendFactory
-
- static OPimGlobal::DatabaseStyle defaultDB( OPimGlobal::PimType backend ){
+ /**
+ * Returns the style of the default database which is used to contact PIM data.
+ * @param type the type of the backend
+ * @see OPimGlobal
+ */
+ static OPimGlobal::DatabaseStyle defaultDB( OPimGlobal::PimType type ){
QString group_name;
- switch ( backend ){
+ switch ( type ){
case OPimGlobal::TODOLIST:
diff --git a/libopie2/opiepim/core/opimaccessfactory.h b/libopie2/opiepim/core/opimaccessfactory.h
index ba99a15..eecfa96 100644
--- a/libopie2/opiepim/core/opimaccessfactory.h
+++ b/libopie2/opiepim/core/opimaccessfactory.h
@@ -94,2 +94,20 @@ class OPimAccessFactory
}
+
+
+ /**
+ * Returns the selected PIM access-object, using the default database style
+ * Which style is selected is defined in the configfile "pimaccess.conf" in
+ * the directory "Settings"
+ * @param type Type of the selected database (addressbook, todolist or datebook)
+ * @param appName "Name" of your application. This should be any constant string which is used
+ * by some backends for creating special files (i.e.journal files). Please keep the
+ * string unique for your application !
+ * @see OPimGlobal
+ *
+ */
+ static T* default( OPimGlobal::PimType type, const QString& appName ){
+
+ return create( type, OPimGlobal::DEFAULT, appName )
+
+ }
};