1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * This file is part of OpenOffice.org.
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.
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).
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.
26 ************************************************************************/
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_extensions.hxx"
30 #include "logrecord.hxx"
32 /** === begin UNO includes === **/
33 /** === end UNO includes === **/
36 #include <osl/thread.h>
37 #include <osl/diagnose.h>
39 //........................................................................
42 //........................................................................
44 /** === begin UNO using === **/
45 using ::com::sun::star::logging::LogRecord
;
46 using ::com::sun::star::util::DateTime
;
47 /** === end UNO using === **/
49 //====================================================================
51 //====================================================================
52 //--------------------------------------------------------------------
55 /** returns a string representation of the current thread
58 We need a way to retrieve the current UNO thread ID as string,
59 which is issue #i77342#
61 ::rtl::OUString
getCurrentThreadID()
63 oslThreadIdentifier
nThreadID( osl_getThreadIdentifier( NULL
) );
64 return ::rtl::OUString::valueOf( (sal_Int64
)nThreadID
);
68 //--------------------------------------------------------------------
69 LogRecord
createLogRecord( const ::rtl::OUString
& _rLoggerName
, const ::rtl::OUString
& _rClassName
,
70 const ::rtl::OUString
& _rMethodName
, const ::rtl::OUString
& _rMessage
,
71 sal_Int32 _nLogLevel
, oslInterlockedCount _nEventNumber
)
74 osl_getSystemTime( &aTimeValue
);
76 oslDateTime aDateTime
;
77 OSL_VERIFY( osl_getDateTimeFromTimeValue( &aTimeValue
, &aDateTime
) );
80 aTimeStamp
.Year
= aDateTime
.Year
;
81 aTimeStamp
.Month
= aDateTime
.Month
;
82 aTimeStamp
.Day
= aDateTime
.Day
;
83 aTimeStamp
.Hours
= aDateTime
.Hours
;
84 aTimeStamp
.Minutes
= aDateTime
.Minutes
;
85 aTimeStamp
.Seconds
= aDateTime
.Seconds
;
86 aTimeStamp
.HundredthSeconds
= ::sal::static_int_cast
< sal_Int16
>( aDateTime
.NanoSeconds
/ 10000000 );
100 //........................................................................
101 } // namespace logging
102 //........................................................................