version 1.69, 2007/02/12 12:18:53
|
version 1.82, 2008/11/26 05:25:27
|
|
|
#include <Pegasus/Common/Config.h> | #include <Pegasus/Common/Config.h> |
#include <Pegasus/Common/System.h> | #include <Pegasus/Common/System.h> |
#include <Pegasus/Common/AutoPtr.h> | #include <Pegasus/Common/AutoPtr.h> |
|
#include <Executor/Match.h> |
#include "FileSystem.h" | #include "FileSystem.h" |
#include "Dir.h" | #include "Dir.h" |
#ifndef PEGASUS_OS_TYPE_WINDOWS | #ifndef PEGASUS_OS_TYPE_WINDOWS |
|
|
| |
Boolean FileSystem::existsNoCase(const String& path, String& realPath) | Boolean FileSystem::existsNoCase(const String& path, String& realPath) |
{ | { |
#ifdef PEGASUS_OS_OS400 |
#if !defined(PEGASUS_OS_VMS) && \ |
// The OS/400 file system is case insensitive, so just call exists( ). |
!defined(PEGASUS_OS_TYPE_WINDOWS) && \ |
// This is faster, but the main reason to do this is to |
!defined(PEGASUS_OS_DARWIN) |
// avoid multi-threading problems with the IFS directory APIs |
|
// (even though they claim to be threadsafe). |
// If a file exists that has the same case as the path parmater, |
|
// then we can bypass the expensive directory scanning below. |
|
|
|
if (FileSystem::exists(path)) |
|
{ |
realPath = path; | realPath = path; |
return exists(path); |
return true; |
#else |
} |
|
|
|
#endif |
|
|
realPath.clear(); | realPath.clear(); |
CString cpath = _clonePath(path); | CString cpath = _clonePath(path); |
const char* p = cpath; | const char* p = cpath; |
|
|
} | } |
| |
return false; | return false; |
#endif |
|
} | } |
| |
Boolean FileSystem::canRead(const String& path) | Boolean FileSystem::canRead(const String& path) |
|
|
#if defined(__GNUC__) && GCC_VERSION >= 30200 | #if defined(__GNUC__) && GCC_VERSION >= 30200 |
fs.open(_clonePath(realPath), PEGASUS_STD(ios_base::openmode)(mode)); | fs.open(_clonePath(realPath), PEGASUS_STD(ios_base::openmode)(mode)); |
#else | #else |
#if defined(PEGASUS_OS_OS400) |
|
fs.open(_clonePath(realPath), mode, PEGASUS_STD(_CCSID_T(1208)) ); |
|
#else |
|
fs.open(_clonePath(realPath), mode); | fs.open(_clonePath(realPath), mode); |
#endif | #endif |
#endif |
|
return !!fs; | return !!fs; |
} | } |
| |
|
|
// Changes file permissions on the given file. | // Changes file permissions on the given file. |
Boolean FileSystem::changeFilePermissions(const String& path, mode_t mode) | Boolean FileSystem::changeFilePermissions(const String& path, mode_t mode) |
{ | { |
#if defined(PEGASUS_OS_OS400) |
|
// ATTN: If getCString() is modified to return UTF8, then handle the |
|
// EBCDIC coversion in SystemUnix.cpp |
|
CString tempPath = path.getCString(); |
|
#else |
|
CString tempPath = path.getCString(); | CString tempPath = path.getCString(); |
#endif |
|
| |
return System::changeFilePermissions(tempPath, mode); | return System::changeFilePermissions(tempPath, mode); |
} | } |
|
|
// | // |
#if defined(PEGASUS_OS_TYPE_WINDOWS) | #if defined(PEGASUS_OS_TYPE_WINDOWS) |
fileName = libraryName + String(".dll"); | fileName = libraryName + String(".dll"); |
|
#else |
|
fileName = String("lib") + libraryName + getDynamicLibraryExtension(); |
|
#endif |
|
return fileName; |
|
} |
|
|
|
String FileSystem::getDynamicLibraryExtension() |
|
{ |
|
#if defined(PEGASUS_OS_TYPE_WINDOWS) |
|
return String(".dll"); |
#elif defined(PEGASUS_PLATFORM_HPUX_PARISC_ACC) | #elif defined(PEGASUS_PLATFORM_HPUX_PARISC_ACC) |
fileName = String("lib") + libraryName + String(".sl"); |
return String(".sl"); |
#elif defined(PEGASUS_OS_OS400) |
|
fileName = libraryName; |
|
#elif defined(PEGASUS_OS_DARWIN) | #elif defined(PEGASUS_OS_DARWIN) |
fileName = String("lib") + libraryName + String(".dylib"); |
return String(".dylib"); |
#elif defined(PEGASUS_OS_VMS) | #elif defined(PEGASUS_OS_VMS) |
fileName = String("lib") + libraryName; |
return String(".exe"); |
|
#elif defined(PEGASUS_PLATFORM_ZOS_ZSERIES64_IBM) |
|
return String("64.so"); |
#else | #else |
fileName = String("lib") + libraryName + String(".so"); |
return String(".so"); |
#endif | #endif |
|
|
return fileName; |
|
} | } |
| |
|
Boolean GetLine(PEGASUS_STD(istream)& is, Buffer& line) |
Boolean GetLine(PEGASUS_STD(istream)& is, String& line) |
|
{ | { |
|
const Uint32 buffersize = 1024; |
|
Uint32 gcount = 0; |
|
|
line.clear(); | line.clear(); |
| |
Boolean gotChar = false; |
// Read the input line in chunks. A non-full buffer indicates the end of |
#ifdef PEGASUS_PLATFORM_ZOS_ZSERIES_IBM |
// the line has been reached. |
char input[1000]; |
do |
is.getline(input,1000); |
{ |
line.assign(input); |
char input[buffersize]; |
| |
gotChar = !(is.rdstate() & PEGASUS_STD(istream)::failbit); |
// This reads up to buffersize-1 char, but stops before consuming |
#else |
// a newline character ('\n'). |
char c; |
is.get(input, buffersize); |
| |
while (is.get(c)) |
gcount = (Uint32)is.gcount(); |
{ |
line.append(input, gcount); |
gotChar = true; |
|
| |
if (c == '\n') |
if (is.rdstate() & PEGASUS_STD(istream)::failbit) |
|
{ |
|
// It is okay if we encounter the newline character without reading |
|
// data. |
|
is.clear(); |
break; | break; |
|
} |
|
} while (gcount == buffersize-1); |
| |
line.append(c); |
if (!is.eof()) |
|
{ |
|
// we need to consume the '\n', because get() doesn't |
|
char c = 0; |
|
is.get(c); |
} | } |
#endif |
|
| |
return gotChar; |
return !!is; |
} | } |
| |
// | // |
|
|
PEG_METHOD_ENTER(TRC_AUTHENTICATION, "FileSystem::changeFileOwner()"); | PEG_METHOD_ENTER(TRC_AUTHENTICATION, "FileSystem::changeFileOwner()"); |
| |
struct passwd* userPasswd; | struct passwd* userPasswd; |
#if defined(PEGASUS_PLATFORM_SOLARIS_SPARC_CC) || \ |
#if defined(PEGASUS_OS_SOLARIS) || \ |
defined(PEGASUS_OS_HPUX) || \ | defined(PEGASUS_OS_HPUX) || \ |
defined (PEGASUS_OS_LINUX) |
defined(PEGASUS_OS_LINUX) || \ |
|
defined (PEGASUS_OS_VMS) || \ |
|
defined (PEGASUS_OS_AIX) |
| |
const unsigned int PWD_BUFF_SIZE = 1024; | const unsigned int PWD_BUFF_SIZE = 1024; |
struct passwd pwd; | struct passwd pwd; |
struct passwd *result; |
|
char pwdBuffer[PWD_BUFF_SIZE]; | char pwdBuffer[PWD_BUFF_SIZE]; |
| |
if (getpwnam_r(userName.getCString(), &pwd, pwdBuffer, PWD_BUFF_SIZE, | if (getpwnam_r(userName.getCString(), &pwd, pwdBuffer, PWD_BUFF_SIZE, |
|
|
userPasswd = (struct passwd*)NULL; | userPasswd = (struct passwd*)NULL; |
} | } |
| |
#elif defined(PEGASUS_OS_OS400) |
|
CString tempName = userName.getCString(); |
|
const char* tmp = tempName; |
|
AtoE((char *)tmp); |
|
userPasswd = getpwnam(tmp); |
|
#else | #else |
| |
userPasswd = getpwnam(userName.getCString()); | userPasswd = getpwnam(userName.getCString()); |
|
|
return false; | return false; |
} | } |
| |
#if defined(PEGASUS_OS_OS400) |
|
CString tempPath = fileName.getCString(); |
|
const char * tmp1 = tempPath; |
|
AtoE((char *)tmp1); |
|
Sint32 ret = chown(tmp1, userPasswd->pw_uid, userPasswd->pw_gid); |
|
#else |
|
Sint32 ret = chown( | Sint32 ret = chown( |
fileName.getCString(), userPasswd->pw_uid, userPasswd->pw_gid); | fileName.getCString(), userPasswd->pw_uid, userPasswd->pw_gid); |
#endif |
|
if (ret == -1) | if (ret == -1) |
{ | { |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
|
|
return true; | return true; |
#endif | #endif |
} | } |
|
|
|
void FileSystem::syncWithDirectoryUpdates(PEGASUS_STD(fstream)& fs) |
|
{ |
|
#if defined(PEGASUS_OS_HPUX) |
|
// Writes the data from the iostream buffers to the OS buffers |
|
fs.flush(); |
|
// Writes the data from the OS buffers to the disk |
|
fsync(fs.rdbuf()->fd()); |
|
#endif |
|
} |
|
|
|
Boolean FileSystem::glob( |
|
const String& path, |
|
const String& pattern_, |
|
Array<String>& filenames) |
|
{ |
|
filenames.clear(); |
|
|
|
try |
|
{ |
|
CString pattern(pattern_.getCString()); |
|
|
|
for (Dir dir(path); dir.more(); dir.next()) |
|
{ |
|
const char* name = dir.getName(); |
|
|
|
if (strcmp(name, ".") == 0 || strcmp(name, "..") == 0) |
|
continue; |
|
|
|
if (Match(pattern, name) == 0) |
|
filenames.append(name); |
|
} |
|
} |
|
catch (CannotOpenDirectory&) |
|
{ |
|
return false; |
|
} |
|
|
|
return true; |
|
} |
|
|
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |