diff options
author | 2013-12-13 04:15:33 +0000 | |
---|---|---|
committer | 2013-12-13 04:15:33 +0000 | |
commit | 18d033405c18a8dc28f60ca22d1d0df23a679384 (patch) | |
tree | 77ae6dc696eb7f2942e6d5bfebdccb95eebf8a6e /native/jni/src/suggest/policyimpl/dictionary/utils/file_utils.cpp | |
parent | 95050f54e92ff5465e713990315e8cf421836a64 (diff) | |
parent | c95efbbd575239b97db20b71fb347b543b5808f8 (diff) | |
download | latinime-18d033405c18a8dc28f60ca22d1d0df23a679384.tar.gz latinime-18d033405c18a8dc28f60ca22d1d0df23a679384.tar.xz latinime-18d033405c18a8dc28f60ca22d1d0df23a679384.zip |
Merge branch 'master' of https://googleplex-android.googlesource.com/_direct/platform/packages/inputmethods/LatinIME
Diffstat (limited to 'native/jni/src/suggest/policyimpl/dictionary/utils/file_utils.cpp')
-rw-r--r-- | native/jni/src/suggest/policyimpl/dictionary/utils/file_utils.cpp | 157 |
1 files changed, 0 insertions, 157 deletions
diff --git a/native/jni/src/suggest/policyimpl/dictionary/utils/file_utils.cpp b/native/jni/src/suggest/policyimpl/dictionary/utils/file_utils.cpp deleted file mode 100644 index 1f25cfa1e..000000000 --- a/native/jni/src/suggest/policyimpl/dictionary/utils/file_utils.cpp +++ /dev/null @@ -1,157 +0,0 @@ -/* - * Copyright (C) 2013, The Android Open Source Project - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#include "suggest/policyimpl/dictionary/utils/file_utils.h" - -#include <cstdio> -#include <cstring> -#include <dirent.h> -#include <fcntl.h> -#include <libgen.h> -#include <sys/types.h> -#include <sys/stat.h> -#include <unistd.h> - -namespace latinime { - -// Returns -1 on error. -/* static */ int FileUtils::getFileSize(const char *const filePath) { - const int fd = open(filePath, O_RDONLY); - if (fd == -1) { - return -1; - } - struct stat statBuf; - if (fstat(fd, &statBuf) != 0) { - close(fd); - return -1; - } - close(fd); - return static_cast<int>(statBuf.st_size); -} - -/* static */ bool FileUtils::existsDir(const char *const dirPath) { - DIR *const dir = opendir(dirPath); - if (dir == NULL) { - return false; - } - closedir(dir); - return true; -} - -// Remove a directory and all files in the directory. -/* static */ bool FileUtils::removeDirAndFiles(const char *const dirPath) { - DIR *const dir = opendir(dirPath); - if (dir == NULL) { - AKLOGE("Cannot open dir %s.", dirPath); - return true; - } - struct dirent *dirent; - while ((dirent = readdir(dir)) != NULL) { - if (dirent->d_type != DT_REG) { - continue; - } - const int filePathBufSize = getFilePathBufSize(dirPath, dirent->d_name); - char filePath[filePathBufSize]; - getFilePath(dirPath, dirent->d_name, filePathBufSize, filePath); - if (remove(filePath) != 0) { - AKLOGE("Cannot remove file %s.", filePath); - closedir(dir); - return false; - } - } - closedir(dir); - if (remove(dirPath) != 0) { - AKLOGE("Cannot remove directory %s.", dirPath); - return false; - } - return true; -} - -/* static */ int FileUtils::getFilePathWithSuffixBufSize(const char *const filePath, - const char *const suffix) { - return strlen(filePath) + strlen(suffix) + 1 /* terminator */; -} - -/* static */ void FileUtils::getFilePathWithSuffix(const char *const filePath, - const char *const suffix, const int filePathBufSize, char *const outFilePath) { - snprintf(outFilePath, filePathBufSize, "%s%s", filePath, suffix); -} - -/* static */ int FileUtils::getFilePathBufSize(const char *const dirPath, - const char *const fileName) { - return strlen(dirPath) + 1 /* '/' */ + strlen(fileName) + 1 /* terminator */; -} - -/* static */ void FileUtils::getFilePath(const char *const dirPath, const char *const fileName, - const int filePathBufSize, char *const outFilePath) { - snprintf(outFilePath, filePathBufSize, "%s/%s", dirPath, fileName); -} - -/* static */ bool FileUtils::getFilePathWithoutSuffix(const char *const filePath, - const char *const suffix, const int outDirPathBufSize, char *const outDirPath) { - const int filePathLength = strlen(filePath); - const int suffixLength = strlen(suffix); - if (filePathLength <= suffixLength) { - AKLOGE("File path length (%s:%d) is shorter that suffix length (%s:%d).", - filePath, filePathLength, suffix, suffixLength); - return false; - } - const int resultFilePathLength = filePathLength - suffixLength; - if (outDirPathBufSize <= resultFilePathLength) { - AKLOGE("outDirPathBufSize is too small. filePath: %s, suffix: %s, outDirPathBufSize: %d", - filePath, suffix, outDirPathBufSize); - return false; - } - if (strncmp(filePath + resultFilePathLength, suffix, suffixLength) != 0) { - AKLOGE("File Path %s does not have %s as a suffix", filePath, suffix); - return false; - } - snprintf(outDirPath, resultFilePathLength + 1 /* terminator */, "%s", filePath); - return true; -} - -/* static */ void FileUtils::getDirPath(const char *const filePath, const int outDirPathBufSize, - char *const outDirPath) { - for (int i = strlen(filePath) - 1; i >= 0; --i) { - if (filePath[i] == '/') { - if (i >= outDirPathBufSize) { - AKLOGE("outDirPathBufSize is too small. filePath: %s, outDirPathBufSize: %d", - filePath, outDirPathBufSize); - ASSERT(false); - return; - } - snprintf(outDirPath, i + 1 /* terminator */, "%s", filePath); - return; - } - } -} - -/* static */ void FileUtils::getBasename(const char *const filePath, - const int outNameBufSize, char *const outName) { - const int filePathBufSize = strlen(filePath) + 1 /* terminator */; - char filePathBuf[filePathBufSize]; - snprintf(filePathBuf, filePathBufSize, "%s", filePath); - const char *const baseName = basename(filePathBuf); - const int baseNameLength = strlen(baseName); - if (baseNameLength >= outNameBufSize) { - AKLOGE("outNameBufSize is too small. filePath: %s, outNameBufSize: %d", - filePath, outNameBufSize); - return; - } - snprintf(outName, baseNameLength + 1 /* terminator */, "%s", baseName); -} - -} // namespace latinime |