__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
# Process 
from __future__ import annotations
from ..common.utils import isStrSpace, normalizeReference
from ..token import Token
from .state_inline import StateInline
def image(state: StateInline, silent: bool) -> bool:
label = None
href = ""
oldPos = state.pos
max = state.posMax
if state.src[state.pos] != "!":
return False
if state.pos + 1 < state.posMax and state.src[state.pos + 1] != "[":
return False
labelStart = state.pos + 2
labelEnd = state.md.helpers.parseLinkLabel(state, state.pos + 1, False)
# parser failed to find ']', so it's not a valid link
if labelEnd < 0:
return False
pos = labelEnd + 1
if pos < max and state.src[pos] == "(":
#
# Inline link
#
# [link]( <href> "title" )
# ^^ skipping these spaces
pos += 1
while pos < max:
ch = state.src[pos]
if not isStrSpace(ch) and ch != "\n":
break
pos += 1
if pos >= max:
return False
# [link]( <href> "title" )
# ^^^^^^ parsing link destination
start = pos
res = state.md.helpers.parseLinkDestination(state.src, pos, state.posMax)
if res.ok:
href = state.md.normalizeLink(res.str)
if state.md.validateLink(href):
pos = res.pos
else:
href = ""
# [link]( <href> "title" )
# ^^ skipping these spaces
start = pos
while pos < max:
ch = state.src[pos]
if not isStrSpace(ch) and ch != "\n":
break
pos += 1
# [link]( <href> "title" )
# ^^^^^^^ parsing link title
res = state.md.helpers.parseLinkTitle(state.src, pos, state.posMax)
if pos < max and start != pos and res.ok:
title = res.str
pos = res.pos
# [link]( <href> "title" )
# ^^ skipping these spaces
while pos < max:
ch = state.src[pos]
if not isStrSpace(ch) and ch != "\n":
break
pos += 1
else:
title = ""
if pos >= max or state.src[pos] != ")":
state.pos = oldPos
return False
pos += 1
else:
#
# Link reference
#
if "references" not in state.env:
return False
# /* [ */
if pos < max and state.src[pos] == "[":
start = pos + 1
pos = state.md.helpers.parseLinkLabel(state, pos)
if pos >= 0:
label = state.src[start:pos]
pos += 1
else:
pos = labelEnd + 1
else:
pos = labelEnd + 1
# covers label == '' and label == undefined
# (collapsed reference link and shortcut reference link respectively)
if not label:
label = state.src[labelStart:labelEnd]
label = normalizeReference(label)
ref = state.env["references"].get(label, None)
if not ref:
state.pos = oldPos
return False
href = ref["href"]
title = ref["title"]
#
# We found the end of the link, and know for a fact it's a valid link
# so all that's left to do is to call tokenizer.
#
if not silent:
content = state.src[labelStart:labelEnd]
tokens: list[Token] = []
state.md.inline.parse(content, state.md, state.env, tokens)
token = state.push("image", "img", 0)
token.attrs = {"src": href, "alt": ""}
token.children = tokens or None
token.content = content
if title:
token.attrSet("title", title)
# note, this is not part of markdown-it JS, but is useful for renderers
if label and state.md.options.get("store_labels", False):
token.meta["label"] = label
state.pos = pos
state.posMax = max
return True
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 696 B | 0644 |
|
| autolink.py | File | 2.03 KB | 0644 |
|
| backticks.py | File | 1.99 KB | 0644 |
|
| balance_pairs.py | File | 4.74 KB | 0644 |
|
| emphasis.py | File | 3.05 KB | 0644 |
|
| entity.py | File | 1.61 KB | 0644 |
|
| escape.py | File | 1.62 KB | 0644 |
|
| fragments_join.py | File | 1.46 KB | 0644 |
|
| html_inline.py | File | 1.1 KB | 0644 |
|
| image.py | File | 4.04 KB | 0644 |
|
| link.py | File | 4.22 KB | 0644 |
|
| linkify.py | File | 1.66 KB | 0644 |
|
| newline.py | File | 1.27 KB | 0644 |
|
| state_inline.py | File | 4.98 KB | 0644 |
|
| strikethrough.py | File | 3.14 KB | 0644 |
|
| text.py | File | 901 B | 0644 |
|