2015-12-30 11:57:38 +00:00
|
|
|
//===- Error.h --------------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Linker
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2017-01-02 19:19:15 +00:00
|
|
|
//
|
|
|
|
// In LLD, we have three levels of errors: fatal, error or warn.
|
|
|
|
//
|
|
|
|
// Fatal makes the program exit immediately with an error message.
|
|
|
|
// You shouldn't use it except for reporting a corrupted input file.
|
|
|
|
//
|
|
|
|
// Error prints out an error message and increment a global variable
|
|
|
|
// ErrorCount to record the fact that we met an error condition. It does
|
|
|
|
// not exit, so it is safe for a lld-as-a-library use case. It is generally
|
2017-04-16 16:03:39 +00:00
|
|
|
// useful because it can report more than one error in a single run.
|
2017-01-02 19:19:15 +00:00
|
|
|
//
|
|
|
|
// Warn doesn't do anything but printing out a given message.
|
|
|
|
//
|
2017-04-16 16:03:39 +00:00
|
|
|
// It is not recommended to use llvm::outs() or llvm::errs() directly
|
|
|
|
// in LLD because they are not thread-safe. The functions declared in
|
|
|
|
// this file are mutually excluded, so you want to use them instead.
|
|
|
|
//
|
2017-01-02 19:19:15 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
2015-12-30 11:57:38 +00:00
|
|
|
|
2017-01-02 19:19:15 +00:00
|
|
|
#ifndef LLD_ELF_ERROR_H
|
|
|
|
#define LLD_ELF_ERROR_H
|
2015-12-30 11:57:38 +00:00
|
|
|
|
|
|
|
#include "lld/Core/LLVM.h"
|
|
|
|
|
2017-01-02 19:19:15 +00:00
|
|
|
#include "llvm/Support/Error.h"
|
|
|
|
|
2015-12-30 11:57:38 +00:00
|
|
|
namespace lld {
|
2016-07-23 20:48:50 +00:00
|
|
|
namespace elf {
|
2015-12-30 11:57:38 +00:00
|
|
|
|
2017-01-02 19:19:15 +00:00
|
|
|
extern uint64_t ErrorCount;
|
2016-07-23 20:48:50 +00:00
|
|
|
extern llvm::raw_ostream *ErrorOS;
|
2017-01-02 19:19:15 +00:00
|
|
|
extern llvm::StringRef Argv0;
|
2016-07-23 20:48:50 +00:00
|
|
|
|
|
|
|
void log(const Twine &Msg);
|
2017-04-16 16:03:39 +00:00
|
|
|
void message(const Twine &Msg);
|
2017-01-02 19:19:15 +00:00
|
|
|
void warn(const Twine &Msg);
|
2016-07-23 20:48:50 +00:00
|
|
|
void error(const Twine &Msg);
|
2017-04-16 16:03:39 +00:00
|
|
|
LLVM_ATTRIBUTE_NORETURN void fatal(const Twine &Msg);
|
2015-12-30 11:57:38 +00:00
|
|
|
|
2017-01-02 19:19:15 +00:00
|
|
|
LLVM_ATTRIBUTE_NORETURN void exitLld(int Val);
|
2016-07-23 20:48:50 +00:00
|
|
|
|
2017-01-02 19:19:15 +00:00
|
|
|
// check() functions are convenient functions to strip errors
|
|
|
|
// from error-or-value objects.
|
2016-07-23 20:48:50 +00:00
|
|
|
template <class T> T check(ErrorOr<T> E) {
|
|
|
|
if (auto EC = E.getError())
|
|
|
|
fatal(EC.message());
|
|
|
|
return std::move(*E);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T> T check(Expected<T> E) {
|
|
|
|
if (!E)
|
2017-01-14 15:39:25 +00:00
|
|
|
fatal(llvm::toString(E.takeError()));
|
2016-07-23 20:48:50 +00:00
|
|
|
return std::move(*E);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T> T check(ErrorOr<T> E, const Twine &Prefix) {
|
|
|
|
if (auto EC = E.getError())
|
2017-01-02 19:19:15 +00:00
|
|
|
fatal(Prefix + ": " + EC.message());
|
2016-07-23 20:48:50 +00:00
|
|
|
return std::move(*E);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T> T check(Expected<T> E, const Twine &Prefix) {
|
|
|
|
if (!E)
|
2017-04-16 16:03:39 +00:00
|
|
|
fatal(Prefix + ": " + toString(E.takeError()));
|
2016-07-23 20:48:50 +00:00
|
|
|
return std::move(*E);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace elf
|
2015-12-30 11:57:38 +00:00
|
|
|
} // namespace lld
|
|
|
|
|
|
|
|
#endif
|