add bitcode support, optimize reading to not read all function bodies just

to get deplibs

llvm-svn: 36851
This commit is contained in:
Chris Lattner 2007-05-06 05:51:37 +00:00
parent 206534649d
commit 5f13aacd15
2 changed files with 17 additions and 5 deletions

View File

@ -15,7 +15,9 @@
#include "CompilerDriver.h"
#include "ConfigLexer.h"
#include "llvm/Module.h"
#include "llvm/Bitcode/ReaderWriter.h"
#include "llvm/Bytecode/Reader.h"
#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Support/Timer.h"
#include "llvm/System/Signals.h"
#include "llvm/ADT/SetVector.h"
@ -24,6 +26,9 @@
#include <iostream>
using namespace llvm;
static bool Bitcode = false;
namespace {
void WriteAction(CompilerDriver::Action* action ) {
@ -66,14 +71,21 @@ static bool GetBytecodeDependentLibraries(const std::string &fname,
Module::LibraryListType& deplibs,
BCDecompressor_t *BCDC,
std::string* ErrMsg) {
ModuleProvider* MP = getBytecodeModuleProvider(fname, BCDC, ErrMsg);
ModuleProvider *MP = 0;
if (Bitcode) {
if (MemoryBuffer *Buffer = MemoryBuffer::getFileOrSTDIN(&fname[0],
fname.size())) {
MP = getBitcodeModuleProvider(Buffer);
if (MP == 0) delete Buffer;
}
} else {
MP = getBytecodeModuleProvider(fname, BCDC, ErrMsg);
}
if (!MP) {
deplibs.clear();
return true;
}
Module* M = MP->releaseModule(ErrMsg);
deplibs = M->getLibraries();
delete M;
deplibs = MP->getModule()->getLibraries();
delete MP;
return false;
}

View File

@ -8,7 +8,7 @@
##===----------------------------------------------------------------------===##
LEVEL = ../..
TOOLNAME = llvmc
LINK_COMPONENTS = support system core bcreader
LINK_COMPONENTS = support system core bcreader bitreader
CONFIG_FILES = c cpp ll st
EXTRA_DIST = c cpp ll ConfigLexer.cpp.cvs ConfigLexer.l.cvs
REQUIRES_EH := 1