mirror of https://github.com/tLDP/python-tldp
124 lines
3.6 KiB
Python
124 lines
3.6 KiB
Python
#! /usr/bin/python
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
|
|
import os
|
|
import errno
|
|
import shutil
|
|
|
|
import collections
|
|
from .utils import logger, logdir, statfiles
|
|
|
|
|
|
class OutputNamingConvention(object):
|
|
|
|
expected = ['name_txt', 'name_pdf', 'name_htmls', 'name_html',
|
|
'name_index']
|
|
|
|
def __init__(self, dirname, stem):
|
|
self.dirname = dirname
|
|
self.stem = stem
|
|
|
|
@property
|
|
def name_txt(self):
|
|
return os.path.join(self.dirname, self.stem + '.txt')
|
|
|
|
@property
|
|
def name_pdf(self):
|
|
return os.path.join(self.dirname, self.stem + '.pdf')
|
|
|
|
@property
|
|
def name_html(self):
|
|
return os.path.join(self.dirname, self.stem + '.html')
|
|
|
|
@property
|
|
def name_htmls(self):
|
|
return os.path.join(self.dirname, self.stem + '-single.html')
|
|
|
|
@property
|
|
def name_epub(self):
|
|
return os.path.join(self.dirname, self.stem + '.epub')
|
|
|
|
@property
|
|
def name_index(self):
|
|
return os.path.join(self.dirname, 'index.html')
|
|
|
|
|
|
class OutputDirectory(OutputNamingConvention):
|
|
|
|
def __repr__(self):
|
|
return '<%s:%s>' % (self.__class__.__name__, self.dirname)
|
|
|
|
def __init__(self, dirname):
|
|
self.dirname = os.path.abspath(dirname)
|
|
self.stem = os.path.basename(self.dirname)
|
|
parent = os.path.dirname(self.dirname)
|
|
if not os.path.isdir(parent):
|
|
logger.critical("Missing output tree %s.", parent)
|
|
raise IOError(errno.ENOENT, os.strerror(errno.ENOENT), parent)
|
|
self.statinfo = statfiles(self.dirname, relative=self.dirname)
|
|
self.status = 'output'
|
|
self.logdir = os.path.join(self.dirname, logdir)
|
|
super(OutputDirectory, self).__init__(self.dirname, self.stem)
|
|
|
|
def clean(self):
|
|
logger.info("%s cleaning dir %s.", self.stem, self.dirname)
|
|
if os.path.isdir(self.dirname):
|
|
shutil.rmtree(self.dirname)
|
|
|
|
def prebuild_hook(self):
|
|
self.clean()
|
|
for d in (self.dirname, self.logdir):
|
|
if not os.path.isdir(d):
|
|
logger.info("%s creating dir %s.", self.stem, d)
|
|
os.mkdir(d)
|
|
self.copy_ancillaries(self.dirname)
|
|
|
|
def build_failure_hook(self):
|
|
logger.critical("%s FAILURE, see logs in %s", self.stem, self.logdir)
|
|
|
|
def build_success_hook(self):
|
|
logger.info("%s SUCCESS!", self.stem)
|
|
logger.debug("%s removing logs %s)", self.stem, self.logdir)
|
|
if os.path.isdir(self.logdir):
|
|
shutil.rmtree(logdir)
|
|
|
|
|
|
class OutputCollection(collections.MutableMapping):
|
|
|
|
def __repr__(self):
|
|
return '<%s:(%s docs)>' % (self.__class__.__name__, len(self))
|
|
|
|
def __init__(self, dirname=None):
|
|
if dirname is None:
|
|
return
|
|
elif not os.path.isdir(dirname):
|
|
logger.critical("Directory %s must already exist.", dirname)
|
|
raise IOError(errno.ENOENT, os.strerror(errno.ENOENT), dirname)
|
|
for fname in os.listdir(dirname):
|
|
name = os.path.join(dirname, fname)
|
|
if not os.path.isdir(name):
|
|
logger.info("Skipping non-directory %s (in %s)", name, dirname)
|
|
continue
|
|
o = OutputDirectory(name)
|
|
assert o.stem not in self
|
|
self[o.stem] = o
|
|
|
|
def __delitem__(self, key):
|
|
del self.__dict__[key]
|
|
|
|
def __getitem__(self, key):
|
|
return self.__dict__[key]
|
|
|
|
def __setitem__(self, key, value):
|
|
self.__dict__[key] = value
|
|
|
|
def __iter__(self):
|
|
return iter(self.__dict__)
|
|
|
|
def __len__(self):
|
|
return len(self.__dict__)
|
|
|
|
#
|
|
# -- end of file
|