From 61d23149893dcba75115486187a39ce853e091b9 Mon Sep 17 00:00:00 2001 From: Brad King Date: Thu, 26 Apr 2001 15:27:38 -0400 Subject: ENH: Changed WriteConfiguration to non-const so it can do error checking. Added parsing and output of a name for each WrapperSet generated from a CABLE_WRAP command. --- Source/cmCableInstantiateClassCommand.cxx | 4 +++- Source/cmCableInstantiateClassCommand.h | 2 +- Source/cmCableInstantiateCommand.cxx | 4 +++- Source/cmCableInstantiateCommand.h | 2 +- Source/cmCablePackageCommand.cxx | 22 ++++++++++++++++++++++ Source/cmCablePackageEntryCommand.cxx | 4 +--- Source/cmCablePackageEntryCommand.h | 2 +- Source/cmCableSourceFilesCommand.cxx | 4 +++- Source/cmCableSourceFilesCommand.h | 2 +- Source/cmCableWrapCommand.cxx | 16 ++++++++++++---- Source/cmCableWrapCommand.h | 2 +- 11 files changed, 49 insertions(+), 15 deletions(-) diff --git a/Source/cmCableInstantiateClassCommand.cxx b/Source/cmCableInstantiateClassCommand.cxx index 939f530..f6ab833 100644 --- a/Source/cmCableInstantiateClassCommand.cxx +++ b/Source/cmCableInstantiateClassCommand.cxx @@ -23,7 +23,7 @@ * Write the CABLE configuration code to define this InstantiationSet. * This includes the "class" keyword to do class template instantiations. */ -void cmCableInstantiateClassCommand::WriteConfiguration() const +bool cmCableInstantiateClassCommand::WriteConfiguration() { std::ostream& os = m_CableData->GetOutputStream(); cmCableData::Indentation indent = m_CableData->GetIndentation(); @@ -46,4 +46,6 @@ void cmCableInstantiateClassCommand::WriteConfiguration() const os << "" << std::endl; } os << indent << "" << std::endl; + + return true; } diff --git a/Source/cmCableInstantiateClassCommand.h b/Source/cmCableInstantiateClassCommand.h index b592cd7..5663093 100644 --- a/Source/cmCableInstantiateClassCommand.h +++ b/Source/cmCableInstantiateClassCommand.h @@ -63,7 +63,7 @@ public: "template classes (not functions, operators, etc)."; } - virtual void WriteConfiguration() const; + virtual bool WriteConfiguration(); cmTypeMacro(cmCableInstantiateClassCommand, cmCableInstantiateCommand); protected: diff --git a/Source/cmCableInstantiateCommand.cxx b/Source/cmCableInstantiateCommand.cxx index 629e6da..09483bb 100644 --- a/Source/cmCableInstantiateCommand.cxx +++ b/Source/cmCableInstantiateCommand.cxx @@ -22,7 +22,7 @@ /** * Write the CABLE configuration code to define this InstantiationSet. */ -void cmCableInstantiateCommand::WriteConfiguration() const +bool cmCableInstantiateCommand::WriteConfiguration() { std::ostream& os = m_CableData->GetOutputStream(); cmCableData::Indentation indent = m_CableData->GetIndentation(); @@ -45,4 +45,6 @@ void cmCableInstantiateCommand::WriteConfiguration() const os << "" << std::endl; } os << indent << "" << std::endl; + + return true; } diff --git a/Source/cmCableInstantiateCommand.h b/Source/cmCableInstantiateCommand.h index 4f8f2bd..d8ea9f6 100644 --- a/Source/cmCableInstantiateCommand.h +++ b/Source/cmCableInstantiateCommand.h @@ -62,7 +62,7 @@ public: "template non-classes (functions, operators, etc)."; } - virtual void WriteConfiguration() const; + virtual bool WriteConfiguration(); cmTypeMacro(cmCableInstantiateCommand, cmCablePackageCommand); protected: diff --git a/Source/cmCablePackageCommand.cxx b/Source/cmCablePackageCommand.cxx index 1808dee..6776fc3 100644 --- a/Source/cmCablePackageCommand.cxx +++ b/Source/cmCablePackageCommand.cxx @@ -100,6 +100,7 @@ bool cmCablePackageCommand::Invoke(std::vector& args) // Add custom rules to the makefile to generate this package's source // files. + { std::string command = "${CABLE}"; m_Makefile->ExpandVariablesInString(command); std::vector depends; @@ -115,6 +116,27 @@ bool cmCablePackageCommand::Invoke(std::vector& args) command.c_str(), depends, outputs, m_TargetName.c_str()); + } + + // Add custom rules to the makefile to generate this package's xml files. + { + std::string command = "${GCCXML}"; + m_Makefile->ExpandVariablesInString(command); + std::vector depends; + depends.push_back(command); + std::string input = "Cxx/"+m_PackageName+"_cxx.cxx"; + std::string output = "Cxx/"+m_PackageName+"_cxx.xml"; + command = "\""+command+"\" ${CXX_FLAGS} -fsyntax-only -fxml=" + output + " -c " + input; + + std::vector outputs; + outputs.push_back("Cxx/"+m_PackageName+"_cxx.xml"); + + // A rule for the package's source files. + m_Makefile->AddCustomCommand(input.c_str(), + command.c_str(), + depends, + outputs, m_TargetName.c_str()); + } // add the source list to the target m_Makefile->GetTargets()[m_TargetName.c_str()].GetSourceLists().push_back(m_PackageName); diff --git a/Source/cmCablePackageEntryCommand.cxx b/Source/cmCablePackageEntryCommand.cxx index 5930272..add6a35 100644 --- a/Source/cmCablePackageEntryCommand.cxx +++ b/Source/cmCablePackageEntryCommand.cxx @@ -36,7 +36,5 @@ bool cmCablePackageEntryCommand::Invoke(std::vector& args) } // Write this command's configuration. - this->WriteConfiguration(); - - return true; + return this->WriteConfiguration(); } diff --git a/Source/cmCablePackageEntryCommand.h b/Source/cmCablePackageEntryCommand.h index e4ef3bd..a108ae1 100644 --- a/Source/cmCablePackageEntryCommand.h +++ b/Source/cmCablePackageEntryCommand.h @@ -42,7 +42,7 @@ public: cmTypeMacro(cmCablePackageEntryCommand, cmCableCommand); - virtual void WriteConfiguration() const =0; + virtual bool WriteConfiguration() =0; protected: typedef std::vector Entries; diff --git a/Source/cmCableSourceFilesCommand.cxx b/Source/cmCableSourceFilesCommand.cxx index 50e4d2c..13f1218 100644 --- a/Source/cmCableSourceFilesCommand.cxx +++ b/Source/cmCableSourceFilesCommand.cxx @@ -45,7 +45,7 @@ void cmCableSourceFilesCommand::FinalPass() * Write the CABLE configuration code to indicate header dependencies for * a package. */ -void cmCableSourceFilesCommand::WriteConfiguration() const +bool cmCableSourceFilesCommand::WriteConfiguration() { std::ostream& os = m_CableData->GetOutputStream(); cmCableData::Indentation indent = m_CableData->GetIndentation(); @@ -77,6 +77,8 @@ void cmCableSourceFilesCommand::WriteConfiguration() const } } os << indent << "" << std::endl; + + return true; } diff --git a/Source/cmCableSourceFilesCommand.h b/Source/cmCableSourceFilesCommand.h index 4aefeb0..7b58c21 100644 --- a/Source/cmCableSourceFilesCommand.h +++ b/Source/cmCableSourceFilesCommand.h @@ -67,7 +67,7 @@ public: "Generates a Package's Headers block in the CABLE configuration."; } - virtual void WriteConfiguration() const; + virtual bool WriteConfiguration(); bool SourceFileExists(const std::string&) const; cmTypeMacro(cmCableSourceFilesCommand, cmCableCommand); diff --git a/Source/cmCableWrapCommand.cxx b/Source/cmCableWrapCommand.cxx index c42f81f..46f5142 100644 --- a/Source/cmCableWrapCommand.cxx +++ b/Source/cmCableWrapCommand.cxx @@ -19,16 +19,22 @@ /** * Write the CABLE configuration code to define this WrapperSet. */ -void cmCableWrapCommand::WriteConfiguration() const +bool cmCableWrapCommand::WriteConfiguration() { + if(m_Entries.size() < 2) + { + this->SetError("called with incorrect number of arguments"); + return false; + } + std::ostream& os = m_CableData->GetOutputStream(); cmCableData::Indentation indent = m_CableData->GetIndentation(); cmRegularExpression needCdataBlock("[&<>]"); - os << indent << "" << std::endl; - for(Entries::const_iterator e = m_Entries.begin(); - e != m_Entries.end(); ++e) + Entries::const_iterator e = m_Entries.begin(); + os << indent << "c_str() << "\">" << std::endl; + for(++e;e != m_Entries.end(); ++e) { os << indent << " "; if(needCdataBlock.find(e->c_str())) @@ -42,4 +48,6 @@ void cmCableWrapCommand::WriteConfiguration() const os << "" << std::endl; } os << indent << "" << std::endl; + + return true; } diff --git a/Source/cmCableWrapCommand.h b/Source/cmCableWrapCommand.h index 9054795..e139714 100644 --- a/Source/cmCableWrapCommand.h +++ b/Source/cmCableWrapCommand.h @@ -59,7 +59,7 @@ public: "Generates a WrapSet in the CABLE configuration."; } - virtual void WriteConfiguration() const; + virtual bool WriteConfiguration(); cmTypeMacro(cmCableWrapCommand, cmCablePackageCommand); }; -- cgit v0.12