
    Dge)                         d dl Z d dlmZ d dlmZmZmZ  G d d          Zeeeeef         ee         f                  Z	 G d d          Z
 G d d	e
          ZdS )
    N)filterfalse)ListTupleUnionc                       e Zd Zd Zd ZdS )_lazyclasspropertyc                 D    || _         |j        | _        |j        | _        d S N)fn__doc____name__)selfr   s     F/var/www/sysmax/venv/lib/python3.11/site-packages/pyparsing/unicode.py__init__z_lazyclassproperty.__init__	   s    z    c                 "   t          |          t          d          r(t          fdj        dd          D                       ri _        | j        j        }|j        vr|                               j        |<   j        |         S )N_internc              3   H   K   | ]}j         t          |d g           u V  dS )r   N)r   getattr).0
superclassclss     r   	<genexpr>z-_lazyclassproperty.__get__.<locals>.<genexpr>   sJ       .
 .
 K7:y"===.
 .
 .
 .
 .
 .
r      )typehasattrany__mro__r   r   r   )r   objr   attrnames     ` r   __get__z_lazyclassproperty.__get__   s    ;s))CsI&& 	# .
 .
 .
 .
!k!""o.
 .
 .
 +
 +
 	 CK7#3;&&$(GGCLLCK!{8$$r   N)r   
__module____qualname__r   r!    r   r   r   r      s2        $ $ $
% % % % %r   r   c                      e Zd ZU dZg Zeed<   edee	         fd            Z
ede	fd            Zede	fd            Zede	fd            Zede	fd            Zede	fd	            Zede	fd
            Zed             ZdS )unicode_seta  
    A set of Unicode characters, for language-specific strings for
    ``alphas``, ``nums``, ``alphanums``, and ``printables``.
    A unicode_set is defined by a list of ranges in the Unicode character
    set, in a class attribute ``_ranges``. Ranges can be specified using
    2-tuples or a 1-tuple, such as::

        _ranges = [
            (0x0020, 0x007e),
            (0x00a0, 0x00ff),
            (0x0100,),
            ]

    Ranges are left- and right-inclusive. A 1-tuple of (x,) is treated as (x, x).

    A unicode set can also be defined using multiple inheritance of other unicode sets::

        class CJK(Chinese, Japanese, Korean):
            pass
    _rangesreturnc           	         g }| j         D ]S}|t          u r nGt          |dd          D ]4}|                    t	          |d         |d         dz                        5Tt          d t          |          D                       S )Nr'   r$   r   r   c              3   4   K   | ]}t          |          V  d S r
   )chrr   cs     r   r   z0unicode_set._chars_for_ranges.<locals>.<genexpr>?   s(      //c!ff//////r   )r   r&   r   extendrangesortedset)r   retccrrs       r   _chars_for_rangeszunicode_set._chars_for_ranges7   s    + 	5 	5B[  b)R00 5 5

5A2
3344445//c#hh//////r   c                 f    d                     t          t          j        | j                            S )z+all non-whitespace characters in this range )joinr   strisspacer6   r   s    r   
printableszunicode_set.printablesA   s%     ww{3;0EFFGGGr   c                 f    d                     t          t          j        | j                            S )z'all alphabetic characters in this ranger8   )r9   filterr:   isalphar6   r<   s    r   alphaszunicode_set.alphasF   %     wwvck3+@AABBBr   c                 f    d                     t          t          j        | j                            S )z*all numeric digit characters in this ranger8   )r9   r?   r:   isdigitr6   r<   s    r   numszunicode_set.numsK   rB   r   c                      | j         | j        z   S )z)all alphanumeric characters in this range)rA   rE   r<   s    r   	alphanumszunicode_set.alphanumsP   s     zCH$$r   c           
          d                     t          t          t          t          j        | j                            t          d          z                      S )zVall characters in this range that are valid identifier characters, plus underscore '_'r8   u   ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyzªµºÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ_)r9   r1   r2   r?   r:   isidentifierr6   r<   s    r   
identcharszunicode_set.identcharsU   sY     wwF3+S-BCCDD  	
 	
 		
r   c                     t          d | j        D                       }d                    t          |t          | j                  z  t          d          z                      S )u   
        all characters in this range that are valid identifier body characters,
        plus the digits 0-9, and · (Unicode MIDDLE DOT)
        c              3   H   K   | ]}d |z                                    |V  dS )_N)rI   r-   s     r   r   z-unicode_set.identbodychars.<locals>.<genexpr>i   sK       
 
q0F0F0H0H

 
 
 
 
 
r   r8   u   0123456789·)r2   r6   r9   r1   rJ   )r   identifier_charss     r   identbodycharszunicode_set.identbodycharsc   ss      
 
,
 
 
 
 
 ww#c#.&9&99C<O<OOPP
 
 	
r   c                 :    ddl m}  || j        | j                  S )z
        a pyparsing Word expression for an identifier using this range's definitions for
        identchars and identbodychars
        r   )Word)	pyparsingrQ   rJ   rO   )r   rQ   s     r   
identifierzunicode_set.identifierp   s-     	#"""""tCNC$6777r   N)r   r"   r#   r   r'   UnicodeRangeList__annotations__r   r   r:   r6   r=   rA   rE   rG   rJ   rO   rS   r$   r   r   r&   r&      sx         * !#G"""0$s) 0 0 0 0 H3 H H H H Cs C C C C CS C C C C %# % % % % 
3 
 
 
 
 

s 

 

 

 

 8 8 8 8 8r   r&   c                      e Zd ZU dZdej        fgZeed<    G d de	          Z
 G d de	          Z G d d	e	          Z G d
 de	          Z G d de	          Z G d de	          Z G d de	          Z G d de	          Z G d de	          ZeZ G d deee          Z G d de	          Z G d de	          Z G d de	          Z G d de	          Ze
ZeZeZeZeZeZeZeZ eZ!eZ"d S )!pyparsing_unicodezF
    A namespace class for defining common language unicode_sets.
        r'   c                   $    e Zd ZU dZdgZeed<   dS )(pyparsing_unicode.BasicMultilingualPlanez,Unicode set for the Basic Multilingual Plane)rX   i  r'   Nr   r"   r#   r   r'   rT   rU   r$   r   r   BasicMultilingualPlanerZ      s8         ::%
! 	
 	
 	
 	
 	
r   r\   c                   &    e Zd ZU dZddgZeed<   dS )pyparsing_unicode.Latin1z/Unicode set for Latin-1 Unicode Character Range)rX   ~   )      r'   Nr[   r$   r   r   Latin1r^      s;         ==%
! 	
 	
 	
 	
 	
r   rb   c                   $    e Zd ZU dZdgZeed<   dS )pyparsing_unicode.LatinAz/Unicode set for Latin-A Unicode Character Range)   i  r'   Nr[   r$   r   r   LatinArd      8         ==%
! 	
 	
 	
 	
 	
r   rf   c                   $    e Zd ZU dZdgZeed<   dS )pyparsing_unicode.LatinBz/Unicode set for Latin-B Unicode Character Range)i  iO  r'   Nr[   r$   r   r   LatinBri      rg   r   rj   c                   &    e Zd ZU dZg dZeed<   dS )pyparsing_unicode.Greekz.Unicode set for Greek Unicode Character Ranges)#)iB  iE  )ip  iw  )iz  i  )i  i  )i  )i  i  )i  i  )i  i  )i&  i*  )i^  )i`  )if  ij  )i   i  )i  i  )i   iE  )iH  iM  )iP  iW  )iY  )i[  )i]  )i_  i}  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i)!  )i'  i'  )ie  )i@ i )i )i  iE )i i r'   Nr[   r$   r   r   Greekrl      s?         <<$%
 $%
 $%
! $	
 $	
 $	
 $	
 $	
r   rm   c                   &    e Zd ZU dZg dZeed<   dS )pyparsing_unicode.Cyrillicz0Unicode set for Cyrillic Unicode Character Range))i   i/  )i  i  )i+  )ix  )i-  i-  )i@  ir  )it  i  )i.  i/  r'   Nr[   r$   r   r   Cyrillicro      s?         >>	%
 	%
 	%
! 		
 		
 		
 		
 		
r   rp   c                   &    e Zd ZU dZg dZeed<   dS )pyparsing_unicode.Chinesez/Unicode set for Chinese Unicode Character Range))i.  i.  )i.  i.  )i1  i1  )i 4  iM  ) N  i  )i   i  )i   im  )ip  i  )io io )i i )i i; )i@ iH )i   i֦ )i  i4 )i@ i )i  i )i i )i  i r'   Nr[   r$   r   r   Chineserr      s?         ==%
 %
 %
! 	
 	
 	
 	
 	
r   rt   c                       e Zd ZdZ G d de          Z G d de          Z G d de          ZeZeZ	eZ
ej        ej        z   ej        z   ZdS )	pyparsing_unicode.Japanesez`Unicode set for Japanese Unicode Character Range, combining Kanji, Hiragana, and Katakana rangesc                   &    e Zd ZU dZddgZeed<   dS ) pyparsing_unicode.Japanese.Kanjiz-Unicode set for Kanji Unicode Character Range)rs   i  )i 0  i?0  r'   Nr[   r$   r   r   Kanjirx      s;         ;;  )G%     r   ry   c                   &    e Zd ZU dZg dZeed<   dS )#pyparsing_unicode.Japanese.Hiraganaz0Unicode set for Hiragana Unicode Character Range))iA0  i0  )0  0  )i0  )ip  )i )iP iR )i  r'   Nr[   r$   r   r   Hiraganar{      s?         BB) ) )G%     r   r~   c                   &    e Zd ZU dZg dZeed<   dS )#pyparsing_unicode.Japanese.Katakanaz1Unicode set for Katakana  Unicode Character Range)	)r|   i0  )r}   i0  )i1  i1  )i2  i2  )ie  i  )i  )id ig )i i )i r'   Nr[   r$   r   r   Katakanar     s?         CC
) 
) 
)G% 
 
 
 
 
r   r   N)r   r"   r#   r   r&   ry   r~   r      漢字   カタカナ   ひらがなr'   r$   r   r   Japaneserv      s        nn	 	 	 	 	K 	 	 	
	 
	 
	 
	 
	{ 
	 
	 
		 	 	 	 	{ 	 	 	  M 	r   r   c                   &    e Zd ZU dZg dZeed<   dS )pyparsing_unicode.Hangulz7Unicode set for Hangul (Korean) Unicode Character Range))i   i  )i.0  i/0  )i11  i1  )i 2  i2  )i`2  i{2  )i~2  )i`  i|  )i   i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  r'   Nr[   r$   r   r   Hangulr     s?         EE%
 %
 %
! 	
 	
 	
 	
 	
r   r   c                       e Zd ZdZdS )pyparsing_unicode.CJKzTUnicode set for combined Chinese, Japanese, and Korean (CJK) Unicode Character RangeN)r   r"   r#   r   r$   r   r   CJKr   0  s        bbbbr   r   c                   &    e Zd ZU dZddgZeed<   dS )pyparsing_unicode.Thaiz,Unicode set for Thai Unicode Character Range)i  i:  )i?  i[  r'   Nr[   r$   r   r   Thair   3  s;         ::%
! 	
 	
 	
 	
 	
r   r   c                   &    e Zd ZU dZg dZeed<   dS )pyparsing_unicode.Arabicz.Unicode set for Arabic Unicode Character Range))i   i  )i  i  )i   i  r'   Nr[   r$   r   r   Arabicr   :  s?         <<%
 %
 %
! 	
 	
 	
 	
 	
r   r   c                   &    e Zd ZU dZg dZeed<   dS )pyparsing_unicode.Hebrewz.Unicode set for Hebrew Unicode Character Range)	)i  i  )i  i  )i  i  )i  i6  )i8  i<  )i>  )i@  iA  )iC  iD  )iF  iO  r'   Nr[   r$   r   r   Hebrewr   B  s?         <<
%
 
%
 
%
! 
	
 
	
 
	
 
	
 
	
r   r   c                   &    e Zd ZU dZddgZeed<   dS )pyparsing_unicode.Devanagariz2Unicode set for Devanagari Unicode Character Range)i 	  i	  )i  i  r'   Nr[   r$   r   r   
Devanagarir   P  s;         @@%
! 	
 	
 	
 	
 	
r   r   N)#r   r"   r#   r   sys
maxunicoder'   rT   rU   r&   r\   rb   rf   rj   rm   rp   rt   r   r   Koreanr   r   r   r   r   BMP   العربية   中文   кириллица   Ελληνικά   עִברִית	   日本語	   한국어	   ไทย   देवनागरीr$   r   r   rW   rW   {   s          
 !G   
 
 
 
 
 
 
 

 
 
 
 
 
 
 

 
 
 
 
 
 
 

 
 
 
 
 
 
 
&
 &
 &
 &
 &
 &
 &
 &
P
 
 
 
 
; 
 
 

 
 
 
 
+ 
 
 
.,
 ,
 ,
 ,
 ,
; ,
 ,
 ,
\
 
 
 
 
 
 
 
( Fc c c c cgx c c c
 
 
 
 
{ 
 
 

 
 
 
 
 
 
 

 
 
 
 
 
 
 

 
 
 
 
[ 
 
 
 !C NF!NIII)r   rW   )r   	itertoolsr   typingr   r   r   r   intrT   r&   rW   r$   r   r   <module>r      s    


 ! ! ! ! ! ! % % % % % % % % % %% % % % % % % %( eCHouSz9:; Y8 Y8 Y8 Y8 Y8 Y8 Y8 Y8xg* g* g* g* g* g* g* g* g* g*r   