
    ik                     <    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mSn [        SS5      m " U4S jS[        5      nU4S jn[        [        T5      S [        U 5      [        S5      S S S	S
S SS UU5      nU$ )Nl   l   S9i@eM^w|o                zCrypto.PublicKey._curve25519a  
typedef void Point;

int curve25519_new_point(Point **out,
                         const uint8_t x[32],
                         size_t modsize,
                         const void* context);
int curve25519_clone(Point **P, const Point *Q);
void curve25519_free_point(Point *p);
int curve25519_get_x(uint8_t *xb, size_t modsize, Point *p);
int curve25519_scalar(Point *P, const uint8_t *scalar, size_t scalar_len, uint64_t seed);
int curve25519_cmp(const Point *ecp1, const Point *ecp2);
c                      > \ rS rSr Y R                  r Y R                  r Y R                  r	 Y R                  r Y R                  r Y R                  rSrg)curve25519_curve.<locals>.EcLib    N)__name__
__module____qualname____firstlineno__curve25519_new_point	new_pointcurve25519_cloneclonecurve25519_free_point
free_pointcurve25519_get_xget_xcurve25519_scalarscalarcurve25519_cmpcmp__static_attributes__)_curve25519_libs   W/var/www/html/trading/venv/lib/python3.13/site-packages/Crypto/PublicKey/_montgomery.pyEcLibr      sE    #88	00$::
00 22,,    r!   c                    > TS-  nSnSnSSUUTS-
  TTS-   TU-   TU-   US-
  UUS-   4n U R                   U;  nU(       d  [        S5      eg ! [         a    Sn N!f = f)N   l   kxujaj\~|ObjZs	oP,E$ l   _+yBb$:6gw[8cph[DS7OWr   r   FzInvalid Curve25519 public keyx
ValueError)pointp2x1x2	deny_listvalidps         r    _validate_x25519_point0curve25519_curve.<locals>._validate_x25519_point$   s    UXZ EEFFFF
		GG9,E <==   	E	s   A AA	      z1.3.101.110
Curve25519)r   objectr   r   )orderr!   r/   
curve25519r   r.   s       @@r    curve25519_curver7   
   sw    JANE/0N Q O- ->< 

%$.J r"   c                  ~  ^^ SmSn [        SS5      m " U4S jS[        5      n[        5       nUR                  UR	                  5       5      nU(       a  [        SU-  5      eU4S jn[        [        T5      S [        U 5      [        S	5      S S S
S[        UR                  5       UR                  5      SS UU5      nU$ )Nl   ?l   DVJ
Ru8a6!m,&vD}D2_zCrypto.PublicKey._curve448a  
typedef void Curve448Context;
typedef void Curve448Point;

int curve448_new_context(Curve448Context **pec_ctx);
void curve448_free_context(Curve448Context *ec_ctx);
int curve448_new_point(Curve448Point **out,
                       const uint8_t *x,
                       size_t len,
                       const Curve448Context *ec_ctx);
void curve448_free_point(Curve448Point *p);
int curve448_clone(Curve448Point **P, const Curve448Point *Q);
int curve448_get_x(uint8_t *xb, size_t modsize, const Curve448Point *p);
int curve448_scalar(Curve448Point *P, const uint8_t *scalar, size_t scalar_len, uint64_t seed);
int curve448_cmp(const Curve448Point *ecp1, const Curve448Point *ecp2);
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Srg)curve448_curve.<locals>.EcLibi   r   N)r   r   r   r   curve448_new_contextnew_contextcurve448_free_contextfree_contextcurve448_new_pointr   curve448_cloner   curve448_free_pointr   curve448_get_xr   curve448_scalarr   curve448_cmpr   r   )_curve448_libs   r    r!   r:   i   s[    #88$::!44	,,"66
,,..((r"   r!   z&Error %d initializing Curve448 contextc                    > SSTS-
  TTS-   4n U R                   U;  nU(       d  [        S5      eg ! [         a    Sn N!f = f)Nr   r   FzInvalid Curve448 public keyr%   )r(   r,   r-   r.   s      r    _validate_x448_point,curve448_curve.<locals>._validate_x448_pointx   s`    EE
		GG9,E :;;   	E	s   2 A A   i  z1.3.101.111Curve448)r   r4   r   r=   
address_ofImportErrorr   r   r   getr?   )r5   r!   curve448_contextresultrH   curve448rF   r.   s         @@r    curve448_curverR   T   s    zA~E-.J M M") ) #}/::<=FBVKLL<" gajenaj#"#3#7#7#95;M;MN *H Or"   N)
_curver   Crypto.Math.Numbersr   Crypto.Util._raw_apir   r   r   r7   rR   r   r"   r    <module>rV      s$     '0 0GTDr"   