stif/TestServer/inc/Logging.h
author Stefan Karlsson <stefan.karlsson@nokia.com>
Sun, 28 Mar 2010 16:41:07 +0100
branchCompilerCompatibility
changeset 10 6c5f86e4c374
parent 0 a03f92240627
permissions -rw-r--r--
Fixed "extra qualification" syntax errors.

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
* 
* Description: This file contains the CPrintQueue and 
* CPrintQueueItem class definitions.
*
*/

#ifndef LOGGINGDEFS_H
#define LOGGINGDEFS_H

//  INCLUDES
#include <e32std.h>
#include <e32base.h>


// CONSTANTS
const TUint KError           = 0x1;
const TUint KInit            = 0x2;
const TUint KThreadOperation = 0x4;
const TUint KRunTestCase     = 0x8;
const TUint KPrint           = 0x10;
const TUint KMessage         = 0x20;
const TUint KVerbose         = 0x40;
const TUint KAlways          = 0xFFFFFFFF;
const TUint KDebugLevel      = ( KMessage | KInit | KError );

// MACROS
#define __TRACING_ENABLED

// Define USE_RDEBUG to use RDebug::Print for logging
//#define USE_RDEBUG

// Define USE_LOGGER to use logger for logging
#define USE_LOGGER

#ifdef __TRACING_ENABLED

    // TRACE macro is used in server thread
    
    // Disable conditional expression is constant -warning
    #pragma warning( disable : 4127 )

    // Using logger and not RDebug
    #if defined (USE_LOGGER) && !defined (USE_RDEBUG)
    #define __TRACE(level,p) if ( (level) & KDebugLevel) { ((CStifLogger*) Dll::Tls())->Log p; }
    #endif

    // Using RDebug and not Logger
    #if defined (USE_RDEBUG) && !defined (USE_LOGGER)
    #define __TRACE(level,p) if ( (level) & KDebugLevel) { RDebug::Print p; }
    #endif

    // Using Logger and RDebug
    #if defined (USE_RDEBUG) && defined (USE_LOGGER)
    #define __TRACE(level,p) if ( (level) & KDebugLevel) {\
    ((CStifLogger*) Dll::Tls())->Log p;\
    RDebug::Print p;\
    }
    #endif

    // Not using RDebug and not using logger
    #if !defined(USE_RDEBUG) && !defined (USE_LOGGER)
    #define __TRACE(level,p);
    #endif
    
    #define __RDEBUG(x) if( KVerbose & KDebugLevel){ RDebug::Print x ; }

#else
    // No tracing
    #define __TRACE(level,p);
    
    #define  __RDEBUG(x)
#endif


// DATA TYPES

// FUNCTION PROTOTYPES

// FORWARD DECLARATIONS

// CLASS DECLARATION

#endif // LOGGINGDEFS_H

// End of File