summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-07-06 20:24:32 (GMT)
committerBrad King <brad.king@kitware.com>2009-07-06 20:24:32 (GMT)
commit82a8c6b0c725496315e45e11ce8bcfb970c82bcf (patch)
tree9baa68401cd24f44a2e52ca40b8322ba551d8897 /Source
parent2b85fcdd7d6fb3f08a20d57f3c6bdad30d9d880c (diff)
downloadCMake-82a8c6b0c725496315e45e11ce8bcfb970c82bcf.zip
CMake-82a8c6b0c725496315e45e11ce8bcfb970c82bcf.tar.gz
CMake-82a8c6b0c725496315e45e11ce8bcfb970c82bcf.tar.bz2
ENH: Exception safe link interface computation
This fixes cmTarget::GetLinkInterface to compute and return the link interface in an exception-safe manner. We manage the link interface returned by cmTarget::ComputeLinkInterface using auto_ptr.
Diffstat (limited to 'Source')
-rw-r--r--Source/cmTarget.cxx17
-rw-r--r--Source/cmTarget.h5
2 files changed, 14 insertions, 8 deletions
diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx
index 6065890..3d6e1b7 100644
--- a/Source/cmTarget.cxx
+++ b/Source/cmTarget.cxx
@@ -3696,19 +3696,22 @@ cmTargetLinkInterface const* cmTarget::GetLinkInterface(const char* config)
if(i == this->LinkInterface.end())
{
// Compute the link interface for this configuration.
- cmTargetLinkInterface* iface = this->ComputeLinkInterface(config);
+ cmsys::auto_ptr<cmTargetLinkInterface>
+ iface(this->ComputeLinkInterface(config));
// Store the information for this configuration.
std::map<cmStdString, cmTargetLinkInterface*>::value_type
- entry(config?config:"", iface);
+ entry(config?config:"", 0);
i = this->LinkInterface.insert(entry).first;
+ i->second = iface.release();
}
return i->second;
}
//----------------------------------------------------------------------------
-cmTargetLinkInterface* cmTarget::ComputeLinkInterface(const char* config)
+cmsys::auto_ptr<cmTargetLinkInterface>
+cmTarget::ComputeLinkInterface(const char* config)
{
// Construct the property name suffix for this configuration.
std::string suffix = "_";
@@ -3739,14 +3742,14 @@ cmTargetLinkInterface* cmTarget::ComputeLinkInterface(const char* config)
// If still not set, there is no link interface.
if(!libs)
{
- return 0;
+ return cmsys::auto_ptr<cmTargetLinkInterface>();
}
// Allocate the interface.
- cmTargetLinkInterface* iface = new cmTargetLinkInterface;
- if(!iface)
+ cmsys::auto_ptr<cmTargetLinkInterface> iface(new cmTargetLinkInterface);
+ if(!iface.get())
{
- return 0;
+ return cmsys::auto_ptr<cmTargetLinkInterface>();
}
// Expand the list of libraries in the interface.
diff --git a/Source/cmTarget.h b/Source/cmTarget.h
index 12b8bb4..9e17d60 100644
--- a/Source/cmTarget.h
+++ b/Source/cmTarget.h
@@ -21,6 +21,8 @@
#include "cmPropertyMap.h"
#include "cmPolicies.h"
+#include <cmsys/auto_ptr.hxx>
+
class cmake;
class cmMakefile;
class cmSourceFile;
@@ -533,7 +535,8 @@ private:
cmTargetLinkInformationMap LinkInformation;
// Link interface.
- cmTargetLinkInterface* ComputeLinkInterface(const char* config);
+ cmsys::auto_ptr<cmTargetLinkInterface>
+ ComputeLinkInterface(const char* config);
cmTargetLinkInterfaceMap LinkInterface;
// The cmMakefile instance that owns this target. This should