sqliteadmin.cpp
Go to the documentation of this file.00001 /* This file is part of the KDE project 00002 Copyright (C) 2006 Jaroslaw Staniek <js@iidea.pl> 00003 00004 This library is free software; you can redistribute it and/or 00005 modify it under the terms of the GNU Library General Public 00006 License as published by the Free Software Foundation; either 00007 version 2 of the License, or (at your option) any later version. 00008 00009 This library is distributed in the hope that it will be useful, 00010 but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00012 Library General Public License for more details. 00013 00014 You should have received a copy of the GNU Library General Public License 00015 along with this library; see the file COPYING.LIB. If not, write to 00016 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, 00017 * Boston, MA 02110-1301, USA. 00018 */ 00019 00020 #include <qdir.h> 00021 00022 #include "sqliteadmin.h" 00023 #include <kexidb/drivermanager.h> 00024 #include <kexidb/driver_p.h> 00025 00026 #ifndef SQLITE2 00027 # include "sqlitevacuum.h" 00028 #endif 00029 00030 SQLiteAdminTools::SQLiteAdminTools() 00031 : KexiDB::AdminTools() 00032 { 00033 } 00034 00035 SQLiteAdminTools::~SQLiteAdminTools() 00036 { 00037 } 00038 00039 bool SQLiteAdminTools::vacuum(const KexiDB::ConnectionData& data, const QString& databaseName) 00040 { 00041 clearError(); 00042 #ifdef SQLITE2 00043 Q_UNUSED(data); 00044 Q_UNUSED(databaseName); 00045 return false; 00046 #else 00047 KexiDB::DriverManager manager; 00048 KexiDB::Driver *drv = manager.driver(data.driverName); 00049 QString title( i18n("Could not compact database \"%1\".").arg(QDir::convertSeparators(databaseName)) ); 00050 if (!drv) { 00051 setError(&manager, title); 00052 return false; 00053 } 00054 SQLiteVacuum vacuum(data.dbPath()+QDir::separator()+databaseName); 00055 tristate result = vacuum.run(); 00056 if (!result) { 00057 setError(title); 00058 return false; 00059 } 00060 else //success or cancelled 00061 return true; 00062 #endif 00063 } 00064
