From a87bdb793ec3f2f14fc2ca441851c0387bbeec35 Mon Sep 17 00:00:00 2001 From: Benjamin Kramer Date: Sat, 30 Jan 2010 14:01:39 +0000 Subject: We don't need to place 0 in the URL string now that we return a StringRef. - URL can go into read only memory now. - Compilers will fold away all the strstr calls. llvm-svn: 94887 --- clang/lib/Basic/Version.cpp | 31 +++++++++++++------------------ 1 file changed, 13 insertions(+), 18 deletions(-) (limited to 'clang/lib/Basic/Version.cpp') diff --git a/clang/lib/Basic/Version.cpp b/clang/lib/Basic/Version.cpp index fdb96e5..f9d62f9 100644 --- a/clang/lib/Basic/Version.cpp +++ b/clang/lib/Basic/Version.cpp @@ -21,27 +21,22 @@ using namespace std; namespace clang { llvm::StringRef getClangRepositoryPath() { - static const char *Path = 0; - if (Path) - return Path; - - static char URL[] = "$URL$"; - char *End = strstr(URL, "/lib/Basic"); + static const char URL[] = "$URL$"; + const char *URLEnd = URL + strlen(URL); + + const char *End = strstr(URL, "/lib/Basic"); if (End) - *End = 0; - + URLEnd = End; + End = strstr(URL, "/clang/tools/clang"); if (End) - *End = 0; - - char *Begin = strstr(URL, "cfe/"); - if (Begin) { - Path = Begin + 4; - return Path; - } - - Path = URL; - return Path; + URLEnd = End; + + const char *Begin = strstr(URL, "cfe/"); + if (Begin) + return llvm::StringRef(Begin + 4, URLEnd - Begin - 4); + + return llvm::StringRef(URL, URLEnd - URL); } -- cgit v1.1