aboutsummaryrefslogtreecommitdiffstats
path: root/lib/System
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-05-06 05:32:21 +0000
committerChris Lattner <sabre@nondot.org>2007-05-06 05:32:21 +0000
commitf283a5e53a99d13035a9e783acff80d4ea064a92 (patch)
tree427ceda31a38aa6c237ac5a53a6601325b22cad7 /lib/System
parent609083b9e035b1545cf75111c576fc32aa536d6d (diff)
downloadexternal_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.cpp29
-rw-r--r--lib/System/Unix/Path.inc31
-rw-r--r--lib/System/Win32/Path.inc15
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());