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 27cdf0e10cSrcweir #ifdef HSQLDB_DBG 28cdf0e10cSrcweir #include "accesslog.hxx" 29cdf0e10cSrcweir #include "hsqldb/HStorageMap.hxx" 30cdf0e10cSrcweir 31cdf0e10cSrcweir #include <osl/thread.h> 32cdf0e10cSrcweir 33cdf0e10cSrcweir namespace connectivity { namespace hsqldb 34cdf0e10cSrcweir { 35cdf0e10cSrcweir DECLARE_STL_USTRINGACCESS_MAP(FILE *,TDebugStreamMap); getStreams()36cdf0e10cSrcweir TDebugStreamMap& getStreams() 37cdf0e10cSrcweir { 38cdf0e10cSrcweir static TDebugStreamMap streams; 39cdf0e10cSrcweir return streams; 40cdf0e10cSrcweir } 41cdf0e10cSrcweir 42cdf0e10cSrcweir //--------------------------------------------------------------------- LogFile(JNIEnv * env,jstring streamName,const sal_Char * _pAsciiSuffix)43cdf0e10cSrcweir LogFile::LogFile( JNIEnv* env, jstring streamName, const sal_Char* _pAsciiSuffix ) 44cdf0e10cSrcweir { 45cdf0e10cSrcweir m_sFileName = StorageContainer::jstring2ustring(env,streamName); 46cdf0e10cSrcweir m_sFileName += ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(".")); 47cdf0e10cSrcweir m_sFileName += ::rtl::OUString::createFromAscii( _pAsciiSuffix ); 48cdf0e10cSrcweir } 49cdf0e10cSrcweir 50cdf0e10cSrcweir //--------------------------------------------------------------------- getLogFile()51cdf0e10cSrcweir FILE*& LogFile::getLogFile() 52cdf0e10cSrcweir { 53cdf0e10cSrcweir FILE*& pLogFile = getStreams()[m_sFileName]; 54cdf0e10cSrcweir if ( !pLogFile ) 55cdf0e10cSrcweir { 56cdf0e10cSrcweir ::rtl::OString sByteLogName = ::rtl::OUStringToOString(m_sFileName,osl_getThreadTextEncoding()); 57cdf0e10cSrcweir pLogFile = fopen( sByteLogName.getStr(), "a+" ); 58cdf0e10cSrcweir } 59cdf0e10cSrcweir return pLogFile; 60cdf0e10cSrcweir } 61cdf0e10cSrcweir 62cdf0e10cSrcweir //--------------------------------------------------------------------- writeString(const sal_Char * _pString,bool _bEndLine)63cdf0e10cSrcweir void LogFile::writeString( const sal_Char* _pString, bool _bEndLine ) 64cdf0e10cSrcweir { 65cdf0e10cSrcweir FILE* pLogFile = getLogFile(); 66cdf0e10cSrcweir fwrite( _pString, sizeof( *_pString ), strlen( _pString ), pLogFile ); 67cdf0e10cSrcweir if ( _bEndLine ) 68cdf0e10cSrcweir fwrite( "\n", sizeof( *_pString ), strlen( "\n" ), pLogFile ); 69cdf0e10cSrcweir fflush( pLogFile ); 70cdf0e10cSrcweir } 71cdf0e10cSrcweir 72cdf0e10cSrcweir //--------------------------------------------------------------------- close()73cdf0e10cSrcweir void LogFile::close() 74cdf0e10cSrcweir { 75cdf0e10cSrcweir fclose( getLogFile() ); 76cdf0e10cSrcweir getLogFile() = NULL; 77cdf0e10cSrcweir } 78cdf0e10cSrcweir } } 79cdf0e10cSrcweir #endif 80