diff options
Diffstat (limited to 'lib/ReaderWriter/MachO/MachONormalizedFileBinaryUtils.h')
| -rw-r--r-- | lib/ReaderWriter/MachO/MachONormalizedFileBinaryUtils.h | 9 | 
1 files changed, 4 insertions, 5 deletions
diff --git a/lib/ReaderWriter/MachO/MachONormalizedFileBinaryUtils.h b/lib/ReaderWriter/MachO/MachONormalizedFileBinaryUtils.h index 407bd9b97020..ee9e174b82e0 100644 --- a/lib/ReaderWriter/MachO/MachONormalizedFileBinaryUtils.h +++ b/lib/ReaderWriter/MachO/MachONormalizedFileBinaryUtils.h @@ -186,11 +186,10 @@ packRelocation(const Relocation &r, bool swap, bool isBigEndian) {  }  inline StringRef getString16(const char s[16]) { -  StringRef x = s; -  if ( x.size() > 16 ) -    return x.substr(0, 16); -  else -    return x; +  // The StringRef(const char *) constructor passes the const char * to +  // strlen(), so we can't use this constructor here, because if there is no +  // null terminator in s, then strlen() will read past the end of the array. +  return StringRef(s, strnlen(s, 16));  }  inline void setString16(StringRef str, char s[16]) {  | 
