Left: | ||
Right: |
OLD | NEW |
---|---|
1 # coding: utf-8 | 1 # coding: utf-8 |
2 | 2 |
3 # This file is part of the Adblock Plus web scripts, | 3 # This file is part of the Adblock Plus web scripts, |
4 # Copyright (C) 2006-2015 Eyeo GmbH | 4 # Copyright (C) 2006-2015 Eyeo GmbH |
5 # | 5 # |
6 # Adblock Plus is free software: you can redistribute it and/or modify | 6 # Adblock Plus is free software: you can redistribute it and/or modify |
7 # it under the terms of the GNU General Public License version 3 as | 7 # it under the terms of the GNU General Public License version 3 as |
8 # published by the Free Software Foundation. | 8 # published by the Free Software Foundation. |
9 # | 9 # |
10 # Adblock Plus is distributed in the hope that it will be useful, | 10 # Adblock Plus is distributed in the hope that it will be useful, |
(...skipping 274 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
285 Converter.__init__(self, *args, **kwargs) | 285 Converter.__init__(self, *args, **kwargs) |
286 | 286 |
287 filters = { | 287 filters = { |
288 "translate": self.translate, | 288 "translate": self.translate, |
289 "linkify": self.linkify, | 289 "linkify": self.linkify, |
290 "toclist": self.toclist, | 290 "toclist": self.toclist, |
291 } | 291 } |
292 | 292 |
293 globals = { | 293 globals = { |
294 "get_string": self.get_string, | 294 "get_string": self.get_string, |
295 "get_page_content": self.get_page_content, | |
295 } | 296 } |
296 | 297 |
297 for dirname, dictionary in [("filters", filters), ("globals", globals)]: | 298 for dirname, dictionary in [("filters", filters), ("globals", globals)]: |
298 for filename in self._params["source"].list_files(dirname): | 299 for filename in self._params["source"].list_files(dirname): |
299 root, ext = os.path.splitext(filename) | 300 root, ext = os.path.splitext(filename) |
300 if ext.lower() != ".py": | 301 if ext.lower() != ".py": |
301 continue | 302 continue |
302 | 303 |
303 path = "%s/%s" % (dirname, filename) | 304 path = "%s/%s" % (dirname, filename) |
304 code = self._params["source"].read_file(path) | 305 code = self._params["source"].read_file(path) |
(...skipping 30 matching lines...) Expand all Loading... | |
335 # Note: We currently ignore the comment, it is only relevant when | 336 # Note: We currently ignore the comment, it is only relevant when |
336 # generating the master translation. | 337 # generating the master translation. |
337 localedata = self._params["localedata"] | 338 localedata = self._params["localedata"] |
338 return jinja2.Markup(self.localize_string(name, default, localedata, html_es capes)) | 339 return jinja2.Markup(self.localize_string(name, default, localedata, html_es capes)) |
339 | 340 |
340 def get_string(self, name, page): | 341 def get_string(self, name, page): |
341 localedata = self._params["source"].read_locale(self._params["locale"], page ) | 342 localedata = self._params["source"].read_locale(self._params["locale"], page ) |
342 default = localedata[name] | 343 default = localedata[name] |
343 return jinja2.Markup(self.localize_string(name, default, localedata, html_es capes)) | 344 return jinja2.Markup(self.localize_string(name, default, localedata, html_es capes)) |
344 | 345 |
346 def get_page_content(self, page, locale=None): | |
347 from utils import get_page_params | |
kzar
2015/04/05 12:10:12
(I import this here as we have a circular dependen
Sebastian Noack
2015/04/05 12:50:17
This is usually an indicator, that something is wr
kzar
2015/04/05 13:25:08
I thought about that, and maybe I'm wrong, but I t
Sebastian Noack
2015/04/05 13:30:33
Cyclic dependencies aren't great. However, the log
| |
348 | |
349 page, format = page.rsplit(".") | |
Sebastian Noack
2015/04/05 12:50:17
I suppose you forgot the second argument to .rspli
kzar
2015/04/05 13:25:08
Done.
| |
350 params = get_page_params(self._params["source"], locale, page, format) | |
kzar
2015/04/05 12:10:12
(I'm unsure if I should pass self._params["site_ur
Sebastian Noack
2015/04/05 12:50:17
Shouldn't you fallback to self._params["locale"] i
kzar
2015/04/05 13:25:08
Done.
| |
351 return params["head"], params["body"] | |
Sebastian Noack
2015/04/05 12:50:17
I would rather return a dict here, to make the cal
kzar
2015/04/05 13:25:08
Done.
| |
352 | |
345 def linkify(self, page, locale=None, **attrs): | 353 def linkify(self, page, locale=None, **attrs): |
346 if locale is None: | 354 if locale is None: |
347 locale = self._params["locale"] | 355 locale = self._params["locale"] |
348 | 356 |
349 locale, url = self._params["source"].resolve_link(page, locale) | 357 locale, url = self._params["source"].resolve_link(page, locale) |
350 return jinja2.Markup('<a%s>' % ''.join( | 358 return jinja2.Markup('<a%s>' % ''.join( |
351 ' %s="%s"' % (name, jinja2.escape(value)) for name, value in [ | 359 ' %s="%s"' % (name, jinja2.escape(value)) for name, value in [ |
352 ('href', url), | 360 ('href', url), |
353 ('hreflang', locale) | 361 ('hreflang', locale) |
354 ] + attrs.items() | 362 ] + attrs.items() |
(...skipping 16 matching lines...) Expand all Loading... | |
371 stack.pop() | 379 stack.pop() |
372 stack[-1]["subitems"].append(item) | 380 stack[-1]["subitems"].append(item) |
373 stack.append(item) | 381 stack.append(item) |
374 return structured | 382 return structured |
375 | 383 |
376 converters = { | 384 converters = { |
377 "html": RawConverter, | 385 "html": RawConverter, |
378 "md": MarkdownConverter, | 386 "md": MarkdownConverter, |
379 "tmpl": TemplateConverter, | 387 "tmpl": TemplateConverter, |
380 } | 388 } |
OLD | NEW |