2009-09-28 19:43:28 +04:00
|
|
|
/*============================================================================
|
|
|
|
CMake - Cross Platform Makefile Generator
|
|
|
|
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
|
2000-08-29 23:26:29 +04:00
|
|
|
|
2009-09-28 19:43:28 +04:00
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
|
|
see accompanying file Copyright.txt for details.
|
2000-08-29 23:26:29 +04:00
|
|
|
|
2009-09-28 19:43:28 +04:00
|
|
|
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.
|
|
|
|
============================================================================*/
|
2001-04-25 00:49:12 +04:00
|
|
|
#ifndef cmSourceFile_h
|
|
|
|
#define cmSourceFile_h
|
2000-08-29 23:26:29 +04:00
|
|
|
|
2007-06-18 19:59:23 +04:00
|
|
|
#include "cmSourceFileLocation.h"
|
2003-06-03 18:30:23 +04:00
|
|
|
#include "cmCustomCommand.h"
|
2006-12-07 17:45:32 +03:00
|
|
|
#include "cmPropertyMap.h"
|
|
|
|
|
|
|
|
class cmake;
|
2000-08-29 23:26:29 +04:00
|
|
|
|
2001-04-25 00:49:12 +04:00
|
|
|
/** \class cmSourceFile
|
2001-01-11 22:47:38 +03:00
|
|
|
* \brief Represent a class loaded from a makefile.
|
|
|
|
*
|
2001-04-25 00:49:12 +04:00
|
|
|
* cmSourceFile is represents a class loaded from
|
2001-01-11 22:47:38 +03:00
|
|
|
* a makefile.
|
|
|
|
*/
|
2001-04-25 00:49:12 +04:00
|
|
|
class cmSourceFile
|
2000-08-29 23:26:29 +04:00
|
|
|
{
|
2001-01-11 22:47:38 +03:00
|
|
|
public:
|
|
|
|
/**
|
2007-06-18 19:59:23 +04:00
|
|
|
* Construct with the makefile storing the source and the initial
|
|
|
|
* name referencing it.
|
2001-01-11 22:47:38 +03:00
|
|
|
*/
|
2007-06-18 19:59:23 +04:00
|
|
|
cmSourceFile(cmMakefile* mf, const char* name);
|
|
|
|
|
|
|
|
~cmSourceFile();
|
2001-01-11 22:47:38 +03:00
|
|
|
|
2003-06-03 18:30:23 +04:00
|
|
|
/**
|
|
|
|
* Get the list of the custom commands for this source file
|
|
|
|
*/
|
2007-06-18 19:59:23 +04:00
|
|
|
cmCustomCommand* GetCustomCommand();
|
|
|
|
cmCustomCommand const* GetCustomCommand() const;
|
2005-02-19 00:19:09 +03:00
|
|
|
void SetCustomCommand(cmCustomCommand *cc);
|
2000-08-29 23:26:29 +04:00
|
|
|
|
2002-08-16 19:20:18 +04:00
|
|
|
///! Set/Get a property of this source file
|
|
|
|
void SetProperty(const char *prop, const char *value);
|
2008-01-18 02:13:55 +03:00
|
|
|
void AppendProperty(const char* prop, const char* value);
|
2002-08-16 19:20:18 +04:00
|
|
|
const char *GetProperty(const char *prop) const;
|
|
|
|
bool GetPropertyAsBool(const char *prop) const;
|
2007-06-18 19:59:23 +04:00
|
|
|
|
2008-01-30 19:21:54 +03:00
|
|
|
/** Implement getting a property when called from a CMake language
|
|
|
|
command like get_property or get_source_file_property. */
|
|
|
|
const char* GetPropertyForUser(const char *prop);
|
|
|
|
|
2001-01-11 22:47:38 +03:00
|
|
|
/**
|
2007-12-17 18:12:19 +03:00
|
|
|
* The full path to the file. The non-const version of this method
|
|
|
|
* may attempt to locate the file on disk and finalize its location.
|
|
|
|
* The const version of this method may return an empty string if
|
|
|
|
* the non-const version has not yet been called (yes this is a
|
|
|
|
* horrible interface, but is necessary for backwards
|
|
|
|
* compatibility).
|
2001-01-11 22:47:38 +03:00
|
|
|
*/
|
2007-06-18 19:59:23 +04:00
|
|
|
std::string const& GetFullPath();
|
|
|
|
std::string const& GetFullPath() const;
|
2001-01-11 22:47:38 +03:00
|
|
|
|
2007-12-17 18:12:19 +03:00
|
|
|
/**
|
|
|
|
* Get the information currently known about the source file
|
|
|
|
* location without attempting to locate the file as GetFullPath
|
|
|
|
* would. See cmSourceFileLocation documentation.
|
|
|
|
*/
|
|
|
|
cmSourceFileLocation const& GetLocation() const;
|
|
|
|
|
2001-01-11 22:47:38 +03:00
|
|
|
/**
|
2007-06-18 19:59:23 +04:00
|
|
|
* Get the file extension of this source file.
|
2001-01-11 22:47:38 +03:00
|
|
|
*/
|
2007-06-18 19:59:23 +04:00
|
|
|
std::string const& GetExtension() const;
|
2001-01-11 22:47:38 +03:00
|
|
|
|
2001-02-27 01:15:44 +03:00
|
|
|
/**
|
2007-06-18 19:59:23 +04:00
|
|
|
* Get the language of the compiler to use for this source file.
|
2001-02-27 01:15:44 +03:00
|
|
|
*/
|
2007-06-18 19:59:23 +04:00
|
|
|
const char* GetLanguage();
|
|
|
|
const char* GetLanguage() const;
|
2001-02-27 01:15:44 +03:00
|
|
|
|
2001-01-11 22:47:38 +03:00
|
|
|
/**
|
2001-04-25 00:49:12 +04:00
|
|
|
* Return the vector that holds the list of dependencies
|
2001-01-11 22:47:38 +03:00
|
|
|
*/
|
2006-03-15 19:02:08 +03:00
|
|
|
const std::vector<std::string> &GetDepends() const {return this->Depends;}
|
2007-05-28 18:11:44 +04:00
|
|
|
void AddDepend(const char* d) { this->Depends.push_back(d); }
|
2001-04-25 00:49:12 +04:00
|
|
|
|
2006-12-07 17:45:32 +03:00
|
|
|
// Get the properties
|
|
|
|
cmPropertyMap &GetProperties() { return this->Properties; };
|
|
|
|
|
|
|
|
// Define the properties
|
|
|
|
static void DefineProperties(cmake *cm);
|
|
|
|
|
2007-06-18 19:59:23 +04:00
|
|
|
/**
|
|
|
|
* Check whether the given source file location could refer to this
|
|
|
|
* source.
|
|
|
|
*/
|
|
|
|
bool Matches(cmSourceFileLocation const&);
|
2006-12-13 20:19:59 +03:00
|
|
|
|
2001-04-25 00:49:12 +04:00
|
|
|
private:
|
2007-06-18 19:59:23 +04:00
|
|
|
cmSourceFileLocation Location;
|
2006-12-07 17:45:32 +03:00
|
|
|
cmPropertyMap Properties;
|
2007-06-18 19:59:23 +04:00
|
|
|
cmCustomCommand* CustomCommand;
|
|
|
|
std::string Extension;
|
|
|
|
std::string Language;
|
2006-03-15 19:02:08 +03:00
|
|
|
std::string FullPath;
|
2007-06-18 19:59:23 +04:00
|
|
|
bool FindFullPathFailed;
|
2006-12-13 20:19:59 +03:00
|
|
|
|
2007-06-18 19:59:23 +04:00
|
|
|
bool FindFullPath();
|
|
|
|
bool TryFullPath(const char* tryPath, const char* ext);
|
|
|
|
void CheckExtension();
|
2008-04-29 22:17:42 +04:00
|
|
|
void CheckLanguage(std::string const& ext);
|
2007-06-18 19:59:23 +04:00
|
|
|
|
|
|
|
std::vector<std::string> Depends;
|
2000-08-29 23:26:29 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|