+ (ch.duration, label, ch.title, ch.url))
+
+ def dump(me, f):
+ if opts.list_name is not None: f.write("LIST %s\n" % opts.list_name)
+ if me.series_title is not None and \
+ me.nseries > 1 and not me.single_series_p:
+ raise ExpectedError("can't force series name for multi-series list")
+ series = set()
+ if me.single_series_p:
+ f.write("SERIES - %s\n" % quote(me.series_title))
+ for season in me.seasons:
+ for ep in season:
+ label = ep.label()
+ title = ep.season.series.full_title
+ if me.single_series_p:
+ stag = "-"
+ if title is not None: label = title + " " + label
+ else:
+ if title is None: title = me.series_title
+ stag = ep.season.series.name
+ if stag is None: stag = "-"
+ if stag not in series:
+ f.write("SERIES %s %s\n" % (stag, quote(title)))
+ series.add(stag)
+ f.write("ENTRY %s %s %s %d %d %d %g\n" %
+ (stag, quote(label), quote(ep.source.fn),
+ ep.tno, ep.start_chapter, ep.end_chapter, ep.duration))
+
+ def write_deps(me, f, out):
+ deps = set()
+ for season in me.seasons:
+ for ep in season: deps.add(ep.source.fn)
+ f.write("### -*-makefile-*-\n")
+ f.write("%s: $(call check-deps, %s," % (out, out))
+ for dep in sorted(deps):
+ f.write(" \\\n\t'%s'" %
+ OS.path.join(ROOT, dep)
+ .replace(",", "$(comma)")
+ .replace("'", "'\\''"))
+ f.write(")\n")
+
+DEFAULT_EXPVAR = 0.05
+R_DURMULT = RX.compile(r""" ^
+ (\d+ (?: \. \d+)?) x
+$ """, RX.X)
+R_DUR = RX.compile(r""" ^
+ (?: (?: (\d+) :)? (\d+) :)? (\d+)
+ (?: / (\d+ (?: \. \d+)?) \%)?
+$ """, RX.X)
+def parse_duration(s, base = None, basevar = DEFAULT_EXPVAR):
+ if base is not None:
+ m = R_DURMULT.match(s)
+ if m is not None: return base*float(m.group(1)), basevar
+ m = R_DUR.match(s)
+ if not m: raise ExpectedError("invalid duration spec `%s'" % s)
+ hr, min, sec = map(lambda g: filter(m.group(g), int, 0), [1, 2, 3])
+ var = filter(m.group(4), lambda x: float(x)/100.0)
+ if var is None: var = DEFAULT_EXPVAR
+ return 3600*hr + 60*min + sec, var
+def format_duration(d):
+ if d >= 3600: return "%d:%02d:%02d" % (d//3600, (d//60)%60, d%60)
+ elif d >= 60: return "%d:%02d" % (d//60, d%60)
+ else: return "%d s" % d