stif/Logger/src/StifLogger.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 01:57:15 +0200
changeset 0 a03f92240627
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* 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 module contains implementation of CStifLogger 
* class member functions.
*
*/

// INCLUDE FILES
#include <e32std.h>
#include "StifLogger.h"
#include "TxtLogger.h"
#include "HtmlLogger.h"
#include "DataLogger.h"
#include "LoggerTracing.h"
#include "LoggerOverFlow.h"
#include "SettingServerClient.h"

// EXTERNAL DATA STRUCTURES
// None

// EXTERNAL FUNCTION PROTOTYPES  
// None

// CONSTANTS
// None

// MACROS
// None

// LOCAL CONSTANTS AND MACROS
// None

// MODULE DATA STRUCTURES
// None

// LOCAL FUNCTION PROTOTYPES
// None

// FORWARD DECLARATIONS
// None

// ==================== LOCAL FUNCTIONS =======================================
// None

// ================= MEMBER FUNCTIONS =========================================

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: CStifLogger

    Description: Default constructor

    C++ default constructor can NOT contain any code, that
    might leave.

    Parameters: None
    
    Return Values: None

    Errors/Exceptions: None

    Status: Approved

-------------------------------------------------------------------------------
*/
CStifLogger::CStifLogger()
    {

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: NewL

    Description: Two-phased constructor.

    Parameters: const TDesC& aTestPath: in: Path to logged information
                const TDesC& aTestFile: in: Log name for information
                TLoggerType aLoggerType: in: Log file type(txt, html,
                                             data)
                TOutput aOutput: in: Output source(File)
                TBool aOverWrite: in: Indicator to file overwrite
                TBool aWithTimeStamp: in: Indicator to time stamp
                TBool aWithLineBreak: in: Indicator to line break
                TBool aWithEventRanking: in: Indicator to event ranking
                TBool aThreadIdToLogFile: in: Indicator to thread id adding to
                                              end of the log file
                TBool aCreateLogDir: in: Indicator to directory creation
                TInt  aStaticBufferSize
                TBool aUnicode: in: Indicator if file has to be in unicode format

    Return Values: CStifLogger* logger: pointer to CStifLogger object

    Errors/Exceptions: Leaves if aTestPath or aTestFile length is over KMaxName
                       Leaves if called serv.Connect() method fails
                       Leaves if called CHtmlLogger::NewL method fails
                       Leaves if called CDataLogger::NewL method fails
                       Leaves if called CTxtLogger::NewL method fails

    Status: Proposal

-------------------------------------------------------------------------------
*/
EXPORT_C CStifLogger* CStifLogger::NewL( const TDesC& aTestPath,
                                            const TDesC& aTestFile,
                                            TLoggerType aLoggerType,
                                            TOutput aOutput,
                                            TBool aOverWrite,
                                            TBool aWithTimeStamp,
                                            TBool aWithLineBreak,
                                            TBool aWithEventRanking,
                                            TBool aThreadIdToLogFile,
                                            TBool aCreateLogDir,
                                            TInt  aStaticBufferSize,
                                            TBool aUnicode )
    {
    if( KMaxName < aTestPath.Length() || KMaxName < aTestFile.Length() )
        {
        User::Leave( KErrArgument );
        }

    // Handle to Setting server.
    RSettingServer settingServer;
    // Connect to the Setting server and create session
    TInt ret = settingServer.Connect();
    if ( ret != KErrNone )
        {
        User::Leave( ret );
        }
    // Struct to StifLogger settigs.
    TLoggerSettings loggerSettings; 
    // Parse StifLogger defaults from STIF initialization file.
    ret = settingServer.GetLoggerSettings( loggerSettings );
    if ( ret != KErrNone )
        {
        User::Leave( ret );
        } 

    TName testPath = aTestPath;
    TName testFile = aTestFile;

    // Take in use the overwrite parameters
    OverwriteLoggerSettings( loggerSettings, testPath, testFile, aLoggerType,
                                aOutput, aOverWrite, aWithTimeStamp,
                                aWithLineBreak, aWithEventRanking,
                                aThreadIdToLogFile, aCreateLogDir,
                                aUnicode );

    // Close Setting server session
    settingServer.Close();

    // Html file logging
    if ( aLoggerType == EHtml )
        {
        // Create CHtmlLogger object logger
        CHtmlLogger* logger = CHtmlLogger::NewL( testPath,
                                                    testFile,
                                                    aLoggerType,
                                                    aOutput,
                                                    aOverWrite,
                                                    aWithTimeStamp,
                                                    aWithLineBreak,
                                                    aWithEventRanking,
                                                    aThreadIdToLogFile,
                                                    aCreateLogDir,
                                                    aStaticBufferSize,
                                                    aUnicode );
        return (CStifLogger*)logger;
        }
    // Data file
    else if ( aLoggerType == EData )
        {
        // Create CDataLogger object logger
        CDataLogger* logger = CDataLogger::NewL( testPath,
                                                    testFile,
                                                    aLoggerType,
                                                    aOutput,
                                                    aOverWrite,
                                                    aWithTimeStamp,
                                                    aWithLineBreak,
                                                    aWithEventRanking,
                                                    aThreadIdToLogFile,
                                                    aCreateLogDir,
                                                    aStaticBufferSize,
                                                    aUnicode );
        return (CStifLogger*)logger;
        }
    // For default: text file logging
    else
        {
        // Create CTxtLogger object logger
        CTxtLogger* logger = CTxtLogger::NewL( testPath,
                                                testFile,
                                                aLoggerType,
                                                aOutput,
                                                aOverWrite,
                                                aWithTimeStamp,
                                                aWithLineBreak,
                                                aWithEventRanking,
                                                aThreadIdToLogFile,
                                                aCreateLogDir,
                                                aStaticBufferSize,
                                                aUnicode );
        return (CStifLogger*)logger;
        }

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: NewL

    Description: Two-phased constructor.

    TestEngine's and TestServer's are friend. For TestEngine's and
    TestServer's StifLogger creation.

    Parameters: const TDesC& aTestPath: in: Path to logged information
                const TDesC& aTestFile: in: Log name for information
                TLoggerSettings& aLoggerSettings: in: Struct for StifLogger
                                                      settigs

    Return Values: CStifLogger* logger: pointer to CStifLogger object

    Errors/Exceptions:  Leaves if called CHtmlLogger::NewL method fails
                        Leaves if called CDataLogger::NewL method fails
                        Leaves if called CTxtLogger::NewL method fails

    Status: Proposal

-------------------------------------------------------------------------------
*/
EXPORT_C CStifLogger* CStifLogger::NewL( const TDesC& aTestPath,
                                            const TDesC& aTestFile,
                                            TLoggerSettings& aLoggerSettings )
    {
    TInt cpu( 0 );
    HAL::Get( HALData::ECPU, cpu );

    // HW environment
    if ( cpu == HALData::ECPU_ARM )
        {
        // Html file logging
        if ( aLoggerSettings.iHardwareFormat == EHtml )
            {
            // Create CHtmlLogger object logger
            CHtmlLogger* logger = CHtmlLogger::NewL( aTestPath,
                                    aTestFile,
                                    aLoggerSettings.iHardwareFormat,
                                    aLoggerSettings.iHardwareOutput,
                                    aLoggerSettings.iOverwrite,
                                    aLoggerSettings.iTimeStamp,
                                    aLoggerSettings.iLineBreak,
                                    aLoggerSettings.iEventRanking,
                                    aLoggerSettings.iThreadId,
                                    aLoggerSettings.iCreateLogDirectories,
                                    0,
                                    aLoggerSettings.iUnicode );
            return (CStifLogger*)logger;
            }
        // Data file
        else if ( aLoggerSettings.iHardwareFormat == EData )
            {
            // Create CDataLogger object logger
            CDataLogger* logger = CDataLogger::NewL( aTestPath,
                                    aTestFile,
                                    aLoggerSettings.iHardwareFormat,
                                    aLoggerSettings.iHardwareOutput,
                                    aLoggerSettings.iOverwrite,
                                    aLoggerSettings.iTimeStamp,
                                    aLoggerSettings.iLineBreak,
                                    aLoggerSettings.iEventRanking,
                                    aLoggerSettings.iThreadId,
                                    aLoggerSettings.iCreateLogDirectories,
                                    0,
                                    aLoggerSettings.iUnicode );
            return (CStifLogger*)logger;
            }
        // For default: text file logging
        else
            {
            // Create CTxtLogger object logger
            CTxtLogger* logger = CTxtLogger::NewL( aTestPath,
                                    aTestFile,
                                    aLoggerSettings.iHardwareFormat,
                                    aLoggerSettings.iHardwareOutput,
                                    aLoggerSettings.iOverwrite,
                                    aLoggerSettings.iTimeStamp,
                                    aLoggerSettings.iLineBreak,
                                    aLoggerSettings.iEventRanking,
                                    aLoggerSettings.iThreadId,
                                    aLoggerSettings.iCreateLogDirectories,
                                    0,
                                    aLoggerSettings.iUnicode );
            return (CStifLogger*)logger;
            }
        } // End of HW environment branch

    // Wins environment ( cpu == HALData::ECPU_X86 )
    else
        {
        // Html file logging
        if ( aLoggerSettings.iEmulatorFormat == EHtml )
            {
            // Create CHtmlLogger object logger
            CHtmlLogger* logger = CHtmlLogger::NewL( aTestPath,
                                    aTestFile,
                                    aLoggerSettings.iEmulatorFormat,
                                    aLoggerSettings.iEmulatorOutput,
                                    aLoggerSettings.iOverwrite,
                                    aLoggerSettings.iTimeStamp,
                                    aLoggerSettings.iLineBreak,
                                    aLoggerSettings.iEventRanking,
                                    aLoggerSettings.iThreadId,
                                    aLoggerSettings.iCreateLogDirectories,
                                    0,
                                    aLoggerSettings.iUnicode );
            return (CStifLogger*)logger;
            }
        // Data file
        else if ( aLoggerSettings.iEmulatorFormat == EData )
            {
            // Create CDataLogger object logger
            CDataLogger* logger = CDataLogger::NewL( aTestPath,
                                    aTestFile,
                                    aLoggerSettings.iEmulatorFormat,
                                    aLoggerSettings.iEmulatorOutput,
                                    aLoggerSettings.iOverwrite,
                                    aLoggerSettings.iTimeStamp,
                                    aLoggerSettings.iLineBreak,
                                    aLoggerSettings.iEventRanking,
                                    aLoggerSettings.iThreadId,
                                    aLoggerSettings.iCreateLogDirectories,
                                    0,
                                    aLoggerSettings.iUnicode );
            return (CStifLogger*)logger;
            }
        // For default: text file logging
        else
            {
            // Create CTxtLogger object logger
            CTxtLogger* logger = CTxtLogger::NewL( aTestPath,
                                    aTestFile,
                                    aLoggerSettings.iEmulatorFormat,
                                    aLoggerSettings.iEmulatorOutput,
                                    aLoggerSettings.iOverwrite,
                                    aLoggerSettings.iTimeStamp,
                                    aLoggerSettings.iLineBreak,
                                    aLoggerSettings.iEventRanking,
                                    aLoggerSettings.iThreadId,
                                    aLoggerSettings.iCreateLogDirectories,
                                    0,
                                    aLoggerSettings.iUnicode );
            return (CStifLogger*)logger;
            }
        } // End of WINS environment branch

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: ~CStifLogger

    Description: Destructor

    Parameters: None

    Return Values: None

    Errors/Exceptions: None

    Status: Approved

-------------------------------------------------------------------------------
*/
CStifLogger::~CStifLogger()
    {

    delete iOutput;
    iOutput = 0;
    
    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: OverwriteLoggerSettings

    Description: Local CStifLogger's method for StifLogger settings
                 overwriting.

    Overwrite parameters may set in TestFramework.ini file.

    Parameters: TLoggerSettings& aLoggerSettings: inout; Overwrite parameters
                TName& aTestPath: inout: Path to logged information
                TName& aTestFile: inout: Log file name for information
                TLoggerType& aLoggerType: inout: Log file type(txt, html, data)
                TOutput& aOutput: inout: Output source(File)
                TBool& aOverWrite: inout: Indicator to file overwrite
                TBool& aWithTimeStamp: inout: Indicator to time stamp
                TBool& aWithLineBreak: inout: Indicator to line break
                TBool& aWithEventRanking: inout: Indicator to event ranking
                TBool& aThreadIdToLogFile: inout: Indicator to thread id adding to
                                                  end of the log file
                TBool& aCreateLogDir: inout: Indicator to directory creation
                TBool& aUnicode: inout: Indicator if log will be written to file in unicode format
    
    Return Values: None

    Errors/Exceptions: None 

    Status: Proposal

-------------------------------------------------------------------------------
*/
void CStifLogger::OverwriteLoggerSettings( TLoggerSettings& aLoggerSettings,
                                            TName& aTestPath,
                                            TName& aTestFile,
                                            TLoggerType& aLoggerType,
                                            TOutput& aOutput,
                                            TBool& aOverWrite,
                                            TBool& aWithTimeStamp,
                                            TBool& aWithLineBreak,
                                            TBool& aWithEventRanking,
                                            TBool& aThreadIdToLogFile,
                                            TBool& aCreateLogDir,
                                            TBool& aUnicode )
    {
    // Which environment is in use
    TInt cpu( 0 );

    // Indicator is file type remove acceptable operation
    TBool removeFileType( EFalse );

    // Get environment
    HAL::Get( HALData::ECPU, cpu );

    // HW environment
    if ( cpu == HALData::ECPU_ARM )
        {
        TInt pathLen = aTestPath.Length() + 
                        aLoggerSettings.iHardwarePath.Length();

        // Check that path overwrite setting is defined and length is legal
        if( aLoggerSettings.iIsDefined.iHwPath && pathLen < KMaxName )
            {
            TName newPath;
            newPath = aLoggerSettings.iHardwarePath;
            // Check is '\' the last character
            TInt ret( 0 );
            ret = newPath.LocateReverse( 92 );
            // Is '\' character founded
            if( ret != KErrNotFound )
                {
                // Is '\' last character
                if( ret == ( newPath.Length() - 1 ) )
                    {
                    // delete last '\'
                    newPath.Delete( 
                        ( aLoggerSettings.iHardwarePath.Length() -1 ), 1 );
                    }
                }
            // Removes drive letter if given and appends implemented path 
            TParse parse;
            parse.Set( aTestPath, NULL, NULL );
            // Path() return value starts with '\'
            newPath.Append( parse.Path() );
            aTestPath = newPath;
            }
        if( aLoggerSettings.iIsDefined.iHwFormat )
            {
            aLoggerType = aLoggerSettings.iHardwareFormat;
            // Remove file type if it is set
            removeFileType = ETrue;
            }
        if( aLoggerSettings.iIsDefined.iHwOutput )
            {
            aOutput = aLoggerSettings.iHardwareOutput;
            }
        }

    // Wins environment ( cpu == HALData::ECPU_X86 )
    else
        {
        TInt pathLen = aTestPath.Length() + 
                        aLoggerSettings.iEmulatorPath.Length();

        // Check that path overwrite setting is defined and length is legal
        if( aLoggerSettings.iIsDefined.iPath  && pathLen < KMaxName )
            {
            TName newPath;
            newPath = aLoggerSettings.iEmulatorPath;
            // Check is '\' the last character
            TInt ret( 0 );
            ret = newPath.LocateReverse( 92 );
            // Is '\' character founded
            if( ret != KErrNotFound )
                {
                // Is '\' last character
                if( ret == ( newPath.Length() - 1 ) )
                    {
                    // delete last '\'
                    newPath.Delete( 
                        ( aLoggerSettings.iEmulatorPath.Length() -1 ), 1 );
                    }
                }
            // Removes drive letter if given and appends implemented path
            TParse parse;
            parse.Set( aTestPath, NULL, NULL );
            // Path() return value starts with '\'
            newPath.Append( parse.Path() );
            aTestPath = newPath;
            }
        if( aLoggerSettings.iIsDefined.iFormat )
            {
            aLoggerType = aLoggerSettings.iEmulatorFormat;
            // Remove file type if it is set
            removeFileType = ETrue;
            }
        if( aLoggerSettings.iIsDefined.iOutput )
            {
            aOutput = aLoggerSettings.iEmulatorOutput;
            }
        }

    // Rest of the overwrite values
    if( aLoggerSettings.iIsDefined.iOverwrite )
        {
        aOverWrite = aLoggerSettings.iOverwrite;
        }
    if( aLoggerSettings.iIsDefined.iTimeStamp )
        {
        aWithTimeStamp = aLoggerSettings.iTimeStamp;
        }
    if( aLoggerSettings.iIsDefined.iLineBreak )
        {
        aWithLineBreak = aLoggerSettings.iLineBreak;
        }
    if( aLoggerSettings.iIsDefined.iEventRanking )
        {
        aWithEventRanking = aLoggerSettings.iEventRanking;
        }
    if( aLoggerSettings.iIsDefined.iThreadId )
        {
        aThreadIdToLogFile = aLoggerSettings.iThreadId;
        }
    if( aLoggerSettings.iIsDefined.iCreateLogDir )
        {
        aCreateLogDir = aLoggerSettings.iCreateLogDirectories;
        }
    if( aLoggerSettings.iIsDefined.iUnicode )
        {
        aUnicode = aLoggerSettings.iUnicode;
        }

    // Remove file type if allowed and if file type is set to filename
    if( removeFileType )
        {
        // Remove file type '.XXX' from file name if exist
        if( aTestFile.Find( _L( "." ) ) )
            {
            TParse parse;
            parse.Set( aTestFile, NULL, NULL );
            // Type length
            TInt length( 0 );
            // '.XXX'
            length = parse.Ext().Length();
            // Delete type
            aTestFile.Delete ( aTestFile.Length()-length, length );
            }
        }

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 16 bit information.

    This log method accepts only one parameters

    Parameters: const TDesC aLogInfo: in: 8 bit data to be logged

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( const TDesC& aLogInfo )
    {
    // No text style info
    return Send( ENoStyle, aLogInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 8 bit information.

    This log method accepts only one parameters

    Parameters: const TDesC8 aLogInfo: in: 8 bit data to be logged

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( const TDesC8& aLogInfo )
    {
    // No text style info
    return Send( ENoStyle, aLogInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 16 bit information.

    There is also parameter to styling text information e.g. text color.

    Parameters: TInt aStyle: in: Logged text forming parameter
                const TDesC aLogInfo: in: 16 bit data to be logged

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( TInt aStyle, const TDesC& aLogInfo )
    {
    return Send( aStyle, aLogInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 8 bit information.

    There is also parameter to styling text information e.g. text color.

    Parameters: TInt aStyle: in: Logged text forming parameter
                const TDesC8 aLogInfo: in: 8 bit data to be logged

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( TInt aStyle, const TDesC8& aLogInfo )
    {
    return Send( aStyle, aLogInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 16 bit information.

    This log method accepts several parameters.

    Parameters: TRefByValue<const TDesC> aLogInfo: in: A templated class which 
                encapsulates a reference to an object within a wrapper

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  TDesLoggerOverflowHandler called if logged information
                        is over KMaxLogData

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( TRefByValue<const TDesC> aLogInfo,... )
    {
    VA_LIST list;
    VA_START( list, aLogInfo );
    TLogInfo logInfo;

    // Create overflow handler. If the log information size is over the
    // KMaxLogData rest of the information will cut.
    TDesLoggerOverflowHandler overFlowHandler( this, 1 );

    // Parse parameters
    logInfo.AppendFormatList( aLogInfo, list, &overFlowHandler );

    // No text style info
    return Send( ENoStyle, logInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 8 bit information.

    This log method accepts several parameters.

    Parameters: TRefByValue<const TDesC8> aLogInfo: in: A templated class which 
                encapsulates a reference to an object within a wrapper

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  TDes8LoggerOverflowHandler called if logged information is 
                        over KMaxLogData

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( TRefByValue<const TDesC8> aLogInfo,... )
    {
    VA_LIST list;
    VA_START( list, aLogInfo );
    TLogInfo8 logInfo;

    // Create overflow handler. If the log information size is over the
    // KMaxLogData rest of the information will cut.
    TDes8LoggerOverflowHandler overFlowHandler( this, 1 );

    // Parse parameters
    logInfo.AppendFormatList( aLogInfo, list, &overFlowHandler );

    // No text style info
    return Send( ENoStyle, logInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 16 bit information.

    This log method accepts several parameters. There is also parameter to
    styling text information e.g. text color.

    Parameters: TInt aStyle: in: Logged text forming parameter
                TRefByValue<const TDesC> aLogInfo: in: A templated class 
                which encapsulates a reference to an object
                within a wrapper

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  TDesOverflowHandler called if logged information is
                        over KMaxLogData

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( TInt aStyle, 
                           TRefByValue<const TDesC> aLogInfo,... )
    {
    VA_LIST list;
    VA_START( list, aLogInfo );
    TLogInfo logInfo;

    // Create overflow handler. If the log information size is over the
    // KMaxLogData rest of the information will cut.
    TDesLoggerOverflowHandler overFlowHandler( this, 2 );

    // Parse parameters
    logInfo.AppendFormatList( aLogInfo, list, &overFlowHandler );

    return Send( aStyle, logInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: Log

    Description: Log a 8 bit information.

    This log method accepts several parameters. There is also parameter to
    styling text information e.g. text color.

    Parameters: TInt aStyle: in: Logged text forming parameter
                TRefByValue<const TDesC8> aLogInfo: in: A templated class 
                which encapsulates a reference to an object
                within a wrapper

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  TDes8LoggerOverflowHandler called if logged information is
                        over KMaxLogData

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::Log( TInt aStyle, 
                           TRefByValue<const TDesC8> aLogInfo,... )
    {
    VA_LIST list;
    VA_START( list, aLogInfo );
    TLogInfo8 logInfo;

    // Create overflow handler. If the log information size is over the
    // KMaxLogData rest of the information will cut.
    TDes8LoggerOverflowHandler overFlowHandler( this, 2 );

    // Parse parameters
    logInfo.AppendFormatList( aLogInfo, list, &overFlowHandler );

    return Send( aStyle, logInfo );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: WriteDelimiter

    Description: Log a 16 bit delimiter.

    Log a delimiters required locations to the log information.
    This will be used if parameters are not given when calling this method.

    Parameters: const TDesC& aDelimiter: in: Logged delimiter(e.g. '#' or 'XO')
                TInt aCount: in: Repeated count for delimiter

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  TDesLoggerOverflowHandler called if logged information
                        is over KMaxLogData.

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::WriteDelimiter( const TDesC& aDelimiter, TInt aCount )
    {
    TLogInfo delimiter;

    // Create overflow handler. If the delimiter size expands over the
    // KMaxLogData the TDesLoggerOverflowHandler will call.
    TDesLoggerOverflowHandler overFlowHandler( this, 3 );

    // Create a delimiter
    for( TInt a = 0; a < aCount; a++ )
        {
        // If delimiter creation keeps under the KMaxLogData.
        // If not we use TDesLoggerOverflowHandler.
        if( ( a * aDelimiter.Length() ) < KMaxLogData ) 
            {
            delimiter.Append( aDelimiter );
            }
        // KMaxLogData is exceeded
        else
            {
            // If the title size is over the KMaxLogData default delimiter will
            // use. Use normal overflowhandler to print overflow information.
            TBuf<4> empty; // Not really used.
            overFlowHandler.Overflow( empty );
            delimiter.Copy( 
                _L( "##################################################" ) );
            break;
            }
        }

    // No text style info
    return Send( ENoStyle, delimiter );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: WriteDelimiter

    Description: Log a 8 bit delimiter.

    Log a delimiters required locations to the log information.

    Parameters: const TDesC8& aDelimiter: in: Logged delimiter
                                              (e.g. '#' or 'XO')
                TInt aCount: in: Repeated count for delimiter

    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  TDes8LoggerOverflowHandler called if logged information is
                        over KMaxLogData.

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::WriteDelimiter( const TDesC8& aDelimiter, TInt aCount )
    {
    TLogInfo8 delimiter;

    // Create overflow handler. If the delimiter size expands over the
    // KMaxLogData the TDesLoggerOverflowHandler will call.
    TDes8LoggerOverflowHandler overFlowHandler( this, 3 );

    // Create a delimiter
    for( TInt a = 0; a < aCount; a++ )
        {
        // If delimiter creation keeps under the KMaxLogData.
        // If not we use TDesLoggerOverflowHandler.
        if( ( a * aDelimiter.Length() ) < KMaxLogData ) 
            {
            delimiter.Append( aDelimiter );
            }
        // KMaxLogData is exceeded
        else
            {
            // If the title size is over the KMaxLogData default delimiter will
            // use. Use normal overflowhandler to print overflow information.
            TBuf8<4> empty; // Not really used.
            overFlowHandler.Overflow( empty );
            delimiter.Copy( 
                _L8( "##################################################" ) );
            break;
            }
        }

    // No text style info
    return Send( ENoStyle, delimiter );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: SaveData

    Description: Save file or data( 16 bit ).

    Used when is need to save file or data to storage e.g. web page.

    Parameters: TDesC& aData: in: Data to be saved
    
    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::SaveData( TDesC& aData )
    {
    // No text style info
    return Send( ENoStyle, aData );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: SaveData

    Description: Save file or data( 8 bit ).

    Used when is need to save file or data to storage e.g. web page.

    Parameters: TDesC8& aData: in: Data to be saved
    
    Return Values: TInt: Symbian error code.

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::SaveData( TDesC8& aData )
    {
    // No text style info
    return Send( ENoStyle, aData );

    }

/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: CreationResult

    Description: Return StifLogger creation result.

    Parameters: None
    
    Return Values: StifLogger creation result

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C TInt CStifLogger::CreationResult()
    {
     
    TOutput outputType;
    return iOutput->OutputCreationResult( outputType );
    
    }
    
/*
-------------------------------------------------------------------------------

    Class: CStifLogger

    Method: OutputType

    Description: Get output type. Valid only if CreationResult returns KErrNone.

    Parameters: TOutput& aOutput
    
    Return Values: StifLogger creation result

    Errors/Exceptions:  None

    Status: Approved

-------------------------------------------------------------------------------
*/
EXPORT_C CStifLogger::TOutput CStifLogger::OutputType()
    {
    
    TOutput outputType;
    iOutput->OutputCreationResult( outputType );
    return outputType;
    
    }

// End of File