blob: 03e065666a189cb9d93788e60a69c4f3d3c7eecb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
/*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: $RCSfile$
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) 2000 National Library of Medicine
All rights reserved.
See COPYRIGHT.txt for copyright details.
=========================================================================*/
#include "cmCableCommand.h"
#include "cmCacheManager.h"
// cmCableCommand
/**
* Constructor initializes to empty m_CableData.
*/
cmCableCommand::cmCableCommand(): m_CableData(0)
{
}
/**
* Destructor frees the cmCableData only if this command is its owner.
*/
cmCableCommand::~cmCableCommand()
{
if(m_CableData && m_CableData->OwnerIs(this))
{
delete m_CableData;
}
}
/**
* Ensure that this cmCableCommand has a valid m_CableData pointer.
*/
void cmCableCommand::SetupCableData()
{
// Only do something if the pointer is invalid.
if(m_CableData)
{ return; }
// Look through the vector of commands from the makefile.
const std::vector<cmCommand*>& usedCommands =
m_Makefile->GetUsedCommands();
for(std::vector<cmCommand*>::const_iterator commandIter =
usedCommands.begin(); commandIter != usedCommands.end(); ++commandIter)
{
// If this command is a cmCableCommand, see if it has a cmCableData
// instance.
cmCableCommand* command = cmCableCommand::SafeDownCast(*commandIter);
if(command)
{ m_CableData = command->m_CableData; }
// If we found an instance of cmCableData, then we are done.
if(m_CableData)
{ return; }
}
// We must make sure the output directory exists so that the CABLE
// configuration file can be opened by the cmCableData.
std::string pathName = m_Makefile->GetStartOutputDirectory();
if(!cmSystemTools::MakeDirectory(pathName.c_str()))
{
cmSystemTools::Error("Unable to make directory ", pathName.c_str());
}
// We didn't find another cmCableCommand with a valid cmCableData.
// We must allocate the new cmCableData ourselves, and with this
// command as its owner.
pathName += "/cable_config.xml";
m_CableData = new cmCableData(this, pathName);
// We must add a custom rule to cause the cable_config.xml to be re-built
// when it is removed. Rebuilding it means re-running CMake.
std::string cMakeLists = "\"";
cMakeLists += m_Makefile->GetStartDirectory();
cMakeLists += "/";
cMakeLists += "CMakeLists.txt\"";
std::string command;
#if defined(_WIN32) && !defined(__CYGWIN__)
command = "\"";
command += m_Makefile->GetHomeDirectory();
command += "/CMake/Source/CMakeSetupCMD\" ";
command += cMakeLists;
command += " -DSP";
#else
command = "\"";
command += m_Makefile->GetHomeOutputDirectory();
command += "/CMake/Source/CMakeBuildTargets\" ";
command += cMakeLists;
#endif
command += " -H\"";
command += m_Makefile->GetHomeDirectory();
command += "\" -S\"";
command += m_Makefile->GetStartDirectory();
command += "\" -O\"";
command += m_Makefile->GetStartOutputDirectory();
command += "\" -B\"";
command += m_Makefile->GetHomeOutputDirectory();
command += "\"";
std::vector<std::string> depends;
m_Makefile->AddCustomCommand(cMakeLists.c_str(),
command.c_str(),
depends,
"cable_config.xml");
}
|