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

Diff for /pegasus/src/Pegasus/Common/TraceFileHandler.cpp between version 1.1 and 1.2

version 1.1, 2001/07/31 23:57:08 version 1.2, 2001/12/13 14:54:05
Line 0 
Line 1 
   //%/////////////////////////////////////////////////////////////////////////////
   //
   // Copyright (c) 2000, 2001 BMC Software, Hewlett-Packard Company, IBM,
   // The Open Group, Tivoli Systems, Compaq Computer Corporation
   //
   // Permission is hereby granted, free of charge, to any person obtaining a copy
   // of this software and associated documentation files (the "Software"), to
   // deal in the Software without restriction, including without limitation the
   // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
   // sell copies of the Software, and to permit persons to whom the Software is
   // furnished to do so, subject to the following conditions:
   //
   // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
   // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
   // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
   // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
   // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
   // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
   // 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.
   //
   //==============================================================================
   //
   // Author: Sushma Fernandes, Hewlett-Packard Company (sushma_fernandes@hp.com)
   //
   // Modified By: Rudy Schuet (rudy.schuet@compaq.com) 11/12/01
   //              added nsk platform support
   //
   //%/////////////////////////////////////////////////////////////////////////////
   
   #include <fstream>
   #include <iostream>
   #include <Pegasus/Common/FileSystem.h>
   #include <Pegasus/Common/TraceFileHandler.h>
   
   #if defined(PEGASUS_OS_TYPE_WINDOWS)
   # include <Pegasus/Common/TraceFileHandlerWindows.cpp>
   #elif defined(PEGASUS_OS_TYPE_UNIX)
   # include <Pegasus/Common/TraceFileHandlerUnix.cpp>
   #elif defined(PEGASUS_OS_TYPE_NSK)
   # include <Pegasus/Common/TraceFileHandlerNsk.cpp>
   #else
   # error "Unsupported platform"
   #endif
   
   
   PEGASUS_USING_STD;
   
   PEGASUS_NAMESPACE_BEGIN
   
   ////////////////////////////////////////////////////////////////////////////////
   //  Constructs TraceFileHandler
   ////////////////////////////////////////////////////////////////////////////////
   
   TraceFileHandler::TraceFileHandler ()
   {
       _fileHandle = 0;
       _wroteToLog = false;
   }
   
   ////////////////////////////////////////////////////////////////////////////////
   //  Destructs TraceFileHandler
   ////////////////////////////////////////////////////////////////////////////////
   
   TraceFileHandler::~TraceFileHandler ()
   {
       // Close the File
       if (_fileHandle)
       {
           fclose(_fileHandle);
       }
       delete []_fileName;
   }
   
   ////////////////////////////////////////////////////////////////////////////////
   //  Sets the filename to the given filename and opens the file in append
   //  mode
   ////////////////////////////////////////////////////////////////////////////////
   
   Uint32 TraceFileHandler::setFileName(const char* fileName)
   {
       if (!isValidFilePath(fileName))
       {
           return 1;
       }
       // Check if a file is already open, if so close it
       if (_fileHandle)
       {
           fclose(_fileHandle);
       }
   
       // Now open the file
       _fileHandle = fopen(fileName,"a+");
       if (!_fileHandle)
       {
           // Unable to open file, log a message
           Logger::put(Logger::DEBUG_LOG,"Tracer",Logger::WARNING,
              "Failed to open File $0",fileName);
               return 1;
       }
       else
       {
           _fileName = new char [strlen(fileName)+1];
           strcpy (_fileName,fileName);
       }
       return 0;
   }
   
   Boolean TraceFileHandler::isValidFilePath(const char* filePath)
   {
       String fileName = String(filePath);
   
       // Check if the file path is a directory
       FileSystem::translateSlashes(fileName);
       if (FileSystem::isDirectory(fileName))
       {
           return 0;
       }
   
       // Check if the file exists and is writable
       if (FileSystem::exists(fileName))
       {
           if (!FileSystem::canWrite(fileName))
           {
               return 0;
           }
           else
           {
               return 1;
           }
       }
       else
       {
           // Check if directory is writable
           String dirSeparator("/");
   
           Uint32 pos = fileName.reverseFind(*(dirSeparator.getData()));
   
           if (pos != PEG_NOT_FOUND)
           {
               String dirName = fileName.subString(0,pos);
               if (!FileSystem::isDirectory(dirName))
               {
                   return 0;
               }
               if (!FileSystem::canWrite(dirName) )
               {
                   return 0;
               }
               else
               {
                   return 1;
               }
           }
           else
           {
               String currentDir;
   
               // Check if there is permission to write in the
               // current working directory
               FileSystem::getCurrentDirectory(currentDir);
   
               if (!FileSystem::canWrite(currentDir))
               {
                   return 0;
               }
               else
               {
                   return 1;
               }
           }
       }
       return 1;
   }
   PEGASUS_NAMESPACE_END


Legend:
Removed from v.1.1  
changed lines
  Added in v.1.2

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2