/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #ifndef INCLUDED_CONNECTIVITY_SOURCE_DRIVERS_EVOAB2_NSTATEMENT_HXX #define INCLUDED_CONNECTIVITY_SOURCE_DRIVERS_EVOAB2_NSTATEMENT_HXX #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "EApi.h" #include #include namespace connectivity { namespace evoab { typedef ::cppu::WeakComponentImplHelper< css::sdbc::XWarningsSupplier , css::sdbc::XCloseable > OCommonStatement_IBase; struct FieldSort { sal_Int32 nField; bool bAscending; FieldSort() : nField(0), bAscending( true ) { } FieldSort( const sal_Int32 _nField, const bool _bAscending ) : nField( _nField ), bAscending( _bAscending ) { } }; typedef ::std::vector< FieldSort > SortDescriptor; enum QueryFilterType { eFilterAlwaysFalse, eFilterNone, eFilterOther }; struct QueryData { private: EBookQuery* pQuery; public: OUString sTable; QueryFilterType eFilterType; ::rtl::Reference< ::connectivity::OSQLColumns > xSelectColumns; SortDescriptor aSortOrder; QueryData() :pQuery( nullptr ) ,sTable() ,eFilterType( eFilterOther ) ,xSelectColumns() ,aSortOrder() { } QueryData( const QueryData& _rhs ) :pQuery( nullptr ) ,sTable() ,eFilterType( eFilterOther ) ,xSelectColumns() ,aSortOrder() { *this = _rhs; } QueryData& operator=( const QueryData& _rhs ) { if ( this == &_rhs ) return *this; setQuery( _rhs.pQuery ); sTable = _rhs.sTable; eFilterType = _rhs.eFilterType; xSelectColumns = _rhs.xSelectColumns; aSortOrder = _rhs.aSortOrder; return *this; } ~QueryData() { setQuery( nullptr ); } EBookQuery* getQuery() const { return pQuery; } void setQuery( EBookQuery* _pQuery ) { if ( pQuery ) e_book_query_unref( pQuery ); pQuery = _pQuery; if ( pQuery ) e_book_query_ref( pQuery ); } }; //************ Class: OCommonStatement // is a base class for the normal statement and for the prepared statement class OCommonStatement; typedef OSubComponent< OCommonStatement, OCommonStatement_IBase > OStatement_CBase; class OCommonStatement :public cppu::BaseMutex ,public OCommonStatement_IBase ,public ::comphelper::OPropertyContainer ,public ::comphelper::OPropertyArrayUsageHelper< OCommonStatement > ,public OStatement_CBase { friend class OSubComponent< OCommonStatement, OCommonStatement_IBase >; private: css::uno::WeakReference< css::sdbc::XResultSet> m_xResultSet; // The last ResultSet created OEvoabConnection *m_pConnection; connectivity::OSQLParser m_aParser; connectivity::OSQLParseTreeIterator m_aSQLIterator; connectivity::OSQLParseNode *m_pParseTree; // OUString m_aCursorName; sal_Int32 m_nMaxFieldSize; sal_Int32 m_nMaxRows; sal_Int32 m_nQueryTimeOut; sal_Int32 m_nFetchSize; sal_Int32 m_nResultSetType; sal_Int32 m_nFetchDirection; sal_Int32 m_nResultSetConcurrency; bool m_bEscapeProcessing; // protected: void disposeResultSet(); // OPropertyArrayUsageHelper virtual ::cppu::IPropertyArrayHelper* createArrayHelper() const override; // OPropertySetHelper virtual ::cppu::IPropertyArrayHelper & SAL_CALL getInfoHelper() override; virtual ~OCommonStatement() override; protected: void parseSql( const OUString& sql, QueryData& _out_rQueryData ); EBookQuery *whereAnalysis( const OSQLParseNode* parseTree ); void orderByAnalysis( const OSQLParseNode* _pOrderByClause, SortDescriptor& _out_rSort ); OUString getTableName(); public: // other methods OEvoabConnection* getOwnConnection() const { return m_pConnection;} using OCommonStatement_IBase::operator css::uno::Reference< css::uno::XInterface >; protected: explicit OCommonStatement( OEvoabConnection* _pConnection ); // OComponentHelper virtual void SAL_CALL disposing() override; // XInterface virtual void SAL_CALL release() throw() override; virtual void SAL_CALL acquire() throw() override; // XInterface virtual css::uno::Any SAL_CALL queryInterface( const css::uno::Type & rType ) throw(css::uno::RuntimeException, std::exception) override; //XTypeProvider virtual css::uno::Sequence< css::uno::Type > SAL_CALL getTypes( ) throw(css::uno::RuntimeException, std::exception) override; // XPropertySet virtual css::uno::Reference< css::beans::XPropertySetInfo > SAL_CALL getPropertySetInfo( ) throw(css::uno::RuntimeException, std::exception) override; // XWarningsSupplier virtual css::uno::Any SAL_CALL getWarnings( ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override; virtual void SAL_CALL clearWarnings( ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override; // XCloseable virtual void SAL_CALL close( ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override; protected: /** will return the EBookQuery representing the statement WHERE condition, or throw Also, all statement dependent members (such as the parser/iterator) will be inited afterwards. */ QueryData impl_getEBookQuery_throw( const OUString& _rSql ); css::uno::Reference< css::sdbc::XResultSet > impl_executeQuery_throw( const OUString& _rSql ); css::uno::Reference< css::sdbc::XResultSet > impl_executeQuery_throw( const QueryData& _rData ); css::uno::Reference< css::sdbc::XConnection > impl_getConnection() { return css::uno::Reference< css::sdbc::XConnection >( m_pConnection ); } OUString impl_getColumnRefColumnName_throw( const ::connectivity::OSQLParseNode& _rColumnRef ); }; typedef ::cppu::ImplHelper2 < css::lang::XServiceInfo , css::sdbc::XStatement > OStatement_IBase; class OStatement :public OCommonStatement ,public OStatement_IBase { protected: virtual ~OStatement() override {} public: explicit OStatement( OEvoabConnection* _pConnection) :OCommonStatement( _pConnection) { } // XInterface virtual css::uno::Any SAL_CALL queryInterface( const css::uno::Type & rType ) throw(css::uno::RuntimeException, std::exception) override; virtual void SAL_CALL acquire() throw() override; virtual void SAL_CALL release() throw() override; // XTypeProvider DECLARE_XTYPEPROVIDER() // XServiceInfo DECLARE_SERVICE_INFO(); // XStatement virtual css::uno::Reference< css::sdbc::XResultSet > SAL_CALL executeQuery( const OUString& sql ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override ; virtual sal_Int32 SAL_CALL executeUpdate( const OUString& sql ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override ; virtual sal_Bool SAL_CALL execute( const OUString& sql ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override ; virtual css::uno::Reference< css::sdbc::XConnection > SAL_CALL getConnection( ) throw(css::sdbc::SQLException, css::uno::RuntimeException, std::exception) override ; }; } } #endif // INCLUDED_CONNECTIVITY_SOURCE_DRIVERS_EVOAB2_NSTATEMENT_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */