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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
#include "converter.h"
#include <qdatetime.h>
#include <qprogressbar.h>
#include <qpe/qpeapplication.h>
#include <opie/ocontactaccess.h>
#include <opie/ocontactaccessbackend_xml.h>
#include <opie/ocontactaccessbackend_sql.h>
#include <opie/odatebookaccess.h>
#include <opie/odatebookaccessbackend_xml.h>
#include <opie/odatebookaccessbackend_sql.h>
// #define _ADDRESSBOOK_ACCESS
Converter::Converter(){
}
void Converter::start_conversion(){
qWarning("Converting Contacts from XML to SQL..");
// Creating backends to the requested databases..
#ifdef _ADDRESSBOOK_ACCESS
OContactAccessBackend* xmlBackend = new OContactAccessBackend_XML( "Converter",
QString::null );
OContactAccessBackend* sqlBackend = new OContactAccessBackend_SQL( QString::null,
QString::null );
// Put the created backends into frontends to access them
OContactAccess* xmlAccess = new OContactAccess ( "addressbook_xml",
QString::null , xmlBackend, true );
OContactAccess* sqlAccess = new OContactAccess ( "addressbook_sql",
QString::null );
#else
ODateBookAccessBackend* xmlBackend = new ODateBookAccessBackend_XML( "Converter",
QString::null );
ODateBookAccessBackend* sqlBackend = new ODateBookAccessBackend_SQL( QString::null,
QString::null );
// Put the created backends into frontends to access them
ODateBookAccess* xmlAccess = new ODateBookAccess ( xmlBackend );
ODateBookAccess* sqlAccess = new ODateBookAccess ( sqlBackend );
xmlAccess->load();
#endif
QTime t;
t.start();
// Clean the sql-database..
sqlAccess->clear();
#ifdef _ADDRESSBOOK_ACCESS
// Now trasmit every contact from the xml database to the sql-database
OContactAccess::List contactList = xmlAccess->allRecords();
m_progressBar->setTotalSteps( contactList.count() );
int count = 0;
if ( sqlAccess && xmlAccess ){
OContactAccess::List::Iterator it;
for ( it = contactList.begin(); it != contactList.end(); ++it ){
sqlAccess->add( *it );
m_progressBar->setProgress( ++count );
}
}
#else
// Now transmit every contact from the xml database to the sql-database
ODateBookAccess::List dateList = xmlAccess->allRecords();
m_progressBar->setTotalSteps( dateList.count() );
qWarning( "Number of elements to copy: %d", dateList.count() );
int count = 0;
if ( sqlAccess && xmlAccess ){
ODateBookAccess::List::Iterator it;
for ( it = dateList.begin(); it != dateList.end(); ++it ){
sqlAccess->add( *it );
m_progressBar->setProgress( ++count );
}
}
#endif
// Delete the frontends. Backends will be deleted automatically, too !
delete sqlAccess;
qWarning("Conversion is finished and needed %d ms !", t.elapsed());
delete xmlAccess;
}
int main( int argc, char** argv ) {
QPEApplication a( argc, argv );
Converter dlg;
a.showMainWidget( &dlg );
// dlg. showMaximized ( );
return a.exec();
}
|