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

 1 karl  1.8 //%2006////////////////////////////////////////////////////////////////////////
 2 mike  1.2 //
 3 karl  1.6 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
 4           // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
 5           // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
 6 karl  1.5 // IBM Corp.; EMC Corporation, The Open Group.
 7 karl  1.6 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
 8           // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
 9 karl  1.7 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10           // EMC Corporation; VERITAS Software Corporation; The Open Group.
11 karl  1.8 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12           // EMC Corporation; Symantec Corporation; The Open Group.
13 mike  1.2 //
14           // Permission is hereby granted, free of charge, to any person obtaining a copy
15           // of this software and associated documentation files (the "Software"), to
16           // deal in the Software without restriction, including without limitation the
17           // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
18           // sell copies of the Software, and to permit persons to whom the Software is
19           // furnished to do so, subject to the following conditions:
20 kumpf 1.3 // 
21 mike  1.2 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
22           // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
23           // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
24           // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
25           // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26           // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
27           // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28           // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29           //
30           //==============================================================================
31           //
32           //%/////////////////////////////////////////////////////////////////////////////
33           
34           #include <iostream>
35           #include <Pegasus/Common/Logger.h>
36           #include <Pegasus/Common/TraceFileHandler.h>
37           
38           PEGASUS_USING_STD;
39           
40           PEGASUS_NAMESPACE_BEGIN
41           
42 mike  1.2 ////////////////////////////////////////////////////////////////////////////////
43 kumpf 1.11 //   Writes message to file.
44 mike  1.2  //   Implementation of this function is platform specific
45 kumpf 1.11 //
46 mike  1.2  //   Note: The current implementation writes the message to the defined file.
47            //         Will have to be enhanced to support synchronous write operations to
48            //         the same file.
49            ////////////////////////////////////////////////////////////////////////////////
50            void TraceFileHandler::handleMessage(
51                const char* message,
52                const char* fmt,
53 kumpf 1.11     va_list argList)
54 mike  1.2  {
55                Uint32 retCode;
56            
57                if (_fileHandle)
58                {
59                    //Move to the End of File
60                    fseek(_fileHandle,0,SEEK_SET);
61            
62                    // Write message to file
63                    fprintf(_fileHandle,"%s", message);
64                    vfprintf(_fileHandle,fmt,argList);
65                    retCode = fprintf(_fileHandle,"\n");
66            
67                    if (retCode < 0)
68                    {
69 kumpf 1.11             // Unable to write message to file
70                        // Log message
71                        Logger::put_l(Logger::DEBUG_LOG, System::CIMSERVER, Logger::WARNING,
72                            "Common.TraceFileHandlerWindows.UNABLE_TO_WRITE_TRACE_TO_FILE",
73                            "Unable to write trace message to File $0", _fileName);
74 mike  1.2          }
75 kumpf 1.11         else
76                    {
77 mike  1.2              fflush(_fileHandle);
78                    }
79                }
80                else
81                {
82 kumpf 1.11         // Invalid file handle
83                    // Log message
84                    Logger::put_l(Logger::DEBUG_LOG, System::CIMSERVER, Logger::WARNING,
85                        "Common.TraceFileHandlerWindows.INVALID_FILE_HANDLE",
86                        "Invalid file handle for file $0", _fileName);
87 mike  1.2      }
88 kumpf 1.11 }
89 mike  1.2  
90            PEGASUS_NAMESPACE_END

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2