1 /************************************************************************* 2 * 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * Copyright 2000, 2010 Oracle and/or its affiliates. 6 * 7 * OpenOffice.org - a multi-platform office productivity suite 8 * 9 * This file is part of OpenOffice.org. 10 * 11 * OpenOffice.org is free software: you can redistribute it and/or modify 12 * it under the terms of the GNU Lesser General Public License version 3 13 * only, as published by the Free Software Foundation. 14 * 15 * OpenOffice.org is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU Lesser General Public License version 3 for more details 19 * (a copy is included in the LICENSE file that accompanied this code). 20 * 21 * You should have received a copy of the GNU Lesser General Public License 22 * version 3 along with OpenOffice.org. If not, see 23 * <http://www.openoffice.org/license.html> 24 * for a copy of the LGPLv3 License. 25 * 26 ************************************************************************/ 27 28 // MARKER(update_precomp.py): autogen include statement, do not remove 29 #include "precompiled_connectivity.hxx" 30 31 #ifdef HSQLDB_DBG 32 #include "accesslog.hxx" 33 #include "hsqldb/HStorageMap.hxx" 34 35 #include <osl/thread.h> 36 37 namespace connectivity { namespace hsqldb 38 { 39 DECLARE_STL_USTRINGACCESS_MAP(FILE *,TDebugStreamMap); 40 TDebugStreamMap& getStreams() 41 { 42 static TDebugStreamMap streams; 43 return streams; 44 } 45 46 //--------------------------------------------------------------------- 47 LogFile::LogFile( JNIEnv* env, jstring streamName, const sal_Char* _pAsciiSuffix ) 48 { 49 m_sFileName = StorageContainer::jstring2ustring(env,streamName); 50 m_sFileName += ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(".")); 51 m_sFileName += ::rtl::OUString::createFromAscii( _pAsciiSuffix ); 52 } 53 54 //--------------------------------------------------------------------- 55 FILE*& LogFile::getLogFile() 56 { 57 FILE*& pLogFile = getStreams()[m_sFileName]; 58 if ( !pLogFile ) 59 { 60 ::rtl::OString sByteLogName = ::rtl::OUStringToOString(m_sFileName,osl_getThreadTextEncoding()); 61 pLogFile = fopen( sByteLogName.getStr(), "a+" ); 62 } 63 return pLogFile; 64 } 65 66 //--------------------------------------------------------------------- 67 void LogFile::writeString( const sal_Char* _pString, bool _bEndLine ) 68 { 69 FILE* pLogFile = getLogFile(); 70 fwrite( _pString, sizeof( *_pString ), strlen( _pString ), pLogFile ); 71 if ( _bEndLine ) 72 fwrite( "\n", sizeof( *_pString ), strlen( "\n" ), pLogFile ); 73 fflush( pLogFile ); 74 } 75 76 //--------------------------------------------------------------------- 77 void LogFile::close() 78 { 79 fclose( getLogFile() ); 80 getLogFile() = NULL; 81 } 82 } } 83 #endif 84