ó
    §9i7  ã                   ó<   • S SK Jr  SSKJr  SSKJrJrJr  S rS r	g)é   )Ú_Curveé    )ÚInteger)Úload_pycryptodome_raw_libÚVoidPointerÚSmartPointerc                  óÈ   ^• Sn SnSnSn[        SS5      m " U4S jS[        5      n[        [        U 5      S [        U5      [        U5      [        U5      S S	S
S SSU5      nU$ )Nl   íÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿl   íSë9i“@eMó^¨w|o                l   UK‚5±J,{´$%Xci\¸-÷G'
lJ[sii!l   XfÌL™33ffÌL™33ffÌL™33ffÌL™33ffzCrypto.PublicKey._ed25519ai  
typedef void Point;
int ed25519_new_point(Point **out,
                      const uint8_t x[32],
                      const uint8_t y[32],
                      size_t modsize,
                      const void *context);
int ed25519_clone(Point **P, const Point *Q);
void ed25519_free_point(Point *p);
int ed25519_cmp(const Point *p1, const Point *p2);
int ed25519_neg(Point *p);
int ed25519_get_xy(uint8_t *xb, uint8_t *yb, size_t modsize, Point *p);
int ed25519_double(Point *p);
int ed25519_add(Point *P1, const Point *P2);
int ed25519_scalar(Point *P, const uint8_t *scalar, size_t scalar_len, uint64_t seed);
c                   ó   >• \ rS rSr Y R                  r Y R                  r Y R                  r	 Y R                  r Y R                  r Y R                  r Y R                   r Y R$                  r Y R(                  rSrg)Úed25519_curve.<locals>.EcLibé!   © N)Ú__name__Ú
__module__Ú__qualname__Ú__firstlineno__Úed25519_new_pointÚ	new_pointÚed25519_cloneÚcloneÚed25519_free_pointÚ
free_pointÚed25519_cmpÚcmpÚed25519_negÚnegÚed25519_get_xyÚget_xyÚed25519_doubleÚdoubleÚed25519_addÚaddÚed25519_scalarÚscalarÚ__static_attributes__)Ú_ed25519_libs   €ÚY/var/www/html/land-doc-ocr/venv/lib/python3.13/site-packages/Crypto/PublicKey/_edwards.pyÚEcLibr   !   sf   ø† Ù ×2Ñ2ˆ	Ù×*Ñ*ˆÙ!×4Ñ4ˆ
Ù×&Ñ&ˆÙ×&Ñ&ˆÙ×,Ñ,ˆÙ×,Ñ,ˆÙ×&Ñ&ˆÙ×,Ñ,‹ó    r'   éÿ   z1.3.101.112ÚEd25519zssh-ed25519)r   Úobjectr   r   )ÚpÚorderÚGxÚGyr'   Úed25519r%   s         @r&   Úed25519_curver1   
   s|   ø€ ØJ€AØN€EØ	K€BØ	K€Bä,Ð-Hð Kó €L÷"	-”ô 	-ô ”W˜Q“ZØÜ˜U“^Ü˜R“[Ü˜R“[ØØØ"ØØØ"Øó€Gð €Nr(   c                  óŒ  ^	• Sn SnSnSn[        SS5      m	 " U	4S jS[        5      n[        5       nT	R                  UR	                  5       5      nU(       a  [        S	U-  5      e[        UR                  5       T	R                  5      n[        [        U 5      S [        U5      [        U5      [        U5      S S
SUSS U5      nU$ )Nl   ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿ?ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿl   óD°VJ
ÆRu±8£a6!m,»&ÚvD}D2_ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿl   ^@¯ 51â8`b8ÀCÊlª\×p*AŒtô(’qmjÏ.<‚+FaS[Í/SDZ74_3ã	l   zadoeC@Ù
ùZK‰^ýDsx™sø­sZhNx0Ž2›§>Ilq2« vIðZugt'zCrypto.PublicKey._ed448a*  
typedef void EcContext;
typedef void PointEd448;
int ed448_new_context(EcContext **pec_ctx);
void ed448_context(EcContext *ec_ctx);
void ed448_free_context(EcContext *ec_ctx);
int ed448_new_point(PointEd448 **out,
                    const uint8_t x[56],
                    const uint8_t y[56],
                    size_t len,
                    const EcContext *context);
int ed448_clone(PointEd448 **P, const PointEd448 *Q);
void ed448_free_point(PointEd448 *p);
int ed448_cmp(const PointEd448 *p1, const PointEd448 *p2);
int ed448_neg(PointEd448 *p);
int ed448_get_xy(uint8_t *xb, uint8_t *yb, size_t len, const PointEd448 *p);
int ed448_double(PointEd448 *p);
int ed448_add(PointEd448 *P1, const PointEd448 *P2);
int ed448_scalar(PointEd448 *P, const uint8_t *scalar, size_t scalar_len, uint64_t seed);
c                   ó   >• \ rS rSr Y R                  r Y R                  r Y R                  r	 Y R                  r Y R                  r Y R                  r Y R                   r Y R$                  r Y R(                  rSrg)Úed448_curve.<locals>.EcLibéV   r   N)r   r   r   r   Úed448_new_pointr   Úed448_cloner   Úed448_free_pointr   Ú	ed448_cmpr   Ú	ed448_negr   Úed448_get_xyr   Úed448_doubler   Ú	ed448_addr!   Úed448_scalarr#   r$   )Ú
_ed448_libs   €r&   r'   r4   V   sf   ø† Ù×.Ñ.ˆ	Ù×&Ñ&ˆÙ×0Ñ0ˆ
Ù×"Ñ"ˆÙ×"Ñ"ˆÙ×(Ñ(ˆÙ×(Ñ(ˆÙ×"Ñ"ˆÙ×(Ñ(‹r(   r'   z#Error %d initializing Ed448 contextiÀ  z1.3.101.113ÚEd448)r   r+   r   Úed448_new_contextÚ
address_ofÚImportErrorr   ÚgetÚed448_free_contextr   r   )
r,   r-   r.   r/   r'   Úed448_contextÚresultÚcontextÚed448r?   s
            @r&   Úed448_curverJ   ;   sË   ø€ Øz€AØ~€EØ	{€BØ	{€Bä*Ð+Dð Gó €J÷*	)”ô 	)ô  “M€MØ×)Ñ)¨-×*BÑ*BÓ*DÓE€FÞÜÐ?À&ÑHÓIÐIä˜=×,Ñ,Ó.°
×0MÑ0MÓN€Gä”7˜1“:ØÜ˜5“>Ü˜2“;Ü˜2“;ØØØ ØØØØó€Eð €Lr(   N)
Ú_curver   ÚCrypto.Math.Numbersr   ÚCrypto.Util._raw_apir   r   r   r1   rJ   r   r(   r&   Ú<module>rN      s"   ðõ Ý '÷0ñ 0ò.ób9r(   