def _wrap(*args, **kw):
value = f(*args, **kw)
- prefix = (u'<TeXML escape="%d">' % (really and 1 or 0))
+ prefix = (u'<TeXML escape="%d">' % (1 if really else 0))
postfix = u'</TeXML>'
if isinstance(value, list):
import pdb
def get_dc(self, element, dc_field, single=False):
values = map(lambda t: t.text, element.xpath("//dc:%s" % dc_field, namespaces={'dc': DCNS.uri}))
if single:
- return values[0]
+ return values[0] if len(values) else ''
return values
def handle_rdf__RDF(self, _):
@escape(True)
def get_rightsinfo(self, element):
rights_lic = self.get_dc(element, 'rights.license', True)
- return u'<cmd name="rightsinfostr">' + (rights_lic and u'<opt>%s</opt>' % rights_lic or '') + \
+ return u'<cmd name="rightsinfostr">' + (u'<opt>%s</opt>' % rights_lic if rights_lic else '') + \
u'<parm>%s</parm>' % self.get_dc(element, 'rights', True) + \
u'</cmd>'
authors = getattr(dc, "authors_%s" % which)
return u', '.join(author.readable() for author in authors if author)
- @escape(1)
+ @escape(True)
def get_title(self, element):
return self.get_dc(element, 'title', True)
+ @escape(True)
+ def get_description(self, element):
+ desc = self.get_dc(element, 'description', single=True)
+ if not desc:
+ print '!! no description'
+ return desc
+
+ @escape(True)
+ def get_curriculum(self, element):
+ identifiers = self.get_dc(element, 'subject.curriculum')
+ if not identifiers:
+ return ''
+ try:
+ from curriculum.templatetags.curriculum_tags import curriculum
+ curr_elements = curriculum(identifiers)
+ except ImportError:
+ curr_elements = {'identifiers': identifiers}
+ items = ['Podstawa programowa:']
+ newline = '<ctrl ch="\\"/>\n'
+ if 'currset' in curr_elements:
+ for (course, level), types in curr_elements['currset'].iteritems():
+ lines = [u'%s, %s poziom edukacyjny' % (course, level)]
+ for type, currs in types.iteritems():
+ lines.append(type)
+ lines += [curr.title for curr in currs]
+ items.append(newline.join(lines))
+ else:
+ items += identifiers
+ return '\n<cmd name="vspace"><parm>.6em</parm></cmd>\n'.join(
+ '<cmd name="akap"><parm>%s</parm></cmd>' % item for item in items)
+
def handle_utwor(self, element):
lines = [
u'''
u'''\\def\\authorsexpert{%s}''' % self.get_authors(element, 'expert'),
u'''\\def\\authorsscenario{%s}''' % self.get_authors(element, 'scenario'),
u'''\\def\\authorstextbook{%s}''' % self.get_authors(element, 'textbook'),
+ u'''\\def\\description{%s}''' % self.get_description(element),
u'''\\author{\\authors}''',
u'''\\title{%s}''' % self.get_title(element),
u'''\\def\\bookurl{%s}''' % self.options['wldoc'].book_info.url.canonical(),
u'''\\def\\rightsinfo{%s}''' % self.get_rightsinfo(element),
+ u'''\\def\\curriculum{%s}''' % self.get_curriculum(element),
u'</TeXML>'
]
return u"".join(filter(None, lines)), u'</TeXML>'
- @escape(1)
+ @escape(True)
def handle_powiesc(self, element):
return u"""
<env name="document">
<cmd name="maketitle"/>
""", """<cmd name="editorialsection" /></env>"""
- @escape(1)
+ @escape(True)
def handle_texcommand(self, element):
cmd = functions.texcommand(element.tag)
return u'<TeXML escape="1"><cmd name="%s"><parm>' % cmd, u'</parm></cmd></TeXML>'
<cmd name="begin"><parm>tabular</parm><parm>%s</parm></cmd>
''' % ('l' * max_col), u'''<cmd name="end"><parm>tabular</parm></cmd>'''
- @escape(1)
+ @escape(True)
def handle_wiersz(self, element):
return u"", u'<ctrl ch="\\"/>'
- @escape(1)
+ @escape(True)
def handle_kol(self, element):
if element.getnext() is not None:
return u"", u'<spec cat="align" />'