2001-07-24 12:56:11 +02:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
|
|
|
# Script to properly insert an entry into the man-refs.ent file.
|
|
|
|
# Originally by Dima Dorfman, public domain, 2001.
|
|
|
|
#
|
|
|
|
# This makes *a lot* of assumptions about the format; particularly it
|
|
|
|
# requires that all man pages in a section are in one contiguous
|
|
|
|
# block, and that everything is sorted alphabetically within the
|
|
|
|
# aforementioned block. This will edit the file in place, but will
|
|
|
|
# not commit it; since it doesn't do a good job of handling corner
|
|
|
|
# cases, the user should review its work before committing its
|
|
|
|
# changes.
|
|
|
|
#
|
|
|
|
# This is also very ugly, but that's the price of not having Tcl in
|
|
|
|
# the base system!
|
|
|
|
#
|
2012-10-01 13:56:00 +02:00
|
|
|
# Tested with doc/share/xml/man-refs.ent rev. 1.85 (dd, 2001/06/30).
|
2001-07-24 12:56:11 +02:00
|
|
|
#
|
|
|
|
# Exit codes: 0- added; 1- exists; 2- something else;
|
|
|
|
#
|
|
|
|
# $FreeBSD$
|
|
|
|
#
|
|
|
|
|
|
|
|
# Input: $wol_l - line
|
|
|
|
# Output: $wol_w - word
|
|
|
|
word_on_line () {
|
|
|
|
wol_w=`grep -n . $i | grep "^${wol_l}:" | \
|
|
|
|
sed -E 's/^[[:digit:]]*:<\\!ENTITY man[.]([-[:alnum:].]*)[.][[:digit:]]* \".*$$/\1/'`;
|
|
|
|
}
|
|
|
|
|
2015-04-02 03:30:08 +02:00
|
|
|
if [ -z "$3" ]; then
|
2001-07-24 12:56:11 +02:00
|
|
|
echo "usage: $0 file name section";
|
|
|
|
exit 2;
|
|
|
|
fi
|
|
|
|
|
|
|
|
i=$1;
|
|
|
|
n=$2;
|
|
|
|
s=$3;
|
|
|
|
k=`echo $n | sed 's/_/./g'`;
|
|
|
|
|
|
|
|
firstline=`grep -n "^<\\!ENTITY man[.][-[:alnum:].]*[.]$s \"" $i | \
|
|
|
|
head -1 | cut -d: -f1`;
|
2015-04-02 03:30:08 +02:00
|
|
|
if [ -z "$firstline" ]; then
|
2001-07-24 12:56:11 +02:00
|
|
|
echo "Can't find first line of section $s.";
|
|
|
|
exit 2;
|
|
|
|
fi
|
|
|
|
echo "First line of section $s is $firstline.";
|
|
|
|
lastline=`grep -n "^<\\!ENTITY man[.][-[:alnum:].]*[.]$s \"" $i | \
|
|
|
|
tail -1 | cut -d: -f1`;
|
2015-04-02 03:30:08 +02:00
|
|
|
if [ -z "$lastline" ]; then
|
2001-07-24 12:56:11 +02:00
|
|
|
echo "Can't find last line of section $s.";
|
|
|
|
exit 2;
|
|
|
|
fi
|
|
|
|
echo "Last line of section $s is $lastline.";
|
|
|
|
|
|
|
|
l=$firstline;
|
|
|
|
u=$lastline;
|
|
|
|
while [ $u -ge $l ]; do
|
|
|
|
r=`expr $l + $u`;
|
|
|
|
m=`expr $r / 2`;
|
|
|
|
wol_l=$m;
|
|
|
|
word_on_line;
|
|
|
|
km=$wol_w;
|
|
|
|
if [ "$k" = "$km" ]; then
|
|
|
|
echo "$n($s) already exists; line $m";
|
|
|
|
exit 1;
|
|
|
|
elif [ "$k" '<' "$km" ]; then
|
|
|
|
u=`expr $m - 1`;
|
|
|
|
elif [ "$k" '>' "$km" ]; then
|
|
|
|
l=`expr $m + 1`;
|
|
|
|
else
|
|
|
|
echo "Thou shalt not defy the laws of mathematics!";
|
|
|
|
echo "Thou shalt not make silly bugs in thy shell scripts!";
|
|
|
|
exit 2;
|
|
|
|
fi
|
|
|
|
done;
|
|
|
|
|
2014-01-21 01:45:03 +01:00
|
|
|
t="<!ENTITY man.$k.$s \"<citerefentry xmlns='http://docbook.org/ns/docbook'><refentrytitle>$n</refentrytitle><manvolnum>$s</manvolnum></citerefentry>\">";
|
2001-07-24 12:56:11 +02:00
|
|
|
echo "Inserting line $l:";
|
|
|
|
echo $t;
|
|
|
|
echo -n "Last chance to interrupt (or press enter to continue)> ";
|
|
|
|
read okay;
|
|
|
|
ed -s $i <<EOF
|
|
|
|
${l}i
|
|
|
|
$t
|
|
|
|
.
|
|
|
|
w
|
|
|
|
q
|
|
|
|
EOF
|
|
|
|
|
|
|
|
echo "All done!";
|
|
|
|
exit 0;
|