11 #include "cl_number.h"
15 uintD* I_to_DS_n_aux (const cl_I& obj, uintC n, uintD* destptr)
16 { // Nun sind unterhalb von destptr n Digits Platz.
17 // oberen Teil der DS aus obj füllen, dabei destptr erniedrigen:
21 #if (intDsize==64) // && (FN_maxlength==1)
22 lsprefnext(destptr) = FN_to_Q(obj);
23 #else // (intDsize<=32)
24 var uint32 wert = FN_to_L(obj);
25 #define FN_maxlength_a (intLsize/intDsize)
26 #define FN_maxlength_b (FN_maxlength<=FN_maxlength_a ? FN_maxlength : FN_maxlength_a)
27 // FN_maxlength Digits ablegen. Davon kann man FN_maxlength_b Digits aus wert nehmen.
28 #if (FN_maxlength_b > 1)
29 doconsttimes(FN_maxlength_b-1,
30 lsprefnext(destptr) = (uintD)wert; wert = wert >> intDsize;
33 lsprefnext(destptr) = (uintD)wert;
34 #if (FN_maxlength > FN_maxlength_b)
35 // Es ist oint_data_len = intLsize, brauche
36 // noch FN_maxlength-FN_maxlength_b = 1 Digit.
37 lsprefnext(destptr) = (sintD)sign_of(FN_to_L(obj));
44 { var uintC len = TheBignum(obj)->length;
46 destptr = copy_loop_lsp(BN_LSDptr(obj),destptr,len); // DS kopieren
48 // unteren Teil mit Fülldigits, gebildet aus dem Vorzeichen, füllen:
50 { destptr = fill_loop_lsp(destptr,n,sign_of_sintD(mspref(destptr,0))); }
51 // destptr zeigt nun aufs untere Ende der DS.