1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 #ifndef _CONNECTIVITY_ADO_ADATABASEMETADATARESULTSET_HXX_
29 #define _CONNECTIVITY_ADO_ADATABASEMETADATARESULTSET_HXX_
30 
31 #include <com/sun/star/sdbc/XResultSet.hpp>
32 #include <com/sun/star/sdbc/XRow.hpp>
33 #include <com/sun/star/sdbc/XResultSetMetaDataSupplier.hpp>
34 #include <com/sun/star/sdbc/XCloseable.hpp>
35 #include <com/sun/star/sdbc/XColumnLocate.hpp>
36 #include <com/sun/star/util/XCancellable.hpp>
37 #include <com/sun/star/sdbc/XWarningsSupplier.hpp>
38 #include <com/sun/star/sdbc/XResultSetUpdate.hpp>
39 #include <com/sun/star/sdbc/XRowUpdate.hpp>
40 #include <cppuhelper/compbase7.hxx>
41 #include <comphelper/proparrhlp.hxx>
42 #include "ado/AStatement.hxx"
43 //#ifndef _CONNECTIVITY_COMMONTOOLS_HXX_
44 //#include "connectivity/CommonTools.hxx"
45 //#endif
46 #include <comphelper/broadcasthelper.hxx>
47 #include "connectivity/StdTypeDefs.hxx"
48 
49 namespace connectivity
50 {
51 	namespace ado
52 	{
53 		class ODatabaseMetaDataResultSetMetaData;
54 		/*
55 		**	java_sql_ResultSet
56 		*/
57         typedef ::cppu::WeakComponentImplHelper7<	::com::sun::star::sdbc::XResultSet,
58                                                     ::com::sun::star::sdbc::XRow,
59                                                     ::com::sun::star::sdbc::XResultSetMetaDataSupplier,
60                                                     ::com::sun::star::util::XCancellable,
61                                                     ::com::sun::star::sdbc::XWarningsSupplier,
62                                                     ::com::sun::star::sdbc::XCloseable,
63                                                     ::com::sun::star::sdbc::XColumnLocate> ODatabaseMetaDataResultSet_BASE;
64 
65 		class ODatabaseMetaDataResultSet :	public comphelper::OBaseMutex,
66 									public	ODatabaseMetaDataResultSet_BASE,
67 									public	::cppu::OPropertySetHelper,
68 									public	::comphelper::OPropertyArrayUsageHelper<ODatabaseMetaDataResultSet>
69 		{
70 			::std::vector<sal_Int32>		m_aColMapping; // pos 0 is unused so we don't have to decrement 1 everytime
71 
72 			::std::map<sal_Int32, TInt2IntMap >	m_aValueRange;
73 			::std::map<sal_Int32, TInt2IntMap >::iterator	m_aValueRangeIter;
74 
75 			::std::map<sal_Int32, ::std::map< ::rtl::OUString,sal_Int32> >				m_aStrValueRange;
76 			::std::map<sal_Int32, ::std::map< ::rtl::OUString,sal_Int32> >::iterator	m_aStrValueRangeIter;
77 
78 			::std::map<sal_Int32, ::std::map< sal_Int32,::rtl::OUString> >				m_aIntValueRange;
79 			::std::map<sal_Int32, ::std::map< sal_Int32,::rtl::OUString> >::iterator	m_aIntValueRangeIter;
80 
81 			ADORecordset*					m_pRecordSet;
82                         ::com::sun::star::uno::WeakReferenceHelper    m_aStatement;
83                         ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSetMetaData>        m_xMetaData;
84 			OLEVariant						m_aValue;
85 			sal_Int32						m_nRowPos;
86 			sal_Bool						m_bWasNull;
87 			sal_Bool						m_bEOF;
88 			sal_Bool						m_bOnFirstAfterOpen;
89 
90 			sal_Int32 getResultSetConcurrency() const throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
91 			sal_Int32 getResultSetType()		const throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
92 			sal_Int32 getFetchDirection()		const throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
93 			sal_Int32 getFetchSize()			const throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
94 			::rtl::OUString getCursorName()		const throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
95 
96 			void setFetchDirection(sal_Int32 _par0) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
97 			void setFetchSize(sal_Int32 _par0) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
98 
99 
100 			inline sal_Int32 mapColumn (sal_Int32	column);
101 			void checkRecordSet() throw(::com::sun::star::sdbc::SQLException);
102 			OLEVariant getValue(sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
103 
104 		protected:
105 
106 			// OPropertyArrayUsageHelper
107 			virtual ::cppu::IPropertyArrayHelper* createArrayHelper( ) const;
108 			// OPropertySetHelper
109 			virtual ::cppu::IPropertyArrayHelper & SAL_CALL getInfoHelper();
110 
111 			virtual sal_Bool SAL_CALL convertFastPropertyValue(
112                                                                 ::com::sun::star::uno::Any & rConvertedValue,
113                                                                 ::com::sun::star::uno::Any & rOldValue,
114 								sal_Int32 nHandle,
115                                                                 const ::com::sun::star::uno::Any& rValue )
116 									throw (::com::sun::star::lang::IllegalArgumentException);
117 			virtual void SAL_CALL setFastPropertyValue_NoBroadcast(
118 									sal_Int32 nHandle,
119                                                                         const ::com::sun::star::uno::Any& rValue
120 													 )
121                                                                                                          throw (::com::sun::star::uno::Exception);
122 			virtual void SAL_CALL getFastPropertyValue(
123                                                                         ::com::sun::star::uno::Any& rValue,
124 									sal_Int32 nHandle
125 										 ) const;
126 		public:
127 			// ein Konstruktor, der fuer das Returnen des Objektes benoetigt wird:
128 			ODatabaseMetaDataResultSet( ADORecordset* _pRecordSet);
129 			~ODatabaseMetaDataResultSet();
130 
131 			// ::cppu::OComponentHelper
132 			virtual void SAL_CALL disposing(void);
133 			// XInterface
134             virtual ::com::sun::star::uno::Any SAL_CALL queryInterface( const ::com::sun::star::uno::Type & rType ) throw(::com::sun::star::uno::RuntimeException);
135 			virtual void SAL_CALL acquire() throw();
136             virtual void SAL_CALL release() throw();
137 			//XTypeProvider
138             virtual ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Type > SAL_CALL getTypes(  ) throw(::com::sun::star::uno::RuntimeException);
139 			// XPropertySet
140             virtual ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySetInfo > SAL_CALL getPropertySetInfo(  ) throw(::com::sun::star::uno::RuntimeException);
141 			// XResultSet
142             virtual sal_Bool SAL_CALL next(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
143             virtual sal_Bool SAL_CALL isBeforeFirst(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
144             virtual sal_Bool SAL_CALL isAfterLast(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
145             virtual sal_Bool SAL_CALL isFirst(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
146             virtual sal_Bool SAL_CALL isLast(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
147             virtual void SAL_CALL beforeFirst(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
148             virtual void SAL_CALL afterLast(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
149             virtual sal_Bool SAL_CALL first(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
150             virtual sal_Bool SAL_CALL last(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
151             virtual sal_Int32 SAL_CALL getRow(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
152             virtual sal_Bool SAL_CALL absolute( sal_Int32 row ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
153             virtual sal_Bool SAL_CALL relative( sal_Int32 rows ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
154             virtual sal_Bool SAL_CALL previous(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
155             virtual void SAL_CALL refreshRow(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
156             virtual sal_Bool SAL_CALL rowUpdated(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
157             virtual sal_Bool SAL_CALL rowInserted(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
158             virtual sal_Bool SAL_CALL rowDeleted(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
159             virtual ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > SAL_CALL getStatement(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
160 			// XRow
161 			virtual sal_Bool SAL_CALL wasNull(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
162 			virtual ::rtl::OUString SAL_CALL getString( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
163 			virtual sal_Bool SAL_CALL getBoolean( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
164 			virtual sal_Int8 SAL_CALL getByte( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
165 			virtual sal_Int16 SAL_CALL getShort( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
166 			virtual sal_Int32 SAL_CALL getInt( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
167 			virtual sal_Int64 SAL_CALL getLong( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
168 			virtual float SAL_CALL getFloat( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
169 			virtual double SAL_CALL getDouble( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
170 			virtual ::com::sun::star::uno::Sequence< sal_Int8 > SAL_CALL getBytes( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
171 			virtual ::com::sun::star::util::Date SAL_CALL getDate( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
172 			virtual ::com::sun::star::util::Time SAL_CALL getTime( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
173 			virtual ::com::sun::star::util::DateTime SAL_CALL getTimestamp( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
174 			virtual ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream > SAL_CALL getBinaryStream( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
175 			virtual ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream > SAL_CALL getCharacterStream( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
176 			virtual ::com::sun::star::uno::Any SAL_CALL getObject( sal_Int32 columnIndex, const ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameAccess >& typeMap ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
177 			virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XRef > SAL_CALL getRef( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
178 			virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XBlob > SAL_CALL getBlob( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
179 			virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XClob > SAL_CALL getClob( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
180 			virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XArray > SAL_CALL getArray( sal_Int32 columnIndex ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
181 			// XResultSetMetaDataSupplier
182             virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSetMetaData > SAL_CALL getMetaData(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
183 			// XCancellable
184             virtual void SAL_CALL cancel(  ) throw(::com::sun::star::uno::RuntimeException);
185 			// XCloseable
186             virtual void SAL_CALL close(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
187 			// XWarningsSupplier
188             virtual ::com::sun::star::uno::Any SAL_CALL getWarnings(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
189             virtual void SAL_CALL clearWarnings(  ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
190 			// XColumnLocate
191             virtual sal_Int32 SAL_CALL findColumn( const ::rtl::OUString& columnName ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException);
192 
193 			const ::std::vector<sal_Int32>& getColumnMapping() { return m_aColMapping; }
194 
195 			void setCatalogsMap();
196 			void setSchemasMap();
197 			void setColumnPrivilegesMap();
198 			void setColumnsMap();
199 			void setTablesMap();
200 			void setProcedureColumnsMap();
201 			void setProceduresMap();
202 			void setExportedKeysMap();
203 			void setImportedKeysMap();
204 			void setPrimaryKeysMap();
205 			void setIndexInfoMap();
206 			void setTablePrivilegesMap();
207 			void setCrossReferenceMap();
208 			void setTypeInfoMap(sal_Bool _bJetEngine);
209 		};
210 		// -------------------------------------------------------------------------
211 		inline sal_Int32 ODatabaseMetaDataResultSet::mapColumn (sal_Int32	column)
212 		{
213 			sal_Int32	map = column;
214 
215 			if (!m_aColMapping.empty())
216 			{
217 				// Validate column number
218 				map = m_aColMapping[column];
219 			}
220 
221 			return map;
222 		}
223 	}
224 
225 }
226 #endif // _CONNECTIVITY_ADO_ADATABASEMETADATARESULTSET_HXX_
227 
228