summaryrefslogtreecommitdiffstats
path: root/Source/cmExtraCodeBlocksGenerator.h
blob: e5ede9aca99b26a9dcbbd2cec3aac5e7157759d0 (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
/*============================================================================
  CMake - Cross Platform Makefile Generator
  Copyright 2004-2009 Kitware, Inc.
  Copyright 2004 Alexander Neundorf (neundorf@kde.org)

  Distributed under the OSI-approved BSD License (the "License");
  see accompanying file Copyright.txt for details.

  This software is distributed WITHOUT ANY WARRANTY; without even the
  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  See the License for more information.
============================================================================*/
#ifndef cmExtraCodeBlocksGenerator_h
#define cmExtraCodeBlocksGenerator_h

#include "cmExternalMakefileProjectGenerator.h"

class cmLocalGenerator;
class cmMakefile;
class cmTarget;
class cmGeneratedFileStream;

/** \class cmExtraCodeBlocksGenerator
 * \brief Write CodeBlocks project files for Makefile based projects
 */
class cmExtraCodeBlocksGenerator : public cmExternalMakefileProjectGenerator
{
public:
  cmExtraCodeBlocksGenerator();

  virtual std::string GetName() const
                         { return cmExtraCodeBlocksGenerator::GetActualName();}
  static std::string GetActualName()                    { return "CodeBlocks";}
  static cmExternalMakefileProjectGenerator* New()
                                     { return new cmExtraCodeBlocksGenerator; }
  /** Get the documentation entry for this generator.  */
  virtual void GetDocumentation(cmDocumentationEntry& entry,
                                const std::string& fullName) const;

  virtual void Generate();
private:
  struct CbpUnit
  {
    std::vector<const cmTarget*> Targets;
  };

  void CreateProjectFile(const std::vector<cmLocalGenerator*>& lgs);

  void CreateNewProjectFile(const std::vector<cmLocalGenerator*>& lgs,
                                const std::string& filename);
  std::string CreateDummyTargetFile(cmLocalGenerator* lg,
                                    cmTarget* target) const;

  std::string GetCBCompilerId(const cmMakefile* mf);
  int GetCBTargetType(cmTarget* target);
  std::string BuildMakeCommand(const std::string& make, const char* makefile,
                               const std::string& target);
  void AppendTarget(cmGeneratedFileStream& fout,
                    const std::string& targetName,
                    cmTarget* target,
                    const char* make,
                    const cmLocalGenerator* lg,
                    const char* compiler);

};

#endif
rorString.size()) { std::string err = "had incorrect arguments: "; unsigned int i; for(i =0; i < this->Args.size(); ++i) { err += (this->Args[i].Quoted?"\"":""); err += this->Args[i].Value; err += (this->Args[i].Quoted?"\"":""); err += " "; } err += "("; err += errorString; err += ")."; mf.IssueMessage(messageType, err); if (messageType == cmake::FATAL_ERROR) { cmSystemTools::SetFatalErrorOccured(); return true; } } // Invoke all the functions that were collected in the block. for(unsigned int c = 0; c < this->Functions.size(); ++c) { cmExecutionStatus status; mf.ExecuteCommand(this->Functions[c],status); if (status.GetReturnInvoked()) { inStatus.SetReturnInvoked(true); return true; } if (status.GetBreakInvoked()) { return true; } if(cmSystemTools::GetFatalErrorOccured() ) { return true; } } expandedArguments.clear(); mf.ExpandArguments(this->Args, expandedArguments); isTrue = cmIfCommand::IsTrue(expandedArguments,errorString, &mf, messageType); } return true; } else { // decrement for each nested while that ends this->Depth--; } } // record the command this->Functions.push_back(lff); // always return true return true; } bool cmWhileFunctionBlocker:: ShouldRemove(const cmListFileFunction& lff, cmMakefile& ) { if(!cmSystemTools::Strucmp(lff.Name.c_str(),"endwhile")) { // if the endwhile has arguments, then make sure // they match the arguments of the matching while if (lff.Arguments.size() == 0 || lff.Arguments == this->Args) { return true; } } return false; } bool cmWhileCommand ::InvokeInitialPass(const std::vector<cmListFileArgument>& args, cmExecutionStatus &) { if(args.size() < 1) { this->SetError("called with incorrect number of arguments"); return false; } // create a function blocker cmWhileFunctionBlocker *f = new cmWhileFunctionBlocker(); f->Args = args; this->Makefile->AddFunctionBlocker(f); return true; }