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 #ifndef _TRACE_HXX_ 28 #define _TRACE_HXX_ 29 30 #if defined(DBG_UTIL) 31 32 #include <tools/string.hxx> 33 #include <vos/thread.hxx> 34 #include <vos/mutex.hxx> 35 #include <comphelper/stl_types.hxx> 36 37 38 class Tracer 39 { 40 ByteString m_sBlockDescription; 41 42 DECLARE_STL_STDKEY_MAP( ::vos::OThread::TThreadIdentifier, sal_Int32, MapThreadId2Int ); 43 static MapThreadId2Int s_aThreadIndents; 44 45 static ::vos::OMutex s_aMapSafety; 46 47 public: 48 Tracer(const char* _pBlockDescription); 49 ~Tracer(); 50 51 void TraceString(const char* _pMessage); 52 void TraceString1StringParam(const char* _pMessage, const char* _pParam); 53 }; 54 55 56 #define TRACE_RANGE(range_description) Tracer aTrace(range_description); 57 #define TRACE_RANGE_MESSAGE(message) { aTrace.TraceString(message); } 58 #define TRACE_RANGE_MESSAGE1(message, param) { aTrace.TraceString1StringParam(message, param); } 59 60 #else 61 62 #define TRACE_RANGE(range_description) ; 63 #define TRACE_RANGE_MESSAGE(message) ; 64 #define TRACE_RANGE_MESSAGE1(message, param) ; 65 66 #endif 67 68 #endif // _TRACE_HXX_ 69