Tree @debian/9.9.1-2 (Download .tar.gz)
- ..
- BasicThreadPool.c
- BerlekampTest.c
- BerlekampTestIn
- BerlekampTestOut
- BitMatTest.c
- c_lip_impl.h
- CanZassTest.c
- CanZassTestIn
- CanZassTestOut
- cfile
- CharPolyTest.c
- CharPolyTestIn
- CharPolyTestOut
- CheckAVX.c
- CheckCLZL.c
- CheckCLZLAux.c
- CheckCompile.c
- CheckFMA.c
- CheckLL.c
- CheckLLAux.c
- configure
- CopyFeatures
- ctools.c
- def_makefile
- DIRNAME
- DispSettings.c
- DoConfig
- dosify
- ExceptionTest.c
- FacVec.c
- FFT.c
- fileio.c
- g_lip_impl.h
- G_LLL_FP.c
- G_LLL_QP.c
- G_LLL_RR.c
- G_LLL_XD.c
- gen_gmp_aux.c
- GetPID1.c
- GetPID2.c
- GetTime0.c
- GetTime1.c
- GetTime2.c
- GetTime3.c
- GetTime4.c
- GetTime5.c
- GF2.c
- GF2E.c
- GF2EX.c
- GF2EXFactoring.c
- GF2EXTest.c
- GF2X.c
- GF2X1.c
- GF2XFactoring.c
- GF2XTest.c
- GF2XTimeTest.c
- GF2XVec.c
- HNF.c
- InitSettings.c
- lip.c
- LLL.c
- LLL_FP.c
- LLL_QP.c
- LLL_RR.c
- LLL_XD.c
- LLLTest.c
- LLLTestIn
- LLLTestOut
- lzz_p.c
- lzz_pE.c
- lzz_pEX.c
- lzz_pEXFactoring.c
- lzz_pEXTest.c
- lzz_pX.c
- lzz_pX1.c
- lzz_pXCharPoly.c
- lzz_pXFactoring.c
- mach_desc.win
- MakeCheckFeature
- MakeDesc.c
- MakeDescAux.c
- makefile
- MakeGetPID
- MakeGetTime
- mat_GF2.c
- mat_GF2E.c
- mat_lzz_p.c
- mat_lzz_pE.c
- mat_lzz_pTest.c
- mat_poly_lzz_p.c
- mat_poly_ZZ.c
- mat_poly_ZZ_p.c
- mat_RR.c
- mat_ZZ.c
- mat_ZZ_p.c
- mat_ZZ_pE.c
- MatrixTest.c
- MatrixTestIn
- MatrixTestOut
- mfile
- MoreFacTest.c
- MoreFacTestIn
- MulTimeTest.c
- newnames.c
- NOTES
- Poly1TimeTest.c
- Poly2TimeTest.c
- Poly3TimeTest.c
- ppscript
- quad_float.c
- QuadTest.c
- QuadTestIn
- QuadTestOut
- QuickTest.c
- RemoveProg
- ResetFeatures
- RR.c
- RRTest.c
- RRTestIn
- RRTestOut
- subset.c
- TestGetPID.c
- TestGetTime.c
- TestScript
- thread.c
- ThreadTest.c
- Timing.c
- tools.c
- unixify
- vec_GF2.c
- vec_GF2E.c
- vec_lzz_p.c
- vec_lzz_pE.c
- vec_RR.c
- vec_ZZ.c
- vec_ZZ_p.c
- vec_ZZ_pE.c
- VERSION_INFO
- WINDIR
- Wizard
- WizardAux
- WordVector.c
- xdouble.c
- ZZ.c
- ZZ_p.c
- ZZ_pE.c
- ZZ_pEX.c
- ZZ_pEXFactoring.c
- ZZ_pEXTest.c
- ZZ_pX.c
- ZZ_pX1.c
- ZZ_pXCharPoly.c
- ZZ_pXFactoring.c
- ZZVec.c
- ZZX.c
- ZZX1.c
- ZZXCharPoly.c
- ZZXFacTest.c
- ZZXFacTestIn
- ZZXFacTestOut
- ZZXFactoring.c
tools.c @debian/9.9.1-2 — raw · history · blame
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 | #include <NTL/tools.h> #include <cctype> #include <cstdio> #include <NTL/new.h> NTL_START_IMPL NTL_CHEAP_THREAD_LOCAL void (*ErrorCallback)() = 0; NTL_CHEAP_THREAD_LOCAL void (*ErrorMsgCallback)(const char *) = 0; void TerminalError(const char *s) { if (ErrorMsgCallback) (*ErrorMsgCallback)(s); else cerr << s << "\n"; if (ErrorCallback) (*ErrorCallback)(); abort(); } // The following implementation of CharToIntVal is completely portable. long CharToIntVal(long a) { switch (a) { case '0': return 0; case '1': return 1; case '2': return 2; case '3': return 3; case '4': return 4; case '5': return 5; case '6': return 6; case '7': return 7; case '8': return 8; case '9': return 9; case 'A': return 10; case 'B': return 11; case 'C': return 12; case 'D': return 13; case 'E': return 14; case 'F': return 15; case 'a': return 10; case 'b': return 11; case 'c': return 12; case 'd': return 13; case 'e': return 14; case 'f': return 15; default: return -1; } } // The following implementation of IntValToChar is completely portable. char IntValToChar(long a) { switch (a) { case 0: return '0'; case 1: return '1'; case 2: return '2'; case 3: return '3'; case 4: return '4'; case 5: return '5'; case 6: return '6'; case 7: return '7'; case 8: return '8'; case 9: return '9'; case 10: return 'a'; case 11: return 'b'; case 12: return 'c'; case 13: return 'd'; case 14: return 'e'; case 15: return 'f'; default: LogicError("IntValToChar: bad arg"); } return 0; // to supress warnings } long IsWhiteSpace(long a) { if (a > NTL_MAX_INT || a < NTL_MIN_INT) return 0; int b = (int) a; if (isspace(b)) return 1; else return 0; } long SkipWhiteSpace(istream& s) { long c; c = s.peek(); while (IsWhiteSpace(c)) { s.get(); c = s.peek(); } if (c == EOF) return 0; else return 1; } long IsEOFChar(long c) { return c == EOF; } void PrintTime(ostream& s, double t) { long hh, mm, ss; ss = long(t + 0.5); hh = ss/3600; ss = ss - hh*3600; mm = ss/60; ss = ss - mm*60; if (hh > 0) s << hh << ":"; if (hh > 0 || mm > 0) { if (hh > 0 && mm < 10) s << "0"; s << mm << ":"; } if ((hh > 0 || mm > 0) && ss < 10) s << "0"; s << ss; } NTL_END_IMPL |