(file) Return to TraceFileHandlerWindows.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

Diff for /pegasus/src/Pegasus/Common/TraceFileHandlerWindows.cpp between version 1.14 and 1.26

version 1.14, 2008/05/07 19:41:42 version 1.26, 2013/03/14 10:23:37
Line 1 
Line 1 
 //%2006////////////////////////////////////////////////////////////////////////  //%LICENSE////////////////////////////////////////////////////////////////
 // //
 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development  // Licensed to The Open Group (TOG) under one or more contributor license
 // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.  // agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
 // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;  // this work for additional information regarding copyright ownership.
 // IBM Corp.; EMC Corporation, The Open Group.  // Each contributor licenses this file to you under the OpenPegasus Open
 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;  // Source License; you may not use this file except in compliance with the
 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.  // License.
 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;  //
 // EMC Corporation; VERITAS Software Corporation; The Open Group.  // Permission is hereby granted, free of charge, to any person obtaining a
 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;  // copy of this software and associated documentation files (the "Software"),
 // EMC Corporation; Symantec Corporation; The Open Group.  // to deal in the Software without restriction, including without limitation
 //  // the rights to use, copy, modify, merge, publish, distribute, sublicense,
 // Permission is hereby granted, free of charge, to any person obtaining a copy  // and/or sell copies of the Software, and to permit persons to whom the
 // of this software and associated documentation files (the "Software"), to  // Software is furnished to do so, subject to the following conditions:
 // deal in the Software without restriction, including without limitation the  //
 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or  // The above copyright notice and this permission notice shall be included
 // sell copies of the Software, and to permit persons to whom the Software is  // in all copies or substantial portions of the Software.
 // furnished to do so, subject to the following conditions:  //
 //  // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN  // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED  // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT  // IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR  // CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT  // TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN  // SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION  
 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.  
 // //
 //==============================================================================  //////////////////////////////////////////////////////////////////////////
 // //
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
 #include <iostream> #include <iostream>
 #include <Pegasus/Common/Logger.h>  
 #include <Pegasus/Common/TraceFileHandler.h> #include <Pegasus/Common/TraceFileHandler.h>
 #include <Pegasus/Common/Mutex.h> #include <Pegasus/Common/Mutex.h>
  
Line 42 
Line 39 
  
 static Mutex writeMutex; static Mutex writeMutex;
  
 ////////////////////////////////////////////////////////////////////////////////  
 //   On other platforms prepares the file handle (open file etc.).  
 //   Implementation of this function is platform specific  
 //  
 //   Note: The current implementation on Windows does nothing.  
 //         Should be optimized out by the compiler  
 ////////////////////////////////////////////////////////////////////////////////  
 void TraceFileHandler::prepareFileHandle(void)  
 {  
     return;  
 }  
  
 //////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
 //   Writes message to file. //   Writes message to file.
Line 64 
Line 50 
 //////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
 void TraceFileHandler::handleMessage( void TraceFileHandler::handleMessage(
     const char* message,     const char* message,
       Uint32,
     const char* fmt,     const char* fmt,
     va_list argList)     va_list argList)
 { {
     Uint32 retCode;     Uint32 retCode;
  
     if (_fileHandle)  
       if (_configHasChanged)
       {
           _reConfigure();
       }
   
       if (!_fileHandle)
     {     {
           // The trace file is not open, which means an earlier fopen() was
           // unsuccessful.  Stop now to avoid logging duplicate error messages.
           return;
       }
   
       if(!_fileExists(_fileName))
       {
           return;
       }
   
         AutoMutex writeLock(writeMutex);         AutoMutex writeLock(writeMutex);
  
         //Move to the End of File         //Move to the End of File
Line 85 
Line 88 
         {         {
             // Unable to write message to file             // Unable to write message to file
             // Log message             // Log message
             Logger::put_l(              MessageLoaderParms parm(
                 Logger::ERROR_LOG,  
                 System::CIMSERVER,  
                 Logger::WARNING,  
                 "Common.TraceFileHandlerWindows.UNABLE_TO_WRITE_TRACE_TO_FILE",                 "Common.TraceFileHandlerWindows.UNABLE_TO_WRITE_TRACE_TO_FILE",
                 "Unable to write trace message to File $0",                 "Unable to write trace message to File $0",
                 _fileName);                 _fileName);
               _logError(TRCFH_UNABLE_TO_WRITE_TRACE_TO_FILE,parm);
         }         }
         else         else
         {         {
             fflush(_fileHandle);             fflush(_fileHandle);
               // trace message successful written, reset error log messages
               // thus allow writing of errors to log again
               _logErrorBitField = 0;
         }         }
     }  
     else  
     {  
         // Invalid file handle  
         // Log message  
         Logger::put_l(  
             Logger::ERROR_LOG,  
             System::CIMSERVER,  
             Logger::WARNING,  
             "Common.TraceFileHandlerWindows.INVALID_FILE_HANDLE",  
             "Invalid file handle for file $0",  
             _fileName);  
     }  
 } }
  
 //////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
Line 120 
Line 112 
 //         Will have to be enhanced to support synchronous write operations to //         Will have to be enhanced to support synchronous write operations to
 //         the same file. //         the same file.
 //////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
 void TraceFileHandler::handleMessage(const char* message)  void TraceFileHandler::handleMessage(const char* message, Uint32)
 { {
     Uint32 retCode;     Uint32 retCode;
  
     if (_fileHandle)      if (_configHasChanged)
       {
           _reConfigure();
       }
   
       if (!_fileHandle)
     {     {
           // The trace file is not open, which means an earlier fopen() was
           // unsuccessful.  Stop now to avoid logging duplicate error messages.
           return;
       }
   
       if(!_fileExists(_fileName))
       {
           return;
       }
   
   
         AutoMutex writeLock(writeMutex);         AutoMutex writeLock(writeMutex);
  
         //Move to the End of File         //Move to the End of File
Line 137 
Line 145 
         {         {
             // Unable to write message to file             // Unable to write message to file
             // Log message             // Log message
             Logger::put_l(              MessageLoaderParms parm(
                 Logger::ERROR_LOG,  
                 System::CIMSERVER,  
                 Logger::WARNING,  
                 "Common.TraceFileHandlerWindows.UNABLE_TO_WRITE_TRACE_TO_FILE",                 "Common.TraceFileHandlerWindows.UNABLE_TO_WRITE_TRACE_TO_FILE",
                 "Unable to write trace message to File $0",                 "Unable to write trace message to File $0",
                 _fileName);                 _fileName);
               _logError(TRCFH_UNABLE_TO_WRITE_TRACE_TO_FILE,parm);
         }         }
         else         else
         {         {
             fflush(_fileHandle);             fflush(_fileHandle);
               // trace message successful written, reset error log messages
               // thus allow writing of errors to log again
               _logErrorBitField = 0;
         }         }
     }  
     else  
     {  
         // Invalid file handle  
         // Log message  
         Logger::put_l(  
             Logger::ERROR_LOG,  
             System::CIMSERVER,  
             Logger::WARNING,  
             "Common.TraceFileHandlerWindows.INVALID_FILE_HANDLE",  
             "Invalid file handle for file $0",  
             _fileName);  
     }  
 } }
  
  


Legend:
Removed from v.1.14  
changed lines
  Added in v.1.26

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2