blob: a83d7e1eab11489a25cfae0739e9debb08ea473e (
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
/*=========================================================================
Program: CMake - Cross-Platform Makefile Generator
Module: $RCSfile$
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#include "cmExportLibraryDependencies.h"
#include "cmGlobalGenerator.h"
#include "cmLocalGenerator.h"
#include "cmGeneratedFileStream.h"
#include "cmake.h"
#include <memory> // auto_ptr
// cmExecutableCommand
bool cmExportLibraryDependenciesCommand::InitialPass(std::vector<std::string> const& args)
{
// First argument is the name of the test
// Second argument is the name of the executable to run (a target or external
// program)
// Remaining arguments are the arguments to pass to the executable
if(args.size() < 1 )
{
this->SetError("called with incorrect number of arguments");
return false;
}
// store the arguments for the final pass
// also expand any CMake variables
m_Args = args;
return true;
}
void cmExportLibraryDependenciesCommand::FinalPass()
{
// don't do anything if local mode
if(m_Makefile->GetLocal())
{
return;
}
// Create a full path filename for output
std::string fname = m_Args[0];
bool append = false;
if(m_Args.size() > 1)
{
if(m_Args[1] == "APPEND")
{
append = true;
}
}
// Use copy-if-different if not appending.
std::ostream* foutPtr;
std::auto_ptr<cmGeneratedFileStream> foutNew;
if(append)
{
foutPtr = new std::ofstream(fname.c_str(), std::ios::app);
}
else
{
std::auto_ptr<cmGeneratedFileStream> ap(
new cmGeneratedFileStream(fname.c_str(), true, true));
foutNew = ap;
foutPtr = foutNew.get();
}
std::ostream& fout = *foutPtr;
if (!fout)
{
cmSystemTools::Error("Error Writing ", fname.c_str());
cmSystemTools::ReportLastSystemError("");
return;
}
cmake* cm = m_Makefile->GetCMakeInstance();
cmGlobalGenerator* global = cm->GetGlobalGenerator();
std::vector<cmLocalGenerator *> locals;
global->GetLocalGenerators(locals);
std::string libDepName;
for(std::vector<cmLocalGenerator *>::iterator i = locals.begin();
i != locals.end(); ++i)
{
cmLocalGenerator* gen = *i;
cmTargets &tgts = gen->GetMakefile()->GetTargets();
std::vector<std::string> depends;
const char *defType;
for(cmTargets::const_iterator l = tgts.begin();
l != tgts.end(); ++l)
{
if ((l->second.GetType() != cmTarget::INSTALL_FILES)
&& (l->second.GetType() != cmTarget::INSTALL_PROGRAMS))
{
libDepName = l->first;
libDepName += "_LIB_DEPENDS";
const char* def = m_Makefile->GetDefinition(libDepName.c_str());
if(def)
{
fout << "SET(" << libDepName << " \"" << def << "\")\n";
// now for each dependency, check for link type
cmSystemTools::ExpandListArgument(def, depends);
for(std::vector<std::string>::const_iterator d = depends.begin();
d != depends.end(); ++d)
{
libDepName = *d;
libDepName += "_LINK_TYPE";
defType = m_Makefile->GetDefinition(libDepName.c_str());
libDepName = cmSystemTools::EscapeSpaces(libDepName.c_str());
if(defType)
{
fout << "SET(" << libDepName << " \"" << defType << "\")\n";
}
}
}
}
}
}
return;
}
|