diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2008-03-13 01:06:32 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2008-03-13 01:06:32 (GMT) |
commit | 5ab6c0f0ed39136bd778a6f982691e5142a7aceb (patch) | |
tree | 69b11472960aa7b64dea7527c42526a66671c197 /Source/cmTarget.cxx | |
parent | 8bf388109d1d95d1f269b6e78c90e88f217bafa3 (diff) | |
download | CMake-5ab6c0f0ed39136bd778a6f982691e5142a7aceb.zip CMake-5ab6c0f0ed39136bd778a6f982691e5142a7aceb.tar.gz CMake-5ab6c0f0ed39136bd778a6f982691e5142a7aceb.tar.bz2 |
ENH: remove abort calls and replace with an IssueMessage INTERANL_ERROR, better to not crash on the end user.
Diffstat (limited to 'Source/cmTarget.cxx')
-rw-r--r-- | Source/cmTarget.cxx | 38 |
1 files changed, 32 insertions, 6 deletions
diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx index 33c3032..2d650ac 100644 --- a/Source/cmTarget.cxx +++ b/Source/cmTarget.cxx @@ -643,7 +643,11 @@ void cmTarget::SetType(TargetType type, const char* name) type == cmTarget::INSTALL_PROGRAMS || type == cmTarget::INSTALL_DIRECTORY) { - abort(); + this->Makefile-> + IssueMessage(cmake::INTERNAL_ERROR, + "SetType called on cmTarget for INSTALL_FILES, " + "INSTALL_PROGRAMS, or INSTALL_DIRECTORY "); + return; } // only add dependency information for library targets this->TargetTypeValue = type; @@ -2099,7 +2103,11 @@ std::string cmTarget::NormalGetRealName(const char* config) // enforcement of the limited imported target API. if(this->IsImported()) { - abort(); + std::string msg = "NormalGetRealName called on imported target: "; + msg += this->GetName(); + this->GetMakefile()-> + IssueMessage(cmake::INTERNAL_ERROR, + msg.c_str()); } if(this->GetType() == cmTarget::EXECUTABLE) @@ -2424,7 +2432,11 @@ void cmTarget::GetLibraryNamesInternal(std::string& name, // enforcement of the limited imported target API. if(this->IsImported()) { - abort(); + std::string msg = "GetLibraryNamesInternal called on imported target: "; + msg += this->GetName(); + this->Makefile->IssueMessage(cmake::INTERNAL_ERROR, + msg.c_str()); + return; } // Construct the name of the soname flag variable for this language. @@ -2553,7 +2565,11 @@ void cmTarget::GetExecutableNamesInternal(std::string& name, // enforcement of the limited imported target API. if(this->IsImported()) { - abort(); + std::string msg = "GetExecutableNamesInternal called on imported target: "; + msg += this->GetName(); + this->GetMakefile()-> + IssueMessage(cmake::INTERNAL_ERROR, + msg.c_str()); } // This versioning is supported only for executables and then only @@ -2828,11 +2844,21 @@ const char* cmTarget::GetAndCreateOutputDir(bool implib, bool create) if(implib && !this->Makefile->GetDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX")) { - abort(); + std::string msg = "GetAndCreateOutputDir, imlib set but there is no " + "CMAKE_IMPORT_LIBRARY_SUFFIX for target: "; + msg += this->GetName(); + this->GetMakefile()-> + IssueMessage(cmake::INTERNAL_ERROR, + msg.c_str()); } if(implib && !this->DLLPlatform) { - abort(); + std::string msg = "implib set for platform that does not " + " support DLL's for target: "; + msg += this->GetName(); + this->GetMakefile()-> + IssueMessage(cmake::INTERNAL_ERROR, + msg.c_str()); } // Select whether we are constructing the directory for the main |