diff options
author | Chris Lattner <sabre@nondot.org> | 2007-02-07 21:41:02 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-02-07 21:41:02 +0000 |
commit | f2e292ce58ca07d9bbe3cad75f8baa35bd85964a (patch) | |
tree | d3bc0114e2f71983baef4c33631278640cd7a1cd /include/llvm/Bytecode/Analyzer.h | |
parent | 403e4a4725af21c267d4189fe88bc48bd438b08c (diff) |
push bytecode decompressor out through APIs. Now the bytecode reader
api's look like this:
ModuleProvider *getBytecodeModuleProvider(
const std::string &Filename, ///< Name of file to be read
BCDecompressor_t *BCDC = Compressor::decompressToNewBuffer,
std::string* ErrMsg = 0, ///< Optional error message holder
BytecodeHandler* H = 0 ///< Optional handler for reader events
);
This is ugly, but allows a client to say:
getBytecodeModuleProvider("foo", 0);
If they do this, there is no dependency on the compression libraries, saving
codesize.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34012 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Bytecode/Analyzer.h')
-rw-r--r-- | include/llvm/Bytecode/Analyzer.h | 17 |
1 files changed, 3 insertions, 14 deletions
diff --git a/include/llvm/Bytecode/Analyzer.h b/include/llvm/Bytecode/Analyzer.h index b6a0eed220..7d02f68eee 100644 --- a/include/llvm/Bytecode/Analyzer.h +++ b/include/llvm/Bytecode/Analyzer.h @@ -20,9 +20,10 @@ #define LLVM_BYTECODE_ANALYZER_H #include "llvm/Bytecode/Format.h" +#include "llvm/Bytecode/Reader.h" #include <string> #include <map> -#include <ostream> +#include <iosfwd> namespace llvm { @@ -102,23 +103,11 @@ struct BytecodeAnalysis { Module* AnalyzeBytecodeFile( const std::string& Filename, ///< The name of the bytecode file to read BytecodeAnalysis& Results, ///< The results of the analysis + BCDecompressor_t *BCDC = 0, ///< Optional decompressor to use. std::string* ErrorStr = 0, ///< Errors, if any. std::ostream* output = 0 ///< Stream for dump output, if wanted ); -/// This function is an alternate entry point into the bytecode analysis -/// library. It allows you to provide an arbitrary memory buffer which is -/// assumed to contain a complete bytecode file. The \p Buffer is analyzed and -/// the \p Results are filled in. -/// @brief Analyze contents of a bytecode buffer. -Module* AnalyzeBytecodeBuffer( - const unsigned char* Buffer, ///< Pointer to start of bytecode buffer - unsigned BufferSize, ///< Size of the bytecode buffer - const std::string& ModuleID, ///< Identifier for the module - BytecodeAnalysis& Results, ///< The results of the analysis - std::string* ErrorStr = 0, ///< Errors, if any. - std::ostream* output = 0 ///< Stream for dump output, if wanted - ); /// This function prints the contents of rhe BytecodeAnalysis structure in /// a human legible form. |