Canola
0.8.D001
|
00001 // 00002 // canola - canon canola 1614p emulator 00003 // Copyright (C) 2011, 2012 Peter Miller 00004 // 00005 // This program is free software; you can redistribute it and/or modify 00006 // it under the terms of the GNU General Public License, version 3, as 00007 // published by the Free Software Foundation. 00008 // 00009 // This program is distributed in the hope that it will be useful, 00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00012 // General Public License for more details. 00013 // 00014 // You should have received a copy of the GNU General Public License along 00015 // with this program. If not, see <http://www.gnu.org/licenses/>. 00016 // 00017 00018 #include <lib/ac/assert.h> 00019 00020 #include <lib/number.h> 00021 00022 00023 void 00024 number::operator*=(const number &rhs) 00025 { 00026 *this = operator*(rhs); 00027 } 00028 00029 00030 number 00031 number::operator*(const number &rhs) 00032 const 00033 { 00034 bool neg = (negative != rhs.negative); 00035 number_z t1(value); 00036 number_z t2(rhs.value); 00037 number_z t3(t1 * t2); 00038 unsigned t3ndec = decimal + rhs.decimal; 00039 00040 // Instruction Manual, p. 21: 00041 // "If the number of digits in the result exceeds 16, the leftmost 00042 // digit priority system functions and excess digits at the right 00043 // are dropped." 00044 truncate_floating_operation(t3, t3ndec); 00045 assert(t3ndec < 16); 00046 00047 // <question> 00048 // Does multiply strip redundant decimal places to the right of the 00049 // decimal point? 00050 // Does "1.25 [times] 1.22 [+=]" display "1.525" or "1.5250"? 00051 // </question> 00052 #if 1 00053 strip_redundant_decimal_places(t3, t3ndec); 00054 #endif 00055 00056 return number(t3, t3ndec, neg); 00057 } 00058 00059 00060 // vim: set ts=8 sw=4 et :