/adei/trunk

To get this branch, use:
bzr branch http://darksoft.org/webbzr/adei/trunk
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
function adeiMathPreciseSubstract(a, b) {
    var ra, rb;
    var astr = a.toString();
    var bstr = b.toString();

    var pos = astr.indexOf(".");
    if (pos < 0) ra = 0;
    else ra = parseFloat("0." + astr.substr(pos + 1));

    pos = bstr.indexOf(".");
    if (pos < 0) rb = 0;
    else rb = parseFloat("0." + bstr.substr(pos + 1));

    if ((ra)||(rb)) {
	var ia = Math.floor(a);
	var ib = Math.floor(b);

	var r = ra - rb;
	if (r < 0) {
	    var rstr = (r+1).toString();
	    pos = rstr.indexOf('.');
	    return (ia - ib - 1).toString() + rstr.substr(pos);
	} else if (r > 0) {
	    var rstr = r.toString();
	    pos = rstr.indexOf('.');
	    return (ia - ib).toString() + rstr.substr(pos);
	} else return ia - ib;
    } 
    return a - b;	
}

function adeiMathPreciseAdd(a, b) {
    var ra, rb;

    var astr = a.toString();
    var bstr = b.toString();
    
    var pos = astr.indexOf(".");
    if (pos < 0) ra = 0;
    else ra = parseFloat("0." + astr.substr(pos + 1));

    pos = bstr.indexOf(".");
    if (pos < 0) rb = 0;
    else rb = parseFloat("0." + bstr.substr(pos + 1));

    if ((ra)||(rb)) {
	var ia = Math.floor(a);
	var ib = Math.floor(b);

	var r = ra + rb;
	if (r > 1) {
	    var rstr = r.toString();
	    pos = rstr.indexOf('.');
	    return (ia + ib + 1).toString() + rstr.substr(pos);
	} else if (r < 1) {
	    var rstr = r.toString();
	    pos = rstr.indexOf('.');
	    return (ia + ib).toString() + rstr.substr(pos);
	} else return ia + ib + 1;
    } 
    return a + b;	
}