# tclTomMath.decls -- # # This file contains the declarations for the functions in # 'libtommath' that are contained within the Tcl library. # This file is used to generate the 'tclTomMathDecls.h' and # 'tclTomMathStub.c' files. # # If you edit this file, advance the revision number (and the epoch # if the new stubs are not backward compatible) in tclTomMathDecls.h # # Copyright (c) 2005 by Kevin B. Kenny. All rights reserved. # # See the file "license.terms" for information on usage and redistribution # of this file, and for a DISCLAIMER OF ALL WARRANTIES. # # RCS: @(#) $Id: tclTomMath.decls,v 1.3 2007/12/13 15:23:20 dgp Exp $ library tcl # Define the unsupported generic interfaces. interface tclTomMath # hooks {tclTomMathInt} # Declare each of the functions in the Tcl tommath interface declare 0 generic { int TclBN_epoch(void) } declare 1 generic { int TclBN_revision(void) } declare 2 generic { int TclBN_mp_add(mp_int* a, mp_int* b, mp_int* c) } declare 3 generic { int TclBN_mp_add_d(mp_int* a, mp_digit b, mp_int* c) } declare 4 generic { int TclBN_mp_and(mp_int* a, mp_int* b, mp_int* c) } declare 5 generic { void TclBN_mp_clamp(mp_int* a) } declare 6 generic { void TclBN_mp_clear(mp_int* a) } declare 7 generic { void TclBN_mp_clear_multi(mp_int* a, ...) } declare 8 generic { int TclBN_mp_cmp(mp_int* a, mp_int* b) } declare 9 generic { int TclBN_mp_cmp_d(mp_int* a, mp_digit b) } declare 10 generic { int TclBN_mp_cmp_mag(mp_int* a, mp_int* b) } declare 11 generic { int TclBN_mp_copy(mp_int* a, mp_int* b) } declare 12 generic { int TclBN_mp_count_bits(mp_int* a) } declare 13 generic { int TclBN_mp_div(mp_int* a, mp_int* b, mp_int* q, mp_int* r) } declare 14 generic { int TclBN_mp_div_d(mp_int* a, mp_digit b, mp_int* q, mp_digit* r) } declare 15 generic { int TclBN_mp_div_2(mp_int* a, mp_int* q) } declare 16 generic { int TclBN_mp_div_2d(mp_int* a, int b, mp_int* q, mp_int* r) } declare 17 generic { int TclBN_mp_div_3(mp_int* a, mp_int* q, mp_digit* r) } declare 18 generic { void TclBN_mp_exch(mp_int* a, mp_int* b) } declare 19 generic { int TclBN_mp_expt_d(mp_int* a, mp_digit b, mp_int* c) } declare 20 generic { int TclBN_mp_grow(mp_int* a, int size) } declare 21 generic { int TclBN_mp_init(mp_int* a) } declare 22 generic { int TclBN_mp_init_copy(mp_int * a, mp_int* b) } declare 23 generic { int TclBN_mp_init_multi(mp_int* a, ...) } declare 24 generic { int TclBN_mp_init_set(mp_int* a, mp_digit b) } declare 25 generic { int TclBN_mp_init_size(mp_int* a, int size) } declare 26 generic { int TclBN_mp_lshd(mp_int* a, int shift) } declare 27 generic { int TclBN_mp_mod(mp_int* a, mp_int* b, mp_int* r) } declare 28 generic { int TclBN_mp_mod_2d(mp_int* a, int b, mp_int* r) } declare 29 generic { int TclBN_mp_mul(mp_int* a, mp_int* b, mp_int* p) } declare 30 generic { int TclBN_mp_mul_d(mp_int* a, mp_digit b, mp_int* p) } declare 31 generic { int TclBN_mp_mul_2(mp_int* a, mp_int* p) } declare 32 generic { int TclBN_mp_mul_2d(mp_int* a, int d, mp_int* p) } declare 33 generic { int TclBN_mp_neg(mp_int* a, mp_int* b) } declare 34 generic { int TclBN_mp_or(mp_int* a, mp_int* b, mp_int* c) } declare 35 generic { int TclBN_mp_radix_size(mp_int* a, int radix, int* size) } declare 36 generic { int TclBN_mp_read_radix(mp_int* a, const char* str, int radix) } declare 37 generic { void TclBN_mp_rshd(mp_int * a, int shift) } declare 38 generic { int TclBN_mp_shrink(mp_int* a) } declare 39 generic { void TclBN_mp_set(mp_int* a, mp_digit b) } declare 40 generic { int TclBN_mp_sqr(mp_int* a, mp_int* b) } declare 41 generic { int TclBN_mp_sqrt(mp_int* a, mp_int* b) } declare 42 generic { int TclBN_mp_sub(mp_int* a, mp_int* b, mp_int* c) } declare 43 generic { int TclBN_mp_sub_d(mp_int* a, mp_digit b, mp_int* c) } declare 44 generic { int TclBN_mp_to_unsigned_bin(mp_int* a, unsigned char* b) } declare 45 generic { int TclBN_mp_to_unsigned_bin_n(mp_int* a, unsigned char* b, unsigned long* outlen) } declare 46 generic { int TclBN_mp_toradix_n(mp_int* a, char* str, int radix, int maxlen) } declare 47 generic { int TclBN_mp_unsigned_bin_size(mp_int* a) } declare 48 generic { int TclBN_mp_xor(mp_int* a, mp_int* b, mp_int* c) } declare 49 generic { void TclBN_mp_zero(mp_int* a) } # internal routines to libtommath - should not be called but must be # exported to accommodate the "tommath" extension declare 50 generic { void TclBN_reverse(unsigned char* s, int len) } declare 51 generic { int TclBN_fast_s_mp_mul_digs(mp_int *a, mp_int *b, mp_int *c, int digs) } declare 52 generic { int TclBN_fast_s_mp_sqr(mp_int* a, mp_int* b) } declare 53 generic { int TclBN_mp_karatsuba_mul(mp_int* a, mp_int* b, mp_int* c) } declare 54 generic { int TclBN_mp_karatsuba_sqr(mp_int* a, mp_int* b) } declare 55 generic { int TclBN_mp_toom_mul(mp_int* a, mp_int* b, mp_int* c) } declare 56 generic { int TclBN_mp_toom_sqr(mp_int* a, mp_int* b) } declare 57 generic { int TclBN_s_mp_add(mp_int* a, mp_int* b, mp_int* c) } declare 58 generic { int TclBN_s_mp_mul_digs(mp_int* a, mp_int* b, mp_int* c, int digs) } declare 59 generic { int TclBN_s_mp_sqr(mp_int* a, mp_int* b) } declare 60 generic { int TclBN_s_mp_sub(mp_int* a, mp_int* b, mp_int* c) }