diff options
author | The Android Open Source Project <initial-contribution@android.com> | 2009-03-03 19:30:52 -0800 |
---|---|---|
committer | The Android Open Source Project <initial-contribution@android.com> | 2009-03-03 19:30:52 -0800 |
commit | 8e35f3cfc7fba1d1c829dc557ebad6409cbe16a2 (patch) | |
tree | 11425ea0b299d6fb89c6d3618a22d97d5bf68d0f /WebCore/platform/posix/FileSystemPOSIX.cpp | |
parent | 648161bb0edfc3d43db63caed5cc5213bc6cb78f (diff) | |
download | external_webkit-8e35f3cfc7fba1d1c829dc557ebad6409cbe16a2.zip external_webkit-8e35f3cfc7fba1d1c829dc557ebad6409cbe16a2.tar.gz external_webkit-8e35f3cfc7fba1d1c829dc557ebad6409cbe16a2.tar.bz2 |
auto import from //depot/cupcake/@135843
Diffstat (limited to 'WebCore/platform/posix/FileSystemPOSIX.cpp')
-rw-r--r-- | WebCore/platform/posix/FileSystemPOSIX.cpp | 193 |
1 files changed, 193 insertions, 0 deletions
diff --git a/WebCore/platform/posix/FileSystemPOSIX.cpp b/WebCore/platform/posix/FileSystemPOSIX.cpp new file mode 100644 index 0000000..82ae087 --- /dev/null +++ b/WebCore/platform/posix/FileSystemPOSIX.cpp @@ -0,0 +1,193 @@ +/* + * Copyright (C) 2007, 2008 Apple Inc. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of + * its contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY + * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include "config.h" +#include "FileSystem.h" + +#include "CString.h" +#include "NotImplemented.h" +#include "PlatformString.h" + +#include <sys/stat.h> +#ifdef ANDROID_PLUGINS +#include <sys/types.h> +#include <dirent.h> +#include <fnmatch.h> +#endif +#include <libgen.h> +#include <unistd.h> + +namespace WebCore { + +bool fileExists(const String& path) +{ + if (path.isNull()) + return false; + + CString fsRep = fileSystemRepresentation(path); + + if (!fsRep.data() || fsRep.data()[0] == '\0') + return false; + + struct stat fileInfo; + + // stat(...) returns 0 on successful stat'ing of the file, and non-zero in any case where the file doesn't exist or cannot be accessed + return !stat(fsRep.data(), &fileInfo); +} + +bool deleteFile(const String& path) +{ + CString fsRep = fileSystemRepresentation(path); + + if (!fsRep.data() || fsRep.data()[0] == '\0') + return false; + + // unlink(...) returns 0 on successful deletion of the path and non-zero in any other case (including invalid permissions or non-existent file) + return !unlink(fsRep.data()); +} + +bool deleteEmptyDirectory(const String& path) +{ + CString fsRep = fileSystemRepresentation(path); + + if (!fsRep.data() || fsRep.data()[0] == '\0') + return false; + + // rmdir(...) returns 0 on successful deletion of the path and non-zero in any other case (including invalid permissions or non-existent file) + return !rmdir(fsRep.data()); +} + +bool getFileSize(const String& path, long long& result) +{ + CString fsRep = fileSystemRepresentation(path); + + if (!fsRep.data() || fsRep.data()[0] == '\0') + return false; + + struct stat fileInfo; + + if (stat(fsRep.data(), &fileInfo)) + return false; + + result = fileInfo.st_size; + return true; +} + +bool getFileModificationTime(const String& path, time_t& result) +{ + CString fsRep = fileSystemRepresentation(path); + + if (!fsRep.data() || fsRep.data()[0] == '\0') + return false; + + struct stat fileInfo; + + if (stat(fsRep.data(), &fileInfo)) + return false; + + result = fileInfo.st_mtime; + return true; +} + +String pathByAppendingComponent(const String& path, const String& component) +{ + if (path.endsWith("/")) + return path + component; + else + return path + "/" + component; +} + +bool makeAllDirectories(const String& path) +{ + CString fullPath = fileSystemRepresentation(path); + if (!access(fullPath.data(), F_OK)) + return true; + + char* p = fullPath.mutableData() + 1; + int length = fullPath.length(); + + if(p[length - 1] == '/') + p[length - 1] = '\0'; + for (; *p; ++p) + if (*p == '/') { + *p = '\0'; + if (access(fullPath.data(), F_OK)) + if (mkdir(fullPath.data(), S_IRWXU)) + return false; + *p = '/'; + } + if (access(fullPath.data(), F_OK)) + if (mkdir(fullPath.data(), S_IRWXU)) + return false; + + return true; +} + +String pathGetFileName(const String& path) +{ + return path.substring(path.reverseFind('/') + 1); +} + +String directoryName(const String& path) +{ + CString fsRep = fileSystemRepresentation(path); + + if (!fsRep.data() || fsRep.data()[0] == '\0') + return String(); + + return dirname(fsRep.mutableData()); +} + +Vector<String> listDirectory(const String& path, const String& filter) +{ +#ifdef ANDROID_PLUGINS + CString fsRepPath = fileSystemRepresentation(path); + CString fsRepFilter = fileSystemRepresentation(filter); +#endif + Vector<String> entries; +#ifdef ANDROID_PLUGINS + DIR *dir = opendir(fsRepPath.data()); + if (dir == NULL) + return entries; + for (;;) { + struct dirent *entry = readdir(dir); + if (entry == NULL) + break; + if (!fnmatch(fsRepFilter.data(), entry->d_name, FNM_NOESCAPE)) { + String fullPath = path + "/" + entry->d_name; + entries.append(fullPath); + } + } + closedir(dir); +#else + notImplemented(); +#endif + return entries; +} + +} // namespace WebCore |