office-gobmx/soltools/testSHL/util/tlog.cxx
Oliver Bolte 0d71cfe214 INTEGRATION: CWS pchfix02 (1.3.30); FILE MERGED
2006/09/01 17:40:18 kaib 1.3.30.1: #i68856# Added header markers and pch files
2006-09-17 10:35:16 +00:00

116 lines
3.2 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: tlog.cxx,v $
*
* $Revision: 1.4 $
*
* last change: $Author: obo $ $Date: 2006-09-17 11:35:16 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_soltools.hxx"
#include "tlog.hxx"
using namespace std;
// <namespace_tstutl>
namespace tstutl {
// <method_initialize>
void tLog::initialize( const ::rtl::OString& name ) {
m_logname = cnvrtPth( name );
m_logfile = new ::osl::File( m_logname );
} // </method_initialize>
// <method_open>
::osl::FileBase::RC tLog::open( sal_Bool append ) {
if ( m_logfile ) {
::osl::FileBase::RC ret;
if ( ! append ) {
ret = ::osl::File::remove( m_logname );
}
if( m_logfile->open( OpenFlag_Write ) == ::osl::FileBase::E_NOENT ) {
ret = m_logfile->open( OpenFlag_Write | OpenFlag_Create );
}
else {
ret = m_logfile->setPos( Pos_End, 0 );
}
return ret;
}
return ( ::osl::FileBase::E_INVAL );
} // </method_open>
// <method_close>
::osl::FileBase::RC tLog::close() {
if ( m_logfile ) {
return m_logfile->close();
}
return ( ::osl::FileBase::E_INVAL );
} // </method_close>
// <method_writeRes>
::osl::FileBase::RC tLog::writeRes( ::rtl::TestResult& oRes, sal_Bool v, sal_Bool xml ) {
::osl::FileBase::RC ret;
sal_Char* ptr = oRes.getName();
ptr = cat( ptr, ";" );
ptr = cat( ptr, oRes.getResult() );
ret = write( cat( ptr, "\n" ), v );
delete [] ptr;
return( ret );
} // </method_writeRes>
// <method_write>
::osl::FileBase::RC tLog::write( const sal_Char* buf, sal_Bool v ) {
if ( ! m_logfile ) {
fprintf( stderr, "%s", buf );
return ( ::osl::FileBase::E_NOENT );
}
sal_uInt64 uBytes=0;
sal_uInt32 len = ln( buf );
const sal_Char* ptr = buf;
if ( v ) {
fprintf( stderr, "%s", buf );
}
return m_logfile->write( buf, len , uBytes );
} // </method_write>
} // </namespace_tstutl>