1*9b5730f6SAndrew Rist /**************************************************************
2cdf0e10cSrcweir *
3*9b5730f6SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
4*9b5730f6SAndrew Rist * or more contributor license agreements. See the NOTICE file
5*9b5730f6SAndrew Rist * distributed with this work for additional information
6*9b5730f6SAndrew Rist * regarding copyright ownership. The ASF licenses this file
7*9b5730f6SAndrew Rist * to you under the Apache License, Version 2.0 (the
8*9b5730f6SAndrew Rist * "License"); you may not use this file except in compliance
9*9b5730f6SAndrew Rist * with the License. You may obtain a copy of the License at
10*9b5730f6SAndrew Rist *
11*9b5730f6SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12*9b5730f6SAndrew Rist *
13*9b5730f6SAndrew Rist * Unless required by applicable law or agreed to in writing,
14*9b5730f6SAndrew Rist * software distributed under the License is distributed on an
15*9b5730f6SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*9b5730f6SAndrew Rist * KIND, either express or implied. See the License for the
17*9b5730f6SAndrew Rist * specific language governing permissions and limitations
18*9b5730f6SAndrew Rist * under the License.
19*9b5730f6SAndrew Rist *
20*9b5730f6SAndrew Rist *************************************************************/
21*9b5730f6SAndrew Rist
22*9b5730f6SAndrew Rist
23cdf0e10cSrcweir
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_connectivity.hxx"
26cdf0e10cSrcweir #include "file/FResultSetMetaData.hxx"
27cdf0e10cSrcweir #include "file/FTable.hxx"
28cdf0e10cSrcweir #include <comphelper/extract.hxx>
29cdf0e10cSrcweir #include "connectivity/dbexception.hxx"
30cdf0e10cSrcweir #include <comphelper/types.hxx>
31cdf0e10cSrcweir #include <rtl/logfile.hxx>
32cdf0e10cSrcweir
33cdf0e10cSrcweir using namespace ::comphelper;
34cdf0e10cSrcweir using namespace connectivity;
35cdf0e10cSrcweir using namespace dbtools;
36cdf0e10cSrcweir using namespace connectivity::file;
37cdf0e10cSrcweir using namespace ::com::sun::star::beans;
38cdf0e10cSrcweir using namespace ::com::sun::star::uno;
39cdf0e10cSrcweir using namespace ::com::sun::star::sdbcx;
40cdf0e10cSrcweir using namespace ::com::sun::star::sdbc;
41cdf0e10cSrcweir using namespace ::com::sun::star::container;
42cdf0e10cSrcweir using namespace ::com::sun::star::lang;
43cdf0e10cSrcweir
44cdf0e10cSrcweir // -------------------------------------------------------------------------
OResultSetMetaData(const::vos::ORef<connectivity::OSQLColumns> & _rxColumns,const::rtl::OUString & _aTableName,OFileTable * _pTable)45cdf0e10cSrcweir OResultSetMetaData::OResultSetMetaData(const ::vos::ORef<connectivity::OSQLColumns>& _rxColumns,const ::rtl::OUString& _aTableName,OFileTable* _pTable)
46cdf0e10cSrcweir :m_aTableName(_aTableName)
47cdf0e10cSrcweir ,m_xColumns(_rxColumns)
48cdf0e10cSrcweir ,m_pTable(_pTable)
49cdf0e10cSrcweir {
50cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::OResultSetMetaData" );
51cdf0e10cSrcweir }
52cdf0e10cSrcweir
53cdf0e10cSrcweir // -------------------------------------------------------------------------
~OResultSetMetaData()54cdf0e10cSrcweir OResultSetMetaData::~OResultSetMetaData()
55cdf0e10cSrcweir {
56cdf0e10cSrcweir m_xColumns = NULL;
57cdf0e10cSrcweir }
58cdf0e10cSrcweir // -----------------------------------------------------------------------------
checkColumnIndex(sal_Int32 column)59cdf0e10cSrcweir void OResultSetMetaData::checkColumnIndex(sal_Int32 column) throw(SQLException, RuntimeException)
60cdf0e10cSrcweir {
61cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::checkColumnIndex" );
62cdf0e10cSrcweir if(column <= 0 || column > (sal_Int32)(sal_Int32)m_xColumns->get().size())
63cdf0e10cSrcweir throwInvalidIndexException(*this);
64cdf0e10cSrcweir }
65cdf0e10cSrcweir // -------------------------------------------------------------------------
getColumnDisplaySize(sal_Int32 column)66cdf0e10cSrcweir sal_Int32 SAL_CALL OResultSetMetaData::getColumnDisplaySize( sal_Int32 column ) throw(SQLException, RuntimeException)
67cdf0e10cSrcweir {
68cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnDisplaySize" );
69cdf0e10cSrcweir return getPrecision(column);
70cdf0e10cSrcweir }
71cdf0e10cSrcweir // -------------------------------------------------------------------------
72cdf0e10cSrcweir
getColumnType(sal_Int32 column)73cdf0e10cSrcweir sal_Int32 SAL_CALL OResultSetMetaData::getColumnType( sal_Int32 column ) throw(SQLException, RuntimeException)
74cdf0e10cSrcweir {
75cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnType" );
76cdf0e10cSrcweir checkColumnIndex(column);
77cdf0e10cSrcweir return getINT32((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPE)));
78cdf0e10cSrcweir }
79cdf0e10cSrcweir // -------------------------------------------------------------------------
80cdf0e10cSrcweir
getColumnCount()81cdf0e10cSrcweir sal_Int32 SAL_CALL OResultSetMetaData::getColumnCount( ) throw(SQLException, RuntimeException)
82cdf0e10cSrcweir {
83cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnCount" );
84cdf0e10cSrcweir return (m_xColumns->get()).size();
85cdf0e10cSrcweir }
86cdf0e10cSrcweir // -------------------------------------------------------------------------
87cdf0e10cSrcweir
isCaseSensitive(sal_Int32)88cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isCaseSensitive( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
89cdf0e10cSrcweir {
90cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isCaseSensitive" );
91cdf0e10cSrcweir return sal_False;
92cdf0e10cSrcweir }
93cdf0e10cSrcweir // -------------------------------------------------------------------------
94cdf0e10cSrcweir
getSchemaName(sal_Int32)95cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getSchemaName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
96cdf0e10cSrcweir {
97cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getSchemaName" );
98cdf0e10cSrcweir return ::rtl::OUString();
99cdf0e10cSrcweir }
100cdf0e10cSrcweir // -------------------------------------------------------------------------
101cdf0e10cSrcweir
getColumnName(sal_Int32 column)102cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnName( sal_Int32 column ) throw(SQLException, RuntimeException)
103cdf0e10cSrcweir {
104cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnName" );
105cdf0e10cSrcweir checkColumnIndex(column);
106cdf0e10cSrcweir
107cdf0e10cSrcweir Any aName((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_NAME)));
108cdf0e10cSrcweir return aName.hasValue() ? getString(aName) : getString((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_NAME)));
109cdf0e10cSrcweir }
110cdf0e10cSrcweir // -------------------------------------------------------------------------
getTableName(sal_Int32)111cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getTableName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
112cdf0e10cSrcweir {
113cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getTableName" );
114cdf0e10cSrcweir return m_aTableName;
115cdf0e10cSrcweir }
116cdf0e10cSrcweir // -------------------------------------------------------------------------
getCatalogName(sal_Int32)117cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getCatalogName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
118cdf0e10cSrcweir {
119cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getCatalogName" );
120cdf0e10cSrcweir return ::rtl::OUString();
121cdf0e10cSrcweir }
122cdf0e10cSrcweir // -------------------------------------------------------------------------
getColumnTypeName(sal_Int32 column)123cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnTypeName( sal_Int32 column ) throw(SQLException, RuntimeException)
124cdf0e10cSrcweir {
125cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnTypeName" );
126cdf0e10cSrcweir checkColumnIndex(column);
127cdf0e10cSrcweir return getString((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPENAME)));
128cdf0e10cSrcweir }
129cdf0e10cSrcweir // -------------------------------------------------------------------------
getColumnLabel(sal_Int32 column)130cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnLabel( sal_Int32 column ) throw(SQLException, RuntimeException)
131cdf0e10cSrcweir {
132cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnLabel" );
133cdf0e10cSrcweir return getColumnName(column);
134cdf0e10cSrcweir }
135cdf0e10cSrcweir // -------------------------------------------------------------------------
getColumnServiceName(sal_Int32)136cdf0e10cSrcweir ::rtl::OUString SAL_CALL OResultSetMetaData::getColumnServiceName( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
137cdf0e10cSrcweir {
138cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getColumnServiceName" );
139cdf0e10cSrcweir return ::rtl::OUString();
140cdf0e10cSrcweir }
141cdf0e10cSrcweir // -------------------------------------------------------------------------
142cdf0e10cSrcweir
isCurrency(sal_Int32 column)143cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isCurrency( sal_Int32 column ) throw(SQLException, RuntimeException)
144cdf0e10cSrcweir {
145cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isCurrency" );
146cdf0e10cSrcweir checkColumnIndex(column);
147cdf0e10cSrcweir return getBOOL((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISCURRENCY)));
148cdf0e10cSrcweir }
149cdf0e10cSrcweir // -------------------------------------------------------------------------
150cdf0e10cSrcweir
isAutoIncrement(sal_Int32)151cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isAutoIncrement( sal_Int32 /*setCatalogcolumn*/ ) throw(SQLException, RuntimeException)
152cdf0e10cSrcweir {
153cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isAutoIncrement" );
154cdf0e10cSrcweir return sal_False;
155cdf0e10cSrcweir }
156cdf0e10cSrcweir // -------------------------------------------------------------------------
isSigned(sal_Int32)157cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isSigned( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
158cdf0e10cSrcweir {
159cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isSigned" );
160cdf0e10cSrcweir return sal_True;
161cdf0e10cSrcweir }
162cdf0e10cSrcweir // -------------------------------------------------------------------------
getPrecision(sal_Int32 column)163cdf0e10cSrcweir sal_Int32 SAL_CALL OResultSetMetaData::getPrecision( sal_Int32 column ) throw(SQLException, RuntimeException)
164cdf0e10cSrcweir {
165cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getPrecision" );
166cdf0e10cSrcweir checkColumnIndex(column);
167cdf0e10cSrcweir return getINT32((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_PRECISION)));
168cdf0e10cSrcweir }
169cdf0e10cSrcweir // -------------------------------------------------------------------------
getScale(sal_Int32 column)170cdf0e10cSrcweir sal_Int32 SAL_CALL OResultSetMetaData::getScale( sal_Int32 column ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException)
171cdf0e10cSrcweir {
172cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::getScale" );
173cdf0e10cSrcweir checkColumnIndex(column);
174cdf0e10cSrcweir return getINT32((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_SCALE)));
175cdf0e10cSrcweir }
176cdf0e10cSrcweir // -------------------------------------------------------------------------
177cdf0e10cSrcweir
isNullable(sal_Int32 column)178cdf0e10cSrcweir sal_Int32 SAL_CALL OResultSetMetaData::isNullable( sal_Int32 column ) throw(SQLException, RuntimeException)
179cdf0e10cSrcweir {
180cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isNullable" );
181cdf0e10cSrcweir checkColumnIndex(column);
182cdf0e10cSrcweir return getINT32((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISNULLABLE)));
183cdf0e10cSrcweir }
184cdf0e10cSrcweir // -------------------------------------------------------------------------
185cdf0e10cSrcweir
isSearchable(sal_Int32)186cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isSearchable( sal_Int32 /*column*/ ) throw(SQLException, RuntimeException)
187cdf0e10cSrcweir {
188cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isSearchable" );
189cdf0e10cSrcweir return sal_True;
190cdf0e10cSrcweir }
191cdf0e10cSrcweir // -------------------------------------------------------------------------
192cdf0e10cSrcweir
isReadOnly(sal_Int32 column)193cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isReadOnly( sal_Int32 column ) throw(SQLException, RuntimeException)
194cdf0e10cSrcweir {
195cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isReadOnly" );
196cdf0e10cSrcweir checkColumnIndex(column);
197cdf0e10cSrcweir return m_pTable->isReadOnly() || (
198cdf0e10cSrcweir (m_xColumns->get())[column-1]->getPropertySetInfo()->hasPropertyByName(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_FUNCTION)) &&
199cdf0e10cSrcweir ::cppu::any2bool((m_xColumns->get())[column-1]->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_FUNCTION))));
200cdf0e10cSrcweir }
201cdf0e10cSrcweir // -------------------------------------------------------------------------
202cdf0e10cSrcweir
isDefinitelyWritable(sal_Int32 column)203cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isDefinitelyWritable( sal_Int32 column ) throw(SQLException, RuntimeException)
204cdf0e10cSrcweir {
205cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isDefinitelyWritable" );
206cdf0e10cSrcweir return !isReadOnly(column);
207cdf0e10cSrcweir }
208cdf0e10cSrcweir // -------------------------------------------------------------------------
isWritable(sal_Int32 column)209cdf0e10cSrcweir sal_Bool SAL_CALL OResultSetMetaData::isWritable( sal_Int32 column ) throw(SQLException, RuntimeException)
210cdf0e10cSrcweir {
211cdf0e10cSrcweir RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "file", "Ocke.Janssen@sun.com", "OResultSetMetaData::isWritable" );
212cdf0e10cSrcweir return !isReadOnly(column);
213cdf0e10cSrcweir }
214cdf0e10cSrcweir // -------------------------------------------------------------------------
215cdf0e10cSrcweir
216