summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2008-06-15 15:15:19 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2008-06-15 15:15:19 +0000
commitfc19988bcbe6cfbe4668c50cd9689a711cc26cdd (patch)
tree6554a7d91fba95551482d0f47239babb2f6c7471
parent1662183a83063313af24708c323817daf4bad195 (diff)
downloadexternal_llvm-fc19988bcbe6cfbe4668c50cd9689a711cc26cdd.zip
external_llvm-fc19988bcbe6cfbe4668c50cd9689a711cc26cdd.tar.gz
external_llvm-fc19988bcbe6cfbe4668c50cd9689a711cc26cdd.tar.bz2
Fix the sys::Path::getSuffix() implementation.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52288 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/System/Path.cpp5
-rw-r--r--lib/System/Unix/Path.inc16
-rw-r--r--lib/System/Win32/Path.inc16
3 files changed, 32 insertions, 5 deletions
diff --git a/lib/System/Path.cpp b/lib/System/Path.cpp
index 03cdbf7..af400e9 100644
--- a/lib/System/Path.cpp
+++ b/lib/System/Path.cpp
@@ -185,11 +185,6 @@ bool Path::hasMagicNumber(const std::string &Magic) const {
return false;
}
-std::string
-Path::getSuffix() const {
- return path.substr(path.rfind('.') + 1);
-}
-
static void getPathList(const char*path, std::vector<Path>& Paths) {
const char* at = path;
const char* delim = strchr(at, PathSeparator);
diff --git a/lib/System/Unix/Path.inc b/lib/System/Unix/Path.inc
index 6035a14..5b91b03 100644
--- a/lib/System/Unix/Path.inc
+++ b/lib/System/Unix/Path.inc
@@ -303,6 +303,22 @@ Path::getBasename() const {
return path.substr(slash, dot - slash);
}
+std::string
+Path::getSuffix() const {
+ // Find the last slash
+ std::string::size_type slash = path.rfind('/');
+ if (slash == std::string::npos)
+ slash = 0;
+ else
+ slash++;
+
+ std::string::size_type dot = path.rfind('.');
+ if (dot == std::string::npos || dot < slash)
+ return std::string()
+ else
+ return path.substr(dot + 1);
+}
+
bool Path::getMagicNumber(std::string& Magic, unsigned len) const {
assert(len < 1024 && "Request for magic string too long");
char* buf = (char*) alloca(1 + len);
diff --git a/lib/System/Win32/Path.inc b/lib/System/Win32/Path.inc
index b5897053..8f33664 100644
--- a/lib/System/Win32/Path.inc
+++ b/lib/System/Win32/Path.inc
@@ -259,6 +259,22 @@ Path::getBasename() const {
return path.substr(slash, dot - slash);
}
+std::string
+Path::getSuffix() const {
+ // Find the last slash
+ size_t slash = path.rfind('/');
+ if (slash == std::string::npos)
+ slash = 0;
+ else
+ slash++;
+
+ size_t dot = path.rfind('.');
+ if (dot == std::string::npos || dot < slash)
+ return std::string();
+ else
+ return path.substr(dot + 1);
+}
+
bool
Path::exists() const {
DWORD attr = GetFileAttributes(path.c_str());