# Process html tags from ..common.html_re import HTML_TAG_RE from .state_inline import StateInline def isLetter(ch: int): lc = ch | 0x20 # to lower case # /* a */ and /* z */ return (lc >= 0x61) and (lc <= 0x7A) def html_inline(state: StateInline, silent: bool): pos = state.pos if not state.md.options.get("html", None): return False # Check start maximum = state.posMax if state.srcCharCode[pos] != 0x3C or pos + 2 >= maximum: # /* < */ return False # Quick fail on second char ch = state.srcCharCode[pos + 1] if ( ch != 0x21 and ch != 0x3F # /* ! */ and ch != 0x2F # /* ? */ and not isLetter(ch) # /* / */ ): return False match = HTML_TAG_RE.search(state.src[pos:]) if not match: return False if not silent: token = state.push("html_inline", "", 0) token.content = state.src[pos : pos + len(match.group(0))] state.pos += len(match.group(0)) return True