Support/PathV2: Add has_{root_path,root_name,root_directory,parent_path,filename,stem,extension} implementation.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@120559 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Support/PathV2.cpp b/lib/Support/PathV2.cpp
index 47e59dd..57ccf89 100644
--- a/lib/Support/PathV2.cpp
+++ b/lib/Support/PathV2.cpp
@@ -370,24 +370,6 @@
return make_error_code(errc::success);
}
-error_code has_root_name(const Twine &path, bool &result) {
- SmallString<128> storage;
- StringRef p = path.toStringRef(storage);
-
- if (error_code ec = root_name(p, p)) return ec;
- result = !p.empty();
- return make_error_code(errc::success);
-}
-
-error_code has_root_directory(const Twine &path, bool &result) {
- SmallString<128> storage;
- StringRef p = path.toStringRef(storage);
-
- if (error_code ec = root_directory(p, p)) return ec;
- result = !p.empty();
- return make_error_code(errc::success);
-}
-
error_code relative_path(const StringRef &path, StringRef &result) {
StringRef root;
if (error_code ec = root_path(path, root)) return ec;
@@ -590,6 +572,76 @@
return make_error_code(errc::success);
}
+error_code has_root_name(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = root_name(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
+error_code has_root_directory(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = root_directory(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
+error_code has_root_path(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = root_path(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
+error_code has_filename(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = filename(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
+error_code has_parent_path(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = parent_path(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
+error_code has_stem(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = stem(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
+error_code has_extension(const Twine &path, bool &result) {
+ SmallString<128> path_storage;
+ StringRef p = path.toStringRef(path_storage);
+
+ if (error_code ec = extension(p, p)) return ec;
+
+ result = !p.empty();
+ return make_error_code(errc::success);
+}
+
}
}
}