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 #ifndef CONNECTIVITY_CONNECTIONLOG_HXX 29*cdf0e10cSrcweir #define CONNECTIVITY_CONNECTIONLOG_HXX 30*cdf0e10cSrcweir 31*cdf0e10cSrcweir /** === begin UNO includes === **/ 32*cdf0e10cSrcweir #include <com/sun/star/logging/LogLevel.hpp> 33*cdf0e10cSrcweir /** === end UNO includes === **/ 34*cdf0e10cSrcweir 35*cdf0e10cSrcweir #include <rtl/ustring.hxx> 36*cdf0e10cSrcweir 37*cdf0e10cSrcweir // Strange enough, GCC requires the following forward declarations of the various 38*cdf0e10cSrcweir // convertLogArgToString flavors to be *before* the inclusion of comphelper/logging.hxx 39*cdf0e10cSrcweir 40*cdf0e10cSrcweir namespace com { namespace sun { namespace star { namespace util 41*cdf0e10cSrcweir { 42*cdf0e10cSrcweir struct Date; 43*cdf0e10cSrcweir struct Time; 44*cdf0e10cSrcweir struct DateTime; 45*cdf0e10cSrcweir } } } } 46*cdf0e10cSrcweir 47*cdf0e10cSrcweir //........................................................................ 48*cdf0e10cSrcweir namespace comphelper { namespace log { namespace convert 49*cdf0e10cSrcweir { 50*cdf0e10cSrcweir //........................................................................ 51*cdf0e10cSrcweir 52*cdf0e10cSrcweir // helpers for logging more data types than are defined in comphelper/logging.hxx 53*cdf0e10cSrcweir ::rtl::OUString convertLogArgToString( const ::com::sun::star::util::Date& _rDate ); 54*cdf0e10cSrcweir ::rtl::OUString convertLogArgToString( const ::com::sun::star::util::Time& _rTime ); 55*cdf0e10cSrcweir ::rtl::OUString convertLogArgToString( const ::com::sun::star::util::DateTime& _rDateTime ); 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir //........................................................................ 58*cdf0e10cSrcweir } } } 59*cdf0e10cSrcweir //........................................................................ 60*cdf0e10cSrcweir 61*cdf0e10cSrcweir #include <comphelper/logging.hxx> 62*cdf0e10cSrcweir 63*cdf0e10cSrcweir namespace connectivity 64*cdf0e10cSrcweir { 65*cdf0e10cSrcweir namespace LogLevel = ::com::sun::star::logging::LogLevel; 66*cdf0e10cSrcweir } 67*cdf0e10cSrcweir 68*cdf0e10cSrcweir //........................................................................ 69*cdf0e10cSrcweir namespace connectivity { namespace java { namespace sql { 70*cdf0e10cSrcweir //........................................................................ 71*cdf0e10cSrcweir 72*cdf0e10cSrcweir //==================================================================== 73*cdf0e10cSrcweir //= ConnectionLog 74*cdf0e10cSrcweir //==================================================================== 75*cdf0e10cSrcweir typedef ::comphelper::ResourceBasedEventLogger ConnectionLog_Base; 76*cdf0e10cSrcweir class ConnectionLog : public ConnectionLog_Base 77*cdf0e10cSrcweir { 78*cdf0e10cSrcweir public: 79*cdf0e10cSrcweir enum ObjectType 80*cdf0e10cSrcweir { 81*cdf0e10cSrcweir CONNECTION = 0, 82*cdf0e10cSrcweir STATEMENT, 83*cdf0e10cSrcweir RESULTSET, 84*cdf0e10cSrcweir 85*cdf0e10cSrcweir ObjectTypeCount = RESULTSET + 1 86*cdf0e10cSrcweir }; 87*cdf0e10cSrcweir 88*cdf0e10cSrcweir private: 89*cdf0e10cSrcweir const sal_Int32 m_nObjectID; 90*cdf0e10cSrcweir 91*cdf0e10cSrcweir public: 92*cdf0e10cSrcweir /// will construct an instance of ObjectType CONNECTION 93*cdf0e10cSrcweir ConnectionLog( const ::comphelper::ResourceBasedEventLogger& _rDriverLog ); 94*cdf0e10cSrcweir /// will create an instance with the same object ID / ObjectType as a given source instance 95*cdf0e10cSrcweir ConnectionLog( const ConnectionLog& _rSourceLog ); 96*cdf0e10cSrcweir /// will create an instance of arbitrary ObjectType 97*cdf0e10cSrcweir ConnectionLog( const ConnectionLog& _rSourceLog, ObjectType _eType ); 98*cdf0e10cSrcweir 99*cdf0e10cSrcweir sal_Int32 getObjectID() const { return m_nObjectID; } 100*cdf0e10cSrcweir 101*cdf0e10cSrcweir /// logs a given message, without any arguments, or source class/method names 102*cdf0e10cSrcweir bool log( const sal_Int32 _nLogLevel, const sal_Int32 _nMessageResID ) 103*cdf0e10cSrcweir { 104*cdf0e10cSrcweir return ConnectionLog_Base::log( _nLogLevel, _nMessageResID, m_nObjectID ); 105*cdf0e10cSrcweir } 106*cdf0e10cSrcweir 107*cdf0e10cSrcweir template< typename ARGTYPE1 > 108*cdf0e10cSrcweir bool log( const sal_Int32 _nLogLevel, const sal_Int32 _nMessageResID, ARGTYPE1 _argument1 ) const 109*cdf0e10cSrcweir { 110*cdf0e10cSrcweir return ConnectionLog_Base::log( _nLogLevel, _nMessageResID, m_nObjectID, _argument1 ); 111*cdf0e10cSrcweir } 112*cdf0e10cSrcweir 113*cdf0e10cSrcweir template< typename ARGTYPE1, typename ARGTYPE2 > 114*cdf0e10cSrcweir bool log( const sal_Int32 _nLogLevel, const sal_Int32 _nMessageResID, ARGTYPE1 _argument1, ARGTYPE2 _argument2 ) const 115*cdf0e10cSrcweir { 116*cdf0e10cSrcweir return ConnectionLog_Base::log( _nLogLevel, _nMessageResID, m_nObjectID, _argument1, _argument2 ); 117*cdf0e10cSrcweir } 118*cdf0e10cSrcweir 119*cdf0e10cSrcweir template< typename ARGTYPE1, typename ARGTYPE2, typename ARGTYPE3 > 120*cdf0e10cSrcweir bool log( const sal_Int32 _nLogLevel, const sal_Int32 _nMessageResID, ARGTYPE1 _argument1, ARGTYPE2 _argument2, ARGTYPE3 _argument3 ) const 121*cdf0e10cSrcweir { 122*cdf0e10cSrcweir return ConnectionLog_Base::log( _nLogLevel, _nMessageResID, m_nObjectID, _argument1, _argument2, _argument3 ); 123*cdf0e10cSrcweir } 124*cdf0e10cSrcweir 125*cdf0e10cSrcweir template< typename ARGTYPE1, typename ARGTYPE2, typename ARGTYPE3, typename ARGTYPE4 > 126*cdf0e10cSrcweir bool log( const sal_Int32 _nLogLevel, const sal_Int32 _nMessageResID, ARGTYPE1 _argument1, ARGTYPE2 _argument2, ARGTYPE3 _argument3, ARGTYPE4 _argument4 ) const 127*cdf0e10cSrcweir { 128*cdf0e10cSrcweir return ConnectionLog_Base::log( _nLogLevel, _nMessageResID, m_nObjectID, _argument1, _argument2, _argument3, _argument4 ); 129*cdf0e10cSrcweir } 130*cdf0e10cSrcweir 131*cdf0e10cSrcweir template< typename ARGTYPE1, typename ARGTYPE2, typename ARGTYPE3, typename ARGTYPE4, typename ARGTYPE5 > 132*cdf0e10cSrcweir bool log( const sal_Int32 _nLogLevel, const sal_Int32 _nMessageResID, ARGTYPE1 _argument1, ARGTYPE2 _argument2, ARGTYPE3 _argument3, ARGTYPE4 _argument4, ARGTYPE5 _argument5 ) const 133*cdf0e10cSrcweir { 134*cdf0e10cSrcweir return ConnectionLog_Base::log( _nLogLevel, _nMessageResID, m_nObjectID, _argument1, _argument2, _argument3, _argument4, _argument5 ); 135*cdf0e10cSrcweir } 136*cdf0e10cSrcweir }; 137*cdf0e10cSrcweir 138*cdf0e10cSrcweir //........................................................................ 139*cdf0e10cSrcweir } } } // namespace connectivity::java::sql 140*cdf0e10cSrcweir //........................................................................ 141*cdf0e10cSrcweir 142*cdf0e10cSrcweir #endif // CONNECTIVITY_CONNECTIONLOG_HXX 143