| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 | 
							
- // qCTKDCMTK includes
 
- #include "qCTKDCMTK.h"
 
- // Qt includes
 
- #include <QDebug>
 
- #include <QSqlDatabase>
 
- #include <QSqlError>
 
- #include <QSqlQuery>
 
- #include <QFile>
 
- #include <QStringList>
 
- #include <iostream>
 
- //----------------------------------------------------------------------------
 
- class qCTKDCMTKPrivate: public qCTKPrivate<qCTKDCMTK>
 
- {
 
- public:
 
-   qCTKDCMTKPrivate(); 
 
-   bool executeScript(const QString& script);
 
-   QSqlDatabase  Database;
 
-   QString       DatabaseFileName;
 
-   QString       LastError;
 
- };
 
- //----------------------------------------------------------------------------
 
- // qCTKDCMTKPrivate methods
 
- qCTKDCMTKPrivate::qCTKDCMTKPrivate() 
 
- {
 
- }
 
- //----------------------------------------------------------------------------
 
- // qCTKDCMTKWidget methods
 
- qCTKDCMTK::qCTKDCMTK(QObject* _parent): Superclass(_parent)
 
- {
 
-   QCTK_INIT_PRIVATE(qCTKDCMTK);
 
- }
 
- //----------------------------------------------------------------------------
 
- qCTKDCMTK::~qCTKDCMTK()
 
- {
 
- }
 
- //----------------------------------------------------------------------------
 
- bool qCTKDCMTK::openDatabase(const QString& databaseFileName) 
 
- {
 
-   QCTK_D(qCTKDCMTK);
 
-   d->Database = QSqlDatabase::addDatabase("QSQLITE","DICOM-DB");
 
-   d->Database.setDatabaseName(databaseFileName);
 
-   if ( ! (d->Database.open()) )
 
-     {
 
-     d->LastError = d->Database.lastError().text();
 
-     return false;
 
-     }
 
-   if ( d->Database.tables().empty() ) 
 
-     {
 
-     initializeDatabase();
 
-     }
 
-   return true;
 
- }
 
- const QString& qCTKDCMTK::GetLastError() const {
 
-   QCTK_D(const qCTKDCMTK);
 
-   return d->LastError; 
 
- }
 
- const QSqlDatabase& qCTKDCMTK::database() const {
 
-   QCTK_D(const qCTKDCMTK);
 
-   return d->Database;
 
- }
 
- bool qCTKDCMTKPrivate::executeScript(const QString& script) {
 
-   QFile scriptFile(script);
 
-   scriptFile.open(QIODevice::ReadOnly);
 
-   QString sqlCommands( QTextStream(&scriptFile).readAll() );
 
-   sqlCommands.replace( '\n', ' ' );
 
-   sqlCommands.replace("; ", ";\n");
 
-   QStringList sqlCommandsLines = sqlCommands.split('\n');
 
-   QSqlQuery query(Database);
 
-   for (QStringList::iterator it = sqlCommandsLines.begin(); it != sqlCommandsLines.end()-1; ++it)
 
-   {
 
-     if (! (*it).startsWith("--") )
 
-       {
 
-       query.exec(*it);
 
-       if (query.lastError().type())
 
-         {
 
-         qDebug() << "There was an error during execution of the statement: " << (*it);
 
-         return false;
 
-         }
 
-       }
 
-   }
 
-   return true;
 
- }
 
- bool qCTKDCMTK::initializeDatabase(const char* sqlFileName) 
 
- {
 
-   QCTK_D(qCTKDCMTK);
 
-   return d->executeScript(sqlFileName);
 
- }
 
-   
 
- void qCTKDCMTK::closeDatabase()
 
- {
 
-   QCTK_D(qCTKDCMTK);
 
-   d->Database.close();
 
- }
 
 
  |