X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/a4a0d6ab3c0a97fbb7ffeae0454e448c92cb67ce..a36b71e91ec260eae71f133f450fe4de80974461:/librarian/pypdf.py?ds=inline
diff --git a/librarian/pypdf.py b/librarian/pypdf.py
index d89d4af..9034753 100644
--- a/librarian/pypdf.py
+++ b/librarian/pypdf.py
@@ -66,9 +66,10 @@ def mark_alien_characters(text):
class EduModule(Xmill):
- def __init__(self, options=None):
- super(EduModule, self).__init__(options)
+ def __init__(self, options=None, state=None):
+ super(EduModule, self).__init__(options, state)
self.activity_counter = 0
+ self.activity_last = None
self.exercise_counter = 0
def swap_endlines(txt):
@@ -173,10 +174,6 @@ class EduModule(Xmill):
handle_naglowek_czesc = \
handle_naglowek_listy = \
handle_naglowek_osoba = \
- handle_naglowek_podrozdzial = \
- handle_naglowek_podrozdzial = \
- handle_naglowek_rozdzial = \
- handle_naglowek_rozdzial = \
handle_naglowek_scena = \
handle_nazwa_utworu = \
handle_nota = \
@@ -197,6 +194,20 @@ class EduModule(Xmill):
handle_dywiz = \
handle_texcommand
+ def handle_naglowek_rozdzial(self, element):
+ if not self.options['teacher']:
+ if element.text.startswith((u'Wiedza', u'Zadania', u'SÅowniczek')):
+ self.state['mute'] = False
+ else:
+ self.state['mute'] = True
+ return None
+ return self.handle_texcommand(element)
+ handle_naglowek_rozdzial.unmuter = True
+
+ def handle_naglowek_podrozdzial(self, element):
+ self.activity_counter = 0
+ return self.handle_texcommand(element)
+
def handle_uwaga(self, _e):
return None
def handle_extra(self, _e):
@@ -218,9 +229,12 @@ class EduModule(Xmill):
'activity_counter': self.activity_counter,
'sub_gen': True,
}
- submill = EduModule(self.options)
+ submill = EduModule(self.options, self.state)
- opis = submill.generate(element.xpath('opis')[0])
+ if element.xpath('opis'):
+ opis = submill.generate(element.xpath('opis')[0])
+ else:
+ opis = ''
n = element.xpath('wskazowki')
if n: wskazowki = submill.generate(n[0])
@@ -237,9 +251,16 @@ class EduModule(Xmill):
counter = self.activity_counter
+ if element.getnext().tag == 'aktywnosc' or self.activity_last.getnext() == element:
+ counter_tex = """%(counter)d.""" % locals()
+ else:
+ counter_tex = ''
+
+ self.activity_last = element
+
return u"""
-%(counter)d.
+%(counter_tex)s
%(czas)s
%(forma)s
@@ -308,7 +329,7 @@ class EduModule(Xmill):
if not typ in exercise_handlers:
return '(no handler)'
self.options = {'exercise_counter': self.exercise_counter}
- handler = exercise_handlers[typ](self.options)
+ handler = exercise_handlers[typ](self.options, self.state)
return handler.generate(element)
# XXX this is copied from pyhtml.py, except for return and
@@ -325,7 +346,7 @@ class EduModule(Xmill):
if defloc:
definiens = defloc[0].getnext()
if definiens.tag == 'definiens':
- subgen = EduModule(self.options)
+ subgen = EduModule(self.options, self.state)
definiens_s = subgen.generate(definiens)
return u'', u": " + definiens_s
@@ -375,7 +396,7 @@ class EduModule(Xmill):
def handle_obraz(self, element):
frmt = self.options['format']
- name = element.attrib['nazwa'].strip()
+ name = element.attrib.get('nazwa', '').strip()
image = frmt.get_image(name.strip())
img_path = "obraz/%s" % name.replace("_", "")
frmt.attachments[img_path] = image
@@ -469,13 +490,13 @@ class Wybor(Exercise):
if not pytania:
pytania = [element]
for p in pytania:
- solutions = re.split(r"[, ]+", p.attrib['rozw'])
+ solutions = re.split(r"[, ]+", p.attrib.get('rozw', ''))
if len(solutions) != 1:
is_single_choice = False
break
choices = p.xpath(".//*[@nazwa]")
uniq = set()
- for n in choices: uniq.add(n.attrib['nazwa'])
+ for n in choices: uniq.add(n.attrib.get('nazwa', ''))
if len(choices) != len(uniq):
is_single_choice = False
break
@@ -552,7 +573,7 @@ class Zastap(Luki):
return question.xpath(".//zastap")
def solution(self, piece):
- return piece.attrib['rozw']
+ return piece.attrib.get('rozw', '')
def list_header(self):
return u"Elementy do wstawienia"