add_custom_command: Manage backtrace memory correctly (#14299)
Add an assignment operator to cmCustomCommand to copy the Backtrace member pointee and avoid multiple-free on destruction. Reported-by: Vitezslav Cizek <vcizek@suse.cz>
This commit is contained in:
parent
5dd8c01429
commit
17c841c42d
|
@ -13,6 +13,8 @@
|
||||||
|
|
||||||
#include "cmMakefile.h"
|
#include "cmMakefile.h"
|
||||||
|
|
||||||
|
#include <cmsys/auto_ptr.hxx>
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
cmCustomCommand::cmCustomCommand()
|
cmCustomCommand::cmCustomCommand()
|
||||||
{
|
{
|
||||||
|
@ -35,6 +37,32 @@ cmCustomCommand::cmCustomCommand(const cmCustomCommand& r):
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
cmCustomCommand& cmCustomCommand::operator=(cmCustomCommand const& r)
|
||||||
|
{
|
||||||
|
if(this == &r)
|
||||||
|
{
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
this->Outputs = r.Outputs;
|
||||||
|
this->Depends = r.Depends;
|
||||||
|
this->CommandLines = r.CommandLines;
|
||||||
|
this->HaveComment = r.HaveComment;
|
||||||
|
this->Comment = r.Comment;
|
||||||
|
this->WorkingDirectory = r.WorkingDirectory;
|
||||||
|
this->EscapeAllowMakeVars = r.EscapeAllowMakeVars;
|
||||||
|
this->EscapeOldStyle = r.EscapeOldStyle;
|
||||||
|
this->ImplicitDepends = r.ImplicitDepends;
|
||||||
|
|
||||||
|
cmsys::auto_ptr<cmListFileBacktrace>
|
||||||
|
newBacktrace(new cmListFileBacktrace(*r.Backtrace));
|
||||||
|
delete this->Backtrace;
|
||||||
|
this->Backtrace = newBacktrace.release();
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
cmCustomCommand::cmCustomCommand(cmMakefile* mf,
|
cmCustomCommand::cmCustomCommand(cmMakefile* mf,
|
||||||
const std::vector<std::string>& outputs,
|
const std::vector<std::string>& outputs,
|
||||||
|
|
|
@ -27,6 +27,7 @@ public:
|
||||||
/** Default and copy constructors for STL containers. */
|
/** Default and copy constructors for STL containers. */
|
||||||
cmCustomCommand();
|
cmCustomCommand();
|
||||||
cmCustomCommand(const cmCustomCommand& r);
|
cmCustomCommand(const cmCustomCommand& r);
|
||||||
|
cmCustomCommand& operator=(cmCustomCommand const& r);
|
||||||
|
|
||||||
/** Main constructor specifies all information for the command. */
|
/** Main constructor specifies all information for the command. */
|
||||||
cmCustomCommand(cmMakefile* mf,
|
cmCustomCommand(cmMakefile* mf,
|
||||||
|
|
Loading…
Reference in New Issue