summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndroid (Google) Code Review <android-gerrit@google.com>2009-06-04 14:10:07 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2009-06-04 14:10:07 -0700
commit2b5f84a117ee6f51ed21239719afba0f33c182ff (patch)
treeb771095d36081829fe9323631d0d20b2787a3ca7
parent2a3188672ab2b65c0ce7c9c598a463e382c47696 (diff)
parent24bd82a92fe13040e9d7e2ca1942043ed5931754 (diff)
downloadframeworks_base-2b5f84a117ee6f51ed21239719afba0f33c182ff.zip
frameworks_base-2b5f84a117ee6f51ed21239719afba0f33c182ff.tar.gz
frameworks_base-2b5f84a117ee6f51ed21239719afba0f33c182ff.tar.bz2
Merge change 3207 into donut
* changes: localize: remove dependency on mkdirs/etc in libhost
-rw-r--r--tools/localize/Android.mk1
-rw-r--r--tools/localize/file_utils.cpp36
2 files changed, 35 insertions, 2 deletions
diff --git a/tools/localize/Android.mk b/tools/localize/Android.mk
index 186177f..ab79f8d 100644
--- a/tools/localize/Android.mk
+++ b/tools/localize/Android.mk
@@ -53,4 +53,3 @@ ifeq (a,a)
endif
include $(BUILD_HOST_EXECUTABLE)
-
diff --git a/tools/localize/file_utils.cpp b/tools/localize/file_utils.cpp
index bb82a9c..8792b9e 100644
--- a/tools/localize/file_utils.cpp
+++ b/tools/localize/file_utils.cpp
@@ -3,12 +3,46 @@
#include <unistd.h>
#include "file_utils.h"
#include "Perforce.h"
+#include <utils/String8.h>
#include <sys/fcntl.h>
#include <sys/stat.h>
#include <errno.h>
-#include <host/Directories.h>
#include "log.h"
+using namespace android;
+using namespace std;
+
+static string
+parent_dir(const string& path)
+{
+ return string(String8(path.c_str()).getPathDir().string());
+}
+
+static int
+mkdirs(const char* last)
+{
+ String8 dest;
+ const char* s = last-1;
+ int err;
+ do {
+ s++;
+ if (s > last && (*s == '.' || *s == 0)) {
+ String8 part(last, s-last);
+ dest.appendPath(part);
+#ifdef HAVE_MS_C_RUNTIME
+ err = _mkdir(dest.string());
+#else
+ err = mkdir(dest.string(), S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP);
+#endif
+ if (err != 0) {
+ return err;
+ }
+ last = s+1;
+ }
+ } while (*s);
+ return 0;
+}
+
string
translated_file_name(const string& file, const string& locale)
{