C-6: ConnectorRuntime enforces capability_mask per operation.
READ-only ACs cannot invoke MUTATE operations (wipe, lock, retire).
C-7: AC validated against database (exists, active, not expired)
before connector invocation.
C-9: Delegated AC capability bounded by delegator's capability.
C-10: Command counter uses atomic SQL increment with limit check.
M-23: expire_stale() uses same atomic SQL pattern.
H-1: Sensitive credential fields hidden from repr/logs via repr=False.
H-2: Stub backend requires ALLOW_STUB_CREDENTIALS=true to activate.
H-3: Kerberos backend raises CredentialResolutionError instead of
returning stub ticket.
H-4: Chronicle INTENT emitted before execution, RESULT after.
H-5: device_id validated as UUID before Graph API URL interpolation.
H-8: ConnectorRuntime enforces governance for all connector invocations.
Signed-off-by: Tyler King <tking@guildhouse.dev>
85 lines
2.5 KiB
Python
85 lines
2.5 KiB
Python
"""
|
|
pygments.lexers.scdoc
|
|
~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Lexer for scdoc, a simple man page generator.
|
|
|
|
:copyright: Copyright 2006-present 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
|