diff options
author | 2023-09-06 18:16:00 +0000 | |
---|---|---|
committer | 2023-09-06 18:16:00 +0000 | |
commit | 13ab173d417f9b64161b0101d15b63fddf9fc0ee (patch) | |
tree | 43aaf343533ecd7a3c7eab67e6b4e36fa6e6b631 /tools/aapt/Utils.cpp | |
parent | 45d1834d5e63badf9b770d222f479640be8ef658 (diff) | |
parent | 9a80e1b70c9b9aaef268c8c0ea04b3fa5ce3debb (diff) |
Merge "Move String8 path functions to androidfw and aapt" into main am: 713e3930c4 am: 0cfc1c6ddd am: 9a80e1b70c
Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/2723454
Change-Id: I62ce3b1f70692316e65c3531b1dda07ceb25fea8
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'tools/aapt/Utils.cpp')
-rw-r--r-- | tools/aapt/Utils.cpp | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/tools/aapt/Utils.cpp b/tools/aapt/Utils.cpp index 36b018e7dd2c..946916a0598a 100644 --- a/tools/aapt/Utils.cpp +++ b/tools/aapt/Utils.cpp @@ -36,3 +36,26 @@ void convertToResPath([[maybe_unused]] String8& s) { } #endif } + +String8 walkPath(const String8& path, String8* outRemains) { + const char* cp; + const char* const str = path.c_str(); + const char* buf = str; + + cp = strchr(buf, OS_PATH_SEPARATOR); + if (cp == buf) { + // don't include a leading '/'. + buf = buf + 1; + cp = strchr(buf, OS_PATH_SEPARATOR); + } + + if (cp == nullptr) { + String8 res = buf != str ? String8(buf) : path; + if (outRemains) *outRemains = String8(); + return res; + } + + String8 res(buf, cp - buf); + if (outRemains) *outRemains = String8(cp + 1); + return res; +} |