CMakeProxy.hpp
Go to the documentation of this file.
1 /*
2 
3  This file is part of OpenFLUID software
4  Copyright(c) 2007, INRA - Montpellier SupAgro
5 
6 
7  == GNU General Public License Usage ==
8 
9  OpenFLUID is free software: you can redistribute it and/or modify
10  it under the terms of the GNU General Public License as published by
11  the Free Software Foundation, either version 3 of the License, or
12  (at your option) any later version.
13 
14  OpenFLUID is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  GNU General Public License for more details.
18 
19  You should have received a copy of the GNU General Public License
20  along with OpenFLUID. If not, see <http://www.gnu.org/licenses/>.
21 
22 
23  == Other Usage ==
24 
25  Other Usage means a use of OpenFLUID that is inconsistent with the GPL
26  license, and requires a written agreement between You and INRA.
27  Licensees for Other Usage of OpenFLUID may use this file in accordance
28  with the terms contained in the written agreement between You and INRA.
29 
30 */
31 
32 /**
33  @file CMakeProxy.hpp
34 
35  @author Jean-Christophe FABRE <jean-christophe.fabre@inra.fr>
36 */
37 
38 
39 #include <map>
40 #include <vector>
41 
42 #include <QStringList>
43 
44 #include <openfluid/dllexport.hpp>
46 
47 
48 #ifndef __OPENFLUID_UTILS_CMAKEPROXY_HPP__
49 #define __OPENFLUID_UTILS_CMAKEPROXY_HPP__
50 
51 
52 namespace openfluid { namespace utils {
53 
54 
55 class OPENFLUID_API CMakeProxy : public ProgramProxy<CMakeProxy>
56 {
57  private:
58 
59  static void findCMakeProgram();
60 
61 
62  public:
63 
64  CMakeProxy();
65 
66  virtual ~CMakeProxy();
67 
68  static bool isAvailable();
69 
70  static QString getConfigureCommand(const QString& BuildDir, const QString& SrcDir,
71  const std::map<QString,QString>& Variables = {},
72  const QString& Generator = "", const std::vector<QString>& Options = {});
73 
74  /**
75  Returns a build command prepared using the given arguments
76  @param[in] BuildDir the directory where the build will be performed
77  @param[in] Target the target to build (empty by default)
78  @param[in] Jobs the number of parallel jobs to use, 0 means that parallel build is not active (0 by default)
79  @param[in] CMakeOptions a string of options passed to CMake (empty by default)
80  @param[in] OtherOptions a string of options passed to the build tool (empty by default)
81  */
82  static QString getBuildCommand(const QString& BuildDir,
83  const QString& Target = "",
84  const unsigned int Jobs = 0,
85  const QString& CMakeOptions = "", const QString& OtherOptions = "");
86 
87  static QString getTarCompressCommand(const QString& WorkDir,
88  const QString& TarFilePath, const QStringList& RelativePathsToCompress,
89  const QString& Options = "");
90 
91  static QString getTarUncompressCommand(const QString& WorkDir, const QString& TarFilePath,
92  const QString& Options = "");
93 
94 
95 };
96 
97 
98 } } // namespaces
99 
100 
101 #endif /* __OPENFLUID_UTILS_CMAKEPROXY_HPP__ */
Definition: CMakeProxy.hpp:55
Definition: ApplicationException.hpp:47
Definition: ProgramProxy.hpp:51
#define OPENFLUID_API
Definition: dllexport.hpp:86