blob: c0efdcbd51dda9ad36c6e5881f14078a8f62e577 [file] [log] [blame]
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -04001
2#
3#==================================================================================
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -04004# Copyright (c) 2019 Nokia
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -04005# Copyright (c) 2018-2019 AT&T Intellectual Property.
6#
7# Licensed under the Apache License, Version 2.0 (the "License");
8# you may not use this file except in compliance with the License.
9# You may obtain a copy of the License at
10#
11# http://www.apache.org/licenses/LICENSE-2.0
12#
13# Unless required by applicable law or agreed to in writing, software
14# distributed under the License is distributed on an "AS IS" BASIS,
15# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16# See the License for the specific language governing permissions and
17# limitations under the License.
18#==================================================================================
19#
20
21
22# builds the man pages for the deb file (generates troff from {X}fm).
23# also builds postscript files, but leaves them in the current build dir.
24# but, ONLY if build_doc variable is true
25#
26
27# look for tfm to build the man pages with. if not found, then we pull
28# and build in the current build environment setting tfm/pfm commands to
29# point at the correct spot. If the user has {X}fm installed, we just
30# use their install.
31#
32if( BUILD_DOC )
33 find_program( tfm NAMES tfm )
34 find_program( pfm NAMES pfm )
35
36 if( "${tfm}" MATCHES "tfm-NOTFOUND" ) # user doesn't have installed; set where we expect them
37 set( tfm ${CMAKE_CURRENT_BINARY_DIR}/xfm/.build/src/tfm/tfm )
38 set( pfm "${CMAKE_CURRENT_BINARY_DIR}/xfm/.build/src/pfm/pfm" )
39
40 if( NOT EXISTS ${tfm} ) # not yet built here, pull and build
41 # pull and build {X}fm tools needed to generate manpages
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -040042 execute_process(
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -040043 COMMAND "bash" "-c" "git clone https://github.com/ScottDaniels/xfm.git && cd xfm && mkdir .build && cd .build && cmake .. && make"
44 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
45 )
46 message( "+++ xfm pulled and built" )
47 else()
48 message( "+++ found xfm in the build environment" )
49 endif()
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -040050
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -040051 endif()
52
53 # base filenames (with .xfm are input)
54 set( man_names
55 rmr.7
56 rmr_bytes2meid.3
57 rmr_bytes2xact.3
58 rmr_bytes2payload.3
59 rmr_free_msg.3
60 rmr_payload_size.3
61 rmr_rts_msg.3
62 rmr_wh_close.3
63 rmr_alloc_msg.3
64 rmr_get_rcvfd.3
E. Scott Daniels15390d72019-05-06 20:19:59 +000065 rmr_get_meid.3
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -040066 rmr_rcv_msg.3
67 rmr_send_msg.3
68 rmr_wh_open.3
69 rmr_call.3
70 rmr_init.3
71 rmr_ready.3
72 rmr_str2meid.3
73 rmr_str2xact.3
74 rmr_support.3
75 rmr_torcv_msg.3
76 rmr_wh_send_msg.3
E. Scott Daniels08aee4a2019-04-19 19:51:41 +000077 rmr_get_trace.3
78 rmr_init_trace.3
79 rmr_set_trace.3
E. Scott Daniels0d4def62020-01-28 16:50:27 -050080 rmr_set_vlevel.3
E. Scott Daniels08aee4a2019-04-19 19:51:41 +000081 rmr_tralloc_msg.3
82 rmr_get_trlen.3
E. Scott Danielsc1aee2b2019-04-19 21:12:25 +000083 rmr_get_src.3
E. Scott Daniels412d53d2019-05-20 20:00:52 +000084 rmr_mt_call.3
85 rmr_mt_rcv.3
E. Scott Daniels68d09fa2019-06-03 19:45:12 +000086 rmr_get_srcip.3
E. Scott Danielsd9de79a2019-10-31 09:20:33 -040087 rmr_realloc_payload.3
E. Scott Danielsa7610c62019-07-11 10:24:01 -040088 rmr_trace_ref.3
E. Scott Danielse30fc3a2019-07-16 12:03:45 -040089 rmr_set_stimeout.3
E. Scott Daniels4ac73e32019-08-13 11:35:04 -040090 rmr_get_xact.3
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -040091 )
92
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -040093 # initialise lists of files we generated
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -040094 set( man3_files )
95 set( man7_files )
96
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -040097 # for each source, build a specific command that runs tfm to generate the
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -040098 # troff output as a gzipped file. Sed is needed to remove the leading blank
E. Scott Danielse30fc3a2019-07-16 12:03:45 -040099 # that tfm likes to insert even if indention is 0. We also generate postscript
E. Scott Danielsffba61c2019-07-29 14:28:00 -0400100 # markdown, plain ascii and rts output which are left in the build directory
101 # for the developer to use as needed.
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400102 #
103 foreach( nm IN LISTS man_names )
104 set( out ${CMAKE_BINARY_DIR}/${nm} )
105 set( in ${CMAKE_SOURCE_DIR}/doc/src/man/${nm}.xfm )
106
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -0400107 add_custom_command(
108 OUTPUT ${out}.gz
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400109 DEPENDS ${in}
E. Scott Danielsffba61c2019-07-29 14:28:00 -0400110 COMMAND bash -c "export LIB=${CMAKE_SOURCE_DIR}/doc/src; \
111 export OUTPUT_TYPE=troff; \
112 ${tfm} ${in} stdout | sed 's/^ //' | gzip >${out}.gz; \
113 export OUTPUT_TYPE=rst; \
114 ${tfm} ${in} ${out}.rst; \
115 export OUTPUT_TYPE=txt; \
116 ${tfm} ${in} ${out}.txt; \
117 export OUTPUT_TYPE=markdown; \
118 ${tfm} ${in} stdout | sed 's/^ //' >${out}.md; \
119 export OUTPUT_TYPE=postscript; \
120 ${pfm} ${in} ${out}.ps"
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400121 WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
122 COMMENT "Building manpage ${out}"
123 VERBATIM
124 )
125 if( ${out} MATCHES ".*\.3" )
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -0400126 list( APPEND man3_files ${out}.gz )
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400127 else()
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -0400128 list( APPEND man7_files ${out}.gz )
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400129 endif()
130 endforeach()
131
132 # we must force these to install
E. Scott Danielsd4f18ba2019-06-17 15:08:17 -0400133 # find all of the man pages in build and add them to the package
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400134 #
135 install( FILES ${man3_files} DESTINATION ${install_man}/man3/ )
136 install( FILES ${man7_files} DESTINATION ${install_man}/man7/ )
137
138 add_custom_target( man_pages ALL DEPENDS ${man3_files};${man7_files} )
139
140else()
E. Scott Danielsa9435332019-05-09 14:39:19 +0000141 message( "+++ not building doc, set -DBULID_DOC=1 on cmake command line to enable" )
Ashwin Sridharanfd9cc7a2019-04-03 16:47:02 -0400142endif()
143unset( BUILD_DOC CACHE ) # prevent it from being applied next build unless specifically set on comd line