cmake/Source/CPack/cmCPackArchiveGenerator.h

75 lines
2.3 KiB
C
Raw Normal View History

2010-06-23 01:18:35 +03:00
/*============================================================================
CMake - Cross Platform Makefile Generator
Copyright 2000-2009 Kitware, Inc.
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 cmCPackArchiveGenerator_h
#define cmCPackArchiveGenerator_h
2010-11-13 01:00:53 +02:00
#include "cmArchiveWrite.h"
2010-06-23 01:18:35 +03:00
#include "cmCPackGenerator.h"
/** \class cmCPackArchiveGenerator
2010-11-13 01:00:53 +02:00
* \brief A generator base for libarchive generation.
* The generator itself uses the libarchive wrapper
* \ref cmArchiveWrite.
2010-06-23 01:18:35 +03:00
*
*/
class cmCPackArchiveGenerator : public cmCPackGenerator
2010-11-13 01:00:53 +02:00
{
2010-06-23 01:18:35 +03:00
public:
cmTypeMacro(cmCPackArchiveGenerator, cmCPackGenerator);
/**
* Construct generator
*/
2010-11-13 01:00:53 +02:00
cmCPackArchiveGenerator(cmArchiveWrite::Compress, cmArchiveWrite::Type);
2010-06-23 01:18:35 +03:00
virtual ~cmCPackArchiveGenerator();
// Used to add a header to the archive
virtual int GenerateHeader(std::ostream* os);
2010-11-13 01:00:53 +02:00
// component support
virtual bool SupportsComponentInstallation() const;
2010-06-23 01:18:35 +03:00
protected:
virtual int InitializeInternal();
2010-11-13 01:00:53 +02:00
/**
* Add the files belonging to the specified component
* to the provided (already opened) archive.
* @param[in,out] archive the archive object
* @param[in] component the component whose file will be added to archive
*/
int addOneComponentToArchive(cmArchiveWrite& archive,
cmCPackComponent* component);
/**
* The main package file method.
* If component install was required this
* method will call either PackageComponents or
* PackageComponentsAllInOne.
*/
int PackageFiles();
/**
* The method used to package files when component
* install is used. This will create one
* archive for each component group.
*/
2011-01-16 11:35:12 +01:00
int PackageComponents(bool ignoreGroup);
2010-11-13 01:00:53 +02:00
/**
* Special case of component install where all
* components will be put in a single installer.
*/
2011-01-16 11:35:12 +01:00
int PackageComponentsAllInOne(bool allComponent);
2010-06-23 01:18:35 +03:00
virtual const char* GetOutputExtension() = 0;
2010-11-13 01:00:53 +02:00
cmArchiveWrite::Compress Compress;
cmArchiveWrite::Type Archive;
};
2010-06-23 01:18:35 +03:00
#endif