fnp
/
librarian.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Avoid hanging conjunction on covers.
[librarian.git]
/
src
/
librarian
/
document.py
diff --git
a/src/librarian/document.py
b/src/librarian/document.py
index
8876294
..
a3ee093
100644
(file)
--- a/
src/librarian/document.py
+++ b/
src/librarian/document.py
@@
-1,20
+1,26
@@
import gettext
import os
import re
import gettext
import os
import re
-from urllib.request import urlopen
from lxml import etree
from lxml import etree
+import six
from .parser import parser
from .parser import parser
-from . import dcparser
+from . import dcparser
, DCNS, DirDocProvider
from .functions import lang_code_3to2
class WLDocument:
from .functions import lang_code_3to2
class WLDocument:
- def __init__(self, filename=None, url=None):
- source = filename or urlopen(url)
+ def __init__(self, filename=None, url=None
, provider=None
):
+ source = filename or
six.moves.urllib.request.
urlopen(url)
tree = etree.parse(source, parser=parser)
self.tree = tree
tree.getroot().document = self
tree = etree.parse(source, parser=parser)
self.tree = tree
tree.getroot().document = self
- self.base_meta = dcparser.BookInfo({}, {}, validate_required=False)
+ self.base_meta = dcparser.BookInfo({}, {
+ DCNS('language'): ["pol"],
+ }, validate_required=False)
+
+ self.provider = provider if provider is not None else DirDocProvider('.')
+
+ self.tree.getroot().validate()
@property
def meta(self):
@property
def meta(self):
@@
-23,8
+29,17
@@
class WLDocument:
return self.tree.getroot().meta
return master.meta
return self.tree.getroot().meta
return master.meta
- def build(self, builder, **kwargs):
- return builder().build(self, **kwargs)
+ @property
+ def children(self):
+ for part_uri in self.meta.parts or []:
+ yield type(self)(
+ filename=self.provider.by_uri(part_uri),
+ provider=self.provider
+ )
+
+
+ def build(self, builder, base_url=None, **kwargs):
+ return builder(base_url=base_url).build(self, **kwargs)
def _compat_assign_ordered_ids(self):
"""
def _compat_assign_ordered_ids(self):
"""
@@
-64,3
+79,13
@@
class WLDocument:
_compat_assigns_section_ids_in_elem(child, idfier + '-')
_compat_assigns_section_ids_in_elem(self.tree.getroot().master)
_compat_assigns_section_ids_in_elem(child, idfier + '-')
_compat_assigns_section_ids_in_elem(self.tree.getroot().master)
+
+ def editors(self):
+ persons = set(self.meta.editors
+ + self.meta.technical_editors)
+ for child in self.children:
+ persons.update(child.editors())
+ if None in persons:
+ persons.remove(None)
+ return persons
+