version 1.26.6.1, 2003/08/13 19:39:50
|
version 1.48.6.1, 2007/09/12 15:46:57
|
|
|
//%///////////////////////////////////////////////////////////////////////////// |
//%2006//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Company, IBM, |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// The Open Group, Tivoli Systems |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
|
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; |
|
// IBM Corp.; EMC Corporation, The Open Group. |
|
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; |
|
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
|
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
|
// EMC Corporation; VERITAS Software Corporation; The Open Group. |
|
// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
|
// EMC Corporation; Symantec Corporation; The Open Group. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// | // |
//============================================================================== | //============================================================================== |
// | // |
// Author: Mike Brasher (mbrasher@bmc.com) |
|
// |
|
// Modified By: |
|
// |
|
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
#ifndef Pegasus_FileSystem_h | #ifndef Pegasus_FileSystem_h |
|
|
#include <Pegasus/Common/Linkage.h> | #include <Pegasus/Common/Linkage.h> |
#include <fstream> | #include <fstream> |
#include <cstdio> | #include <cstdio> |
#if defined(PEGASUS_OS_OS400) |
#include <Pegasus/Common/Buffer.h> |
#include "OS400ConvertChar.h" |
|
#endif |
|
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
|
|
*/ | */ |
static Boolean removeFileNoCase(const String& path); | static Boolean removeFileNoCase(const String& path); |
| |
|
/** Produces an array of filenames that match the given pattern under |
|
the directory given by path. The pattern is limited to asterisks |
|
only. Examples: "*.txt", "hello*world.c". Returns true on success. |
|
Return false if the base diretory does not exist or cannot be |
|
accessed. |
|
*/ |
|
static Boolean FileSystem::glob( |
|
const String& path, |
|
const String& pattern, |
|
Array<String>& filenames); |
|
|
|
/** Removes all files located under the directory given by *path* that |
|
match the given pattern. Uses FileSystem::glob() to match file names. |
|
Example: removeMatchingFiles("/tmp", "*.txt"). Fails if the pattern |
|
matches a directory. May only remove ordinary files. |
|
*/ |
|
static Boolean removeMatchingFiles( |
|
const String& path, const String& pattern); |
|
|
/** Loads contents of the file into the array. Note that the file is | /** Loads contents of the file into the array. Note that the file is |
opened using binary mode (newline sequences are not expanded to | opened using binary mode (newline sequences are not expanded to |
carriage-return-line-feed sequences on Windows). | carriage-return-line-feed sequences on Windows). |
|
|
@exception CannotOpenFile | @exception CannotOpenFile |
*/ | */ |
static void loadFileToMemory( | static void loadFileToMemory( |
Array<Sint8>& array, |
Buffer& array, |
const String& fileName); | const String& fileName); |
| |
/** Determines whether two files have exactly the same content. | /** Determines whether two files have exactly the same content. |
|
|
*/ | */ |
static String extractFilePath(const String& path); | static String extractFilePath(const String& path); |
| |
|
/** Changes file permissions on the given file. |
|
@param path path of the file. |
|
@param mode the bit-wise inclusive OR of the values for the |
|
desired permissions. |
|
@return true on success, false on error and errno is set appropriately. |
|
*/ |
|
static Boolean changeFilePermissions(const String& path, mode_t mode); |
|
|
|
/** |
|
Return OS path specific delimiter. |
|
|
|
@return delimiter specific to the platform |
|
*/ |
|
static String getPathDelimiter(); |
|
|
|
/** |
|
Returns the absolute pathname for the specified filename. |
|
|
|
@param paths directories seperated by an OS specific delimiter to search |
|
@param filename filename to search for in the paths |
|
|
|
@return the full absolute pathname to the found filename or an empty |
|
string on failure. |
|
*/ |
|
static String getAbsoluteFileName( |
|
const String& paths, |
|
const String& filename); |
|
|
|
/** |
|
Convert a library name to its corresponding file name by adding the |
|
appropriate prefix and suffix. |
|
|
|
@param libraryName The name of the library for which to build the file |
|
name. |
|
@return The file name corresponding to the specified library name. |
|
*/ |
|
static String buildLibraryFileName(const String &libraryName); |
|
|
|
static Boolean changeFileOwner( |
|
const String& fileName, |
|
const String& userName); |
|
|
|
/** |
|
Flushes the data from the iostream buffers to the OS buffers and |
|
then flushes the data from the OS buffers to the disk. |
|
|
|
This will avoid the possible data loss in case of an OS crash when |
|
OS filesystem commit directory-level changes immediately while |
|
file-level changes remain cached (e.g. HP-UX). |
|
|
|
@param fstream. The iostream that we want to flush data. |
|
*/ |
|
static void syncWithDirectoryUpdates(PEGASUS_STD(fstream)&); |
|
|
private: | private: |
| |
FileSystem() { } | FileSystem() { } |
|
|
| |
inline Boolean Open(PEGASUS_STD(ifstream)& is, const String& path) | inline Boolean Open(PEGASUS_STD(ifstream)& is, const String& path) |
{ | { |
#if defined(PEGASUS_OS_OS400) |
|
CString tempPath = path.getCString(); |
|
const char * tmp = tempPath; |
|
AtoE((char *)tmp); |
|
is.open(tmp, PEGASUS_STD(_CCSID_T(1208))); |
|
#else |
|
is.open(path.getCString()); | is.open(path.getCString()); |
#endif |
|
return !!is; | return !!is; |
} | } |
| |
inline Boolean Open(PEGASUS_STD(ofstream)& os, const String& path) | inline Boolean Open(PEGASUS_STD(ofstream)& os, const String& path) |
{ | { |
#if defined(PEGASUS_OS_OS400) |
|
CString tempPath = path.getCString(); |
|
const char * tmp = tempPath; |
|
AtoE((char *)tmp); |
|
os.open(tmp, PEGASUS_STD(_CCSID_T(1208))); |
|
#else |
|
os.open(path.getCString()); | os.open(path.getCString()); |
#endif |
|
return !!os; | return !!os; |
} | } |
| |
inline Boolean OpenAppend(PEGASUS_STD(ofstream)& os, const String& path) | inline Boolean OpenAppend(PEGASUS_STD(ofstream)& os, const String& path) |
{ | { |
#if defined(PEGASUS_OS_OS400) |
|
CString tempPath = path.getCString(); |
|
const char * tmp = tempPath; |
|
AtoE((char *)tmp); |
|
os.open(tmp, PEGASUS_STD(ios::app), PEGASUS_STD(_CCSID_T(1208))); |
|
#else |
|
os.open(path.getCString(), PEGASUS_STD(ios::app)); | os.open(path.getCString(), PEGASUS_STD(ios::app)); |
#endif |
|
return !!os; | return !!os; |
} | } |
| |
|
inline String FileSystem::getPathDelimiter() |
|
{ |
|
#if defined(PEGASUS_OS_TYPE_WINDOWS) |
|
return String(";"); |
|
#else |
|
return String(":"); |
|
#endif |
|
} |
|
|
/** Get the next line from the input file. | /** Get the next line from the input file. |
*/ | */ |
PEGASUS_COMMON_LINKAGE Boolean GetLine(PEGASUS_STD(istream)& is, String& line); | PEGASUS_COMMON_LINKAGE Boolean GetLine(PEGASUS_STD(istream)& is, String& line); |