masterfix DEV300: #i10000# build fix
[LibreOffice.git] / extensions / source / logging / logrecord.cxx
blobcac9fe79e4594bbddffc44a579346de4189b818e
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 === **/
35 #include <osl/time.h>
36 #include <osl/thread.h>
37 #include <osl/diagnose.h>
39 //........................................................................
40 namespace logging
42 //........................................................................
44 /** === begin UNO using === **/
45 using ::com::sun::star::logging::LogRecord;
46 using ::com::sun::star::util::DateTime;
47 /** === end UNO using === **/
49 //====================================================================
50 //= helper
51 //====================================================================
52 //--------------------------------------------------------------------
53 namespace
55 /** returns a string representation of the current thread
57 @todo
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 )
73 TimeValue aTimeValue;
74 osl_getSystemTime( &aTimeValue );
76 oslDateTime aDateTime;
77 OSL_VERIFY( osl_getDateTimeFromTimeValue( &aTimeValue, &aDateTime ) );
79 DateTime aTimeStamp;
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 );
88 return LogRecord(
89 _rLoggerName,
90 _rClassName,
91 _rMethodName,
92 _rMessage,
93 aTimeStamp,
94 _nEventNumber,
95 getCurrentThreadID(),
96 _nLogLevel
100 //........................................................................
101 } // namespace logging
102 //........................................................................