2016-09-27 22:01:08 +03:00
|
|
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
2009-10-30 20:10:56 +03:00
|
|
|
#ifndef cmCPackArchiveGenerator_h
|
|
|
|
#define cmCPackArchiveGenerator_h
|
|
|
|
|
2016-09-07 01:21:35 +03:00
|
|
|
#include <cmConfigure.h>
|
2009-10-30 20:10:56 +03:00
|
|
|
|
2016-04-29 16:40:20 +03:00
|
|
|
#include "cmArchiveWrite.h"
|
2016-09-07 01:21:35 +03:00
|
|
|
#include "cmCPackGenerator.h"
|
|
|
|
#include "cmTypeMacro.h"
|
|
|
|
|
|
|
|
#include <iosfwd>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
class cmCPackComponent;
|
2016-04-29 16:40:20 +03:00
|
|
|
|
2009-10-30 20:10:56 +03:00
|
|
|
/** \class cmCPackArchiveGenerator
|
2010-08-24 23:41:32 +04:00
|
|
|
* \brief A generator base for libarchive generation.
|
|
|
|
* The generator itself uses the libarchive wrapper
|
|
|
|
* \ref cmArchiveWrite.
|
2009-10-30 20:10:56 +03:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
class cmCPackArchiveGenerator : public cmCPackGenerator
|
2016-05-16 17:34:04 +03:00
|
|
|
{
|
2009-10-30 20:10:56 +03:00
|
|
|
public:
|
|
|
|
cmTypeMacro(cmCPackArchiveGenerator, cmCPackGenerator);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct generator
|
|
|
|
*/
|
2015-04-07 13:36:52 +03:00
|
|
|
cmCPackArchiveGenerator(cmArchiveWrite::Compress, std::string const& format);
|
2016-06-27 22:25:27 +03:00
|
|
|
~cmCPackArchiveGenerator() CM_OVERRIDE;
|
2012-08-13 21:42:58 +04:00
|
|
|
// Used to add a header to the archive
|
2009-10-30 20:10:56 +03:00
|
|
|
virtual int GenerateHeader(std::ostream* os);
|
2010-08-24 23:42:21 +04:00
|
|
|
// component support
|
2016-06-27 22:25:27 +03:00
|
|
|
bool SupportsComponentInstallation() const CM_OVERRIDE;
|
2016-05-16 17:34:04 +03:00
|
|
|
|
2009-10-30 20:10:56 +03:00
|
|
|
protected:
|
2016-06-27 22:25:27 +03:00
|
|
|
int InitializeInternal() CM_OVERRIDE;
|
2010-08-24 23:42:21 +04: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
|
|
|
|
*/
|
2010-09-16 00:41:41 +04:00
|
|
|
int addOneComponentToArchive(cmArchiveWrite& archive,
|
|
|
|
cmCPackComponent* component);
|
2010-08-24 23:42:21 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The main package file method.
|
|
|
|
* If component install was required this
|
|
|
|
* method will call either PackageComponents or
|
|
|
|
* PackageComponentsAllInOne.
|
|
|
|
*/
|
2016-06-27 22:25:27 +03:00
|
|
|
int PackageFiles() CM_OVERRIDE;
|
2010-08-24 23:42:21 +04:00
|
|
|
/**
|
|
|
|
* The method used to package files when component
|
|
|
|
* install is used. This will create one
|
|
|
|
* archive for each component group.
|
|
|
|
*/
|
2010-11-13 19:56:36 +03:00
|
|
|
int PackageComponents(bool ignoreGroup);
|
2010-08-24 23:42:21 +04:00
|
|
|
/**
|
|
|
|
* Special case of component install where all
|
|
|
|
* components will be put in a single installer.
|
|
|
|
*/
|
2011-03-23 20:28:05 +03:00
|
|
|
int PackageComponentsAllInOne();
|
2016-06-27 22:25:27 +03:00
|
|
|
const char* GetOutputExtension() CM_OVERRIDE = 0;
|
2010-08-24 23:41:32 +04:00
|
|
|
cmArchiveWrite::Compress Compress;
|
2015-04-07 13:36:52 +03:00
|
|
|
std::string ArchiveFormat;
|
2016-05-16 17:34:04 +03:00
|
|
|
};
|
2009-10-30 20:10:56 +03:00
|
|
|
|
|
|
|
#endif
|