| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- /*============================================================================
- CMake - Cross Platform Makefile Generator
- Copyright 2004-2009 Kitware, Inc.
- Copyright 2004 Alexander Neundorf ([email protected])
- 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 cmExtraSublimeTextGenerator_h
- #define cmExtraSublimeTextGenerator_h
- #include "cmExternalMakefileProjectGenerator.h"
- #include "cmSourceFile.h"
- class cmLocalGenerator;
- class cmMakefile;
- class cmTarget;
- class cmGeneratedFileStream;
- class cmGeneratorTarget;
- /** \class cmExtraSublimeTextGenerator
- * \brief Write Sublime Text 2 project files for Makefile based projects
- */
- class cmExtraSublimeTextGenerator : public cmExternalMakefileProjectGenerator
- {
- public:
- typedef std::map<std::string, std::vector<std::string> > MapSourceFileFlags;
- cmExtraSublimeTextGenerator();
- virtual const char* GetName() const
- { return cmExtraSublimeTextGenerator::GetActualName();}
- static const char* GetActualName()
- { return "Sublime Text 2";}
- static cmExternalMakefileProjectGenerator* New()
- { return new cmExtraSublimeTextGenerator; }
- /** Get the documentation entry for this generator. */
- virtual void GetDocumentation(cmDocumentationEntry& entry,
- const char* fullName) const;
- virtual void Generate();
- private:
- void CreateProjectFile(const std::vector<cmLocalGenerator*>& lgs);
- void CreateNewProjectFile(const std::vector<cmLocalGenerator*>& lgs,
- const std::string& filename);
- /** Appends all targets as build systems to the project file and get all
- * include directories and compiler definitions used.
- */
- void AppendAllTargets(const std::vector<cmLocalGenerator*>& lgs,
- const cmMakefile* mf,
- cmGeneratedFileStream& fout,
- MapSourceFileFlags& sourceFileFlags);
- /** Returns the build command that needs to be executed to build the
- * specified target.
- */
- std::string BuildMakeCommand(const std::string& make, const char* makefile,
- const std::string& target);
- /** Appends the specified target to the generated project file as a Sublime
- * Text build system.
- */
- void AppendTarget(cmGeneratedFileStream& fout,
- const std::string& targetName,
- cmLocalGenerator* lg,
- cmTarget* target,
- const char* make,
- const cmMakefile* makefile,
- const char* compiler,
- MapSourceFileFlags& sourceFileFlags, bool firstTarget);
- /**
- * Compute the flags for compilation of object files for a given @a language.
- * @note Generally it is the value of the variable whose name is computed
- * by LanguageFlagsVarName().
- */
- std::string ComputeFlagsForObject(cmSourceFile *source,
- cmLocalGenerator* lg,
- cmTarget *target,
- cmGeneratorTarget* gtgt);
- std::string ComputeDefines(cmSourceFile *source, cmLocalGenerator* lg,
- cmTarget *target, cmGeneratorTarget* gtgt);
- };
- #endif
|