diff options
author | Juergen Ributzka <juergen@apple.com> | 2015-03-02 18:59:38 +0000 |
---|---|---|
committer | Juergen Ributzka <juergen@apple.com> | 2015-03-02 18:59:38 +0000 |
commit | a57d588cb7109c45b63a46ef6598f03745486f98 (patch) | |
tree | 24dc8dc3c39c31ca4f35c411678e1ee1fea76c17 /llvm | |
parent | 468e055f5461f8c6aba108a44ef1e3714609f479 (diff) | |
download | llvm-a57d588cb7109c45b63a46ef6598f03745486f98.zip llvm-a57d588cb7109c45b63a46ef6598f03745486f98.tar.gz llvm-a57d588cb7109c45b63a46ef6598f03745486f98.tar.bz2 |
Restore LLVMLinkModules C API until it is properly deprecated.
Add the enum "LLVMLinkerMode" back for backwards-compatibility and add the
linker mode parameter back to the "LLVMLinkModules" function. The paramter is
ignored and has no effect.
Patch provided by: Filip Pizlo
Reviewed by: Rafael and Sean
llvm-svn: 230988
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/bindings/go/llvm/linker.go | 2 | ||||
-rw-r--r-- | llvm/include/llvm-c/Linker.h | 14 | ||||
-rw-r--r-- | llvm/lib/Linker/LinkModules.cpp | 2 |
3 files changed, 14 insertions, 4 deletions
diff --git a/llvm/bindings/go/llvm/linker.go b/llvm/bindings/go/llvm/linker.go index 64d794e..f64f66c 100644 --- a/llvm/bindings/go/llvm/linker.go +++ b/llvm/bindings/go/llvm/linker.go @@ -22,7 +22,7 @@ import "errors" func LinkModules(Dest, Src Module) error { var cmsg *C.char - failed := C.LLVMLinkModules(Dest.C, Src.C, 0, &cmsg) + failed := C.LLVMLinkModules(Dest.C, Src.C, C.LLVMLinkerDestroySource, &cmsg) if failed != 0 { err := errors.New(C.GoString(cmsg)) C.LLVMDisposeMessage(cmsg) diff --git a/llvm/include/llvm-c/Linker.h b/llvm/include/llvm-c/Linker.h index cedde5e..9f98a33 100644 --- a/llvm/include/llvm-c/Linker.h +++ b/llvm/include/llvm-c/Linker.h @@ -20,13 +20,23 @@ extern "C" { #endif +/* This enum is provided for backwards-compatibility only. It has no effect. */ +typedef enum { + LLVMLinkerDestroySource = 0, /* This is the default behavior. */ + LLVMLinkerPreserveSource_Removed = 1 /* This option has been deprecated and + should not be used. */ +} LLVMLinkerMode; + /* Links the source module into the destination module, taking ownership * of the source module away from the caller. Optionally returns a * human-readable description of any errors that occurred in linking. * OutMessage must be disposed with LLVMDisposeMessage. The return value - * is true if an error occurred, false otherwise. */ + * is true if an error occurred, false otherwise. + * + * Note that the linker mode parameter \p Unused is no longer used, and has + * no effect. */ LLVMBool LLVMLinkModules(LLVMModuleRef Dest, LLVMModuleRef Src, - unsigned Unused, char **OutMessage); + LLVMLinkerMode Unused, char **OutMessage); #ifdef __cplusplus } diff --git a/llvm/lib/Linker/LinkModules.cpp b/llvm/lib/Linker/LinkModules.cpp index e6d9acc..e09f02e 100644 --- a/llvm/lib/Linker/LinkModules.cpp +++ b/llvm/lib/Linker/LinkModules.cpp @@ -1777,7 +1777,7 @@ bool Linker::LinkModules(Module *Dest, Module *Src) { //===----------------------------------------------------------------------===// LLVMBool LLVMLinkModules(LLVMModuleRef Dest, LLVMModuleRef Src, - unsigned Unused, char **OutMessages) { + LLVMLinkerMode Unused, char **OutMessages) { Module *D = unwrap(Dest); std::string Message; raw_string_ostream Stream(Message); |