aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Support
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-07-17 15:50:49 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-07-17 15:50:49 +0000
commit766e20fb6bdd526b07dd2b3d391b74707b0a809b (patch)
tree9a6453854b78d8990a35565cc0d1ad21450f4dd8 /lib/Support
parentacc20aa52c02671e05fa411f3b2d086d179794b7 (diff)
downloadexternal_llvm-766e20fb6bdd526b07dd2b3d391b74707b0a809b.zip
external_llvm-766e20fb6bdd526b07dd2b3d391b74707b0a809b.tar.gz
external_llvm-766e20fb6bdd526b07dd2b3d391b74707b0a809b.tar.bz2
Provide slightly more refined error message when trying to lookup a target, and
none are registered. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76181 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support')
-rw-r--r--lib/Support/TargetRegistry.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/lib/Support/TargetRegistry.cpp b/lib/Support/TargetRegistry.cpp
index bf631fe..b3446e6 100644
--- a/lib/Support/TargetRegistry.cpp
+++ b/lib/Support/TargetRegistry.cpp
@@ -21,6 +21,11 @@ TargetRegistry::iterator TargetRegistry::begin() {
const Target *
TargetRegistry::getClosestStaticTargetForTriple(const std::string &TT,
std::string &Error) {
+ // Provide special warning when no targets are initialized.
+ if (begin() == end()) {
+ Error = "Unable to find target for this triple (no targets are registered)";
+ return 0;
+ }
const Target *Best = 0, *EquallyBest = 0;
unsigned BestQuality = 0;
for (iterator it = begin(), ie = end(); it != ie; ++it) {
@@ -35,7 +40,7 @@ TargetRegistry::getClosestStaticTargetForTriple(const std::string &TT,
}
if (!Best) {
- Error = "No available targets are compatible with this module";
+ Error = "No available targets are compatible with this triple";
return 0;
}
@@ -53,6 +58,12 @@ TargetRegistry::getClosestStaticTargetForTriple(const std::string &TT,
const Target *
TargetRegistry::getClosestStaticTargetForModule(const Module &M,
std::string &Error) {
+ // Provide special warning when no targets are initialized.
+ if (begin() == end()) {
+ Error = "Unable to find target for this module (no targets are registered)";
+ return 0;
+ }
+
const Target *Best = 0, *EquallyBest = 0;
unsigned BestQuality = 0;
for (iterator it = begin(), ie = end(); it != ie; ++it) {
@@ -84,6 +95,12 @@ TargetRegistry::getClosestStaticTargetForModule(const Module &M,
const Target *
TargetRegistry::getClosestTargetForJIT(std::string &Error) {
+ // Provide special warning when no targets are initialized.
+ if (begin() == end()) {
+ Error = "No JIT is available for this host (no targets are registered)";
+ return 0;
+ }
+
const Target *Best = 0, *EquallyBest = 0;
unsigned BestQuality = 0;
for (iterator it = begin(), ie = end(); it != ie; ++it) {