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
108
|
/* This file is part of the KDE project
Copyright (C) 2004 Matt Rogers <[email protected]>
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.
*/
//TQt Includes
#include <tqfile.h>
#include <tqdir.h>
#include <tqstring.h>
#include <tqcstring.h>
//KDE Includes
#include <kdebug.h>
//Kexi Includes
#include <kexidb/connection.h>
#include <kexidb/drivermanager.h>
#include <kexidb/driver_p.h>
//ODBC Includes
#include "odbcdriver.h"
#include "odbcconnection.h"
using namespace KexiDB;
KEXIDB_DRIVER_INFO( ODBCDriver, odbc )
ODBCDriver::ODBCDriver( TQObject *parent, const char *name, const TQStringList &args )
: Driver( parent, name, args )
{
d->isFileDriver = false;
d->isDBOpenedAfterCreate = true;
d->features = SingleTransactions | CursorForward;
//predefined properties
d->properties["client_library_version"] = "";//TODO
d->properties["default_server_encoding"] = ""; //TODO
d->typeNames[ Field::Byte ] = "Byte";
d->typeNames[ Field::ShortInteger ] = "ShortInteger";
d->typeNames[ Field::Integer ] = "Integer";
d->typeNames[ Field::BigInteger ] = "BigInteger";
d->typeNames[ Field::Boolean ] = "Boolean";
d->typeNames[ Field::Date ] = "Date";
d->typeNames[ Field::DateTime ] = "DateTime";
d->typeNames[ Field::Time ] = "Time";
d->typeNames[ Field::Float ] = "Float";
d->typeNames[ Field::Double ] = "Double";
d->typeNames[ Field::Text ] = "Text";
d->typeNames[ Field::LongText ] = "CLOB";
d->typeNames[ Field::BLOB ] = "BLOB";
}
ODBCDriver::~ODBCDriver()
{
}
KexiDB::Connection* ODBCDriver::drv_createConnection( ConnectionData &conn_data )
{
Q_UNUSED( conn_data );
return 0L;
//return new ODBCConnection( this, conn_data );
}
bool ODBCDriver::isSystemDatabaseName( const TQString& name ) const
{
Q_UNUSED( name );
return false;
}
bool ODBCDriver::isSystemObjectName( const TQString& name )
{
Q_UNUSED( name );
return false;
}
bool ODBCDriver::isSystemFieldName( const TQString& name ) const
{
Q_UNUSED( name );
return false;
}
TQString ODBCDriver::escapeString( const TQString& str ) const
{
return str;
}
TQCString ODBCDriver::escapeString( const TQCString& str ) const
{
return str;
}
#include "odbcdriver.moc"
|