[cfe-commits] r115049 - in /cfe/trunk: include/clang/Basic/Version.h lib/Basic/Makefile lib/Basic/Version.cpp

Daniel Dunbar daniel at zuster.org
Wed Sep 29 11:35:06 PDT 2010


On Wed, Sep 29, 2010 at 11:17 AM, Benjamin Kramer
<benny.kra at googlemail.com> wrote:
>
> On 29.09.2010, at 19:57, Daniel Dunbar wrote:
>
>> Author: ddunbar
>> Date: Wed Sep 29 12:57:10 2010
>> New Revision: 115049
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=115049&view=rev
>> Log:
>> Basic: Add support for git svn to get the repo version in clang executable,
>> patch by Jonathan Mulder!
>>
>> Modified:
>>    cfe/trunk/include/clang/Basic/Version.h
>>    cfe/trunk/lib/Basic/Makefile
>>    cfe/trunk/lib/Basic/Version.cpp
>>
>> Modified: cfe/trunk/lib/Basic/Version.cpp
>> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/Version.cpp?rev=115049&r1=115048&r2=115049&view=diff
>> ==============================================================================
>> --- cfe/trunk/lib/Basic/Version.cpp (original)
>> +++ cfe/trunk/lib/Basic/Version.cpp Wed Sep 29 12:57:10 2010
>> @@ -21,26 +21,27 @@
>> namespace clang {
>>
>> llvm::StringRef getClangRepositoryPath() {
>> -  static const char URL[] = "$URL$";
>> -  const char *URLEnd = URL + strlen(URL);
>> +#ifdef SVN_REPOSITORY
>> +  if (SVN_REPOSITORY[0] != '\0') {
>> +    static const char URL[] = SVN_REPOSITORY;
>> +    const char *URLEnd = URL + strlen(URL) - 1;
>> +
>> +    // Strip off version from a build from an integration branch.
>> +    const char *End = strstr(URL, "/src/tools/clang");
>> +    if (End)
>> +      URLEnd = End;
>> +
>> +    const char *Begin = strstr(URL, "cfe/");
>> +    if (Begin)
>> +      return llvm::StringRef(Begin + 4, URLEnd - Begin - 4);
>>
>> -  const char *End = strstr(URL, "/lib/Basic");
>> -  if (End)
>> -    URLEnd = End;
>> -
>> -  // Strip off version from a build from an integration branch.
>> -  End = strstr(URL, "/src/tools/clang");
>> -  if (End)
>> -    URLEnd = End;
>> -
>> -  const char *Begin = strstr(URL, "cfe/");
>> -  if (Begin)
>> -    return llvm::StringRef(Begin + 4, URLEnd - Begin - 4);
>> -
>> -  return llvm::StringRef(URL, URLEnd - URL);
>> +    return llvm::StringRef(URL, URLEnd - URL);
>> +  }
>> +#endif
>> +  return "";
>> }
>>
>> -std::string getClangRevision() {
>> +llvm::StringRef getClangRevision() {
>
> We can't return a string temporary as a StringRef safely.

Silly me. I spot checked the code for this in getClangRepositoryPath,
which is safe, and almost changed it anyway. Then I forgot to check
getClangRevision.

Will fix.

 - Daniel

>> #ifdef SVN_REVISION
>>   if (SVN_REVISION[0] != '\0') {
>>     std::string revision;
>> @@ -55,10 +56,15 @@
>> std::string getClangFullRepositoryVersion() {
>>   std::string buf;
>>   llvm::raw_string_ostream OS(buf);
>> -  OS << getClangRepositoryPath();
>> -  const std::string &Revision = getClangRevision();
>> -  if (!Revision.empty())
>> -    OS << ' ' << Revision;
>> +  const llvm::StringRef &Path = getClangRepositoryPath();
>> +  const llvm::StringRef &Revision = getClangRevision();
>
> Use after free due to the string problem above.
>
>> +  if (!Path.empty())
>> +    OS << Path;
>> +  if (!Revision.empty()) {
>> +    if (!Path.empty())
>> +      OS << ' ';
>> +    OS << Revision;
>> +  }
>>   return OS.str();
>> }
>




More information about the cfe-commits mailing list