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_HSQLDB_ACCESSLOG_HXX
29*cdf0e10cSrcweir #define CONNECTIVITY_HSQLDB_ACCESSLOG_HXX
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #ifdef HSQLDB_DBG
32*cdf0e10cSrcweir 
33*cdf0e10cSrcweir #include <stdio.h>
34*cdf0e10cSrcweir #include <jni.h>
35*cdf0e10cSrcweir #include <rtl/ustring.hxx>
36*cdf0e10cSrcweir #include <rtl/string.hxx>
37*cdf0e10cSrcweir 
38*cdf0e10cSrcweir namespace connectivity { namespace hsqldb
39*cdf0e10cSrcweir {
40*cdf0e10cSrcweir     class LogFile
41*cdf0e10cSrcweir     {
42*cdf0e10cSrcweir     private:
43*cdf0e10cSrcweir         ::rtl::OUString     m_sFileName;
44*cdf0e10cSrcweir 
45*cdf0e10cSrcweir     public:
46*cdf0e10cSrcweir         LogFile( JNIEnv* env, jstring streamName, const sal_Char* _pAsciiSuffix );
47*cdf0e10cSrcweir 
48*cdf0e10cSrcweir     public:
49*cdf0e10cSrcweir                 void    writeString( const sal_Char* _pString, bool _bEndLine = true );
50*cdf0e10cSrcweir                 void    create() { getLogFile(); }
51*cdf0e10cSrcweir         virtual void    close();
52*cdf0e10cSrcweir 
53*cdf0e10cSrcweir     protected:
54*cdf0e10cSrcweir         FILE*&  getLogFile();
55*cdf0e10cSrcweir     };
56*cdf0e10cSrcweir 
57*cdf0e10cSrcweir     class OperationLogFile : public LogFile
58*cdf0e10cSrcweir     {
59*cdf0e10cSrcweir     public:
60*cdf0e10cSrcweir         OperationLogFile( JNIEnv* env, jstring streamName, const sal_Char* _pAsciiSuffix )
61*cdf0e10cSrcweir             :LogFile( env, streamName, ( ::rtl::OString( _pAsciiSuffix ) += ".op" ).getStr() )
62*cdf0e10cSrcweir         {
63*cdf0e10cSrcweir         }
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir         void logOperation( const sal_Char* _pOp )
66*cdf0e10cSrcweir         {
67*cdf0e10cSrcweir             writeString( _pOp, true );
68*cdf0e10cSrcweir         }
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir         void logOperation( const sal_Char* _pOp, jlong _nLongArg )
71*cdf0e10cSrcweir         {
72*cdf0e10cSrcweir             ::rtl::OString sLine( _pOp );
73*cdf0e10cSrcweir             sLine += "( ";
74*cdf0e10cSrcweir             sLine += ::rtl::OString::valueOf( _nLongArg );
75*cdf0e10cSrcweir             sLine += " )";
76*cdf0e10cSrcweir             writeString( sLine.getStr(), true );
77*cdf0e10cSrcweir         }
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir         void logReturn( jlong _nRetVal )
80*cdf0e10cSrcweir         {
81*cdf0e10cSrcweir             ::rtl::OString sLine( " -> " );
82*cdf0e10cSrcweir             sLine += ::rtl::OString::valueOf( _nRetVal );
83*cdf0e10cSrcweir             writeString( sLine.getStr(), true );
84*cdf0e10cSrcweir         }
85*cdf0e10cSrcweir 
86*cdf0e10cSrcweir         void logReturn( jint _nRetVal )
87*cdf0e10cSrcweir         {
88*cdf0e10cSrcweir             ::rtl::OString sLine( " -> " );
89*cdf0e10cSrcweir             sLine += ::rtl::OString::valueOf( _nRetVal );
90*cdf0e10cSrcweir             writeString( sLine.getStr(), true );
91*cdf0e10cSrcweir         }
92*cdf0e10cSrcweir 
93*cdf0e10cSrcweir         virtual void close()
94*cdf0e10cSrcweir         {
95*cdf0e10cSrcweir             writeString( "-------------------------------", true );
96*cdf0e10cSrcweir             writeString( "", true );
97*cdf0e10cSrcweir             LogFile::close();
98*cdf0e10cSrcweir         }
99*cdf0e10cSrcweir     };
100*cdf0e10cSrcweir 
101*cdf0e10cSrcweir     class DataLogFile : public LogFile
102*cdf0e10cSrcweir     {
103*cdf0e10cSrcweir     public:
104*cdf0e10cSrcweir         DataLogFile( JNIEnv* env, jstring streamName, const sal_Char* _pAsciiSuffix )
105*cdf0e10cSrcweir             :LogFile( env, streamName, _pAsciiSuffix )
106*cdf0e10cSrcweir         {
107*cdf0e10cSrcweir         }
108*cdf0e10cSrcweir 
109*cdf0e10cSrcweir         void write( jint value )
110*cdf0e10cSrcweir         {
111*cdf0e10cSrcweir 			fputc( value, getLogFile() );
112*cdf0e10cSrcweir             fflush( getLogFile() );
113*cdf0e10cSrcweir         }
114*cdf0e10cSrcweir 
115*cdf0e10cSrcweir         void write( const sal_Int8* buffer, sal_Int32 bytesRead )
116*cdf0e10cSrcweir         {
117*cdf0e10cSrcweir 			fwrite( buffer, sizeof(sal_Int8), bytesRead, getLogFile() );
118*cdf0e10cSrcweir             fflush( getLogFile() );
119*cdf0e10cSrcweir         }
120*cdf0e10cSrcweir 
121*cdf0e10cSrcweir         sal_Int64 seek( sal_Int64 pos )
122*cdf0e10cSrcweir         {
123*cdf0e10cSrcweir             FILE* pFile = getLogFile();
124*cdf0e10cSrcweir             fseek( pFile, 0, SEEK_END );
125*cdf0e10cSrcweir             if ( ftell( pFile ) < pos )
126*cdf0e10cSrcweir             {
127*cdf0e10cSrcweir                 sal_Int8 filler( 0 );
128*cdf0e10cSrcweir                 while ( ftell( pFile ) < pos )
129*cdf0e10cSrcweir                     fwrite( &filler, sizeof( sal_Int8 ), 1, pFile );
130*cdf0e10cSrcweir                 fflush( pFile );
131*cdf0e10cSrcweir             }
132*cdf0e10cSrcweir             fseek( pFile, pos, SEEK_SET );
133*cdf0e10cSrcweir             return ftell( pFile );
134*cdf0e10cSrcweir         }
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir         sal_Int64 tell()
137*cdf0e10cSrcweir         {
138*cdf0e10cSrcweir             return ftell( getLogFile() );
139*cdf0e10cSrcweir         }
140*cdf0e10cSrcweir     };
141*cdf0e10cSrcweir 
142*cdf0e10cSrcweir } }
143*cdf0e10cSrcweir #endif
144*cdf0e10cSrcweir 
145*cdf0e10cSrcweir #endif // CONNECTIVITY_HSQLDB_ACCESSLOG_HXX
146