2018-01-02 18:57:04 +01:00
|
|
|
#!/usr/bin/env python3
|
2018-02-19 19:50:26 +01:00
|
|
|
#******************************************************************************
|
|
|
|
# Copyright (C) 2018 Thomas "Cakeisalie5" Touhey <thomas@touhey.fr>
|
|
|
|
# This file is part of the textoutpc project, which is MIT-licensed.
|
|
|
|
#******************************************************************************
|
2018-01-02 18:57:04 +01:00
|
|
|
|
2018-07-28 19:49:29 +02:00
|
|
|
from .. import InlineTag as _InlineTag
|
2018-01-02 18:57:04 +01:00
|
|
|
import re as _re
|
|
|
|
|
2018-07-28 19:49:29 +02:00
|
|
|
__all__ = ["LabelTag", "TargetTag"]
|
2018-01-02 18:57:04 +01:00
|
|
|
|
2018-01-16 13:34:11 +01:00
|
|
|
_labelexpr = _re.compile('^[a-z0-9-]{1,16}$', _re.I)
|
2018-01-02 18:57:04 +01:00
|
|
|
|
2018-08-25 17:38:24 +02:00
|
|
|
|
2018-07-28 19:49:29 +02:00
|
|
|
class LabelTag(_InlineTag):
|
2018-01-02 18:57:04 +01:00
|
|
|
""" The label tag, defines an anchor at a point of the post.
|
|
|
|
Example uses:
|
2018-08-25 17:38:24 +02:00
|
|
|
|
2018-01-16 13:34:11 +01:00
|
|
|
[label=installation]Installation de tel logiciel... (no ending req.)
|
2018-01-02 18:57:04 +01:00
|
|
|
[label=compilation][/label] Compilation de tel logiciel...
|
|
|
|
"""
|
|
|
|
|
2018-01-05 22:13:30 +01:00
|
|
|
aliases = ('[label]',)
|
|
|
|
|
2018-01-16 13:34:11 +01:00
|
|
|
def prepare(self, name, value):
|
|
|
|
if not _labelexpr.match(value):
|
2018-01-02 18:57:04 +01:00
|
|
|
raise Exception
|
2018-01-21 22:08:23 +01:00
|
|
|
self._label = value
|
2018-01-02 18:57:04 +01:00
|
|
|
|
|
|
|
def begin_html(self):
|
2018-01-21 22:08:23 +01:00
|
|
|
#name = 'label-{}'.format(self._label)
|
2018-01-16 13:34:11 +01:00
|
|
|
#if _v42compat:
|
2018-01-21 22:08:23 +01:00
|
|
|
# name += ' ' + self._label
|
2018-02-11 20:49:33 +01:00
|
|
|
name = self.tweak("label_prefix", "") + self._label
|
2018-01-02 18:57:04 +01:00
|
|
|
return '<a name="{}"></a>'.format(name)
|
|
|
|
|
2018-08-25 17:38:24 +02:00
|
|
|
|
2018-07-28 19:49:29 +02:00
|
|
|
class TargetTag(_InlineTag):
|
2018-01-02 18:57:04 +01:00
|
|
|
""" The goto tag, links to an anchor defined in the post.
|
|
|
|
Example uses:
|
2018-08-25 17:38:24 +02:00
|
|
|
|
2018-01-02 18:57:04 +01:00
|
|
|
[target=installation]Check out the installation manual[/target]!
|
|
|
|
"""
|
|
|
|
|
2018-01-05 22:13:30 +01:00
|
|
|
aliases = ('[target]',)
|
|
|
|
|
2018-01-16 13:34:11 +01:00
|
|
|
def prepare(self, name, value):
|
|
|
|
if not _labelexpr.match(value):
|
2018-01-02 18:57:04 +01:00
|
|
|
raise Exception
|
2018-01-21 22:08:23 +01:00
|
|
|
self._label = value
|
2018-01-02 18:57:04 +01:00
|
|
|
|
|
|
|
def begin_html(self):
|
2018-01-24 12:33:33 +01:00
|
|
|
#name = 'label-' + self._label
|
2018-02-11 20:49:33 +01:00
|
|
|
name = self.tweak("label_prefix", "") + self._label
|
2018-01-02 18:57:04 +01:00
|
|
|
return '<a href="#{}">'.format(name)
|
|
|
|
|
|
|
|
def end_html(self):
|
2018-01-05 22:13:30 +01:00
|
|
|
return '</a>'
|
2018-01-02 18:57:04 +01:00
|
|
|
|
|
|
|
# End of file.
|