summaryrefslogtreecommitdiffstats
path: root/Source/cmLocalKdevelopGenerator.h
blob: e8e7cb3ab68385d933dd3ff6f93c016b9b6c1bb0 (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
/*=========================================================================

  Program:   CMake - Cross-Platform Makefile Generator
  Module:    $RCSfile$
  Language:  C++
  Date:      $Date$
  Version:   $Revision$

  Copyright (c) 2002 Kitware, Inc., Insight Consortium.  All rights reserved.
  Copyright (c) 2004 Alexander Neundorf, neundorf@kde.org. All rights reserved.
  See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.

     This software is distributed WITHOUT ANY WARRANTY; without even 
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
     PURPOSE.  See the above copyright notices for more information.

=========================================================================*/
#ifndef cmLocalKdevelopGenerator_h
#define cmLocalKdevelopGenerator_h

#include "cmLocalUnixMakefileGenerator.h"

class cmDependInformation;
class cmMakeDepend;
class cmTarget;
class cmSourceFile;

/** \class cmLocalKdevelopGenerator
 * \brief Write Unix Makefiles accompanied by KDevelop3 project files.
 *
 * cmLocalKdevelopGenerator produces a project file for KDevelop 3 (KDevelop > 3.1.1). 
 * The project is based on the "Custom Makefile based C/C++" project of KDevelop.
 * Such a project consists of Unix Makefiles in the build directory together
 * with a <your_project>.kdevelop project file, which contains the project settings
 * and a <your_project>.kdevelop.filelist file, which lists the source files relative
 * to the kdevelop project directory. The kdevelop project directory is the base 
 * source directory. 
 */
class cmLocalKdevelopGenerator : public cmLocalUnixMakefileGenerator
{
public:
  ///! Set cache only and recurse to false by default.
  cmLocalKdevelopGenerator();

  virtual ~cmLocalKdevelopGenerator();
  
  /**
   * Generate the makefile for this directory. fromTheTop indicates if this
   * is being invoked as part of a global Generate or specific to this
   * directory. The difference is that when done from the Top we might skip
   * some steps to save time, such as dependency generation for the
   * makefiles. This is done by a direct invocation from make. 
   */
  virtual void Generate(bool fromTheTop);
protected:
  /**
    Create the foo.kdevelop file. This one calls MergeProjectFiles() 
    if it already exists, otherwise createNewProjectFile()
    The project files will be created in \a outputDir (in the build tree), the kdevelop project 
    dir will  be set to \a projectDir (in the source tree). \a cmakeFilePattern consists of a lists
    of all cmake listfiles used by this CMakeLists.txt
  */
  void CreateProjectFile(const std::string& outputDir, const std::string& projectDir,
                         const std::string& projectname, const std::string& executable, 
                         const std::string& cmakeFilePattern);
  /** Create the foo.kdevelop.filelist file, return false if it doesn't succeed.
  If the file already exists the contents will be merged.
  */
  bool CreateFilelistFile(const std::string& outputDir, const std::string& projectDir, 
                          const std::string& projectname, std::string& cmakeFilePattern);
  ///! Reads the old foo.kdevelop line by line and only replaces the "important" lines
  void MergeProjectFiles(const std::string& outputDir, const std::string& projectDir,
                         const std::string& filename, const std::string& executable,
                         const std::string& cmakeFilePattern);
  ///! Creates a new foo.kdevelop file
  void CreateNewProjectFile(const std::string& outputDir, const std::string& projectDir, 
                            const std::string& filename, const std::string& executable, 
                            const std::string& cmakeFilePattern);

};

#endif