00001 #ifndef _XRDOSS_TRACE_H 00002 #define _XRDOSS_TRACE_H 00003 /******************************************************************************/ 00004 /* */ 00005 /* X r d O s s T r a c e . h h */ 00006 /* */ 00007 /* (C) 2003 by the Board of Trustees of the Leland Stanford, Jr., University */ 00008 /* All Rights Reserved */ 00009 /* Produced by Andrew Hanushevsky for Stanford University under contract */ 00010 /* DE-AC02-76-SFO0515 with the Deprtment of Energy */ 00011 /* */ 00012 /* This file is part of the XRootD software suite. */ 00013 /* */ 00014 /* XRootD is free software: you can redistribute it and/or modify it under */ 00015 /* the terms of the GNU Lesser General Public License as published by the */ 00016 /* Free Software Foundation, either version 3 of the License, or (at your */ 00017 /* option) any later version. */ 00018 /* */ 00019 /* XRootD is distributed in the hope that it will be useful, but WITHOUT */ 00020 /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */ 00021 /* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public */ 00022 /* License for more details. */ 00023 /* */ 00024 /* You should have received a copy of the GNU Lesser General Public License */ 00025 /* along with XRootD in a file called COPYING.LESSER (LGPL license) and file */ 00026 /* COPYING (GPL license). If not, see <http://www.gnu.org/licenses/>. */ 00027 /* */ 00028 /* The copyright holder's institutional names and contributor's names may not */ 00029 /* be used to endorse or promote products derived from this software without */ 00030 /* specific prior written permission of the institution or contributor. */ 00031 /******************************************************************************/ 00032 00033 #include "XrdOuc/XrdOucTrace.hh" 00034 00035 // Trace flags 00036 // 00037 #define TRACE_ALL 0x0fff 00038 #define TRACE_Opendir 0x0001 00039 #define TRACE_Open 0x0002 00040 #define TRACE_AIO 0x0004 00041 #define TRACE_Debug 0x0800 00042 00043 #ifndef NODEBUG 00044 00045 #include "XrdSys/XrdSysHeaders.hh" 00046 00047 #define QTRACE(act) OssTrace.What & TRACE_ ## act 00048 00049 #define TRACE(act, x) \ 00050 if (QTRACE(act)) \ 00051 {OssTrace.Beg(epname,tident); cerr <<x; OssTrace.End();} 00052 00053 #define TRACEReturn(type, ecode, msg) \ 00054 {TRACE(type, "err " <<ecode <<msg); return ecode;} 00055 00056 #define DEBUG(y) if (QTRACE(Debug)) \ 00057 {OssTrace.Beg(epname); cerr <<y; OssTrace.End();} 00058 00059 #define EPNAME(x) static const char *epname = x; 00060 00061 #else 00062 00063 #define DEBUG(x) 00064 #define QTRACE(x) 0 00065 #define TRACE(x, y) 00066 #define TRACEReturn(type, ecode, msg) return ecode 00067 #define EPNAME(x) 00068 00069 #endif 00070 #endif