Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 1 | #! /usr/local/python |
| 2 | |
| 3 | # Print some info about a CMIF movie file |
| 4 | |
| 5 | |
| 6 | # Usage: |
| 7 | # |
| 8 | # Vinfo [-d] [-q] [-s] [file] ... |
| 9 | |
| 10 | |
| 11 | # Options: |
| 12 | # |
| 13 | # -d : print deltas between frames instead of frame times |
| 14 | # -q : quick: don't read the frames |
| 15 | # -s : don't print times (but do count frames and print the total) |
| 16 | # file ... : file(s) to inspect; default film.video |
| 17 | |
| 18 | |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 19 | import sys |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 20 | sys.path.append('/ufs/guido/src/video') |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 21 | import VFile |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 22 | import getopt |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 23 | import string |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 24 | |
| 25 | |
| 26 | # Global options |
| 27 | |
| 28 | short = 0 |
| 29 | quick = 0 |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 30 | delta = 0 |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 31 | terse = 0 |
| 32 | maxwidth = 10 |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 33 | |
| 34 | |
| 35 | # Main program -- mostly command line parsing |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 36 | |
| 37 | def main(): |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 38 | global short, quick, delta, terse, maxwidth |
| 39 | try: |
| 40 | opts, args = getopt.getopt(sys.argv[1:], 'dqst') |
| 41 | except getopt.error, msg: |
| 42 | sys.stdout = sys.stderr |
| 43 | print msg |
| 44 | print 'usage: Vinfo [-d] [-q] [-s] [-t] [file] ...' |
| 45 | sys.exit(2) |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 46 | for opt, arg in opts: |
| 47 | if opt == '-q': |
| 48 | quick = 1 |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 49 | if opt == '-d': |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 50 | delta = 1 |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 51 | if opt == '-s': |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 52 | short = 1 |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 53 | if opt == '-t': |
| 54 | terse = short = 1 |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 55 | if not args: |
| 56 | args = ['film.video'] |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 57 | for filename in args: |
| 58 | maxwidth = max(maxwidth, len(filename)) |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 59 | sts = 0 |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 60 | for filename in args: |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 61 | if process(filename): |
| 62 | sts = 1 |
| 63 | sys.exit(sts) |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 64 | |
| 65 | |
| 66 | # Process one file |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 67 | |
| 68 | def process(filename): |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 69 | try: |
Guido van Rossum | 269b2a2 | 1992-09-08 15:04:01 +0000 | [diff] [blame] | 70 | vin = VFile.RandomVinFile().init(filename) |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 71 | except IOError, msg: |
| 72 | sys.stderr.write(filename + ': I/O error: ' + `msg` + '\n') |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 73 | return 1 |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 74 | except VFile.Error, msg: |
| 75 | sys.stderr.write(msg + '\n') |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 76 | return 1 |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 77 | except EOFError: |
| 78 | sys.stderr.write(filename + ': EOF in video file\n') |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 79 | return 1 |
| 80 | |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 81 | if terse: |
| 82 | print string.ljust(filename, maxwidth), |
| 83 | kbytes = (VFile.getfilesize(filename) + 1023) / 1024 |
| 84 | print string.rjust(`kbytes`, 5) + 'K', |
| 85 | print ' ', string.ljust(`vin.version`, 5), |
| 86 | print string.ljust(vin.format, 8), |
| 87 | print string.rjust(`vin.width`, 4), |
| 88 | print string.rjust(`vin.height`, 4), |
| 89 | sys.stdout.flush() |
| 90 | else: |
| 91 | vin.printinfo() |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 92 | |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 93 | if quick: |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 94 | if terse: |
| 95 | print |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 96 | vin.close() |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 97 | return 0 |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 98 | |
Guido van Rossum | 269b2a2 | 1992-09-08 15:04:01 +0000 | [diff] [blame] | 99 | try: |
| 100 | vin.readcache() |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 101 | if not terse: |
| 102 | print '[Using cached index]' |
Guido van Rossum | 269b2a2 | 1992-09-08 15:04:01 +0000 | [diff] [blame] | 103 | except VFile.Error: |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 104 | if not terse: |
| 105 | print '[Constructing index on the fly]' |
Guido van Rossum | 269b2a2 | 1992-09-08 15:04:01 +0000 | [diff] [blame] | 106 | |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 107 | if not short: |
Guido van Rossum | 7268c93 | 1992-08-18 21:11:18 +0000 | [diff] [blame] | 108 | if delta: |
| 109 | print 'Frame time deltas:', |
| 110 | else: |
| 111 | print 'Frame times:', |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 112 | |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 113 | n = 0 |
| 114 | t = 0 |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 115 | told = 0 |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 116 | datasize = 0 |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 117 | while 1: |
| 118 | try: |
Guido van Rossum | 269b2a2 | 1992-09-08 15:04:01 +0000 | [diff] [blame] | 119 | t, ds, cs = vin.getnextframeheader() |
| 120 | vin.skipnextframedata(ds, cs) |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 121 | except EOFError: |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 122 | break |
Guido van Rossum | 269b2a2 | 1992-09-08 15:04:01 +0000 | [diff] [blame] | 123 | datasize = datasize + ds |
| 124 | if cs: datasize = datasize + cs |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 125 | if not short: |
| 126 | if n%8 == 0: |
| 127 | sys.stdout.write('\n') |
| 128 | if delta: |
| 129 | sys.stdout.write('\t' + `t - told`) |
| 130 | told = t |
| 131 | else: |
| 132 | sys.stdout.write('\t' + `t`) |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 133 | n = n+1 |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 134 | |
| 135 | if not short: print |
| 136 | |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 137 | if terse: |
| 138 | print string.rjust(`n`, 6), |
| 139 | print string.rjust(`int(n*10000.0/t)*0.1`, 5) |
| 140 | else: |
| 141 | print 'Total', n, 'frames in', t*0.001, 'sec.', |
| 142 | if t: print '-- average', int(n*10000.0/t)*0.1, 'frames/sec', |
| 143 | print |
| 144 | print 'Total data', 0.1 * int(datasize / 102.4), 'Kbytes', |
| 145 | if t: |
| 146 | print '-- average', |
| 147 | print 0.1 * int(datasize / 0.1024 / t), 'Kbytes/sec', |
| 148 | print |
Guido van Rossum | dfb61fa | 1992-08-20 11:49:58 +0000 | [diff] [blame] | 149 | |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 150 | vin.close() |
Guido van Rossum | 9e3f335 | 1992-09-29 13:40:47 +0000 | [diff] [blame] | 151 | return 0 |
Guido van Rossum | 82534fd | 1992-08-18 17:01:02 +0000 | [diff] [blame] | 152 | |
| 153 | |
| 154 | # Don't forget to call the main program |
Guido van Rossum | 843d153 | 1992-08-18 14:16:12 +0000 | [diff] [blame] | 155 | |
Guido van Rossum | e0be2b3 | 1992-09-01 14:45:57 +0000 | [diff] [blame] | 156 | try: |
| 157 | main() |
| 158 | except KeyboardInterrupt: |
| 159 | print '[Interrupt]' |