File: man2pdf.sh

package info (click to toggle)
mpich 4.0.2-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 423,384 kB
  • sloc: ansic: 1,088,434; cpp: 71,364; javascript: 40,763; f90: 22,829; sh: 17,463; perl: 14,773; xml: 14,418; python: 10,265; makefile: 9,246; fortran: 8,008; java: 4,355; asm: 324; ruby: 176; lisp: 19; php: 8; sed: 4
file content (84 lines) | stat: -rwxr-xr-x 2,920 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/bin/bash

# Copyright (c) 2017 Intel Corp.  All rights reserved.
#
# This software is available to you under a choice of one of two
# licenses.  You may choose to be licensed under the terms of the GNU
# General Public License (GPL) Version 2, available from the file
# COPYING in the main directory of this source tree, or the
# BSD license below:
#
#     Redistribution and use in source and binary forms, with or
#     without modification, are permitted provided that the following
#     conditions are met:
#
#      - Redistributions of source code must retain the above
#        copyright notice, this list of conditions and the following
#        disclaimer.
#
#      - Redistributions in binary form must reproduce the above
#        copyright notice, this list of conditions and the following
#        disclaimer in the documentation and/or other materials
#        provided with the distribution.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.

#
# MAN 2 PDF -- Simple script to convert the libfabric manpages into a PDF
#
# Requires libfabric manpages to be installed and available in MANPATH.
# Uses man and ps2pdf to convert each manpage, followed by Mac join.py or
# pdfjoin to generate final PDF
#

# Generate list of manpages, but exclude manpages that are symlinks to other manpages
MANPAGES=( `echo fabric && man -a -w fi_* | xargs basename | sort | uniq | cut -d . -f 1` )

PDFMANPAGES=( "${MANPAGES[@]/%/.pdf}" )
WORKDIR=`mktemp -d /tmp/libfabric-manpages.XXXXXX || exit 1`
OUTFILE="libfabric-manpages-`date \"+%Y-%m-%d\"`.pdf"
EXITDIR="$PWD"

if [ -e $OUTFILE ]; then
    echo "Error: $OUTFILE already exists"
    exit 1
fi

echo Entering work directory: $WORKDIR
cd $WORKDIR || exit 1

for manpage in "${MANPAGES[@]}"; do
    echo "  - Converting $manpage"
    man -t $manpage | ps2pdf - $WORKDIR/${manpage}.pdf || exit 1
done

echo "  + Merging manpages"

if [ -x /System/Library/Automator/Combine\ PDF\ Pages.action/Contents/Resources/join.py ]; then
    /System/Library/Automator/Combine\ PDF\ Pages.action/Contents/Resources/join.py -o $OUTFILE "${PDFMANPAGES[@]}" || exit 1
elif hash pdfjoin 2>/dev/null; then
    pdfjoin --quiet -o $OUTFILE "${PDFMANPAGES[@]}" || exit 1
else
    echo "Error: could not join PDFs (check installation of pdfjoin)"
fi

echo "  + Cleaning up"

rm -f "${PDFMANPAGES[@]}"
cd $EXITDIR
if [ -e $WORKDIR/$OUTFILE ]; then
    mv $WORKDIR/$OUTFILE .
    echo "Done: $OUTFILE"
else
    echo "PDF generation failed"
fi

rmdir $WORKDIR