diff --git a/bench1.cpp b/bench1.cpp index e0fefc60..3159f54a 100644 --- a/bench1.cpp +++ b/bench1.cpp @@ -70,7 +70,7 @@ void OutputResultBytes(const char *name, double length, double timeTaken) else std::cout << "" << std::setprecision(1) << std::setiosflags(std::ios::fixed) << cpb; } - g_logTotal += ::log(mbs); + g_logTotal += log(mbs); g_logCount++; } @@ -109,7 +109,7 @@ void OutputResultOperations(const char *name, const char *operation, bool pc, un std::cout << "" << std::setprecision(2) << std::setiosflags(std::ios::fixed) << t; } - g_logTotal += ::log(iterations/timeTaken); + g_logTotal += log(iterations/timeTaken); g_logCount++; } diff --git a/nbtheory.cpp b/nbtheory.cpp index feb5802d..de812374 100644 --- a/nbtheory.cpp +++ b/nbtheory.cpp @@ -1021,14 +1021,14 @@ unsigned int FactoringWorkFactor(unsigned int n) // extrapolated from the table in Odlyzko's "The Future of Integer Factorization" // updated to reflect the factoring of RSA-130 if (n<5) return 0; - else return (unsigned int)(2.4 * std::pow((double)n, 1.0/3.0) * std::pow(::log(double(n)), 2.0/3.0) - 5); + else return (unsigned int)(2.4 * std::pow((double)n, 1.0/3.0) * std::pow(log(double(n)), 2.0/3.0) - 5); } unsigned int DiscreteLogWorkFactor(unsigned int n) { // assuming discrete log takes about the same time as factoring if (n<5) return 0; - else return (unsigned int)(2.4 * std::pow((double)n, 1.0/3.0) * std::pow(::log(double(n)), 2.0/3.0) - 5); + else return (unsigned int)(2.4 * std::pow((double)n, 1.0/3.0) * std::pow(log(double(n)), 2.0/3.0) - 5); } // ******************************************************** diff --git a/stdcpp.h b/stdcpp.h index b58b976b..54037e29 100644 --- a/stdcpp.h +++ b/stdcpp.h @@ -62,4 +62,10 @@ namespace std { # include #endif +// C++Builder's standard library (Dinkumware) do not have C's global log() function +// https://github.com/weidai11/cryptopp/issues/520 +#ifdef __BORLANDC__ +using std::log; +#endif + #endif