xref: /trunk/main/connectivity/source/parse/PColumn.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_connectivity.hxx"
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #include "connectivity/PColumn.hxx"
32*cdf0e10cSrcweir #include "connectivity/dbtools.hxx"
33*cdf0e10cSrcweir #include "TConnection.hxx"
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir #include <comphelper/types.hxx>
36*cdf0e10cSrcweir #include <tools/diagnose_ex.h>
37*cdf0e10cSrcweir 
38*cdf0e10cSrcweir using namespace ::comphelper;
39*cdf0e10cSrcweir using namespace connectivity;
40*cdf0e10cSrcweir using namespace dbtools;
41*cdf0e10cSrcweir using namespace connectivity::parse;
42*cdf0e10cSrcweir using namespace ::com::sun::star::uno;
43*cdf0e10cSrcweir using namespace ::com::sun::star::sdbc;
44*cdf0e10cSrcweir using namespace ::com::sun::star::beans;
45*cdf0e10cSrcweir using namespace ::com::sun::star::container;
46*cdf0e10cSrcweir 
47*cdf0e10cSrcweir // -------------------------------------------------------------------------
48*cdf0e10cSrcweir OParseColumn::OParseColumn(const Reference<XPropertySet>& _xColumn,sal_Bool     _bCase)
49*cdf0e10cSrcweir     : connectivity::sdbcx::OColumn( getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_NAME)))
50*cdf0e10cSrcweir                                 ,   getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPENAME)))
51*cdf0e10cSrcweir                                 ,   getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DEFAULTVALUE)))
52*cdf0e10cSrcweir                                 ,   getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DESCRIPTION)))
53*cdf0e10cSrcweir                                 ,   getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISNULLABLE)))
54*cdf0e10cSrcweir                                 ,   getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_PRECISION)))
55*cdf0e10cSrcweir                                 ,   getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_SCALE)))
56*cdf0e10cSrcweir                                 ,   getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPE)))
57*cdf0e10cSrcweir                                 ,   getBOOL(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISAUTOINCREMENT)))
58*cdf0e10cSrcweir                                 ,   sal_False
59*cdf0e10cSrcweir                                 ,   getBOOL(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISCURRENCY)))
60*cdf0e10cSrcweir                                 ,   _bCase
61*cdf0e10cSrcweir                                 )
62*cdf0e10cSrcweir     , m_bFunction(sal_False)
63*cdf0e10cSrcweir     , m_bDbasePrecisionChanged(sal_False)
64*cdf0e10cSrcweir     , m_bAggregateFunction(sal_False)
65*cdf0e10cSrcweir     , m_bIsSearchable( sal_True )
66*cdf0e10cSrcweir {
67*cdf0e10cSrcweir     construct();
68*cdf0e10cSrcweir }
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir // -------------------------------------------------------------------------
71*cdf0e10cSrcweir OParseColumn::OParseColumn( const ::rtl::OUString& _Name,
72*cdf0e10cSrcweir                     const ::rtl::OUString& _TypeName,
73*cdf0e10cSrcweir                     const ::rtl::OUString& _DefaultValue,
74*cdf0e10cSrcweir                     const ::rtl::OUString& _Description,
75*cdf0e10cSrcweir                     sal_Int32       _IsNullable,
76*cdf0e10cSrcweir                     sal_Int32       _Precision,
77*cdf0e10cSrcweir                     sal_Int32       _Scale,
78*cdf0e10cSrcweir                     sal_Int32       _Type,
79*cdf0e10cSrcweir                     sal_Bool        _IsAutoIncrement,
80*cdf0e10cSrcweir                     sal_Bool        _IsCurrency,
81*cdf0e10cSrcweir                     sal_Bool        _bCase
82*cdf0e10cSrcweir                 ) : connectivity::sdbcx::OColumn(_Name,
83*cdf0e10cSrcweir                                   _TypeName,
84*cdf0e10cSrcweir                                   _DefaultValue,
85*cdf0e10cSrcweir                                   _Description,
86*cdf0e10cSrcweir                                   _IsNullable,
87*cdf0e10cSrcweir                                   _Precision,
88*cdf0e10cSrcweir                                   _Scale,
89*cdf0e10cSrcweir                                   _Type,
90*cdf0e10cSrcweir                                   _IsAutoIncrement,
91*cdf0e10cSrcweir                                   sal_False,
92*cdf0e10cSrcweir                                   _IsCurrency,
93*cdf0e10cSrcweir                                   _bCase)
94*cdf0e10cSrcweir     , m_bFunction(sal_False)
95*cdf0e10cSrcweir     , m_bDbasePrecisionChanged(sal_False)
96*cdf0e10cSrcweir     , m_bAggregateFunction(sal_False)
97*cdf0e10cSrcweir     , m_bIsSearchable( sal_True )
98*cdf0e10cSrcweir {
99*cdf0e10cSrcweir     construct();
100*cdf0e10cSrcweir }
101*cdf0e10cSrcweir 
102*cdf0e10cSrcweir // -------------------------------------------------------------------------
103*cdf0e10cSrcweir ::vos::ORef< OSQLColumns > OParseColumn::createColumnsForResultSet( const Reference< XResultSetMetaData >& _rxResMetaData,
104*cdf0e10cSrcweir     const Reference< XDatabaseMetaData >& _rxDBMetaData,const Reference< XNameAccess>& i_xQueryColumns )
105*cdf0e10cSrcweir {
106*cdf0e10cSrcweir     sal_Int32 nColumnCount = _rxResMetaData->getColumnCount();
107*cdf0e10cSrcweir     ::vos::ORef< OSQLColumns > aReturn( new OSQLColumns ); aReturn->get().reserve( nColumnCount );
108*cdf0e10cSrcweir 
109*cdf0e10cSrcweir     StringMap aColumnMap;
110*cdf0e10cSrcweir     for ( sal_Int32 i = 1; i <= nColumnCount; ++i )
111*cdf0e10cSrcweir     {
112*cdf0e10cSrcweir         OParseColumn* pColumn = createColumnForResultSet( _rxResMetaData, _rxDBMetaData, i,aColumnMap );
113*cdf0e10cSrcweir         aReturn->get().push_back( pColumn );
114*cdf0e10cSrcweir         if ( i_xQueryColumns.is() && i_xQueryColumns->hasByName(pColumn->getRealName()) )
115*cdf0e10cSrcweir         {
116*cdf0e10cSrcweir             Reference<XPropertySet> xColumn(i_xQueryColumns->getByName(pColumn->getRealName()),UNO_QUERY_THROW);
117*cdf0e10cSrcweir             ::rtl::OUString sLabel;
118*cdf0e10cSrcweir             xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_LABEL)) >>= sLabel;
119*cdf0e10cSrcweir             if ( sLabel.getLength() )
120*cdf0e10cSrcweir                 pColumn->setLabel(sLabel);
121*cdf0e10cSrcweir         }
122*cdf0e10cSrcweir     }
123*cdf0e10cSrcweir 
124*cdf0e10cSrcweir     return aReturn;
125*cdf0e10cSrcweir }
126*cdf0e10cSrcweir 
127*cdf0e10cSrcweir // -------------------------------------------------------------------------
128*cdf0e10cSrcweir OParseColumn* OParseColumn::createColumnForResultSet( const Reference< XResultSetMetaData >& _rxResMetaData,
129*cdf0e10cSrcweir     const Reference< XDatabaseMetaData >& _rxDBMetaData, sal_Int32 _nColumnPos,StringMap& _rColumns )
130*cdf0e10cSrcweir {
131*cdf0e10cSrcweir     ::rtl::OUString sLabel = _rxResMetaData->getColumnLabel( _nColumnPos );
132*cdf0e10cSrcweir     // retrieve the name of the column
133*cdf0e10cSrcweir     // check for duplicate entries
134*cdf0e10cSrcweir     if(_rColumns.find(sLabel) != _rColumns.end())
135*cdf0e10cSrcweir     {
136*cdf0e10cSrcweir         ::rtl::OUString sAlias(sLabel);
137*cdf0e10cSrcweir         sal_Int32 searchIndex=1;
138*cdf0e10cSrcweir         while(_rColumns.find(sAlias) != _rColumns.end())
139*cdf0e10cSrcweir         {
140*cdf0e10cSrcweir             (sAlias = sLabel) += ::rtl::OUString::valueOf(searchIndex++);
141*cdf0e10cSrcweir         }
142*cdf0e10cSrcweir         sLabel = sAlias;
143*cdf0e10cSrcweir     }
144*cdf0e10cSrcweir     _rColumns.insert(StringMap::value_type(sLabel,0));
145*cdf0e10cSrcweir     OParseColumn* pColumn = new OParseColumn(
146*cdf0e10cSrcweir         sLabel,
147*cdf0e10cSrcweir         _rxResMetaData->getColumnTypeName( _nColumnPos ),
148*cdf0e10cSrcweir         ::rtl::OUString(),
149*cdf0e10cSrcweir         ::rtl::OUString(),
150*cdf0e10cSrcweir         _rxResMetaData->isNullable( _nColumnPos ),
151*cdf0e10cSrcweir         _rxResMetaData->getPrecision( _nColumnPos ),
152*cdf0e10cSrcweir         _rxResMetaData->getScale( _nColumnPos ),
153*cdf0e10cSrcweir         _rxResMetaData->getColumnType( _nColumnPos ),
154*cdf0e10cSrcweir         _rxResMetaData->isAutoIncrement( _nColumnPos ),
155*cdf0e10cSrcweir         _rxResMetaData->isCurrency( _nColumnPos ),
156*cdf0e10cSrcweir         _rxDBMetaData->supportsMixedCaseQuotedIdentifiers()
157*cdf0e10cSrcweir     );
158*cdf0e10cSrcweir     const ::rtl::OUString sTableName = _rxResMetaData->getTableName( _nColumnPos );
159*cdf0e10cSrcweir     if ( sTableName.getLength() )
160*cdf0e10cSrcweir         pColumn->setTableName(  ::dbtools::composeTableName( _rxDBMetaData,
161*cdf0e10cSrcweir             _rxResMetaData->getCatalogName( _nColumnPos ),
162*cdf0e10cSrcweir             _rxResMetaData->getSchemaName( _nColumnPos ),
163*cdf0e10cSrcweir             sTableName,
164*cdf0e10cSrcweir             sal_False,
165*cdf0e10cSrcweir             eComplete
166*cdf0e10cSrcweir         ) );
167*cdf0e10cSrcweir     pColumn->setIsSearchable( _rxResMetaData->isSearchable( _nColumnPos ) );
168*cdf0e10cSrcweir     pColumn->setRealName(_rxResMetaData->getColumnName( _nColumnPos ));
169*cdf0e10cSrcweir     pColumn->setLabel(sLabel);
170*cdf0e10cSrcweir     return pColumn;
171*cdf0e10cSrcweir }
172*cdf0e10cSrcweir 
173*cdf0e10cSrcweir // -------------------------------------------------------------------------
174*cdf0e10cSrcweir OParseColumn::~OParseColumn()
175*cdf0e10cSrcweir {
176*cdf0e10cSrcweir }
177*cdf0e10cSrcweir // -------------------------------------------------------------------------
178*cdf0e10cSrcweir void OParseColumn::construct()
179*cdf0e10cSrcweir {
180*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_FUNCTION),                PROPERTY_ID_FUNCTION,               0,  &m_bFunction,               ::getCppuType(reinterpret_cast< sal_Bool*>(NULL)));
181*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_AGGREGATEFUNCTION),       PROPERTY_ID_AGGREGATEFUNCTION,      0,  &m_bAggregateFunction,      ::getCppuType(reinterpret_cast< sal_Bool*>(NULL)));
182*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TABLENAME),               PROPERTY_ID_TABLENAME,              0,  &m_aTableName,              ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
183*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_REALNAME),                PROPERTY_ID_REALNAME,               0,  &m_aRealName,               ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
184*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DBASEPRECISIONCHANGED),   PROPERTY_ID_DBASEPRECISIONCHANGED,  0,  &m_bDbasePrecisionChanged,  ::getCppuType(reinterpret_cast<sal_Bool*>(NULL)));
185*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISSEARCHABLE),            PROPERTY_ID_ISSEARCHABLE,           0,  &m_bIsSearchable,           ::getCppuType(reinterpret_cast< sal_Bool*>(NULL)));
186*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_LABEL),                   PROPERTY_ID_LABEL,                  0,  &m_sLabel,                  ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
187*cdf0e10cSrcweir }
188*cdf0e10cSrcweir // -----------------------------------------------------------------------------
189*cdf0e10cSrcweir ::cppu::IPropertyArrayHelper* OParseColumn::createArrayHelper() const
190*cdf0e10cSrcweir {
191*cdf0e10cSrcweir     return doCreateArrayHelper();
192*cdf0e10cSrcweir }
193*cdf0e10cSrcweir // -----------------------------------------------------------------------------
194*cdf0e10cSrcweir ::cppu::IPropertyArrayHelper & SAL_CALL OParseColumn::getInfoHelper()
195*cdf0e10cSrcweir {
196*cdf0e10cSrcweir     OSL_ENSURE( !isNew(), "OParseColumn::getInfoHelper: a *new* ParseColumn?" );
197*cdf0e10cSrcweir     return *OParseColumn_PROP::getArrayHelper();
198*cdf0e10cSrcweir }
199*cdf0e10cSrcweir 
200*cdf0e10cSrcweir // -----------------------------------------------------------------------------
201*cdf0e10cSrcweir namespace
202*cdf0e10cSrcweir {
203*cdf0e10cSrcweir     ::rtl::OUString lcl_getColumnTableName( const Reference< XPropertySet >& i_parseColumn )
204*cdf0e10cSrcweir     {
205*cdf0e10cSrcweir         ::rtl::OUString sColumnTableName;
206*cdf0e10cSrcweir         try
207*cdf0e10cSrcweir         {
208*cdf0e10cSrcweir             OSL_VERIFY( i_parseColumn->getPropertyValue( OMetaConnection::getPropMap().getNameByIndex( PROPERTY_ID_TABLENAME ) ) >>= sColumnTableName );
209*cdf0e10cSrcweir         }
210*cdf0e10cSrcweir         catch( const Exception& )
211*cdf0e10cSrcweir         {
212*cdf0e10cSrcweir             DBG_UNHANDLED_EXCEPTION();
213*cdf0e10cSrcweir         }
214*cdf0e10cSrcweir         return sColumnTableName;
215*cdf0e10cSrcweir     }
216*cdf0e10cSrcweir }
217*cdf0e10cSrcweir 
218*cdf0e10cSrcweir // -----------------------------------------------------------------------------
219*cdf0e10cSrcweir OOrderColumn::OOrderColumn( const Reference<XPropertySet>& _xColumn, const ::rtl::OUString& i_rOriginatingTableName,
220*cdf0e10cSrcweir                             sal_Bool    _bCase, sal_Bool _bAscending )
221*cdf0e10cSrcweir     : connectivity::sdbcx::OColumn(
222*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_NAME))),
223*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPENAME))),
224*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DEFAULTVALUE))),
225*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DESCRIPTION))),
226*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISNULLABLE))),
227*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_PRECISION))),
228*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_SCALE))),
229*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPE))),
230*cdf0e10cSrcweir         getBOOL(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISAUTOINCREMENT))),
231*cdf0e10cSrcweir         sal_False,
232*cdf0e10cSrcweir         getBOOL(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISCURRENCY))),
233*cdf0e10cSrcweir         _bCase
234*cdf0e10cSrcweir     )
235*cdf0e10cSrcweir     ,m_bAscending(_bAscending)
236*cdf0e10cSrcweir     ,m_sTableName( i_rOriginatingTableName )
237*cdf0e10cSrcweir {
238*cdf0e10cSrcweir     construct();
239*cdf0e10cSrcweir }
240*cdf0e10cSrcweir 
241*cdf0e10cSrcweir // -----------------------------------------------------------------------------
242*cdf0e10cSrcweir OOrderColumn::OOrderColumn( const Reference<XPropertySet>& _xColumn, sal_Bool _bCase, sal_Bool _bAscending )
243*cdf0e10cSrcweir     : connectivity::sdbcx::OColumn(
244*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_NAME))),
245*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPENAME))),
246*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DEFAULTVALUE))),
247*cdf0e10cSrcweir         getString(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_DESCRIPTION))),
248*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISNULLABLE))),
249*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_PRECISION))),
250*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_SCALE))),
251*cdf0e10cSrcweir         getINT32(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TYPE))),
252*cdf0e10cSrcweir         getBOOL(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISAUTOINCREMENT))),
253*cdf0e10cSrcweir         sal_False,
254*cdf0e10cSrcweir         getBOOL(_xColumn->getPropertyValue(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISCURRENCY))),
255*cdf0e10cSrcweir         _bCase
256*cdf0e10cSrcweir     )
257*cdf0e10cSrcweir     ,m_bAscending(_bAscending)
258*cdf0e10cSrcweir     ,m_sTableName( lcl_getColumnTableName( _xColumn ) )
259*cdf0e10cSrcweir {
260*cdf0e10cSrcweir     construct();
261*cdf0e10cSrcweir }
262*cdf0e10cSrcweir 
263*cdf0e10cSrcweir // -------------------------------------------------------------------------
264*cdf0e10cSrcweir OOrderColumn::~OOrderColumn()
265*cdf0e10cSrcweir {
266*cdf0e10cSrcweir }
267*cdf0e10cSrcweir 
268*cdf0e10cSrcweir // -------------------------------------------------------------------------
269*cdf0e10cSrcweir void OOrderColumn::construct()
270*cdf0e10cSrcweir {
271*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_ISASCENDING), PROPERTY_ID_ISASCENDING,
272*cdf0e10cSrcweir         PropertyAttribute::READONLY,  const_cast< sal_Bool* >( &m_bAscending ),    ::getCppuType( reinterpret_cast< sal_Bool* >( NULL ) ) );
273*cdf0e10cSrcweir     registerProperty(OMetaConnection::getPropMap().getNameByIndex(PROPERTY_ID_TABLENAME),   PROPERTY_ID_TABLENAME,
274*cdf0e10cSrcweir         PropertyAttribute::READONLY,  const_cast< ::rtl::OUString* >( &m_sTableName ),  ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
275*cdf0e10cSrcweir }
276*cdf0e10cSrcweir // -----------------------------------------------------------------------------
277*cdf0e10cSrcweir ::cppu::IPropertyArrayHelper* OOrderColumn::createArrayHelper() const
278*cdf0e10cSrcweir {
279*cdf0e10cSrcweir     return doCreateArrayHelper();
280*cdf0e10cSrcweir }
281*cdf0e10cSrcweir // -----------------------------------------------------------------------------
282*cdf0e10cSrcweir ::cppu::IPropertyArrayHelper & SAL_CALL OOrderColumn::getInfoHelper()
283*cdf0e10cSrcweir {
284*cdf0e10cSrcweir     OSL_ENSURE( !isNew(), "OOrderColumn::getInfoHelper: a *new* OrderColumn?" );
285*cdf0e10cSrcweir     return *OOrderColumn_PROP::getArrayHelper();
286*cdf0e10cSrcweir }
287*cdf0e10cSrcweir // -----------------------------------------------------------------------------
288*cdf0e10cSrcweir ::com::sun::star::uno::Sequence< ::rtl::OUString > SAL_CALL OOrderColumn::getSupportedServiceNames(  ) throw(::com::sun::star::uno::RuntimeException)
289*cdf0e10cSrcweir {
290*cdf0e10cSrcweir     ::com::sun::star::uno::Sequence< ::rtl::OUString > aSupported(1);
291*cdf0e10cSrcweir     aSupported[0] = ::rtl::OUString::createFromAscii("com.sun.star.sdb.OrderColumn");
292*cdf0e10cSrcweir 
293*cdf0e10cSrcweir     return aSupported;
294*cdf0e10cSrcweir }
295*cdf0e10cSrcweir // -----------------------------------------------------------------------------
296