summaryrefslogtreecommitdiffstats
path: root/Source/cmCableInstantiateCommand.cxx
blob: b30a1c531ef28215921f1f37bd69b731ea2d889b (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
/*=========================================================================

  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 "cmCabilInstantiateCommand.h"
#include "cmCacheManager.h"

#include "cmCabilDefineSetCommand.h"
#include "cmRegularExpression.h"

// cmCabilInstantiateCommand
bool cmCabilInstantiateCommand::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 cmCabilData instance.
  this->SetupCabilData();
  
  // 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_CabilData->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 cmCabilInstantiateCommand::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 cmCabilDefineSetCommand, ask it to write its
      // configuration code to the output file.
      cmCabilDefineSetCommand* command =
        cmCabilDefineSetCommand::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 CABIL configuration code to define this InstantiationSet.
 */
void cmCabilInstantiateCommand::WriteConfiguration(std::ostream& os) const
{
  cmRegularExpression needCdataBlock("[&<>]");
  
  os << std::endl
     << "  <InstantiationSet>" << std::endl;
  for(Elements::const_iterator e = m_Elements.begin();
      e != m_Elements.end(); ++e)
    {
    os << "    <Element>";
    if(needCdataBlock.find(e->c_str()))
      {
      os << "<![CDATA[" << e->c_str() << "]]>";
      }
    else
      {
      os << e->c_str();
      }
    os << "</Element>" << std::endl;
    }
  os << "  </InstantiationSet>" << std::endl;
}