Files
intellecton/venv/lib/python3.12/site-packages/pyparsing/__pycache__/actions.cpython-312.pyc
T

187 lines
9.2 KiB
Plaintext
Raw Normal View History

Ë
vRãóDddlmZddlmZmZmZddlmZddlm Z m
Z
ddl m Z eegefee gefee
e gefeee
e geffZGdd«Zdd „Zdd
Zdd Zdd Ze«e_ ddd
Ze
de«Ze
de«Ze
de«Ze
de«Ze
de«Zy)é)Ú annotations)ÚUnionÚCallableÚAnyé)ÚParseException)ÚcolÚreplaced_by_pep8)Ú ParseResultscó&eZdZdZddZddZdZy)ÚOnlyOncezˆ
Wrapper for parse actions, to ensure they are only called once.
Note: parse action signature must include all 3 arguments.
có8ddlm}||«|_d|_y)Nr)Ú _trim_arityF)ÚcorerÚcallableÚcalled)ÚselfÚ method_callrs úT/home/antigravity/intellecton/venv/lib/python3.12/site-packages/pyparsing/actions.pyÚ__init__zOnlyOnce.__init__sÝ# Œ
؈ ócól|js|j|||«}d|_|St||d«)NTz.OnlyOnce obj called multiple times w/out reset)rrr)rÚresultss rÚ__call__zOnlyOnce.__call__s7Ø{Š{Ø—mm A q¨!Ó,ˆG؈DŒK؈˜Q Ð#SÓTrcód|_y)zK
Allow the associated parse action to be called once more.
FN)r)rs rÚresetzOnlyOnce.reset&s ð
ˆ rN)rz'Callable[[str, int, ParseResults], Any]ÚreturnÚNone)rÚstrrÚintrr r r )Ú__name__Ú
__module__Ú __qualname__Ú__doc__rrr©rrr
r
sñó
ó Uórr
códˆfd }|S)zt
Helper method for defining parse actions that require matching at
a specific column in the input text.
cóDt||«k7rt||d«y)Nzmatched token not at column )r r)ÚstrgÚlocnÚtoksÚns €rÚ
verify_colz%match_only_at_col.<locals>.verify_col4s-ø€Ü ˆtT?˜aÒ Ü   tÐ/KÈAÈ3Ð-OÓ  r)r+r"r,r#r-r r r!r()r.r/s` rÚmatch_only_at_colr0.sø€õ Qð ÐrcóˆfdS)
Helper method for common parse actions that simply return
a literal value. Especially useful when used with
:meth:`~ParserElement.transform_string`.
Example:
.. doctest::
>>> num = Word(nums).set_parse_action(lambda toks: int(toks[0]))
>>> na = one_of("N/A NA").set_parse_action(replace_with(math.nan))
>>> term = na | num
>>> term[1, ...].parse_string("324 234 N/A 234")
ParseResults([324, 234, nan, 234], {})
có
gS)Nr()rrrÚrepl_strs €rú<lambda>zreplace_with.<locals>.<lambda>Ls ø€˜H˜:€rr()r3s`rÚ replace_withr5;s ø€ó" %rcó|dddS)a
Helper parse action for removing quotation marks from parsed
quoted strings, that use a single character for quoting. For parsing
strings that may have multiple characters, use the :class:`QuotedString`
class.
Example:
.. doctest::
>>> # by default, quotation marks are included in parsed results
>>> quoted_string.parse_string("'Now is the Winter of our Discontent'")
ParseResults(["'Now is the Winter of our Discontent'"], {})
>>> # use remove_quotes to strip quotation marks from parsed results
>>> dequoted = quoted_string().set_parse_action(remove_quotes)
>>> dequoted.parse_string("'Now is the Winter of our Discontent'")
ParseResults(['Now is the Winter of our Discontent'], {})
rréÿÿÿÿr()rrrs rÚ
remove_quotesr8Osð(
ˆQ‰4"ˆrcó~gŠ|rj|«nj|j««dˆfd }|S)
Helper to create a validating parse action to be used with start
tags created with :class:`make_xml_tags` or
:class:`make_html_tags`. Use ``with_attribute`` to qualify
a starting tag with a required attribute value, to avoid false
matches on common tags such as ``<TD>`` or ``<DIV>``.
Call ``with_attribute`` with a series of attribute names and
values. Specify the list of filter attributes names and values as:
- keyword arguments, as in ``(align="right")``, or
- as an explicit dict with ``**`` operator, when an attribute
name is also a Python reserved word, as in ``**{"class":"Customer", "align":"right"}``
- a list of name-value tuples, as in ``(("ns1:class", "Customer"), ("ns2:align", "right"))``
For attribute names with a namespace prefix, you must use the second
form. Attribute names are matched insensitive to upper/lower case.
If just testing for ``class`` (with or without a namespace), use
:class:`with_class`.
To verify that the attribute exists, but without specifying a value,
pass ``with_attribute.ANY_VALUE`` as the value.
The next two examples use the following input data and tag parsers:
.. testcode::
html = '''
<div>
Some text
<div type="grid">1 4 0 1 0</div>
<div type="graph">1,3 2,3 1,1</div>
<div>this has no type</div>
</div>
'''
div,div_end = make_html_tags("div")
Only match div tag having a type attribute with value "grid":
.. testcode::
div_grid = div().set_parse_action(with_attribute(type="grid"))
grid_expr = div_grid + SkipTo(div | div_end)("body")
for grid_header in grid_expr.search_string(html):
print(grid_header.body)
prints:
.. testoutput::
1 4 0 1 0
Construct a match with any div tag having a type attribute,
regardless of the value:
.. testcode::
div_any_type = div().set_parse_action(
with_attribute(type=with_attribute.ANY_VALUE)
)
div_expr = div_any_type + SkipTo(div | div_end)("body")
for div_header in div_expr.search_string(html):
print(div_header.body)
prints:
.. testoutput::
1 4 0 1 0
1,3 2,3 1,1
c ó¬D]N\}}||vrt||d|«|tjk7sŒ.|||k7sŒ7t||d|d||d|«y)Nzno matching attribute z
attribute z has value z
, must be )rÚwith_attributeÚ ANY_VALUE)rrÚtokensÚattrNameÚ attrValueÚ
attrs_lists €rÚpazwith_attribute.<locals>.paµsø€Ø#-ò Ñ ˆH˜$ Ð-CÀHÀ<Ð+PÓœN×ÀÑ9IÈYÓ9VÜØØ    ¨K¸¸xÑ8HÐ7KÈ:ÐV_ÐUbÐðñ  r)rr"rr#r=r r r!)ÚextendÚitems)ÚargsÚ attr_dictrAr@s @rr;r;fs=ø€ðR)+€JÙ Ø×ј$Õà×ј)Ÿ/™/Ó ð €Ircó.|r|dnd}tdi||i¤ŽS)a

Simplified version of :meth:`with_attribute` when
matching on a div class - made difficult because ``class`` is
a reserved word in Python.
Using similar input data to the :meth:`with_attribute` examples:
.. testcode::
html = '''
<div>
Some text
<div class="grid">1 4 0 1 0</div>
<div class="graph">1,3 2,3 1,1</div>
<div>this &lt;div&gt; has no class</div>
</div>
'''
div,div_end = make_html_tags("div")
Only match div tag having the "grid" class:
.. testcode::
div_grid = div().set_parse_action(with_class("grid"))
grid_expr = div_grid + SkipTo(div | div_end)("body")
for grid_header in grid_expr.search_string(html):
print(grid_header.body)
prints:
.. testoutput::
1 4 0 1 0
Construct a match with any div tag having a class attribute,
regardless of the value:
.. testcode::
div_any_type = div().set_parse_action(
with_class(withAttribute.ANY_VALUE)
)
div_expr = div_any_type + SkipTo(div | div_end)("body")
for div_header in div_expr.search_string(html):
print(div_header.body)
prints: