__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
"""
Meta Data Extension for Python-Markdown
=======================================
This extension adds Meta Data handling to markdown.
See <https://Python-Markdown.github.io/extensions/meta_data>
for documentation.
Original code Copyright 2007-2008 [Waylan Limberg](http://achinghead.com).
All changes Copyright 2008-2014 The Python Markdown Project
License: [BSD](https://opensource.org/licenses/bsd-license.php)
"""
from . import Extension
from ..preprocessors import Preprocessor
import re
import logging
log = logging.getLogger('MARKDOWN')
# Global Vars
META_RE = re.compile(r'^[ ]{0,3}(?P<key>[A-Za-z0-9_-]+):\s*(?P<value>.*)')
META_MORE_RE = re.compile(r'^[ ]{4,}(?P<value>.*)')
BEGIN_RE = re.compile(r'^-{3}(\s.*)?')
END_RE = re.compile(r'^(-{3}|\.{3})(\s.*)?')
class MetaExtension (Extension):
""" Meta-Data extension for Python-Markdown. """
def extendMarkdown(self, md):
""" Add MetaPreprocessor to Markdown instance. """
md.registerExtension(self)
self.md = md
md.preprocessors.register(MetaPreprocessor(md), 'meta', 27)
def reset(self):
self.md.Meta = {}
class MetaPreprocessor(Preprocessor):
""" Get Meta-Data. """
def run(self, lines):
""" Parse Meta-Data and store in Markdown.Meta. """
meta = {}
key = None
if lines and BEGIN_RE.match(lines[0]):
lines.pop(0)
while lines:
line = lines.pop(0)
m1 = META_RE.match(line)
if line.strip() == '' or END_RE.match(line):
break # blank line or end of YAML header - done
if m1:
key = m1.group('key').lower().strip()
value = m1.group('value').strip()
try:
meta[key].append(value)
except KeyError:
meta[key] = [value]
else:
m2 = META_MORE_RE.match(line)
if m2 and key:
# Add another line to existing key
meta[key].append(m2.group('value').strip())
else:
lines.insert(0, line)
break # no meta data - done
self.md.Meta = meta
return lines
def makeExtension(**kwargs): # pragma: no cover
return MetaExtension(**kwargs)
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __init__.py | File | 3.58 KB | 0644 |
|
| abbr.py | File | 3.11 KB | 0644 |
|
| admonition.py | File | 5.71 KB | 0644 |
|
| attr_list.py | File | 5.85 KB | 0644 |
|
| codehilite.py | File | 11.38 KB | 0644 |
|
| def_list.py | File | 3.55 KB | 0644 |
|
| extra.py | File | 1.79 KB | 0644 |
|
| fenced_code.py | File | 7.17 KB | 0644 |
|
| footnotes.py | File | 15.12 KB | 0644 |
|
| legacy_attrs.py | File | 2.49 KB | 0644 |
|
| legacy_em.py | File | 1.54 KB | 0644 |
|
| md_in_html.py | File | 15.46 KB | 0644 |
|
| meta.py | File | 2.28 KB | 0644 |
|
| nl2br.py | File | 783 B | 0644 |
|
| sane_lists.py | File | 1.47 KB | 0644 |
|
| smarty.py | File | 10 KB | 0644 |
|
| tables.py | File | 7.5 KB | 0644 |
|
| toc.py | File | 13.8 KB | 0644 |
|
| wikilinks.py | File | 2.75 KB | 0644 |
|