diff options
author | Georg Brandl <georg@python.org> | 2009-10-11 12:04:10 (GMT) |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2009-10-11 12:04:10 (GMT) |
commit | 41706b3293e59ae35dffe8955674d112ed709a93 (patch) | |
tree | cf7d0b319a5b967aa27e87e9d384c7dd99772748 /Demo/scripts/script.py | |
parent | b243ed2663f5e636859b0d94424e7c6d535f9aba (diff) | |
download | cpython-41706b3293e59ae35dffe8955674d112ed709a93.zip cpython-41706b3293e59ae35dffe8955674d112ed709a93.tar.gz cpython-41706b3293e59ae35dffe8955674d112ed709a93.tar.bz2 |
Merged revisions 75350 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r75350 | georg.brandl | 2009-10-11 14:00:18 +0200 (So, 11 Okt 2009) | 1 line
Use getopt in script.py demo.
........
Diffstat (limited to 'Demo/scripts/script.py')
-rwxr-xr-x | Demo/scripts/script.py | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/Demo/scripts/script.py b/Demo/scripts/script.py index 174c13e..b490b17 100755 --- a/Demo/scripts/script.py +++ b/Demo/scripts/script.py @@ -1,4 +1,5 @@ #! /usr/bin/env python + # script.py -- Make typescript of terminal session. # Usage: # -a Append to typescript. @@ -6,28 +7,36 @@ # Author: Steen Lumholt. -import os, time, sys +import os, time, sys, getopt import pty def read(fd): data = os.read(fd, 1024) - file.write(data) + script.write(data) return data shell = 'sh' filename = 'typescript' -mode = 'w' +mode = 'wb' if 'SHELL' in os.environ: shell = os.environ['SHELL'] -if '-a' in sys.argv: - mode = 'a' -if '-p' in sys.argv: - shell = 'python' -file = open(filename, mode) +try: + opts, args = getopt.getopt(sys.argv[1:], 'ap') +except getopt.error as msg: + print('%s: %s' % (sys.argv[0], msg)) + sys.exit(2) + +for o, a in opts: + if o == '-a': + mode = 'ab' + elif o == '-p': + shell = 'python' + +script = open(filename, mode) sys.stdout.write('Script started, file is %s\n' % filename) -file.write('Script started on %s\n' % time.ctime(time.time())) +script.write(('Script started on %s\n' % time.ctime(time.time())).encode()) pty.spawn(shell, read) -file.write('Script done on %s\n' % time.ctime(time.time())) +script.write(('Script done on %s\n' % time.ctime(time.time())).encode()) sys.stdout.write('Script done, file is %s\n' % filename) |