|
|
|
/* This file is part of the KDE project
|
|
|
|
Copyright (C) 2003 Daniel Molkentin <molkentin@kde.org>
|
|
|
|
Copyright (C) 2003 Joseph Wenninger <jowenn@kde.org>
|
|
|
|
Copyright (C) 2003-2006 Jaroslaw Staniek <js@iidea.pl>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Library General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
|
|
along with this program; see the file COPYING. If not, write to
|
|
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef KEXIDB_DRIVER_MNGR_H
|
|
|
|
#define KEXIDB_DRIVER_MNGR_H
|
|
|
|
|
|
|
|
#include <tqobject.h>
|
|
|
|
#include <tqcstring.h>
|
|
|
|
#include <tqmap.h>
|
|
|
|
#include <tqdict.h>
|
|
|
|
|
|
|
|
#include <klibloader.h>
|
|
|
|
#include <kservice.h>
|
|
|
|
|
|
|
|
#include <kexidb/driver.h>
|
|
|
|
|
|
|
|
namespace KexiDB {
|
|
|
|
|
|
|
|
class DriverManagerInternal;
|
|
|
|
class Connection;
|
|
|
|
class ConnectionData;
|
|
|
|
|
|
|
|
//! Database driver management, e.g. finding and loading drivers.
|
|
|
|
class KEXI_DB_EXPORT DriverManager : public TQObject, public KexiDB::Object
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
typedef TQMap<TQString, KService::Ptr> ServicesMap;
|
|
|
|
|
|
|
|
DriverManager();
|
|
|
|
virtual ~DriverManager();
|
|
|
|
|
|
|
|
/*! Tries to load db driver with named name \a name.
|
|
|
|
The name is case insensitive.
|
|
|
|
\return db driver, or 0 if error (then error message is also set) */
|
|
|
|
Driver* driver(const TQString& name);
|
|
|
|
|
|
|
|
/*! returns list of available drivers names.
|
|
|
|
That drivers can be loaded by first use of driver() method. */
|
|
|
|
const TQStringList driverNames();
|
|
|
|
|
|
|
|
/*! returns information list of available drivers.
|
|
|
|
That drivers can be loaded by first use of driver() method. */
|
|
|
|
const KexiDB::Driver::InfoMap driversInfo();
|
|
|
|
|
|
|
|
/*! \return information about driver's named with \a name.
|
|
|
|
The name is case insensitive.
|
|
|
|
You can check if driver information is not found calling
|
|
|
|
Info::name.isEmpty() (then error message is also set). */
|
|
|
|
KexiDB::Driver::Info driverInfo(const TQString &name);
|
|
|
|
|
|
|
|
/*! \return service information about driver's named with \a name.
|
|
|
|
The name is case insensitive.
|
|
|
|
In most cases you can use driverInfo() instead. */
|
|
|
|
KService::Ptr serviceInfo(const TQString &name);
|
|
|
|
|
|
|
|
/*! \return a map structure of the services. Not necessary for everyday use. */
|
|
|
|
const ServicesMap& services();
|
|
|
|
|
|
|
|
/*! Looks up a drivers list by MIME type of database file.
|
|
|
|
Only file-based database drivers are checked.
|
|
|
|
The lookup is case insensitive.
|
|
|
|
\return driver name or null string if no driver found.
|
|
|
|
*/
|
|
|
|
TQString lookupByMime(const TQString &mimeType);
|
|
|
|
|
|
|
|
//! server error is set if there is error at KService level (useful for debugging)
|
|
|
|
virtual TQString serverErrorMsg();
|
|
|
|
virtual int serverResult();
|
|
|
|
virtual TQString serverResultName();
|
|
|
|
|
|
|
|
/*! HTML information about possible problems encountered.
|
|
|
|
It's displayed in 'details' section, if an error encountered.
|
|
|
|
Currently it contains a list of incompatible db drivers.
|
|
|
|
Used in KexiStartupHandler::detectDriverForFile(). */
|
|
|
|
TQString possibleProblemsInfoMsg() const;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void drv_clearServerResult();
|
|
|
|
|
|
|
|
private:
|
|
|
|
DriverManagerInternal *d_int;
|
|
|
|
};
|
|
|
|
|
|
|
|
} //namespace KexiDB
|
|
|
|
|
|
|
|
#endif
|