Merge topic 'CPack-dynamicDocSection'

9a8103e Try to fix compile error on Win32-vs70
4da2223 Fix typo in end markup
cfac874 More documentation concerning CPack Components
dee0a38 Put CPack DMG and PackageMaker doc in separate files
b4abcfe Correct copy/paste section name mistake
9717727 Suppress unecessary (now empty) doc sections
7a8f44a Add structure documentation for CPack Bundle generator
b8a274c Add structured documentation for NSIS
a6bce55 Dynamically add documentation section specified in documented script.
This commit is contained in:
David Cole 2012-02-21 15:57:17 -05:00 committed by CMake Topic Stage
commit 7d02020d68
11 changed files with 230 additions and 67 deletions

View File

@ -187,61 +187,6 @@
# list of patterns, e.g., /CVS/;/\\.svn/;\\.swp$;\\.#;/#;.*~;cscope.* # list of patterns, e.g., /CVS/;/\\.svn/;\\.swp$;\\.#;/#;.*~;cscope.*
##end ##end
# #
# The following variables are specific to the DragNDrop installers
# built on Mac OS X:
#
# CPACK_DMG_VOLUME_NAME - The volume name of the generated disk
# image. Defaults to CPACK_PACKAGE_FILE_NAME.
#
# CPACK_DMG_FORMAT - The disk image format. Common values are UDRO
# (UDIF read-only), UDZO (UDIF zlib-compressed) or UDBZ (UDIF
# bzip2-compressed). Refer to hdiutil(1) for more information on
# other available formats.
#
# CPACK_DMG_DS_STORE - Path to a custom .DS_Store file which e.g.
# can be used to specify the Finder window position/geometry and
# layout (such as hidden toolbars, placement of the icons etc.).
# This file has to be generated by the Finder (either manually or
# through OSA-script) using a normal folder from which the .DS_Store
# file can then be extracted.
#
# CPACK_DMG_BACKGROUND_IMAGE - Path to an image file which is to be
# used as the background for the Finder Window when the disk image
# is opened. By default no background image is set. The background
# image is applied after applying the custom .DS_Store file.
#
# CPACK_COMMAND_HDIUTIL - Path to the hdiutil(1) command used to
# operate on disk image files on Mac OS X. This variable can be used
# to override the automatically detected command (or specify its
# location if the auto-detection fails to find it.)
#
# CPACK_COMMAND_SETFILE - Path to the SetFile(1) command used to set
# extended attributes on files and directories on Mac OS X. This
# variable can be used to override the automatically detected
# command (or specify its location if the auto-detection fails to
# find it.)
#
# CPACK_COMMAND_REZ - Path to the Rez(1) command used to compile
# resources on Mac OS X. This variable can be used to override the
# automatically detected command (or specify its location if the
# auto-detection fails to find it.)
#
# The following variable is specific to installers build on Mac OS X
# using PackageMaker:
#
# CPACK_OSX_PACKAGE_VERSION - The version of Mac OS X that the
# resulting PackageMaker archive should be compatible
# with. Different versions of Mac OS X support different
# features. For example, CPack can only build component-based
# installers for Mac OS X 10.4 or newer, and can only build
# installers that download component son-the-fly for Mac OS X 10.5
# or newer. If left blank, this value will be set to the minimum
# version of Mac OS X that supports the requested features. Set this
# variable to some value (e.g., 10.4) only if you want to guarantee
# that your installer will work on that version of Mac OS X, and
# don't mind missing extra features available in the installer
# shipping with later versions of Mac OS X.
#
# The following variables are for advanced uses of CPack: # The following variables are for advanced uses of CPack:
# #
##variable ##variable

View File

@ -1,25 +1,37 @@
##section Variables specific to CPack Bundle generator
##end
##module
# - CPack Bundle generator (Mac OS X) specific options # - CPack Bundle generator (Mac OS X) specific options
# #
# Installers built on Mac OS X using the Bundle generator use the # Installers built on Mac OS X using the Bundle generator use the
# aforementioned DragNDrop variables, plus the following Bundle-specific # aforementioned DragNDrop variables, plus the following Bundle-specific
# parameters: # parameters:
##end
# #
##variable
# CPACK_BUNDLE_NAME - The name of the generated bundle. This # CPACK_BUNDLE_NAME - The name of the generated bundle. This
# appears in the OSX finder as the bundle name. Required. # appears in the OSX finder as the bundle name. Required.
##end
# #
##variable
# CPACK_BUNDLE_PLIST - Path to an OSX plist file that will be used # CPACK_BUNDLE_PLIST - Path to an OSX plist file that will be used
# as the Info.plist for the generated bundle. This assumes that # as the Info.plist for the generated bundle. This assumes that
# the caller has generated or specified their own Info.plist file. # the caller has generated or specified their own Info.plist file.
# Required. # Required.
##end
# #
##variable
# CPACK_BUNDLE_ICON - Path to an OSX icns file that will be used as # CPACK_BUNDLE_ICON - Path to an OSX icns file that will be used as
# the icon for the generated bundle. This is the icon that appears # the icon for the generated bundle. This is the icon that appears
# in the OSX finder for the bundle, and in the OSX dock when the # in the OSX finder for the bundle, and in the OSX dock when the
# bundle is opened. Required. # bundle is opened. Required.
##end
# #
##variable
# CPACK_BUNDLE_STARTUP_SCRIPT - Path to an executable or script that # CPACK_BUNDLE_STARTUP_SCRIPT - Path to an executable or script that
# will be run whenever an end-user double-clicks the generated bundle # will be run whenever an end-user double-clicks the generated bundle
# in the OSX Finder. Optional. # in the OSX Finder. Optional.
##end
#============================================================================= #=============================================================================
# Copyright 2006-2009 Kitware, Inc. # Copyright 2006-2009 Kitware, Inc.

View File

@ -1,4 +1,4 @@
##section Variables common to all CPack generators ##section Variables concerning CPack Components
##end ##end
##module ##module
# - Build binary and source package installers # - Build binary and source package installers
@ -25,6 +25,51 @@
# CPack commands: # CPack commands:
##end ##end
# #
##variable
# CPACK_COMPONENTS_ALL - The list of component to install.
#
# The default value of this variable is computed by CPack
# and contains all components defined by the project. The
# user may set it to only include the specified components.
##end
#
##variable
# CPACK_<GENNAME>_COMPONENT_INSTALL - Enable/Disable component install for
# CPack generator <GENNAME>.
#
# Each CPack Generator (RPM, DEB, ARCHIVE, NSIS, DMG, etc...) has a legacy
# default behavior. e.g. RPM builds monolithic whereas NSIS builds component.
# One can change the default behavior by setting this variable to 0/1 or OFF/ON.
##end
##variable
# CPACK_COMPONENTS_GROUPING - Specify how components are grouped for multi-package
# component-aware CPack generators.
#
# Some generators like RPM or ARCHIVE family (TGZ, ZIP, ...) generates several
# packages files when asked for component packaging. They group the component
# differently depending on the value of this variable:
# - ONE_PER_GROUP (default): creates one package file per component group
# - ALL_COMPONENTS_IN_ONE : creates a single package with all (requested) component
# - IGNORE : creates one package per component, i.e. IGNORE component group
# One can specify different grouping for different CPack generator by using
# a CPACK_PROJECT_CONFIG_FILE.
##end
##variable
# CPACK_COMPONENT_<compName>_DISPLAY_NAME - The name to be displayed for a component.
##end
##variable
# CPACK_COMPONENT_<compName>_DESCRIPTION - The description of a component.
##end
##variable
# CPACK_COMPONENT_<compName>_GROUP - The group of a component.
##end
##variable
# CPACK_COMPONENT_<compName>_DEPENDS - The dependencies (list of components)
# on which this component depends.
##end
##variable
# CPACK_COMPONENT_<compName>_REQUIRED - True is this component is required.
##end
##macro ##macro
# cpack_add_component - Describes a CPack installation component # cpack_add_component - Describes a CPack installation component
# named by the COMPONENT argument to a CMake INSTALL command. # named by the COMPONENT argument to a CMake INSTALL command.

70
Modules/CPackDMG.cmake Normal file
View File

@ -0,0 +1,70 @@
##section Variables specific to CPack DragNDrop generator
##end
##module
# - DragNDrop CPack generator (Mac OS X).
# The following variables are specific to the DragNDrop installers
# built on Mac OS X:
##end
#
##variable
# CPACK_DMG_VOLUME_NAME - The volume name of the generated disk
# image. Defaults to CPACK_PACKAGE_FILE_NAME.
##end
#
##variable
# CPACK_DMG_FORMAT - The disk image format. Common values are UDRO
# (UDIF read-only), UDZO (UDIF zlib-compressed) or UDBZ (UDIF
# bzip2-compressed). Refer to hdiutil(1) for more information on
# other available formats.
##end
#
##variable
# CPACK_DMG_DS_STORE - Path to a custom .DS_Store file which e.g.
# can be used to specify the Finder window position/geometry and
# layout (such as hidden toolbars, placement of the icons etc.).
# This file has to be generated by the Finder (either manually or
# through OSA-script) using a normal folder from which the .DS_Store
# file can then be extracted.
##end
#
##variable
# CPACK_DMG_BACKGROUND_IMAGE - Path to an image file which is to be
# used as the background for the Finder Window when the disk image
# is opened. By default no background image is set. The background
# image is applied after applying the custom .DS_Store file.
##end
#
##variable
# CPACK_COMMAND_HDIUTIL - Path to the hdiutil(1) command used to
# operate on disk image files on Mac OS X. This variable can be used
# to override the automatically detected command (or specify its
# location if the auto-detection fails to find it.)
##end
#
##variable
# CPACK_COMMAND_SETFILE - Path to the SetFile(1) command used to set
# extended attributes on files and directories on Mac OS X. This
# variable can be used to override the automatically detected
# command (or specify its location if the auto-detection fails to
# find it.)
##end
#
##variable
# CPACK_COMMAND_REZ - Path to the Rez(1) command used to compile
# resources on Mac OS X. This variable can be used to override the
# automatically detected command (or specify its location if the
# auto-detection fails to find it.)
##end
#=============================================================================
# Copyright 2006-2012 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.
#=============================================================================
# (To distribute this file outside of CMake, substitute the full
# License text for the above reference.)

View File

@ -1,4 +1,4 @@
##section Variables specific to a CPack generator ##section Variables specific to CPack Debian (DEB) generator
##end ##end
##module ##module
# - The builtin (binary) CPack Deb generator (Unix only) # - The builtin (binary) CPack Deb generator (Unix only)

View File

@ -1,70 +1,112 @@
##section Variables specific to CPack NSIS generator
##end
##module
# - CPack NSIS generator specific options # - CPack NSIS generator specific options
# #
# The following variables are specific to the graphical installers built # The following variables are specific to the graphical installers built
# on Windows using the Nullsoft Installation System. # on Windows using the Nullsoft Installation System.
##end
# #
##variable
# CPACK_PACKAGE_INSTALL_REGISTRY_KEY - Registry key used when # CPACK_PACKAGE_INSTALL_REGISTRY_KEY - Registry key used when
# installing this project. # installing this project.
##end
# #
##variable
# CPACK_NSIS_INSTALL_ROOT - The default installation directory presented # CPACK_NSIS_INSTALL_ROOT - The default installation directory presented
# to the end user by the NSIS installer is under this root dir. The full # to the end user by the NSIS installer is under this root dir. The full
# directory presented to the end user is: # directory presented to the end user is:
# ${CPACK_NSIS_INSTALL_ROOT}/${CPACK_PACKAGE_INSTALL_DIRECTORY} # ${CPACK_NSIS_INSTALL_ROOT}/${CPACK_PACKAGE_INSTALL_DIRECTORY}
##end
# #
##variable
# CPACK_NSIS_MUI_ICON - The icon file (.ico) for the generated # CPACK_NSIS_MUI_ICON - The icon file (.ico) for the generated
# install program. # install program.
##end
# #
##variable
# CPACK_NSIS_MUI_UNIICON - The icon file (.ico) for the generated # CPACK_NSIS_MUI_UNIICON - The icon file (.ico) for the generated
# uninstall program. # uninstall program.
##end
# #
##variable
# CPACK_PACKAGE_ICON - A branding image that will be displayed inside # CPACK_PACKAGE_ICON - A branding image that will be displayed inside
# the installer. # the installer.
##end
# #
##variable
# CPACK_NSIS_EXTRA_INSTALL_COMMANDS - Extra NSIS commands that will # CPACK_NSIS_EXTRA_INSTALL_COMMANDS - Extra NSIS commands that will
# be added to the install Section. # be added to the install Section.
##end
# #
##variable
# CPACK_NSIS_EXTRA_UNINSTALL_COMMANDS - Extra NSIS commands that will # CPACK_NSIS_EXTRA_UNINSTALL_COMMANDS - Extra NSIS commands that will
# be added to the uninstall Section. # be added to the uninstall Section.
##end
# #
##variable
# CPACK_NSIS_COMPRESSOR - The arguments that will be passed to the # CPACK_NSIS_COMPRESSOR - The arguments that will be passed to the
# NSIS SetCompressor command. # NSIS SetCompressor command.
##end
# #
##variable
# CPACK_NSIS_MODIFY_PATH - If this is set to "ON", then an extra page # CPACK_NSIS_MODIFY_PATH - If this is set to "ON", then an extra page
# will appear in the installer that will allow the user to choose # will appear in the installer that will allow the user to choose
# whether the program directory should be added to the system PATH # whether the program directory should be added to the system PATH
# variable. # variable.
##end
# #
##variable
# CPACK_NSIS_DISPLAY_NAME - The display name string that appears in # CPACK_NSIS_DISPLAY_NAME - The display name string that appears in
# the Windows Add/Remove Program control panel # the Windows Add/Remove Program control panel
##end
# #
##variable
# CPACK_NSIS_PACKAGE_NAME - The title displayed at the top of the # CPACK_NSIS_PACKAGE_NAME - The title displayed at the top of the
# installer. # installer.
##end
# #
##variable
# CPACK_NSIS_INSTALLED_ICON_NAME - A path to the executable that # CPACK_NSIS_INSTALLED_ICON_NAME - A path to the executable that
# contains the installer icon. # contains the installer icon.
##end
# #
##variable
# CPACK_NSIS_HELP_LINK - URL to a web site providing assistance in # CPACK_NSIS_HELP_LINK - URL to a web site providing assistance in
# installing your application. # installing your application.
##end
# #
##variable
# CPACK_NSIS_URL_INFO_ABOUT - URL to a web site providing more # CPACK_NSIS_URL_INFO_ABOUT - URL to a web site providing more
# information about your application. # information about your application.
##end
# #
##variable
# CPACK_NSIS_CONTACT - Contact information for questions and comments # CPACK_NSIS_CONTACT - Contact information for questions and comments
# about the installation process. # about the installation process.
##end
# #
##variable
# CPACK_NSIS_CREATE_ICONS_EXTRA - Additional NSIS commands for # CPACK_NSIS_CREATE_ICONS_EXTRA - Additional NSIS commands for
# creating start menu shortcuts. # creating start menu shortcuts.
##end
# #
##variable
# CPACK_NSIS_DELETE_ICONS_EXTRA -Additional NSIS commands to # CPACK_NSIS_DELETE_ICONS_EXTRA -Additional NSIS commands to
# uninstall start menu shortcuts. # uninstall start menu shortcuts.
##end
# #
##variable
# CPACK_NSIS_EXECUTABLES_DIRECTORY - Creating NSIS start menu links # CPACK_NSIS_EXECUTABLES_DIRECTORY - Creating NSIS start menu links
# assumes that they are in 'bin' unless this variable is set. # assumes that they are in 'bin' unless this variable is set.
# For example, you would set this to 'exec' if your executables are # For example, you would set this to 'exec' if your executables are
# in an exec directory. # in an exec directory.
##end
# #
##variable
# CPACK_NSIS_MUI_FINISHPAGE_RUN - Specify an executable to add an option # CPACK_NSIS_MUI_FINISHPAGE_RUN - Specify an executable to add an option
# to run on the finish page of the NSIS installer. # to run on the finish page of the NSIS installer.
##end
#============================================================================= #=============================================================================
# Copyright 2006-2009 Kitware, Inc. # Copyright 2006-2009 Kitware, Inc.

View File

@ -0,0 +1,34 @@
##section Variables specific to CPack PackageMaker generator
##end
##module
# - PackageMaker CPack generator (Mac OS X).
# The following variable is specific to installers build on Mac OS X
# using PackageMaker:
#
##variable
# CPACK_OSX_PACKAGE_VERSION - The version of Mac OS X that the
# resulting PackageMaker archive should be compatible
# with. Different versions of Mac OS X support different
# features. For example, CPack can only build component-based
# installers for Mac OS X 10.4 or newer, and can only build
# installers that download component son-the-fly for Mac OS X 10.5
# or newer. If left blank, this value will be set to the minimum
# version of Mac OS X that supports the requested features. Set this
# variable to some value (e.g., 10.4) only if you want to guarantee
# that your installer will work on that version of Mac OS X, and
# don't mind missing extra features available in the installer
# shipping with later versions of Mac OS X.
##end
#=============================================================================
# Copyright 2006-2012 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.
#=============================================================================
# (To distribute this file outside of CMake, substitute the full
# License text for the above reference.)

View File

@ -1,4 +1,4 @@
##section Variables specific to a CPack generator ##section Variables specific to CPack RPM generator
##end ##end
##module ##module
# - The builtin (binary) CPack RPM generator (Unix only) # - The builtin (binary) CPack RPM generator (Unix only)

View File

@ -514,7 +514,6 @@ int main (int argc, char *argv[])
if ( help ) if ( help )
{ {
// Construct and print requested documentation. // Construct and print requested documentation.
std::vector<cmDocumentationEntry> variables;
doc.SetName("cpack"); doc.SetName("cpack");
doc.SetSection("Name",cmDocumentationName); doc.SetSection("Name",cmDocumentationName);
@ -545,7 +544,7 @@ int main (int argc, char *argv[])
{ {
doc.GetStructuredDocFromFile( doc.GetStructuredDocFromFile(
(docedIt->first).c_str(), (docedIt->first).c_str(),
commands,&cminst,(docedIt->second).c_str()); commands,&cminst);
} }
std::map<std::string,cmDocumentationSection *> propDocs; std::map<std::string,cmDocumentationSection *> propDocs;

View File

@ -16,6 +16,7 @@
#include <cmsys/Directory.hxx> #include <cmsys/Directory.hxx>
#include <cmsys/Glob.hxx> #include <cmsys/Glob.hxx>
#include <algorithm>
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
static const char *cmDocumentationStandardOptions[][3] = static const char *cmDocumentationStandardOptions[][3] =
@ -741,10 +742,20 @@ void cmDocumentation::addCPackStandardDocSections()
this->VariableSections.push_back( this->VariableSections.push_back(
"Variables common to all CPack generators"); "Variables common to all CPack generators");
this->VariableSections.push_back(
"Variables specific to a CPack generator");
} }
void cmDocumentation::addAutomaticVariableSections(const std::string& section)
{
std::vector<std::string>::iterator it;
it = std::find(this->VariableSections.begin(),
this->VariableSections.end(),
section);
/* if the section does not exist then add it */
if (it==this->VariableSections.end())
{
this->VariableSections.push_back(section);
}
}
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
int cmDocumentation::getDocumentedModulesListInDir( int cmDocumentation::getDocumentedModulesListInDir(
std::string path, std::string path,
@ -818,8 +829,7 @@ static void trim(std::string& s)
int cmDocumentation::GetStructuredDocFromFile( int cmDocumentation::GetStructuredDocFromFile(
const char* fname, const char* fname,
std::vector<cmDocumentationEntry>& commands, std::vector<cmDocumentationEntry>& commands,
cmake* cm, cmake* cm)
const char *docSection)
{ {
typedef enum sdoce { typedef enum sdoce {
SDOC_NONE, SDOC_MODULE, SDOC_MACRO, SDOC_FUNCTION, SDOC_VARIABLE, SDOC_NONE, SDOC_MODULE, SDOC_MACRO, SDOC_FUNCTION, SDOC_VARIABLE,
@ -835,6 +845,7 @@ int cmDocumentation::GetStructuredDocFromFile(
{ {
return nbDocItemFound; return nbDocItemFound;
} }
std::string section;
std::string name; std::string name;
std::string full; std::string full;
std::string brief; std::string brief;
@ -886,6 +897,8 @@ int cmDocumentation::GetStructuredDocFromFile(
{ {
docCtxIdx++; docCtxIdx++;
docContextStack[docCtxIdx]=SDOC_SECTION; docContextStack[docCtxIdx]=SDOC_SECTION;
// 10 is the size of '##section' + 1
section = line.substr(10,std::string::npos);
/* drop the rest of the line */ /* drop the rest of the line */
line = ""; line = "";
newCtx = true; newCtx = true;
@ -900,11 +913,12 @@ int cmDocumentation::GetStructuredDocFromFile(
brief.c_str(),full.c_str())); brief.c_str(),full.c_str()));
break; break;
case SDOC_VARIABLE: case SDOC_VARIABLE:
this->addAutomaticVariableSections(section);
cm->DefineProperty cm->DefineProperty
(name.c_str(), cmProperty::VARIABLE, (name.c_str(), cmProperty::VARIABLE,
brief.c_str(), brief.c_str(),
full.c_str(),false, full.c_str(),false,
docSection); section.c_str());
break; break;
case SDOC_MODULE: case SDOC_MODULE:
/* not implemented */ /* not implemented */

View File

@ -147,6 +147,9 @@ public:
/** Add the CPack standard documentation section(s) */ /** Add the CPack standard documentation section(s) */
void addCPackStandardDocSections(); void addCPackStandardDocSections();
/** Add automatic variables sections */
void addAutomaticVariableSections(const std::string& section);
/** /**
* Retrieve the list of documented module located in * Retrieve the list of documented module located in
* path which match the globing expression globExpr. * path which match the globing expression globExpr.
@ -185,8 +188,7 @@ public:
*/ */
int GetStructuredDocFromFile(const char* fname, int GetStructuredDocFromFile(const char* fname,
std::vector<cmDocumentationEntry>& commands, std::vector<cmDocumentationEntry>& commands,
cmake* cm, cmake* cm);
const char *docSection);
private: private:
void SetForm(Form f); void SetForm(Form f);
void SetDocName(const char* docname); void SetDocName(const char* docname);