86 lines
2.5 KiB
Python
86 lines
2.5 KiB
Python
"""
|
|
pygments.lexers.scdoc
|
|
~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Lexer for scdoc, a simple man page generator.
|
|
|
|
:copyright: Copyright 2006-2024 by the Pygments team, see AUTHORS.
|
|
:license: BSD, see LICENSE for details.
|
|
"""
|
|
|
|
import re
|
|
|
|
from pygments.lexer import RegexLexer, include, bygroups, using, this
|
|
from pygments.token import Text, Comment, Keyword, String, Generic
|
|
|
|
__all__ = ['ScdocLexer']
|
|
|
|
|
|
class ScdocLexer(RegexLexer):
|
|
"""
|
|
`scdoc` is a simple man page generator for POSIX systems written in C99.
|
|
"""
|
|
name = 'scdoc'
|
|
url = 'https://git.sr.ht/~sircmpwn/scdoc'
|
|
aliases = ['scdoc', 'scd']
|
|
filenames = ['*.scd', '*.scdoc']
|
|
version_added = '2.5'
|
|
flags = re.MULTILINE
|
|
|
|
tokens = {
|
|
'root': [
|
|
# comment
|
|
(r'^(;.+\n)', bygroups(Comment)),
|
|
|
|
# heading with pound prefix
|
|
(r'^(#)([^#].+\n)', bygroups(Generic.Heading, Text)),
|
|
(r'^(#{2})(.+\n)', bygroups(Generic.Subheading, Text)),
|
|
# bulleted lists
|
|
(r'^(\s*)([*-])(\s)(.+\n)',
|
|
bygroups(Text, Keyword, Text, using(this, state='inline'))),
|
|
# numbered lists
|
|
(r'^(\s*)(\.+\.)( .+\n)',
|
|
bygroups(Text, Keyword, using(this, state='inline'))),
|
|
# quote
|
|
(r'^(\s*>\s)(.+\n)', bygroups(Keyword, Generic.Emph)),
|
|
# text block
|
|
(r'^(```\n)([\w\W]*?)(^```$)', bygroups(String, Text, String)),
|
|
|
|
include('inline'),
|
|
],
|
|
'inline': [
|
|
# escape
|
|
(r'\\.', Text),
|
|
# underlines
|
|
(r'(\s)(_[^_]+_)(\W|\n)', bygroups(Text, Generic.Emph, Text)),
|
|
# bold
|
|
(r'(\s)(\*[^*]+\*)(\W|\n)', bygroups(Text, Generic.Strong, Text)),
|
|
# inline code
|
|
(r'`[^`]+`', String.Backtick),
|
|
|
|
# general text, must come last!
|
|
(r'[^\\\s]+', Text),
|
|
(r'.', Text),
|
|
],
|
|
}
|
|
|
|
def analyse_text(text):
|
|
"""We checks for bold and underline text with * and _. Also
|
|
every scdoc file must start with a strictly defined first line."""
|
|
result = 0
|
|
|
|
if '*' in text:
|
|
result += 0.01
|
|
|
|
if '_' in text:
|
|
result += 0.01
|
|
|
|
# name(section) ["left_footer" ["center_header"]]
|
|
first_line = text.partition('\n')[0]
|
|
scdoc_preamble_pattern = r'^.*\([1-7]\)( "[^"]+"){0,2}$'
|
|
|
|
if re.search(scdoc_preamble_pattern, first_line):
|
|
result += 0.5
|
|
|
|
return result
|