晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/cloudlinux/venv/lib64/python3.11/site-packages/svgwrite/data/ |
| Current File : //opt/cloudlinux/venv/lib64/python3.11/site-packages/svgwrite/data/svgparser.py |
#!/usr/bin/env python
# coding:utf-8
# Authors: mozman <me@mozman.at>, Florian Festi
# Purpose: svgparser using re module
# Created: 16.10.2010
# Copyright (c) 2010, Manfred Moitzi & 2020, Florian Festi
# License: MIT License
__all__ = ["is_valid_transferlist", "is_valid_pathdata", "is_valid_animation_timing"]
import re
event_names = [
"focusin", "focusout", "activate", "click", "mousedown", "mouseup", "mouseover",
"mousemove", "mouseout", "DOMSubtreeModified", "DOMNodeInserted", "DOMNodeRemoved",
"DOMNodeRemovedFromDocument", "DOMNodeInsertedtoDocument", "DOMAttrModified",
"DOMCharacterDataModified", "SVGLoad", "SVGUnload", "SVGAbort", "SVGError",
"SVGResize", "SVGScroll", "SVGZoom", "beginEvent", "endEvent", "repeatEvent",
]
c = r"\s*[, ]\s*"
s = r"\s*[; ]\s*"
integer_constant = r"\d+"
exponent = r"([eE][+-]?\d+)"
nonnegative_number = fr"(\d+\.?\d*|\.\d+){exponent}?"
number = r"[+-]?" + nonnegative_number
flag = r"[01]"
comma_delimited_coordinates = fr"\s*{number}({c}{number})*\s*"
two_comma_delimited_numbers = fr"\s*{number}({c}{number}\s*)" "{1}"
four_comma_delimited_numbers = fr"\s*{number}\s*({c}{number}\s*)" "{3}"
six_comma_delimited_numbers = fr"\s*{number}\s*({c}{number}\s*)" "{5}"
comma_delimited_coordinate_pairs = fr"{two_comma_delimited_numbers}({c}{two_comma_delimited_numbers})*"
def is_valid(regex):
reg = re.compile(regex)
def f(term):
return bool(reg.fullmatch(term))
return f
def build_transferlist_parser():
matrix = fr"matrix\s*\(\s*{six_comma_delimited_numbers}\s*\)"
translate = fr"translate\s*\(\s*{number}({c}{number})?\s*\)"
scale = fr"scale\s*\(\s*{number}({c}{number})?\s*\)"
rotate = fr"rotate\s*\(\s*{number}({c}{number}{c}{number})?\s*\)"
skewX = fr"skewX\s*\(\s*{number}\s*\)"
skewY = fr"skewY\s*\(\s*{number}\s*\)"
tl_re = "|".join((fr"(\s*{cmd}\s*)" for cmd in (
matrix, translate, scale, rotate, skewX, skewY)))
return fr"({tl_re})({c}({tl_re}))*"
is_valid_transferlist = is_valid(build_transferlist_parser())
def build_pathdata_parser():
moveto = fr"[mM]\s*{comma_delimited_coordinate_pairs}"
lineto = fr"[lL]\s*{comma_delimited_coordinate_pairs}"
horizontal_lineto = fr"[hH]\s*{comma_delimited_coordinates}"
vertical_lineto = fr"[vV]\s*{comma_delimited_coordinates}"
curveto = fr"[cC]\s*({six_comma_delimited_numbers})({c}{six_comma_delimited_numbers})*"
smooth_curveto = fr"[sS]{four_comma_delimited_numbers}({c}{four_comma_delimited_numbers})*"
quadratic_bezier_curveto = fr"[qQ]{four_comma_delimited_numbers}({c}{four_comma_delimited_numbers})*"
smooth_quadratic_bezier_curveto = fr"[tT]\s*{comma_delimited_coordinate_pairs}"
elliptical_arc_argument = fr"{c}".join((
fr"{nonnegative_number}",
fr"{nonnegative_number}",
fr"{number}",
fr"{flag}",
fr"{flag}",
fr"{number}",
fr"{number}",))
elliptical_arc_argument = r"\s*" + elliptical_arc_argument + r"\s*"
elliptical_arc = fr"[aA]({elliptical_arc_argument})({c}{elliptical_arc_argument})*"
drawto_command = "|".join((fr"(\s*{cmd}\s*)" for cmd in (
moveto, lineto, horizontal_lineto, vertical_lineto, "[zZ]",
curveto, smooth_curveto, quadratic_bezier_curveto,
smooth_quadratic_bezier_curveto, elliptical_arc)))
return f"{moveto}({drawto_command})*"
is_valid_pathdata = is_valid(build_pathdata_parser())
digit2 = r"\d{2}"
digit4 = r"\d{4}"
seconds = fr"\d+(\.\d+)?"
seconds2 = fr"{digit2}(\.\d+)?"
metric = "(h|min|s|ms)"
def clock_val_re():
timecount_val = fr"{seconds}\s*({metric})?"
clock_val = fr"{digit2}:({digit2}:)?{seconds2}"
return fr"({timecount_val}|{clock_val})"
def wall_clock_val_re():
hhmmss = fr"{digit2}:{digit2}(:{seconds2})?"
walltime = fr"{hhmmss}(Z|[+-]?{digit2}:{digit2})?"
date = fr"{digit4}-{digit2}-{digit2}"
datetime = fr"{date}(T{walltime})?"
return "(" + "|".join((walltime, datetime)) + ")"
def build_animation_timing_parser():
clock_val = clock_val_re()
wallclock_val = wall_clock_val_re()
event_ref = "(" + "|".join(event_names) + ")"
id_value = "#?[-_a-zA-Z0-9]+"
wallclock_sync_value = fr"wallclock\(\s*{wallclock_val}\s*\)"
accesskey_value = fr"accessKey\(\s*[a-zA-Z]\s*\)\s*([+-]?{clock_val})?"
repeat_value = fr"({id_value}\.)?repeat\s*\(\s*\d+\s*\)\s*([+-?]{clock_val})?"
event_value = fr"({id_value}\.)?{event_ref}([+-]?{clock_val})?"
offset_value = fr"[-+]?{clock_val}"
syncbase_value = fr"{id_value}\.(begin|end)({offset_value})?"
begin_value = "(" + "|".join((f"({reg})" for reg in (
offset_value, syncbase_value, event_value, repeat_value,
accesskey_value, wallclock_sync_value, "indefinite"))) + ")"
return fr"{begin_value}({s}{begin_value})*"
is_valid_animation_timing = is_valid(build_animation_timing_parser())
|