summaryrefslogtreecommitdiff
path: root/Source
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2002-01-17 14:11:26 -0500
committerAndy Cedilnik <andy.cedilnik@kitware.com>2002-01-17 14:11:26 -0500
commite77515c2da3fcbc52809de9f148b6807459e1f28 (patch)
tree6e54579c8f873c7651c785be25ee48782cb10da4 /Source
parent3df3d839ccf5430e6c033ab4f0745d5f2e65d8c6 (diff)
downloadcmake-e77515c2da3fcbc52809de9f148b6807459e1f28.tar.gz
Add option of adding generated files to source list
Diffstat (limited to 'Source')
-rw-r--r--Source/cmSourceFilesCommand.cxx59
-rw-r--r--Source/cmSourceFilesCommand.h11
2 files changed, 56 insertions, 14 deletions
diff --git a/Source/cmSourceFilesCommand.cxx b/Source/cmSourceFilesCommand.cxx
index 003bc2f7da..e6d7176200 100644
--- a/Source/cmSourceFilesCommand.cxx
+++ b/Source/cmSourceFilesCommand.cxx
@@ -51,32 +51,65 @@ bool cmSourceFilesCommand::InitialPass(std::vector<std::string> const& args)
std::string name = args[0];
m_Makefile->ExpandVariablesInString(name);
+
+ int generated = 0;
for(std::vector<std::string>::const_iterator i = (args.begin() + 1);
i != args.end(); ++i)
{
std::string copy = *i;
- m_Makefile->ExpandVariablesInString(copy);
+ // Keyword GENERATED in the source file list means that
+ // from here on files will be generated
+ if ( copy == "GENERATED" )
+ {
+ generated = 1;
+ continue;
+ }
cmSourceFile file;
+ m_Makefile->ExpandVariablesInString(copy);
file.SetIsAnAbstractClass(false);
std::string path = cmSystemTools::GetFilenamePath(copy);
- // if this is a full path then
- if((path.size() && path[0] == '/') ||
- (path.size() > 1 && path[1] == ':'))
+ if ( generated )
{
- file.SetName(cmSystemTools::GetFilenameName(copy.c_str()).c_str(),
- path.c_str(),
- m_Makefile->GetSourceExtensions(),
- m_Makefile->GetHeaderExtensions());
+ // This file will be generated, so we should not check
+ // if it exist.
+ std::string ext = cmSystemTools::GetFilenameExtension(copy);
+ std::string name_no_ext = cmSystemTools::GetFilenameName(copy.c_str());
+ name_no_ext = name_no_ext.substr(0, name_no_ext.length()-ext.length());
+ if ( ext[0] == '.' )
+ {
+ ext = ext.substr(1);
+ }
+ if((path.size() && path[0] == '/') ||
+ (path.size() > 1 && path[1] == ':'))
+ {
+ file.SetName(name_no_ext.c_str(), path.c_str(), ext.c_str(), false);
+ }
+ else
+ {
+ file.SetName(name_no_ext.c_str(), m_Makefile->GetCurrentOutputDirectory(),
+ ext.c_str(), false);
+ }
}
else
- {
- file.SetName(copy.c_str(), m_Makefile->GetCurrentDirectory(),
- m_Makefile->GetSourceExtensions(),
- m_Makefile->GetHeaderExtensions());
- }
+ // if this is a full path then
+ if((path.size() && path[0] == '/') ||
+ (path.size() > 1 && path[1] == ':'))
+ {
+ file.SetName(cmSystemTools::GetFilenameName(copy.c_str()).c_str(),
+ path.c_str(),
+ m_Makefile->GetSourceExtensions(),
+ m_Makefile->GetHeaderExtensions());
+ }
+ else
+ {
+ file.SetName(copy.c_str(), m_Makefile->GetCurrentDirectory(),
+ m_Makefile->GetSourceExtensions(),
+ m_Makefile->GetHeaderExtensions());
+ }
m_Makefile->AddSource(file, name.c_str());
}
+
return true;
}
diff --git a/Source/cmSourceFilesCommand.h b/Source/cmSourceFilesCommand.h
index 235c6b6ce3..924573f386 100644
--- a/Source/cmSourceFilesCommand.h
+++ b/Source/cmSourceFilesCommand.h
@@ -53,6 +53,15 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* dependent on other packages (use SOURCE_FILES_REQUIRED() to add
* dependent source files).
*
+ * It allows sources to be added even if they are generated by a build
+ * process. This can be achieved usiong GENERATED keyword:
+ * SOURCE_FILES( Project_SRCS
+ * Source1
+ * Source2
+ * ...
+ * GENERATED
+ * SourceThatDoesNotExist )
+ *
* \sa cmSourceFilesRequireCommand
*/
class cmSourceFilesCommand : public cmCommand
@@ -91,7 +100,7 @@ public:
virtual const char* GetFullDocumentation()
{
return
- "SOURCE_FILES(NAME file1 file2 ...)";
+ "SOURCE_FILES(NAME file1 file2 ... [ GENERATED generated_file1 ... ])";
}
cmTypeMacro(cmSourceFilesCommand, cmCommand);