blob: 28a4b31589d1cf61bfab69224b28601b8af21814 [file] [log] [blame]
Fred Drake692565c2000-10-19 05:54:51 +00001#! /bin/sh
2
3# Script to push docs from my development area to SourceForge, where the
4# update-docs.sh script unpacks them into their final destination.
5
Fred Drakef54519d2002-04-01 20:15:05 +00006TARGETHOST=www.python.org
7TARGETDIR=/usr/home/fdrake/tmp
8
Fred Drake9e1ac242004-06-17 18:36:54 +00009PKGTYPE="bzip" # must be one of: bzip, tar, zip ("tar" implies gzip)
10
Fred Drakef54519d2002-04-01 20:15:05 +000011TARGET="$TARGETHOST:$TARGETDIR"
Fred Drake827bb9f2000-11-30 07:38:59 +000012
Fred Drake3f4e7172001-03-02 21:05:58 +000013ADDRESSES='python-dev@python.org doc-sig@python.org python-list@python.org'
14
Fred Drake69db2b92003-09-28 22:14:29 +000015TOOLDIR="`dirname $0`"
16VERSION=`$TOOLDIR/getversioninfo`
17
18# Set $EXTRA to something non-empty if this is a non-trunk version:
Fred Drake34b48e82001-04-22 06:20:31 +000019EXTRA=`echo "$VERSION" | sed 's/^[0-9][0-9]*\.[0-9][0-9]*//'`
Fred Drake69db2b92003-09-28 22:14:29 +000020
21if echo "$EXTRA" | grep -q '[.]' ; then
Fred Drake34b48e82001-04-22 06:20:31 +000022 DOCLABEL="maintenance"
23 DOCTYPE="maint"
24else
25 DOCLABEL="development"
26 DOCTYPE="devel"
27fi
28
Fred Drake1681b622004-11-13 17:45:39 +000029DOCTYPE_SPECIFIED=false
Fred Drake3f4e7172001-03-02 21:05:58 +000030EXPLANATION=''
Fred Drakee54acfd2001-08-08 05:41:01 +000031ANNOUNCE=true
Fred Drake3f4e7172001-03-02 21:05:58 +000032
Fred Drake964c7982004-06-17 22:04:17 +000033getopt -T >/dev/null
34if [ $? -eq 4 ] ; then
35 # We have a sufficiently useful getopt(1) implementation.
Fred Drake303e30e2004-11-02 19:18:20 +000036 eval "set -- `getopt -ssh m:p:qt:F: \"$@\"`"
Fred Drake964c7982004-06-17 22:04:17 +000037else
38 # This version of getopt doesn't support quoting of long options
39 # with spaces, so let's not rely on it at all.
40 :
41fi
42
Fred Drake66a0a0a2001-06-12 13:31:37 +000043while [ "$#" -gt 0 ] ; do
44 case "$1" in
45 -m)
46 EXPLANATION="$2"
47 shift 2
48 ;;
Fred Drake9e1ac242004-06-17 18:36:54 +000049 -p)
50 PKGTYPE="$2"
51 shift 1
52 ;;
Fred Drakee54acfd2001-08-08 05:41:01 +000053 -q)
54 ANNOUNCE=false
55 shift 1
56 ;;
Fred Drake66a0a0a2001-06-12 13:31:37 +000057 -t)
58 DOCTYPE="$2"
Fred Drake1681b622004-11-13 17:45:39 +000059 DOCTYPE_SPECIFIED=true
Fred Drake66a0a0a2001-06-12 13:31:37 +000060 shift 2
61 ;;
62 -F)
63 EXPLANATION="`cat $2`"
64 shift 2
65 ;;
Fred Drake96b935e2004-06-29 14:39:06 +000066 --)
67 shift 1
68 break
69 ;;
Fred Drake66a0a0a2001-06-12 13:31:37 +000070 -*)
71 echo "Unknown option: $1" >&2
72 exit 2
73 ;;
74 *)
75 break
76 ;;
77 esac
78done
79if [ "$1" ] ; then
80 if [ "$EXPLANATION" ] ; then
81 echo "Explanation may only be given once!" >&2
82 exit 2
83 fi
84 EXPLANATION="$1"
85 shift
Fred Drake827bb9f2000-11-30 07:38:59 +000086fi
87
Fred Drake692565c2000-10-19 05:54:51 +000088START="`pwd`"
89MYDIR="`dirname $0`"
90cd "$MYDIR"
91MYDIR="`pwd`"
Fred Drake692565c2000-10-19 05:54:51 +000092
Fred Drake9e1ac242004-06-17 18:36:54 +000093if [ "$PKGTYPE" = bzip ] ; then
94 PKGEXT=tar.bz2
95elif [ "$PKGTYPE" = tar ] ; then
96 PKGEXT=tgz
97elif [ "$PKGTYPE" = zip ] ; then
98 PKGEXT=zip
99else
100 echo 1>&2 "unsupported package type: $PKGTYPE"
101 exit 2
102fi
103
Fred Drake1681b622004-11-13 17:45:39 +0000104# switch to .../Doc/
Fred Drake7ceab732000-10-24 19:59:55 +0000105cd ..
Fred Drake3f4e7172001-03-02 21:05:58 +0000106
Fred Drake1681b622004-11-13 17:45:39 +0000107# If $DOCTYPE was not specified explicitly, look for .doctype in
108# .../Doc/ and use the content of that file if present.
109if $DOCTYPE_SPECIFIED ; then
110 :
111elif [ -f .doctype ] ; then
112 DOCTYPE="`cat .doctype`"
113fi
114
Fred Drake9e1ac242004-06-17 18:36:54 +0000115make --no-print-directory ${PKGTYPE}html || exit $?
116PACKAGE="html-$VERSION.$PKGEXT"
Fred Drakee1f3ed62001-04-13 05:13:55 +0000117scp "$PACKAGE" tools/update-docs.sh $TARGET/ || exit $?
Fred Drakef54519d2002-04-01 20:15:05 +0000118ssh "$TARGETHOST" tmp/update-docs.sh $DOCTYPE $PACKAGE '&&' rm tmp/update-docs.sh || exit $?
Fred Drake3f4e7172001-03-02 21:05:58 +0000119
Fred Drakee54acfd2001-08-08 05:41:01 +0000120if $ANNOUNCE ; then
121 sendmail $ADDRESSES <<EOF
Fred Drakede6dc1e2001-07-06 23:45:16 +0000122To: $ADDRESSES
123From: "Fred L. Drake" <fdrake@acm.org>
124Subject: [$DOCLABEL doc updates]
Fred Drakee13602e2002-04-04 18:06:06 +0000125X-No-Archive: yes
Fred Drakede6dc1e2001-07-06 23:45:16 +0000126
Fred Drake602cf582001-07-12 21:50:10 +0000127The $DOCLABEL version of the documentation has been updated:
Fred Drake3f4e7172001-03-02 21:05:58 +0000128
Fred Drakef54519d2002-04-01 20:15:05 +0000129 http://$TARGETHOST/dev/doc/$DOCTYPE/
Fred Drake3f4e7172001-03-02 21:05:58 +0000130
131$EXPLANATION
Fred Drake9e1ac242004-06-17 18:36:54 +0000132
133A downloadable package containing the HTML is also available:
134
135 http://$TARGETHOST/dev/doc/python-docs-$DOCTYPE.$PKGEXT
Fred Drake3f4e7172001-03-02 21:05:58 +0000136EOF
Fred Drakee54acfd2001-08-08 05:41:01 +0000137 exit $?
138fi