summaryrefslogtreecommitdiffstats
path: root/Source/cmCableInstantiateCommand.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmCableInstantiateCommand.cxx')
-rw-r--r--Source/cmCableInstantiateCommand.cxx90
1 files changed, 9 insertions, 81 deletions
diff --git a/Source/cmCableInstantiateCommand.cxx b/Source/cmCableInstantiateCommand.cxx
index 705c313..629e6da 100644
--- a/Source/cmCableInstantiateCommand.cxx
+++ b/Source/cmCableInstantiateCommand.cxx
@@ -16,96 +16,24 @@
#include "cmCableInstantiateCommand.h"
#include "cmCacheManager.h"
-#include "cmCableDefineSetCommand.h"
#include "cmRegularExpression.h"
-// cmCableInstantiateCommand
-bool cmCableInstantiateCommand::Invoke(std::vector<std::string>& args)
-{
- if(args.size() < 2)
- {
- this->SetError("called with incorrect number of arguments");
- return false;
- }
-
- // This command instance needs to use the cmCableData instance.
- this->SetupCableData();
-
- // The output file must be opened in the output directory.
- std::string file = m_Makefile->GetStartOutputDirectory();
-
- // The first argument is the file into which the configuration code is to be
- // written.
- std::vector<std::string>::const_iterator arg = args.begin();
-
- // Concatenate the file name onto the path.
- file += "/" + *arg++;
-
- // Get the OutputFile corresponding to this file name.
- m_OutputFile = m_CableData->GetOutputFile(file, this);
-
- // The rest of the arguments are the elements to be placed in the set.
- for(; arg != args.end(); ++arg)
- {
- m_Elements.push_back(*arg);
- }
-
- return true;
-}
-
-
-void cmCableInstantiateCommand::FinalPass()
-{
- // If this command is the first to reference its output file, write the
- // header information.
- if(m_OutputFile->FirstReferencingCommandIs(this))
- {
- this->WriteConfigurationHeader(m_OutputFile->GetStream());
-
- // Need to write out the Set definitions.
- // 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 cmCableDefineSetCommand, ask it to write its
- // configuration code to the output file.
- cmCableDefineSetCommand* command =
- cmCableDefineSetCommand::SafeDownCast(*commandIter);
- if(command)
- {
- command->WriteConfiguration(m_OutputFile->GetStream());
- }
- }
- }
-
- // Write the instantiation block's code.
- this->WriteConfiguration(m_OutputFile->GetStream());
-
- // If this command is the last to reference its output file, write the
- // footer information.
- if(m_OutputFile->LastReferencingCommandIs(this))
- {
- this->WriteConfigurationFooter(m_OutputFile->GetStream());
- }
-}
-
/**
* Write the CABLE configuration code to define this InstantiationSet.
*/
-void cmCableInstantiateCommand::WriteConfiguration(std::ostream& os) const
+void cmCableInstantiateCommand::WriteConfiguration() const
{
+ std::ostream& os = m_CableData->GetOutputStream();
+ cmCableData::Indentation indent = m_CableData->GetIndentation();
+
cmRegularExpression needCdataBlock("[&<>]");
- os << std::endl
- << " <InstantiationSet>" << std::endl;
- for(Elements::const_iterator e = m_Elements.begin();
- e != m_Elements.end(); ++e)
+ os << indent << "<InstantiationSet>" << std::endl;
+ for(Entries::const_iterator e = m_Entries.begin();
+ e != m_Entries.end(); ++e)
{
- os << " <Element>";
+ os << indent << " <Element>";
if(needCdataBlock.find(e->c_str()))
{
os << "<![CDATA[" << e->c_str() << "]]>";
@@ -116,5 +44,5 @@ void cmCableInstantiateCommand::WriteConfiguration(std::ostream& os) const
}
os << "</Element>" << std::endl;
}
- os << " </InstantiationSet>" << std::endl;
+ os << indent << "</InstantiationSet>" << std::endl;
}