Compatibility with older versions of cmake.
After this change, the cmake setup now works even on Debian stretch
(oldoldstable), which runs cmake 3.7.
In order to support a version that early I had to:
- write a fallback implementation of 'add_compile_definitions' for
older cmakes, which is easy, because add_compile_definitions(FOO)
is basically just add_compile_options(-DFOO)
- stop using list(TRANSFORM) and string(JOIN), of which I had one
case each, and they were easily replaced with simple foreach loops
- stop putting OBJECT libraries in the target_link_libraries command
for executable targets, in favour of adding $<TARGET_OBJECTS:foo>
to the main sources list for the same target. That matches what I
do with library targets, so it's probably more sensible anyway.
I tried going back by another Debian release and getting this cmake
setup to work on jessie, but that runs CMake 3.0.1, and in _that_
version of cmake the target_sources command is missing, and I didn't
find any alternative way to add extra sources to a target after having
first declared it. Reorganising to cope with _that_ omission would be
too much upheaval without a very good reason.
2021-10-29 17:08:18 +00:00
|
|
|
cmake_minimum_required(VERSION 3.7)
|
2021-05-08 09:11:56 +00:00
|
|
|
project(putty-documentation LANGUAGES)
|
|
|
|
|
|
|
|
# This build script can be run standalone, or included as a
|
|
|
|
# subdirectory of the main PuTTY cmake build system. If the latter, a
|
|
|
|
# couple of things change: it has to set variables telling the rest of
|
|
|
|
# the build system what manpages are available to be installed, and it
|
|
|
|
# will change whether the 'make doc' target is included in 'make all'.
|
|
|
|
|
|
|
|
include(FindGit)
|
2021-05-02 14:34:57 +00:00
|
|
|
include(FindPerl)
|
|
|
|
find_program(HALIBUT halibut)
|
|
|
|
|
|
|
|
set(doc_outputs)
|
|
|
|
set(manpage_outputs)
|
|
|
|
|
|
|
|
if(HALIBUT AND PERL_EXECUTABLE)
|
|
|
|
# Build the main manual, which requires not only Halibut, but also
|
|
|
|
# Perl to run licence.pl to generate the copyright and licence
|
|
|
|
# sections from the master data outside this directory.
|
|
|
|
|
|
|
|
# If this is a source archive in which a fixed version.but was
|
|
|
|
# provided, use that. Otherwise, infer one from the git checkout (if
|
|
|
|
# possible).
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
|
|
|
|
set(manual_dependencies) # extra target names to depend on
|
|
|
|
|
2021-05-02 14:34:57 +00:00
|
|
|
if(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/version.but)
|
|
|
|
set(VERSION_BUT ${CMAKE_CURRENT_SOURCE_DIR}/version.but)
|
|
|
|
else()
|
|
|
|
set(VERSION_BUT ${CMAKE_CURRENT_BINARY_DIR}/cmake_version.but)
|
|
|
|
set(INTERMEDIATE_VERSION_BUT ${VERSION_BUT}.tmp)
|
|
|
|
add_custom_target(check_git_commit_for_doc
|
|
|
|
BYPRODUCTS ${INTERMEDIATE_VERSION_BUT}
|
|
|
|
COMMAND ${CMAKE_COMMAND}
|
|
|
|
-DGIT_EXECUTABLE=${GIT_EXECUTABLE}
|
|
|
|
-DOUTPUT_FILE=${INTERMEDIATE_VERSION_BUT}
|
|
|
|
-DOUTPUT_TYPE=halibut
|
2021-05-08 09:11:56 +00:00
|
|
|
-P ${CMAKE_CURRENT_SOURCE_DIR}/../cmake/gitcommit.cmake
|
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/../cmake/gitcommit.cmake
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/..
|
2021-05-02 14:34:57 +00:00
|
|
|
COMMENT "Checking current git commit")
|
|
|
|
add_custom_target(cmake_version_but
|
|
|
|
BYPRODUCTS ${VERSION_BUT}
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different
|
|
|
|
${INTERMEDIATE_VERSION_BUT} ${VERSION_BUT}
|
|
|
|
DEPENDS check_git_commit_for_doc ${INTERMEDIATE_VERSION_BUT}
|
|
|
|
COMMENT "Updating cmake_version.but")
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
set(manual_dependencies ${manual_dependencies} cmake_version_but)
|
2021-05-02 14:34:57 +00:00
|
|
|
endif()
|
|
|
|
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
add_custom_target(copy_but
|
|
|
|
BYPRODUCTS copy.but
|
2021-05-08 09:11:56 +00:00
|
|
|
COMMAND ${PERL_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/../licence.pl
|
2021-05-02 14:34:57 +00:00
|
|
|
--copyrightdoc -o copy.but
|
2021-05-08 09:11:56 +00:00
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/../licence.pl ${CMAKE_CURRENT_SOURCE_DIR}/../LICENCE)
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
add_custom_target(licence_but
|
|
|
|
BYPRODUCTS licence.but
|
2021-05-08 09:11:56 +00:00
|
|
|
COMMAND ${PERL_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/../licence.pl
|
2021-05-02 14:34:57 +00:00
|
|
|
--licencedoc -o licence.but
|
2021-05-08 09:11:56 +00:00
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/../licence.pl ${CMAKE_CURRENT_SOURCE_DIR}/../LICENCE)
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
set(manual_dependencies ${manual_dependencies} copy_but licence_but)
|
2021-05-02 14:34:57 +00:00
|
|
|
|
|
|
|
set(manual_sources
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/copy.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/blurb.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/intro.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/gs.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/using.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/config.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/pscp.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/psftp.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/plink.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/pubkey.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/pageant.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/errors.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/faq.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/feedback.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/pubkeyfmt.but
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/licence.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/udp.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/pgpkeys.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/sshnames.but
|
New feature: k-i authentication helper plugins.
In recent months I've had two requests from different people to build
support into PuTTY for automatically handling complicated third-party
auth protocols layered on top of keyboard-interactive - the kind of
thing where you're asked to enter some auth response, and you have to
refer to some external source like a web server to find out what the
right response _is_, which is a pain to do by hand, so you'd prefer it
to be automated in the SSH client.
That seems like a reasonable thing for an end user to want, but I
didn't think it was a good idea to build support for specific
protocols of that kind directly into PuTTY, where there would no doubt
be an ever-lengthening list, and maintenance needed on all of them.
So instead, in collaboration with one of my correspondents, I've
designed and implemented a protocol to be spoken between PuTTY and a
plugin running as a subprocess. The plugin can opt to handle the
keyboard-interactive authentication loop on behalf of the user, in
which case PuTTY passes on all the INFO_REQUEST packets to it, and
lets it make up responses. It can also ask questions of the user if
necessary.
The protocol spec is provided in a documentation appendix. The entire
configuration for the end user consists of providing a full command
line to use as the subprocess.
In the contrib directory I've provided an example plugin written in
Python. It gives a set of fixed responses suitable for getting through
Uppity's made-up k-i system, because that was a reasonable thing I
already had lying around to test against. But it also provides example
code that someone else could pick up and insert their own live
response-provider into the middle of, assuming they were happy with it
being in Python.
2022-09-01 18:38:46 +00:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/authplugin.but
|
2021-05-02 14:34:57 +00:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/index.but
|
|
|
|
${VERSION_BUT})
|
|
|
|
|
|
|
|
# The HTML manual goes in a subdirectory, for convenience.
|
|
|
|
set(html_dir ${CMAKE_CURRENT_BINARY_DIR}/html)
|
|
|
|
file(MAKE_DIRECTORY ${html_dir})
|
|
|
|
add_custom_command(OUTPUT ${html_dir}/index.html
|
|
|
|
COMMAND ${HALIBUT} --html ${manual_sources}
|
|
|
|
WORKING_DIRECTORY ${html_dir}
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
DEPENDS ${manual_sources} ${manual_dependencies})
|
2021-05-02 14:34:57 +00:00
|
|
|
list(APPEND doc_outputs ${html_dir}/index.html)
|
|
|
|
|
|
|
|
# Windows help.
|
|
|
|
file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/chmextra.but
|
|
|
|
"\\cfg{chm-extra-file}{${CMAKE_CURRENT_SOURCE_DIR}/chm.css}{chm.css}\n")
|
|
|
|
add_custom_command(OUTPUT putty.chm
|
|
|
|
COMMAND ${HALIBUT} --chm chmextra.but ${manual_sources}
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
DEPENDS ${manual_sources} ${manual_dependencies})
|
2021-05-02 14:34:57 +00:00
|
|
|
list(APPEND doc_outputs putty.chm)
|
|
|
|
|
|
|
|
# Plain text.
|
|
|
|
add_custom_command(OUTPUT puttydoc.txt
|
|
|
|
COMMAND ${HALIBUT} --text ${manual_sources}
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
doc/CMakeLists.txt: reorganise custom targets.
Jacob reported that on Debian buster, the command sequence
cmake $srcdir
cmake --build .
cmake --build . --target doc
would fail at the third step, with the make error "No rule to make
target 'doc/cmake_version.but', needed by 'doc/html/index.html'".
That seems odd, because the file ${VERSION_BUT} _was_ declared as a
dependency of the rule that builds doc/html/*.html, and _cmake_ knew
what rule built it (namely the custom target 'cmake_version_but'). I
suspect this is a bug in cmake 3.13, because the same command sequence
works fine with cmake 3.20.
However, it's possible to work around, by means of adding the cmake
_target name_ to the dependencies for any rule that uses that file,
instead of relying on it to map the output _file_ name to that target.
While I'm at it, I've transformed the rules that build copy.but and
licence.but in the same way, turning those too into custom targets
instead of custom commands (I've found that the former are more
generally reliable across a range of cmake versions), and including
the target names themselves as dependencies.
2022-01-22 14:42:03 +00:00
|
|
|
DEPENDS ${manual_sources} ${manual_dependencies})
|
2021-05-02 14:34:57 +00:00
|
|
|
list(APPEND doc_outputs puttydoc.txt)
|
2022-10-29 14:30:26 +00:00
|
|
|
|
|
|
|
# PDF. (We don't ship this; so it's only built on explicit request.)
|
|
|
|
add_custom_command(OUTPUT putty.pdf
|
|
|
|
COMMAND ${HALIBUT} --pdf ${manual_sources}
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
|
|
|
DEPENDS ${manual_sources} ${manual_dependencies})
|
|
|
|
add_custom_target(pdf DEPENDS putty.pdf)
|
2021-05-02 14:34:57 +00:00
|
|
|
endif()
|
|
|
|
|
2021-05-08 09:11:56 +00:00
|
|
|
macro(register_manpage title section)
|
|
|
|
list(APPEND manpage_outputs ${title}.${section})
|
|
|
|
if(NOT CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR)
|
|
|
|
# Only set this variable if there _is_ a parent scope.
|
|
|
|
set(HAVE_MANPAGE_${title}_${section} ON PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
endmacro()
|
|
|
|
|
2022-09-01 18:33:44 +00:00
|
|
|
if(NOT HALIBUT)
|
|
|
|
# If we don't have Halibut available to rebuild the man pages from
|
|
|
|
# source, we must check whether the build and source directories
|
|
|
|
# correspond, so as to suppress the build rules that copy them from
|
|
|
|
# the source dir to the build dir. (Otherwise, someone unpacking
|
|
|
|
# putty-src.zip and building on a system without Halibut will find
|
|
|
|
# that there's a circular dependency in the makefile, which at least
|
|
|
|
# Ninja complains about.)
|
|
|
|
get_filename_component(DOCBUILDDIR ${CMAKE_CURRENT_BINARY_DIR} REALPATH)
|
|
|
|
get_filename_component(DOCSRCDIR ${CMAKE_CURRENT_SOURCE_DIR} REALPATH)
|
|
|
|
endif()
|
|
|
|
|
2021-05-02 14:34:57 +00:00
|
|
|
macro(manpage title section)
|
|
|
|
if(HALIBUT)
|
|
|
|
add_custom_command(OUTPUT ${title}.${section}
|
|
|
|
COMMAND ${HALIBUT} --man=${title}.${section}
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/mancfg.but
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/man-${title}.but
|
|
|
|
DEPENDS
|
|
|
|
mancfg.but man-${title}.but)
|
2021-05-08 09:11:56 +00:00
|
|
|
register_manpage(${title} ${section})
|
2022-10-19 18:44:14 +00:00
|
|
|
elseif(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${title}.${section})
|
|
|
|
# Our tarballs include prebuilt man pages in the source tree, so
|
|
|
|
# they can be installed from there even if Halibut isn't available.
|
|
|
|
if(NOT (DOCBUILDDIR STREQUAL DOCSRCDIR))
|
|
|
|
# Iff the build tree isn't the source tree, they'll need copying
|
|
|
|
# to the build tree first.
|
|
|
|
add_custom_command(OUTPUT ${title}.${section}
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/${title}.${section} ${title}.${section}
|
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${title}.${section})
|
|
|
|
endif()
|
2021-05-08 09:11:56 +00:00
|
|
|
register_manpage(${title} ${section})
|
2021-05-02 14:34:57 +00:00
|
|
|
endif()
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
manpage(putty 1)
|
|
|
|
manpage(puttygen 1)
|
|
|
|
manpage(plink 1)
|
|
|
|
manpage(pscp 1)
|
|
|
|
manpage(psftp 1)
|
|
|
|
manpage(puttytel 1)
|
|
|
|
manpage(pterm 1)
|
|
|
|
manpage(pageant 1)
|
|
|
|
manpage(psocks 1)
|
|
|
|
manpage(psusan 1)
|
|
|
|
|
2021-05-08 09:11:56 +00:00
|
|
|
add_custom_target(manpages ALL DEPENDS ${manpage_outputs})
|
|
|
|
add_custom_target(doc DEPENDS ${doc_outputs} manpages)
|
|
|
|
|
|
|
|
if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR)
|
|
|
|
# If we're doing a cmake from just the doc subdir, we expect the
|
|
|
|
# user to want to make all the documentation, including HTML and so
|
|
|
|
# forth. (What else would be the point?)
|
|
|
|
#
|
|
|
|
# But if we're included from the main makefile, then by default we
|
|
|
|
# only make the man pages (which are necessary for 'make install'),
|
|
|
|
# and we leave everything else to a separate 'make doc' target which
|
|
|
|
# the user can invoke if they need to.
|
|
|
|
add_custom_target(doc-default ALL DEPENDS doc)
|
|
|
|
endif()
|