Blame SOURCES/kcalc-4.9.90-misc.patch

f98ce9
diff -ur kcalc-4.9.90/kcalc_core.cpp kcalc-4.9.90-misc/kcalc_core.cpp
f98ce9
--- kcalc-4.9.90/kcalc_core.cpp	2012-11-14 17:46:47.000000000 +0100
f98ce9
+++ kcalc-4.9.90-misc/kcalc_core.cpp	2012-12-08 20:05:58.000000000 +0100
f98ce9
@@ -99,7 +99,13 @@
f98ce9
 }
f98ce9
 
f98ce9
 KNumber ExecMod(const KNumber &left_op, const KNumber &right_op) {
f98ce9
-    return left_op % right_op;
f98ce9
+    KNumber tmp_result = left_op % right_op;
f98ce9
+
f98ce9
+    if ( right_op < KNumber::Zero )
f98ce9
+       return -(-left_op % -right_op);
f98ce9
+    if ( tmp_result < KNumber::Zero )
f98ce9
+       tmp_result += right_op;
f98ce9
+    return tmp_result;
f98ce9
 }
f98ce9
 
f98ce9
 KNumber ExecIntDiv(const KNumber &left_op, const KNumber &right_op) {
f98ce9
@@ -535,8 +541,11 @@
f98ce9
 
f98ce9
 void CalcEngine::Factorial(const KNumber &input)
f98ce9
 {
f98ce9
-    if (input == KNumber::PosInfinity) return;
f98ce9
-    if (input < KNumber::Zero || input.type() == KNumber::TYPE_ERROR) {
f98ce9
+    if (input == KNumber::PosInfinity || input > KNumber(999999)) {
f98ce9
+       last_number_ = KNumber::PosInfinity;
f98ce9
+       return;
f98ce9
+    }
f98ce9
+    if (input < KNumber::Zero || input.type() != KNumber::TYPE_INTEGER) {
f98ce9
         error_ = true;
f98ce9
         last_number_ = KNumber::NaN;
f98ce9
         return;