diff options
author | Chris Lattner <sabre@nondot.org> | 2007-05-06 05:32:21 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-05-06 05:32:21 +0000 |
commit | f283a5e53a99d13035a9e783acff80d4ea064a92 (patch) | |
tree | 427ceda31a38aa6c237ac5a53a6601325b22cad7 /lib/System | |
parent | 609083b9e035b1545cf75111c576fc32aa536d6d (diff) | |
download | external_llvm-f283a5e53a99d13035a9e783acff80d4ea064a92.zip external_llvm-f283a5e53a99d13035a9e783acff80d4ea064a92.tar.gz external_llvm-f283a5e53a99d13035a9e783acff80d4ea064a92.tar.bz2 |
pull some win32 code into common code, add bitcode identification support.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36846 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/System')
-rw-r--r-- | lib/System/Path.cpp | 29 | ||||
-rw-r--r-- | lib/System/Unix/Path.inc | 31 | ||||
-rw-r--r-- | lib/System/Win32/Path.inc | 15 |
3 files changed, 29 insertions, 46 deletions
diff --git a/lib/System/Path.cpp b/lib/System/Path.cpp index 634ce5d..fcdc5ff 100644 --- a/lib/System/Path.cpp +++ b/lib/System/Path.cpp @@ -43,6 +43,10 @@ sys::IdentifyFileType(const char*magic, unsigned length) { assert(magic && "Invalid magic number string"); assert(length >=4 && "Invalid magic number length"); switch (magic[0]) { + case 'B': + if (magic[1] == 'C' && magic[2] == (char)0xC0 && magic[3] == (char)0xDE) + return Bitcode_FileType; + break; case 'l': if (magic[1] == 'l' && magic[2] == 'v') { if (magic[3] == 'c') @@ -160,6 +164,31 @@ std::string Path::GetDLLSuffix() { return LTDL_SHLIB_EXT; } +bool +Path::isBytecodeFile() const { + std::string actualMagic; + if (!getMagicNumber(actualMagic, 4)) + return false; + return actualMagic == "llvc" || actualMagic == "llvm"; +} + +bool +Path::isBitcodeFile() const { + std::string actualMagic; + if (!getMagicNumber(actualMagic, 4)) + return false; + return actualMagic == "BC\xC0\xDE"; +} + +bool Path::hasMagicNumber(const std::string &Magic) const { + std::string actualMagic; + if (getMagicNumber(actualMagic, Magic.size())) + return Magic == actualMagic; + return false; +} + + + // Include the truly platform-specific parts of this class. #if defined(LLVM_ON_UNIX) #include "Unix/Path.inc" diff --git a/lib/System/Unix/Path.inc b/lib/System/Unix/Path.inc index 53906d9..db95e3c 100644 --- a/lib/System/Unix/Path.inc +++ b/lib/System/Unix/Path.inc @@ -267,21 +267,6 @@ Path::getBasename() const { return path.substr(slash, dot - slash); } -bool Path::hasMagicNumber(const std::string &Magic) const { - size_t len = Magic.size(); - assert(len < 1024 && "Request for magic string too long"); - char* buf = (char*) alloca(1 + len); - int fd = ::open(path.c_str(), O_RDONLY); - if (fd < 0) - return false; - size_t read_len = ::read(fd, buf, len); - close(fd); - if (len != read_len) - return false; - buf[len] = '\0'; - return Magic == buf; -} - bool Path::getMagicNumber(std::string& Magic, unsigned len) const { assert(len < 1024 && "Request for magic string too long"); char* buf = (char*) alloca(1 + len); @@ -298,22 +283,6 @@ bool Path::getMagicNumber(std::string& Magic, unsigned len) const { return true; } -bool -Path::isBytecodeFile() const { - char buffer[4]; - buffer[0] = 0; - int fd = ::open(path.c_str(), O_RDONLY); - if (fd < 0) - return false; - ssize_t bytes_read = ::read(fd, buffer, 4); - ::close(fd); - if (4 != bytes_read) - return false; - - return (buffer[0] == 'l' && buffer[1] == 'l' && buffer[2] == 'v' && - (buffer[3] == 'c' || buffer[3] == 'm')); -} - bool Path::exists() const { return 0 == access(path.c_str(), F_OK ); diff --git a/lib/System/Win32/Path.inc b/lib/System/Win32/Path.inc index f28fe86..67f16a7 100644 --- a/lib/System/Win32/Path.inc +++ b/lib/System/Win32/Path.inc @@ -247,21 +247,6 @@ Path::getBasename() const { return path.substr(slash, dot - slash); } -bool Path::hasMagicNumber(const std::string &Magic) const { - std::string actualMagic; - if (getMagicNumber(actualMagic, Magic.size())) - return Magic == actualMagic; - return false; -} - -bool -Path::isBytecodeFile() const { - std::string actualMagic; - if (!getMagicNumber(actualMagic, 4)) - return false; - return actualMagic == "llvc" || actualMagic == "llvm"; -} - bool Path::exists() const { DWORD attr = GetFileAttributes(path.c_str()); |