RegressionTests__IntegerTest.st
author Claus Gittinger <cg@exept.de>
Fri, 26 Feb 2016 15:43:33 +0100
changeset 1316 25e2988d4e60
parent 1315 624d2643334a
child 1317 2efc23013a7b
permissions -rw-r--r--
#BUGFIX class: RegressionTests::IntegerTest changed: #testFactorial
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1315
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
     1
"{ Encoding: utf8 }"
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
     2
69
ffbf7492f5e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 59
diff changeset
     3
"{ Package: 'exept:regression' }"
56
77f5ad522f18 category
Claus Gittinger <cg@exept.de>
parents: 54
diff changeset
     4
70
c677f96c4a0b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
     5
"{ NameSpace: RegressionTests }"
c677f96c4a0b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
     6
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
     7
TestCase subclass:#IntegerTest
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
     8
	instanceVariableNames:''
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
     9
	classVariableNames:''
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
    10
	poolDictionaries:''
1069
071262362c9b category
Claus Gittinger <cg@exept.de>
parents: 1039
diff changeset
    11
	category:'tests-Regression-Numbers'
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    15
!IntegerTest methodsFor:'misc'!
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    16
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    17
doMul0_a:arg
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    18
    ^ arg * 0
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    19
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    20
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    21
     (self doMul0_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    22
     (self doMul0_a:1) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    23
     (self doMul0_a:SmallInteger maxVal) == 0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    24
     (self doMul0_a:SmallInteger minVal) == 0
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    25
    "
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    26
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    27
    "Created: / 9.6.1999 / 15:50:48 / cg"
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    28
!
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    29
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    30
doMul1_a:arg
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    31
    ^ arg * 1
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    32
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    33
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    34
     (self doMul1_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    35
     (self doMul1_a:1) ==   1
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    36
     (self doMul1_a:SmallInteger maxVal) == SmallInteger maxVal
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    37
     (self doMul1_a:SmallInteger minVal) == SmallInteger minVal
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    38
    "
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    39
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    40
    "Created: / 9.6.1999 / 15:49:09 / cg"
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    41
!
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    42
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    43
doMul2_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    44
    ^ arg * 2
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    45
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    46
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    47
     (self doMul2_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    48
     (self doMul2_a:1) ==   2
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    49
     (self doMul2_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    50
     (self doMul2_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal)
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    51
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    52
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    53
    "Modified: / 9.6.1999 / 16:57:20 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    54
!
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    55
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    56
doMul3_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    57
    ^ arg * 3
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    58
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    59
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    60
     (self doMul3_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    61
     (self doMul3_a:1) ==   3
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    62
     (self doMul3_a:-1) ==  -3
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    63
     (self doMul3_a:10000) ==   30000
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    64
     (self doMul3_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    65
     (self doMul3_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal + SmallInteger minVal)
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    66
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    67
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    68
    "Created: / 9.6.1999 / 16:57:47 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    69
    "Modified: / 9.6.1999 / 17:35:34 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    70
!
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    71
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    72
doMul4_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    73
    ^ arg * 4
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    74
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    75
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    76
     (self doMul4_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    77
     (self doMul4_a:1) ==   4
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    78
     (self doMul4_a:-1) ==  -4
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    79
     (self doMul4_a:10000) ==   40000
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    80
     (self doMul4_a:SmallInteger maxVal//4) == 4611686018427387900
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    81
     (self doMul4_a:SmallInteger maxVal//4+1) = 4611686018427387904
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    82
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    83
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    84
    "Created: / 9.6.1999 / 16:57:47 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    85
    "Modified: / 9.6.1999 / 17:37:36 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    86
!
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    87
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    88
doMul5_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    89
    ^ arg * 5
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    90
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    91
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    92
     (self doMul5_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    93
     (self doMul5_a:1) ==   5
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    94
     (self doMul5_a:-1) ==  -5
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    95
     (self doMul5_a:10000) ==   50000
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    96
     (self doMul5_a:SmallInteger maxVal//5) == 4611686018427387900
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    97
     (self doMul5_a:SmallInteger maxVal//4+1) = 4611686018427387905
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    98
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    99
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
   100
    "Created: / 9.6.1999 / 17:38:17 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
   101
!
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
   102
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   103
doMulM1_a:arg
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   104
    ^ arg * -1
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   105
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   106
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   107
     (self doMulM1_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   108
     (self doMulM1_a:1) ==   -1
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   109
     (self doMulM1_a:SmallInteger maxVal) == (SmallInteger minVal + 1)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   110
     (self doMulM1_a:SmallInteger minVal) = (SmallInteger maxVal + 1)
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   111
    "
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   112
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
   113
    "Modified: / 9.6.1999 / 16:54:02 / cg"
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   114
!
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   115
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   116
doPlus1_a:arg
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   117
    ^ arg + 1
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   118
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   119
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   120
     (self doPlus1_a:SmallInteger maxVal) =   1073741824
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   121
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   122
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   123
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   124
doPlus1_b:arg
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   125
    ^ arg perform:#+ with:1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   126
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   127
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   128
     (self doPlus1_b:SmallInteger maxVal) ==   1073741824
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   129
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   130
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   131
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   132
testMul0
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   133
    self assert: ( (self doMul0_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   134
    self assert: ( (self doMul0_a:1) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   135
    self assert: ( (self doMul0_a:SmallInteger maxVal) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   136
    self assert: ( (self doMul0_a:SmallInteger minVal) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   137
    self assert: ( (self doMul0_a:SmallInteger maxVal+1) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   138
    self assert: ( (self doMul0_a:SmallInteger minVal-1) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   139
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   140
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   141
     self basicNew testMul0
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   142
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   143
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   144
    "Created: / 9.6.1999 / 15:50:48 / cg"
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   145
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   146
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   147
testMul1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   148
    self assert: ( (self doMul1_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   149
    self assert: ( (self doMul1_a:1) == 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   150
    self assert: ( (self doMul1_a:SmallInteger maxVal) == SmallInteger maxVal ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   151
    self assert: ( (self doMul1_a:SmallInteger minVal) == SmallInteger minVal ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   152
    self assert: ( (self doMul1_a:SmallInteger maxVal+1) = (SmallInteger maxVal+1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   153
    self assert: ( (self doMul1_a:SmallInteger minVal-1) = (SmallInteger minVal-1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   154
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   155
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   156
     self basicNew testMul1
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   157
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   158
!
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   159
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   160
testMul2
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   161
    self assert: ( (self doMul2_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   162
    self assert: ( (self doMul2_a:1) == 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   163
    self assert: ( (self doMul2_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   164
    self assert: ( (self doMul2_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   165
    self assert: ( (self doMul2_a:SmallInteger maxVal+1) = ((SmallInteger maxVal+1)+(SmallInteger maxVal+1)) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   166
    self assert: ( (self doMul2_a:SmallInteger minVal-1) = ((SmallInteger minVal-1)+(SmallInteger minVal-1)) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   167
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   168
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   169
     self basicNew testMul2
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   170
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   171
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   172
    "Modified: / 9.6.1999 / 16:57:20 / cg"
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   173
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   174
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   175
testMul3
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   176
    self assert: ( (self doMul3_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   177
    self assert: ( (self doMul3_a:1) == 3 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   178
    self assert: ( (self doMul3_a:-1) == -3 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   179
    self assert: ( (self doMul3_a:10000) == 30000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   180
    self assert: ( (self doMul3_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   181
    self assert: ( (self doMul3_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal + SmallInteger minVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   182
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   183
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   184
     self basicNew testMul3
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   185
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   186
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   187
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   188
testMul4
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   189
    self assert: ( (self doMul4_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   190
    self assert: ( (self doMul4_a:1) == 4 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   191
    self assert: ( (self doMul4_a:-1) == -4 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   192
    self assert: ( (self doMul4_a:10000) == 40000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   193
    self assert: ( (self doMul4_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   194
    self assert: ( (self doMul4_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal + SmallInteger minVal + SmallInteger minVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   195
    self assert: ( (self doMul4_a:SmallInteger maxVal+1//4) = (SmallInteger maxVal + 1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   196
    self assert: ( (self doMul4_a:SmallInteger minVal//4) = (SmallInteger minVal) ).
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   197
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   198
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   199
     self basicNew testMul4
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   200
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   201
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   202
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   203
testMul5
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   204
    self assert: ( (self doMul5_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   205
    self assert: ( (self doMul5_a:1) == 5 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   206
    self assert: ( (self doMul5_a:-1) == -5 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   207
    self assert: ( (self doMul5_a:10000) == 50000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   208
    self assert: ( (self doMul5_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   209
    self assert: ( (self doMul5_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal + SmallInteger minVal + SmallInteger minVal + SmallInteger minVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   210
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   211
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   212
     self basicNew testMul5
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   213
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   214
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   215
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   216
testMulM1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   217
    self assert: ( (self doMulM1_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   218
    self assert: ( (self doMulM1_a:1) == -1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   219
    self assert: ( (self doMulM1_a:-1) == 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   220
    self assert: ( (self doMulM1_a:10000) == -10000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   221
    self assert: ( (self doMulM1_a:SmallInteger maxVal) = (SmallInteger minVal + 1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   222
    self assert: ( (self doMulM1_a:SmallInteger minVal) = (SmallInteger maxVal + 1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   223
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   224
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   225
     self basicNew testMulM1
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   226
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   227
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   228
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   229
testPlus1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   230
    self assert: ( (self doPlus1_a:0) = 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   231
    self assert: ( (self doPlus1_a:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   232
    self assert: ( (self doPlus1_a:-1) = 0 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   233
    ExternalAddress pointerSize == 8 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   234
	self assert: ( (self doPlus1_a:SmallInteger maxVal) = 4611686018427387904).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   235
	self assert: ( (self doPlus1_a:SmallInteger minVal) = -4611686018427387903 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   236
    ] ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   237
	self assert: ( (self doPlus1_a:SmallInteger maxVal) = 1073741824).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   238
	self assert: ( (self doPlus1_a:SmallInteger minVal) = -1073741823 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   239
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   240
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   241
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   242
     self basicNew testPlus1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   243
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   244
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   245
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   246
testPlus1perform
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   247
    self assert: ( (self doPlus1_b:0) = 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   248
    self assert: ( (self doPlus1_b:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   249
    self assert: ( (self doPlus1_b:-1) = 0 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   250
    ExternalAddress pointerSize == 8 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   251
	self assert: ( (self doPlus1_b:SmallInteger maxVal) = 4611686018427387904).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   252
	self assert: ( (self doPlus1_b:SmallInteger minVal) = -4611686018427387903 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   253
    ] ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   254
	self assert: ( (self doPlus1_b:SmallInteger maxVal) = 1073741824).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   255
	self assert: ( (self doPlus1_b:SmallInteger minVal) = -1073741823 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   256
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   257
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   258
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   259
     self basicNew testPlus1perform
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   260
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   261
! !
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   262
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   263
!IntegerTest methodsFor:'private'!
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   265
absPlusOneOf:arg
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   266
			|local1|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   267
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   268
			local1 := arg.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   269
			^ local1 abs + 1
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   270
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   271
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   272
"
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   273
 self absPlusOneOf:-1
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   274
 self absPlusOneOf:-1.0
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   275
"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   276
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   277
    "Created: / 31.10.2000 / 20:21:52 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   278
!
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   279
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   280
alwaysTrue
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   281
    ^ true.
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   282
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   283
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   284
checkIsInteger:arg
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   285
    ^ arg isInteger
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   286
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   287
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   288
doConstantIntegerShift
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   289
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   290
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   291
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   292
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   293
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   294
    |flags|
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   295
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   296
    flags := self flagsSlot.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   297
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   298
    self alwaysTrue ifFalse:[self halt].
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   299
    ^ flags bitShift:-1.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   300
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   301
    "
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   302
     self testIntegerShifts3
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   303
    "
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   304
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   305
    "Created: / 6.6.1999 / 14:47:51 / cg"
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   306
    "Modified: / 9.6.1999 / 17:49:57 / cg"
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   307
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   308
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   309
flagsSlot
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   310
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   311
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   312
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   313
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   314
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   315
    ^ 2.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   316
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   317
    "
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   318
     self testIntegerShifts3
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   319
    "
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   320
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   321
    "Created: / 6.6.1999 / 14:47:51 / cg"
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   322
    "Modified: / 9.6.1999 / 17:49:57 / cg"
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   323
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   324
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   325
num_00000000000007FFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   326
    ^ 16r00000000000007FFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   327
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   328
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   329
    "Created: / 4.6.1999 / 15:34:12 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   330
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   331
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   332
num_00000000000008000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   333
    ^ 16r00000000000008000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   334
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   335
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   336
    "Created: / 4.6.1999 / 15:39:32 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   337
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   338
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   339
num_0000000000000FFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   340
    ^ 16r0000000000000FFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   341
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   342
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   343
    "Created: / 4.6.1999 / 15:34:26 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   344
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   345
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   346
num_00000000000010000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   347
    ^ 16r00000000000010000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   348
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   349
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   350
    "Created: / 4.6.1999 / 15:34:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   351
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   352
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   353
num_00000000000100000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   354
    ^ 16r00000000000100000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   355
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   356
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   357
    "Created: / 4.6.1999 / 15:34:36 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   358
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   359
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   360
num_000000000007FFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   361
    ^ 16r000000000007FFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   362
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   363
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   364
    "Created: / 4.6.1999 / 15:37:48 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   365
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   366
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   367
num_00000000000800000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   368
    ^ 16r00000000000800000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   369
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   370
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   371
    "Created: / 4.6.1999 / 15:39:43 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   372
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   373
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   374
num_00000000000FFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   375
    ^ 16r00000000000FFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   376
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   377
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   378
    "Created: / 4.6.1999 / 15:37:52 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   379
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   380
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   381
num_00000000001000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   382
    ^ 16r00000000001000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   383
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   384
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   385
    "Created: / 4.6.1999 / 15:34:42 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   386
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   387
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   388
num_0000000000FFF0000
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   389
    ^ 16r0000000000FFF0000
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   390
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   391
    "self num_0000000000FFF0000 hexPrintString"
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   392
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   393
    "Created: / 4.6.1999 / 17:44:26 / cg"
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   394
    "Modified: / 4.6.1999 / 18:40:47 / cg"
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   395
!
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   396
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   397
num_00000000010000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   398
    ^ 16r00000000010000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   399
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   400
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   401
    "Created: / 4.6.1999 / 15:34:46 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   402
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   403
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   404
num_0000000007FFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   405
    ^ 16r0000000007FFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   406
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   407
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   408
    "Created: / 4.6.1999 / 15:37:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   409
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   410
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   411
num_00000000080000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   412
    ^ 16r00000000080000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   413
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   414
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   415
    "Created: / 4.6.1999 / 15:39:56 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   416
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   417
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   418
num_000000000FFFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   419
    ^ 16r000000000FFFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   420
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   421
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   422
    "Created: / 4.6.1999 / 15:36:16 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   423
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   424
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   425
num_00000000100000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   426
    ^ 16r00000000100000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   427
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   428
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   429
    "Created: / 4.6.1999 / 15:34:51 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   430
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   431
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   432
num_00000001000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   433
    ^ 16r00000001000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   434
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   435
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   436
    "Created: / 4.6.1999 / 15:34:57 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   437
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   438
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   439
num_0000000FFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   440
    ^ 16r0000000FFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   441
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   442
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   443
    "Created: / 4.6.1999 / 17:41:08 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   444
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   445
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   446
num_00000010000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   447
    ^ 16r00000010000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   448
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   449
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   450
    "Created: / 4.6.1999 / 15:35:03 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   451
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   452
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   453
num_00000100000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   454
    ^ 16r00000100000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   455
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   456
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   457
    "Created: / 4.6.1999 / 15:35:07 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   458
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   459
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   460
num_00000FFFFFFFFFF00
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   461
    ^ 16r00000FFFFFFFFFF00
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   462
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   463
    "self num_00000FFFFFFFFFF00"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   464
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   465
    "Created: / 4.6.1999 / 17:44:26 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   466
    "Modified: / 4.6.1999 / 17:46:20 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   467
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   468
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   469
num_00000FFFFFFFFFF80
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   470
    ^ 16r00000FFFFFFFFFF80
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   471
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   472
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   473
    "Created: / 4.6.1999 / 17:44:23 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   474
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   475
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   476
num_00000FFFFFFFFFFC0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   477
    ^ 16r00000FFFFFFFFFFC0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   478
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   479
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   480
    "Created: / 4.6.1999 / 17:44:20 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   481
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   482
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   483
num_00000FFFFFFFFFFE0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   484
    ^ 16r00000FFFFFFFFFFE0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   485
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   486
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   487
    "Created: / 4.6.1999 / 17:44:16 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   488
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   489
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   490
num_00000FFFFFFFFFFF0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   491
    ^ 16r00000FFFFFFFFFFF0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   492
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   493
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   494
    "Created: / 4.6.1999 / 17:44:12 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   495
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   496
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   497
num_00000FFFFFFFFFFF8
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   498
    ^ 16r00000FFFFFFFFFFF8
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   499
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   500
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   501
    "Created: / 4.6.1999 / 17:44:09 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   502
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   503
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   504
num_00000FFFFFFFFFFFC
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   505
    ^ 16r00000FFFFFFFFFFFC
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   506
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   507
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   508
    "Created: / 4.6.1999 / 17:44:05 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   509
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   510
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   511
num_00000FFFFFFFFFFFE
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   512
    ^ 16r00000FFFFFFFFFFFE
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   513
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   514
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   515
    "Created: / 4.6.1999 / 17:45:12 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   516
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   517
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   518
num_00000FFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   519
    ^ 16r00000FFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   520
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   521
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   522
    "Created: / 4.6.1999 / 17:41:22 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   523
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   524
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   525
num_00001000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   526
    ^ 16r00001000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   527
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   528
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   529
    "Created: / 4.6.1999 / 15:35:13 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   530
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   531
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   532
num_00010000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   533
    ^ 16r00010000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   534
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   535
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   536
    "Created: / 4.6.1999 / 15:35:18 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   537
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   538
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   539
num_000FFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   540
    ^ 16r000FFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   541
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   542
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   543
    "Created: / 4.6.1999 / 17:41:26 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   544
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   545
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   546
num_00100000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   547
    ^ 16r00100000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   548
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   549
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   550
    "Created: / 4.6.1999 / 15:35:22 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   551
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   552
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   553
num_01000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   554
    ^ 16r01000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   555
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   556
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   557
    "Created: / 4.6.1999 / 15:35:27 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   558
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   559
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   560
num_0FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   561
    ^ 16r0FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   562
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   563
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   564
    "Created: / 4.6.1999 / 17:41:30 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   565
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   566
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   567
num_10000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   568
    ^ 16r10000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   569
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   570
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   571
    "Created: / 4.6.1999 / 15:35:32 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   572
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   573
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   574
num_16r80000000
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   575
    ^ 16r80000000
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   576
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   577
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   578
num_1FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   579
    ^ 16r1FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   580
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   581
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   582
    "Created: / 4.6.1999 / 17:41:51 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   583
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   584
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   585
num_20000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   586
    ^ 16r20000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   587
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   588
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   589
    "Created: / 4.6.1999 / 17:40:26 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   590
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   591
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   592
num_3FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   593
    ^ 16r3FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   594
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   595
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   596
    "Created: / 4.6.1999 / 17:42:07 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   597
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   598
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   599
num_40000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   600
    ^ 16r40000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   601
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   602
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   603
    "Created: / 4.6.1999 / 17:40:29 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   604
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   605
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   606
num_7FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   607
    ^ 16r7FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   608
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   609
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   610
    "Created: / 4.6.1999 / 17:42:24 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   611
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   612
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   613
num_80000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   614
    ^ 16r80000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   615
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   616
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   617
    "Created: / 4.6.1999 / 17:40:33 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   618
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   619
20
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   620
num_smallInt_maxVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   621
    ^ SmallInteger maxVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   622
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   623
    "self num_smallInt_maxVal"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   624
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   625
    "Modified: / 4.6.1999 / 17:33:22 / cg"
20
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   626
!
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   627
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   628
num_smallInt_minVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   629
    ^ SmallInteger minVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   630
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   631
    "self num_smallInt_minVal"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   632
20
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   633
    "Created: / 4.6.1999 / 16:26:05 / cg"
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   634
    "Modified: / 4.6.1999 / 17:34:31 / cg"
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   635
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   636
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   637
!IntegerTest methodsFor:'tests'!
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   638
362
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   639
doCompare:a againstEqual:b
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   640
    self assert:(a < b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   641
    self assert:(a <= b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   642
    self assert:(a = b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   643
    self assert:(a ~= b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   644
    self assert:(a > b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   645
    self assert:(a >= b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   646
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   647
    self assert:(a perform:#<   with:b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   648
    self assert:(a perform:#<=  with:b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   649
    self assert:(a perform:#=   with:b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   650
    self assert:(a perform:#~=  with:b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   651
    self assert:(a perform:#>   with:b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   652
    self assert:(a perform:#>=  with:b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   653
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   654
    "
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   655
     self basicNew doCompare:12 againstEqual:12
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   656
    "
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   657
!
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   658
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   659
doCompare:a againstGreater:b
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   660
    self assert:(a < b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   661
    self assert:(a <= b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   662
    self assert:(a = b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   663
    self assert:(a ~= b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   664
    self assert:(a == b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   665
    self assert:(a ~~ b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   666
    self assert:(a > b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   667
    self assert:(a >= b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   668
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   669
    self assert:(a perform:#<   with:b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   670
    self assert:(a perform:#<=  with:b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   671
    self assert:(a perform:#=   with:b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   672
    self assert:(a perform:#~=  with:b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   673
    self assert:(a perform:#==  with:b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   674
    self assert:(a perform:#~~  with:b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   675
    self assert:(a perform:#>   with:b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   676
    self assert:(a perform:#>=  with:b) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   677
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   678
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   679
     self basicNew doCompare:12 againstGreater:16r80000000
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   680
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   681
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   682
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   683
doTestAll
10
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   684
    "general conversion & arithmetic tests.
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   685
     Notice, the arithmetic tests are both performed via regular sends
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   686
     and via constructed performs. The reason is to test both inlined
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   687
     JIT-compiler code AND the regular methods code."
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   688
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
   689
    self testInteger1.
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   690
    self testILC.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
   691
    self testSmallIntegerArithmetic.
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   692
    self testLiteralNumbers.
15
99df9ea7f146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 14
diff changeset
   693
    self testLargeAddition.
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   694
    self testLargeMultiplication.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   695
    self testLargeDivision.
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
   696
    self testLargeBitOperations.
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
   697
    self testIntegerShifts.
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
   698
    self testEncodeDecode.
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
   699
    self testIntegerMisc.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   700
    self testInline1
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   701
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   702
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   703
     self basicNew doTestAll
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   704
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   705
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   706
    "Modified: / 31.10.2000 / 20:23:20 / cg"
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   707
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   708
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   709
testBinco
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   710
     self assert: (10 binomialCoefficient:5) = (10 factorial / (5 factorial * 5 factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   711
     self assert: (100 binomialCoefficient:78) = (100 factorial / (78 factorial * (100-78) factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   712
     self assert: (1000 binomialCoefficient:5) = (1000 factorial / (5 factorial * (1000-5) factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   713
     self assert: (10000 binomialCoefficient:78) = (10000 factorial / (78 factorial * (10000-78) factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   714
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   715
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   716
     self basicNew testBinco
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   717
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   718
!
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   719
1039
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   720
testByteSwap
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   721
    "/ <testedMethods: #( (Integer >> #byteSwapped32) (Integer >> #byteSwapped64)) >
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   722
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   723
    self assert:(16r1122 byteSwapped16) = 16r2211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   724
    self assert:(16r2211 byteSwapped16) = 16r1122.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   725
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   726
    self assert:(16r11223344 byteSwapped32) = 16r44332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   727
    self assert:(16r44332211 byteSwapped32) = 16r11223344.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   728
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   729
    self assert:(16r11223344 byteSwapped64) = 16r4433221100000000.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   730
    self assert:(16r44332211 byteSwapped64) = 16r1122334400000000.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   731
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   732
    self assert:(16r8877665544332211 byteSwapped64) = 16r1122334455667788.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   733
    self assert:(16r1122334455667788 byteSwapped64) = 16r8877665544332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   734
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   735
    "/ higher bits are ignored!!
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   736
    self assert:(16r33441122 byteSwapped16) = 16r2211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   737
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   738
    self assert:(16r9911223344 byteSwapped32) = 16r44332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   739
    self assert:(16r8877665544332211 byteSwapped32) = 16r11223344.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   740
    self assert:(16r998877665544332211 byteSwapped64) = 16r1122334455667788.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   741
    self assert:(16r991122334455667788 byteSwapped64) = 16r8877665544332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   742
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   743
    "
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   744
     self basicNew testByteSwap
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   745
    "
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   746
!
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   747
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   748
testComparing
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   749
    |a b|
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   750
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   751
    a := 12.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   752
    b := 16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   753
    self doCompare:a againstGreater:b.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   754
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   755
    a := 12.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   756
    b := 16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   757
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   758
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   759
    a := 0.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   760
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   761
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   762
    a := -1.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   763
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   764
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   765
    a := 16r-80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   766
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   767
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   768
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   769
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   770
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   771
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   772
    self doCompare:a againstGreater:16r40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   773
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   774
    a := 16r-3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   775
    self doCompare:a againstGreater:16r3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   776
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   777
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   778
    self doCompare:a againstGreater:16r3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   779
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   780
    a := 16r-3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   781
    self doCompare:a againstGreater:16r40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   782
362
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   783
    "/ smallint-largeInt boundaries
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   784
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   785
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   786
    self doCompare:a againstEqual:16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   787
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   788
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   789
    self doCompare:a againstGreater:16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   790
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   791
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   792
    self doCompare:a againstGreater:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   793
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   794
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   795
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   796
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   797
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   798
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   799
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   800
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   801
    self doCompare:a againstEqual:16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   802
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   803
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   804
    self doCompare:a againstGreater:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   805
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   806
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   807
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   808
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   809
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   810
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   811
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   812
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   813
    self doCompare:a againstEqual:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   814
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   815
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   816
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   817
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   818
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   819
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   820
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   821
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   822
    self doCompare:a againstEqual:16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   823
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   824
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   825
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   826
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   827
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   828
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   829
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   830
    a := 16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   831
    self doCompare:a againstEqual:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   832
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   833
    a := 16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   834
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   835
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   836
    a := 16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   837
    self doCompare:a againstEqual:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   838
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   839
    a := 16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   840
    self doCompare:a againstGreater:16r100000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   841
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   842
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   843
     self basicNew testComparing
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   844
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   845
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   846
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   847
testConstants
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   848
    |t|
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   849
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   850
    self assert:((t := self num_16r80000000) > 0).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   851
    self assert:((t := self num_16r80000000) = 16r80000000).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   852
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   853
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   854
     self basicNew testConstants
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   855
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   856
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   857
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
   858
testDivision1
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   859
    |a b op rslt|
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   860
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   861
    "/ 10 divMod:3       -> #(3 1)   because 3*3 + 1 = 10
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   862
    "/ 10 divMod:-3      -> #(-4 -2) because -4*-3 + (-2) = 10
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   863
    "/ -10 divMod:3      -> #(-4 2)  because -4*3 + 3 = -10   
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   864
    "/ -10 divMod:-3     -> #(3 -1)  because -3*3 + (-1) = -10
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   865
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   866
    #(
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   867
        ((10 3)      // 3            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   868
        ((10 -3)     // -4           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   869
        ((-10 3)     // -4           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   870
        ((-10 -3)    // 3            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   871
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   872
        ((10 3)      \\ 1            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   873
        ((10 -3)     \\ -2           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   874
        ((-10 3)     \\ 2            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   875
        ((-10 -3)    \\ -1           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   876
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   877
        ((10 3)      divMod: (3 1)   )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   878
        ((10 -3)     divMod: (-4 -2) )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   879
        ((-10 3)     divMod: (-4 2)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   880
        ((-10 -3)    divMod: (3 -1)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   881
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   882
        ((100000000000000000000 3)      // 33333333333333333333            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   883
        ((100000000000000000000 -3)     // -33333333333333333334           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   884
        ((-100000000000000000000 3)     // -33333333333333333334           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   885
        ((-100000000000000000000 -3)    // 33333333333333333333            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   886
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   887
        ((100000000000000000000 3)      \\ 1            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   888
        ((100000000000000000000 -3)     \\ -2           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   889
        ((-100000000000000000000 3)     \\ 2            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   890
        ((-100000000000000000000 -3)    \\ -1           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   891
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   892
        ((100000000000000000000 3)      divMod: (33333333333333333333 1)   )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   893
        ((100000000000000000000 -3)     divMod: (-33333333333333333334 -2) )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   894
        ((-100000000000000000000 3)     divMod: (-33333333333333333334 2)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   895
        ((-100000000000000000000 -3)    divMod: (33333333333333333333 -1)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   896
    ) do:[:each |
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   897
        |inValues rcvr arg op expectedRslt gotRslt|
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   898
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   899
        inValues := each first.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   900
        op := each second.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   901
        expectedRslt := each third.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   902
        rcvr := inValues first.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   903
        arg := inValues second.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   904
        gotRslt := rcvr perform:op with:arg.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   905
        self 
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   906
            assert:(gotRslt = expectedRslt) 
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   907
            description:('%1 %2 %3 - expected:%4 got:%5' 
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   908
                            bindWith:rcvr with:op with:arg
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   909
                            with:expectedRslt with:gotRslt).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   910
    ].
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   911
        
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   912
    op := #//.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   913
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   914
    b := 8.
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   915
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   916
    "/ to check for both compiler-constant folded and actually computed
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   917
    "/ values, these checks are done also with #perform.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   918
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   919
    self assert:(-1 // 8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   920
    self assert:(a // 8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   921
    self assert:(-1 // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   922
    self assert:(a // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   923
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   924
    self assert:((rslt := -1 perform:op with: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   925
    self assert:((rslt := a perform:op with: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   926
    self assert:((rslt := -1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   927
    self assert:((rslt := a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   928
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   929
    self assert:((rslt := -1 perform:#// with: 8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   930
    self assert:((rslt := a perform:#// with: 8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   931
    self assert:((rslt := -1 perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   932
    self assert:((rslt := a perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   933
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   934
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   935
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   936
    self assert:(1 // -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   937
    self assert:(a // -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   938
    self assert:(1 // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   939
    self assert:(a // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   940
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   941
    self assert:((rslt := 1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   942
    self assert:((rslt := a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   943
    self assert:((rslt := 1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   944
    self assert:((rslt := a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   945
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   946
    self assert:((rslt := 1 perform:#// with: -8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   947
    self assert:((rslt := a perform:#// with: -8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   948
    self assert:((rslt := 1 perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   949
    self assert:((rslt := a perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   950
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   951
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   952
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   953
    self assert:(-1 // -8 == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   954
    self assert:(a // -8 == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   955
    self assert:(-1 // b == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   956
    self assert:(a // b == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   957
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   958
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   959
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   960
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   961
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   962
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   963
    self assert:((rslt := -1 perform:#// with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   964
    self assert:((rslt := a perform:#// with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   965
    self assert:((rslt := -1 perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   966
    self assert:((rslt := a perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   967
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   968
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   969
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   970
    self assert:(1 // 8 == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   971
    self assert:(a // 8 == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   972
    self assert:(1 // b == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   973
    self assert:(a // b == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   974
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   975
    self assert:((rslt := 1 perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   976
    self assert:((rslt := a perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   977
    self assert:((rslt := 1 perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   978
    self assert:((rslt := a perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   979
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   980
    self assert:((rslt := 1 perform:#// with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   981
    self assert:((rslt := a perform:#// with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   982
    self assert:((rslt := 1 perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   983
    self assert:((rslt := a perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   984
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   985
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   986
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   987
    self assert:(-16 // 8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   988
    self assert:(a // 8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   989
    self assert:(-16 // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   990
    self assert:(a // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   991
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   992
    self assert:((rslt := -16 perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   993
    self assert:((rslt := a perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   994
    self assert:((rslt := -16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   995
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   996
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   997
    self assert:((rslt := -16 perform:#// with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   998
    self assert:((rslt := a perform:#// with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   999
    self assert:((rslt := -16 perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1000
    self assert:((rslt := a perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1001
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1002
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1003
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1004
    self assert:(16 // -8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1005
    self assert:(a // -8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1006
    self assert:(16 // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1007
    self assert:(a // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1008
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1009
    self assert:((rslt := 16 perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1010
    self assert:((rslt := a perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1011
    self assert:((rslt := 16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1012
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1013
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1014
    self assert:((rslt := 16 perform:#// with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1015
    self assert:((rslt := a perform:#// with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1016
    self assert:((rslt := 16 perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1017
    self assert:((rslt := a perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1018
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1019
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1020
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1021
    self assert:(-16 // -8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1022
    self assert:(a // -8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1023
    self assert:(-16 // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1024
    self assert:(a // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1025
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1026
    self assert:((rslt := -16 perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1027
    self assert:((rslt := a perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1028
    self assert:((rslt := -16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1029
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1030
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1031
    self assert:((rslt := -16 perform:#// with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1032
    self assert:((rslt := a perform:#// with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1033
    self assert:((rslt := -16 perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1034
    self assert:((rslt := a perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1035
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1036
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1037
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1038
    self assert:(16 // 8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1039
    self assert:(a // 8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1040
    self assert:(16 // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1041
    self assert:(a // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1042
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1043
    self assert:((rslt := 16 perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1044
    self assert:((rslt := a perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1045
    self assert:((rslt := 16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1046
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1047
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1048
    self assert:((rslt := 16 perform:#// with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1049
    self assert:((rslt := a perform:#// with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1050
    self assert:((rslt := 16 perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1051
    self assert:((rslt := a perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1052
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1053
    op := #quo:.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1054
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1055
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1056
    self assert:((rslt := -1 quo: 8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1057
    self assert:((rslt := a quo: 8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1058
    self assert:((rslt := -1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1059
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1060
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1061
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1062
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1063
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1064
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1065
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1066
    self assert:((rslt := -1 perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1067
    self assert:((rslt := a perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1068
    self assert:((rslt := -1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1069
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1070
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1071
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1072
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1073
    self assert:((rslt := 1 quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1074
    self assert:((rslt := a quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1075
    self assert:((rslt := 1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1076
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1077
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1078
    self assert:((rslt := 1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1079
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1080
    self assert:((rslt := 1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1081
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1082
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1083
    self assert:((rslt := 1 perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1084
    self assert:((rslt := a perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1085
    self assert:((rslt := 1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1086
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1087
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1088
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1089
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1090
    self assert:((rslt := -1 quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1091
    self assert:((rslt := a quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1092
    self assert:((rslt := -1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1093
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1094
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1095
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1096
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1097
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1098
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1099
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1100
    self assert:((rslt := -1 perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1101
    self assert:((rslt := a perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1102
    self assert:((rslt := -1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1103
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1104
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1105
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1106
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1107
    self assert:((rslt := 1 quo: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1108
    self assert:((rslt := a quo: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1109
    self assert:((rslt := 1 quo: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1110
    self assert:((rslt := a quo: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1111
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1112
    self assert:((rslt := 1 perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1113
    self assert:((rslt := a perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1114
    self assert:((rslt := 1 perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1115
    self assert:((rslt := a perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1116
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1117
    self assert:((rslt := 1 perform:#quo: with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1118
    self assert:((rslt := a perform:#quo: with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1119
    self assert:((rslt := 1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1120
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1121
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1122
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1123
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1124
    self assert:((rslt := -16 quo: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1125
    self assert:((rslt := a quo: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1126
    self assert:((rslt := -16 quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1127
    self assert:((rslt := a quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1128
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1129
    self assert:((rslt := -16 perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1130
    self assert:((rslt := a perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1131
    self assert:((rslt := -16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1132
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1133
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1134
    self assert:((rslt := -16 perform:#quo: with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1135
    self assert:((rslt := a perform:#quo: with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1136
    self assert:((rslt := -16 perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1137
    self assert:((rslt := a perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1138
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1139
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1140
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1141
    self assert:((rslt := 16 quo: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1142
    self assert:((rslt := a quo: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1143
    self assert:((rslt := 16 quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1144
    self assert:((rslt := a quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1145
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1146
    self assert:((rslt := 16 perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1147
    self assert:((rslt := a perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1148
    self assert:((rslt := 16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1149
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1150
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1151
    self assert:((rslt := 16 perform:#quo: with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1152
    self assert:((rslt := a perform:#quo: with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1153
    self assert:((rslt := 16 perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1154
    self assert:((rslt := a perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1155
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1156
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1157
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1158
    self assert:((rslt := -16 quo: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1159
    self assert:((rslt := a quo: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1160
    self assert:((rslt := -16 quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1161
    self assert:((rslt := a quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1162
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1163
    self assert:((rslt := -16 perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1164
    self assert:((rslt := a perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1165
    self assert:((rslt := -16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1166
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1167
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1168
    self assert:((rslt := -16 perform:#quo: with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1169
    self assert:((rslt := a perform:#quo: with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1170
    self assert:((rslt := -16 perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1171
    self assert:((rslt := a perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1172
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1173
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1174
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1175
    self assert:((rslt := 16 quo: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1176
    self assert:((rslt := a quo: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1177
    self assert:((rslt := 16 quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1178
    self assert:((rslt := a quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1179
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1180
    self assert:((rslt := 16 perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1181
    self assert:((rslt := a perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1182
    self assert:((rslt := 16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1183
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1184
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1185
    self assert:((rslt := 16 perform:#quo: with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1186
    self assert:((rslt := a perform:#quo: with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1187
    self assert:((rslt := 16 perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1188
    self assert:((rslt := a perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1189
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1190
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1191
     self basicNew testDivision
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1192
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1193
!
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1194
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1195
testDivision2
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1196
    |nr|
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1197
    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1198
    2 to:17 do:[:m |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1199
        nr := 1.
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1200
        1 to:1000 do:[:n |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1201
            nr := nr * m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1202
        ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1203
        1 to:1000 do:[:n |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1204
            nr := nr / m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1205
        ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1206
        self assert:(nr == 1).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1207
    ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1208
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1209
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1210
     self new testDivision2
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1211
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1212
!
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1213
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1214
testDivision3
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1215
    |nr|
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1216
    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1217
    #( 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1218
        16r00000000000000003F 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1219
        16r000000000000003FFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1220
        16r0000000000003FFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1221
        16r00000000003FFFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1222
        16r000000003FFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1223
        16r0000003FFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1224
        16r00003FFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1225
        16r003FFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1226
        16r3FFFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1227
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1228
        16r000000000000000040 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1229
        16r0000000000000040FF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1230
        16r00000000000040FFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1231
        16r000000000040FFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1232
        16r0000000040FFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1233
        16r00000040FFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1234
        16r000040FFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1235
        16r0040FFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1236
        16r40FFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1237
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1238
        16r00000000000000007F 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1239
        16r000000000000007FFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1240
        16r0000000000007FFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1241
        16r00000000007FFFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1242
        16r000000007FFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1243
        16r0000007FFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1244
        16r00007FFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1245
        16r007FFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1246
        16r7FFFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1247
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1248
        16r0000000000000000FF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1249
        16r00000000000000FFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1250
        16r000000000000FFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1251
        16r0000000000FFFFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1252
        16r00000000FFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1253
        16r000000FFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1254
        16r0000FFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1255
        16r00FFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1256
        16rFFFFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1257
    ) do:[:m |
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1258
        Transcript showCR:m.
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1259
        nr := 1.
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1260
        1 to:100 do:[:n |
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1261
            nr := nr * m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1262
        ].
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1263
        1 to:100 do:[:n |
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1264
            nr := nr / m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1265
        ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1266
        self assert:(nr == 1).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1267
    ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1268
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1269
    "
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1270
     self new testDivision3
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1271
     Time millisecondsToRun:[ self new testDivision3 ] 14440
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1272
     MessageTally spyOn:[ self new testDivision3 ] 
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1273
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1274
!
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1275
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1276
testEncodeDecode
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1277
    self assert:(1 encodeAsBCD hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1278
    self assert:(12 encodeAsBCD hexPrintString = '12').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1279
    self assert:(123 encodeAsBCD hexPrintString = '123').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1280
    self assert:(1234 encodeAsBCD hexPrintString = '1234').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1281
    self assert:(12345 encodeAsBCD hexPrintString = '12345').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1282
    self assert:(123456 encodeAsBCD hexPrintString = '123456').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1283
    self assert:(1234567 encodeAsBCD hexPrintString = '1234567').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1284
    self assert:(12345678 encodeAsBCD hexPrintString = '12345678').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1285
    self assert:(123456789 encodeAsBCD hexPrintString = '123456789').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1286
    self assert:(1234567890 encodeAsBCD hexPrintString = '1234567890').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1287
    self assert:(12345678901 encodeAsBCD hexPrintString = '12345678901').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1288
    self assert:(123456789012 encodeAsBCD hexPrintString = '123456789012').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1289
    self assert:(1234567890123 encodeAsBCD hexPrintString = '1234567890123').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1290
    self assert:(12345678901234 encodeAsBCD hexPrintString = '12345678901234').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1291
    self assert:(123456789012345 encodeAsBCD hexPrintString = '123456789012345').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1292
    self assert:(1234567890123456 encodeAsBCD hexPrintString = '1234567890123456').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1293
    self assert:(12345678901234567 encodeAsBCD hexPrintString = '12345678901234567').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1294
    self assert:(123456789012345678 encodeAsBCD hexPrintString = '123456789012345678').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1295
    self assert:(1234567890123456789 encodeAsBCD hexPrintString = '1234567890123456789').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1296
    self assert:(12345678901234567890 encodeAsBCD hexPrintString = '12345678901234567890').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1297
    self assert:(4611686018427387902 encodeAsBCD hexPrintString = '4611686018427387902').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1298
    self assert:(4611686018427387903 encodeAsBCD hexPrintString = '4611686018427387903').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1299
    self assert:(4611686018427387904 encodeAsBCD hexPrintString = '4611686018427387904').
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1300
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1301
    self assert:(16r1 decodeFromBCD = 1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1302
    self assert:(16r12 decodeFromBCD = 12).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1303
    self assert:(16r123 decodeFromBCD = 123).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1304
    self assert:(16r1234 decodeFromBCD = 1234).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1305
    self assert:(16r12345 decodeFromBCD = 12345).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1306
    self assert:(16r123456 decodeFromBCD = 123456).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1307
    self assert:(16r1234567 decodeFromBCD = 1234567).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1308
    self assert:(16r12345678 decodeFromBCD = 12345678).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1309
    self assert:(16r123456789 decodeFromBCD = 123456789).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1310
    self assert:(16r1234567890 decodeFromBCD = 1234567890).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1311
    self assert:(16r12345678901 decodeFromBCD = 12345678901).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1312
    self assert:(16r123456789012 decodeFromBCD = 123456789012).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1313
    self assert:(16r1000000000000 decodeFromBCD = 1000000000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1314
    self assert:(16r0000500000000 decodeFromBCD = 500000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1315
    self assert:(16r1234500000000 decodeFromBCD = 1234500000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1316
    self assert:(16r1234567890000 decodeFromBCD = 1234567890000).
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1317
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1318
    self assert:(16r1234567890123 decodeFromBCD = 1234567890123).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1319
    self assert:(16r12345678901234 decodeFromBCD = 12345678901234).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1320
    self assert:(16r123456789012345 decodeFromBCD = 123456789012345).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1321
    self assert:(16r1234567890123456 decodeFromBCD = 1234567890123456).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1322
    self assert:(16r12345678901234567 decodeFromBCD = 12345678901234567).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1323
    self assert:(16r123456789012345678 decodeFromBCD = 123456789012345678).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1324
    self assert:(16r1234567890123456789 decodeFromBCD = 1234567890123456789).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1325
    self assert:(16r12345678901234567890 decodeFromBCD = 12345678901234567890).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1326
    self assert:(16r4611686018427387902 decodeFromBCD = 4611686018427387902).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1327
    self assert:(16r4611686018427387903 decodeFromBCD = 4611686018427387903).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1328
    self assert:(16r4611686018427387904 decodeFromBCD = 4611686018427387904).
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1329
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1330
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1331
     self basicNew testEncodeDecode
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1332
    "
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1333
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1334
    "Modified: / 26.10.1999 / 22:01:35 / stefan"
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1335
!
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1336
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1337
testFactorial
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1338
    "/ <testedMethods: #( (Integer >> #factorial) (Integer >> #*) ) >
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1339
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1340
    self assert:(1 factorial = 1).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1341
    self assert:(2 factorial = 2).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1342
    self assert:(10 factorial = 3628800).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1343
    self assert:(11 factorial = 39916800).
1316
25e2988d4e60 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1315
diff changeset
  1344
    self assert:(20 factorial = 2432902008176640000).
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1345
    self assert:(50 factorial = 30414093201713378043612608166064768844377641568960512000000000000).
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1346
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1347
    "
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1348
     self basicNew testFactorial
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1349
    "
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1350
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1351
    "Created: / 24-04-2010 / 13:52:23 / cg"
1316
25e2988d4e60 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1315
diff changeset
  1352
    "Modified: / 26-02-2016 / 15:43:16 / cg"
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1353
!
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1354
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1355
testGCD
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1356
    "/ <testedMethods: #( (Integer >> #gcd:) ) >
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1357
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1358
    self assert:(9 gcd:6) = 3.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1359
    self assert:(6 gcd:9) = 3.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1360
    self assert:(2 gcd:0) = 2.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1361
    self assert:(0 gcd:2) = 2.
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1362
    self assert:(20 factorial gcd:(5*6*7)) = (5*6*7).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1363
    self assert:(20 factorial gcd:(20 factorial / 20)) = (19 factorial).
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1364
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1365
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1366
     self basicNew testGCD
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1367
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1368
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1369
    "Created: / 27-04-2010 / 09:49:31 / cg"
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1370
!
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1371
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1372
testILC
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1373
    "inline-cache"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1374
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1375
    self assert:((self checkIsInteger:1) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1376
    self assert:((self checkIsInteger:nil) == false).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1377
    self assert:((self checkIsInteger:1) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1378
    self assert:((self checkIsInteger:nil) == false).
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1379
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1380
    self assert:((self checkIsInteger:0) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1381
    self assert:((self checkIsInteger:nil) == false).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1382
    self assert:((self checkIsInteger:0) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1383
    self assert:((self checkIsInteger:nil) == false).
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1384
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1385
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1386
     self basicNew testILC
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1387
    "
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1388
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1389
    "Created: / 6.6.1999 / 14:47:51 / cg"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1390
    "Modified: / 9.6.1999 / 17:49:57 / cg"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1391
!
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1392
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1393
testInline1
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1394
    "inlined tests.
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1395
     Notice, the arithmetic tests are both performed via regular sends
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1396
     and via constructed performs. The reason is to test both inlined
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1397
     JIT-compiler code AND the regular methods code."
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1398
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1399
    self assert:( (self absPlusOneOf:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1400
    self assert:( (self absPlusOneOf:-1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1401
    self assert:( (self absPlusOneOf:1.0) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1402
    self assert:( (self absPlusOneOf:-1.0) = 2 ).
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1403
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1404
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1405
     self basicNew testInline1
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1406
    "
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1407
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1408
    "Created: / 31.10.2000 / 20:22:48 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1409
    "Modified: / 31.10.2000 / 20:23:06 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1410
!
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1411
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1412
testInteger1
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1413
    "general conversion & arithmetic tests.
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1414
     Notice, the arithmetic tests are both performed via regular sends
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1415
     and via constructed performs. The reason is to test both inlined
935
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1416
     JIT-compiler code AND the regular method's code."
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1417
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1418
    |minVal maxVal maxValPlus1 minValMinus1 halfMin halfMax t|
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1419
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1420
    minVal := SmallInteger perform:('minVal' asSymbol).
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1421
    maxVal := SmallInteger perform:('maxVal' asSymbol).
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1422
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1423
    self assert:(minVal == self num_smallInt_minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1424
    self assert:(maxVal == self num_smallInt_maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1425
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1426
    self assert:(minVal == SmallInteger minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1427
    self assert:(maxVal == SmallInteger maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1428
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1429
    t := SmallInteger perform:('maxBytes' asSymbol).
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1430
    self assert:(t == SmallInteger maxBytes).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1431
    t := SmallInteger perform:('maxBits' asSymbol).
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1432
    self assert:(t == SmallInteger maxBits).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1433
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1434
    self testPrinting1.
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1435
935
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1436
    self assert:(SmallInteger maxBytes == ExternalAddress pointerSize).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1437
    "/ again, preventing inlining by compiler
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1438
    self assert:(SmallInteger perform:#maxBytes) == (ExternalAddress perform:#pointerSize).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1439
    self assert:(SmallInteger perform:'maxBytes' asSymbol) == (ExternalAddress perform:'pointerSize' asSymbol).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1440
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1441
    SmallInteger maxBytes == 4 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1442
	self assert:(minVal hexPrintString = '-40000000').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1443
	self assert:(maxVal hexPrintString = '3FFFFFFF').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1444
	self assert:(minVal == -1073741824).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1445
	self assert:(maxVal == 1073741823).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1446
	maxValPlus1 := 1073741824.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1447
	minValMinus1 := -1073741825.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1448
	self assert:(minValMinus1 hexPrintString = '-40000001').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1449
	self assert:(maxValPlus1 hexPrintString = '40000000').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1450
	halfMin := -16r20000000.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1451
	halfMax := 16r20000000.
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1452
    ].
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1453
    SmallInteger maxBytes == 8 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1454
	self assert:(minVal hexPrintString = '-4000000000000000').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1455
	self assert:(maxVal hexPrintString = '3FFFFFFFFFFFFFFF').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1456
	self assert:(minVal == -4611686018427387904).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1457
	self assert:(maxVal == 4611686018427387903).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1458
	maxValPlus1 := 4611686018427387904.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1459
	minValMinus1 := -4611686018427387905.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1460
	self assert:(minValMinus1 hexPrintString = '-4000000000000001').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1461
	self assert:(maxValPlus1 hexPrintString = '4000000000000000').
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1462
	halfMin := -16r2000000000000000.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1463
	halfMax := 16r2000000000000000.
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1464
    ].
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1465
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1466
    "arithmetic overFlow checks"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1467
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1468
"/    self assert:((maxVal + 1) inspect.maxValPlus1 inspect. true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1469
    self assert:((maxVal perform:'+' asSymbol with:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1470
    self assert:((maxVal + 1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1471
    self assert:((minVal perform:'-' asSymbol with:1) = minValMinus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1472
    self assert:((minVal - 1) = minValMinus1).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1473
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1474
    self assert:((halfMax perform:'+' asSymbol with:halfMax) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1475
    self assert:((halfMax + halfMax) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1476
    self assert:((halfMin perform:'+' asSymbol with:halfMin) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1477
    self assert:((halfMin + halfMin) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1478
    self assert:((halfMax perform:'*' asSymbol with:2) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1479
    self assert:((halfMax * 2) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1480
    self assert:((halfMin perform:'*' asSymbol with:2) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1481
    self assert:((halfMin * 2) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1482
    self assert:((maxValPlus1 perform:'//' asSymbol with:2) == halfMax).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1483
    self assert:((maxValPlus1 // 2) == halfMax).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1484
    self assert:((halfMax perform:'bitShift:' asSymbol with:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1485
    self assert:((halfMin perform:'bitShift:' asSymbol with:1) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1486
    self assert:((halfMax bitShift:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1487
    self assert:((halfMin bitShift:1) == minVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1488
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1489
    "LargeInt op -> SmallInt result"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1490
    t := maxVal + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1491
    self assert:(t - 1 == maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1492
    t := minVal - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1493
    self assert:(t + 1 == minVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1494
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1495
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1496
     self basicNew testInteger1
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1497
    "
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1498
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1499
    "Modified: / 6.6.1999 / 14:46:11 / cg"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1500
!
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1501
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1502
testIntegerMisc
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1503
    "misc tests.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1504
     Notice, the arithmetic tests are both performed via regular sends
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1505
     and via constructed performs. The reason is to test both inlined
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1506
     JIT-compiler code AND the regular methods code."
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1507
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1508
    |n1 n2 s|
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1509
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1510
    n1 := 100000.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1511
    n2 := n1 negated.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1512
    s := 1.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1513
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1514
    self assert:(n1 printString = '100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1515
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1516
    self assert:(n1 negated printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1517
    self assert:((n1 perform:'negated' asSymbol) printString = '-100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1518
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1519
    self assert:(n1 negated abs printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1520
    self assert:((n1 perform:'negated' asSymbol) abs printString = '100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1521
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1522
    self assert:(n1 abs negated printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1523
    self assert:((n1 perform:'abs' asSymbol) negated printString = '-100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1524
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1525
    n1 := SmallInteger maxVal.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1526
    self assert:(n1 negated class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1527
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1528
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1529
    n1 := SmallInteger minVal.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1530
    self assert:(n1 negated class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1531
    self assert:((n1 perform:'negated' asSymbol) class == LargeInteger).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1532
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1533
    n1 := SmallInteger minVal negated - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1534
    self assert:(n1 negated class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1535
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1536
    self assert:(n1 == SmallInteger maxVal).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1537
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1538
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1539
     self basicNew testIntegerMisc
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1540
    "
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1541
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1542
    "Created: / 6.6.1999 / 14:47:51 / cg"
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1543
    "Modified: / 9.6.1999 / 17:49:57 / cg"
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1544
!
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1545
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1546
testIntegerMisc2
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1547
    "misc tests.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1548
     Notice, the arithmetic tests are both performed via regular sends
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1549
     and via constructed performs. The reason is to test both inlined
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1550
     JIT-compiler code AND the regular methods code."
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1551
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1552
    |n sel|
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1553
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1554
    "/ fib is optional
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1555
    (0 respondsTo:#fib) ifFalse:[^ self].
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1556
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1557
    self assert:(0 fib == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1558
    self assert:(1 fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1559
    self assert:(2 fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1560
    self assert:(3 fib == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1561
    self assert:(4 fib == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1562
    self assert:(5 fib == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1563
    self assert:(6 fib == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1564
    self assert:(7 fib == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1565
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1566
    n := 0.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1567
    self assert:(n fib == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1568
    n := 1.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1569
    self assert:(n fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1570
    n := 2.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1571
    self assert:(n fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1572
    n := 3.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1573
    self assert:(n fib == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1574
    n := 4.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1575
    self assert:(n fib == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1576
    n := 5.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1577
    self assert:(n fib == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1578
    n := 6.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1579
    self assert:(n fib == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1580
    n := 7.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1581
    self assert:(n fib == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1582
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1583
    #(0 1 2 3 4 5 6 7)
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1584
    with:#(0 1 1 2 3 5 8 13)
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1585
    do:[:n :rslt |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1586
	self assert:(n fib == rslt).
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1587
    ].
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1588
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1589
"/    #(0 1 2 3 4 5 6 7)
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1590
"/    with:#(0 1 1 2 3 5 8 13)
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1591
"/    do:[:n :rslt |
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1592
"/        self assert:(n fib_recursive == rslt).
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1593
"/    ].
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1594
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1595
    sel := #fib.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1596
    self assert:((0 perform:sel) == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1597
    self assert:((1 perform:sel) == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1598
    self assert:((2 perform:sel) == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1599
    self assert:((3 perform:sel) == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1600
    self assert:((4 perform:sel) == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1601
    self assert:((5 perform:sel) == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1602
    self assert:((6 perform:sel) == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1603
    self assert:((7 perform:sel) == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1604
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1605
    "
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1606
     self basicNew testIntegerMisc2
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1607
    "
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1608
!
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1609
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1610
testIntegerShifts
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1611
    "arithmetic tests.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1612
     Notice, the arithmetic tests are both performed via regular sends
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1613
     and via constructed performs. The reason is to test both inlined
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1614
     JIT-compiler code AND the regular methods code."
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1615
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1616
    self testIntegerShifts1.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1617
    self testIntegerShifts2.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1618
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1619
    self assert:(
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1620
     (((0 to:64) collect:[:s | 1 bitShift:s])
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1621
	collect:[:n | n highBit]) = (1 to:65)
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1622
    ).
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1623
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1624
    1 to:10000 do:[:s |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1625
	self assert:( (1 bitShift:s) highBit == (s+1) )
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1626
    ].
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1627
    1 to:10000 do:[:s |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1628
	self assert:( ((1 bitShift:s) - 1) highBit == s )
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1629
    ].
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1630
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1631
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1632
     self basicNew testIntegerShifts
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1633
    "
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1634
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1635
    "Created: / 6.6.1999 / 14:47:51 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1636
    "Modified: / 9.6.1999 / 17:49:57 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1637
!
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1638
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1639
testIntegerShifts1
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1640
    "arithmetic tests.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1641
     Notice, the arithmetic tests are both performed via regular sends
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1642
     and via constructed performs. The reason is to test both inlined
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1643
     JIT-compiler code AND the regular methods code."
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1644
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1645
    |n1 n2 s|
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1646
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1647
    n1 := 100000.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1648
    n2 := n1 negated.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1649
    s := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1650
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1651
    self assert:(n1 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1652
    self assert:(n2 printString = '-100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1653
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1654
    self assert:((n1 bitShift:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1655
    self assert:((n1 bitShift:1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1656
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1657
    self assert:((n1 perform:'bitShift:' asSymbol with:1) printString = '200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1658
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1659
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1660
    self assert:((n1 bitShift:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1661
    self assert:((n1 bitShift:2) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1662
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1663
    self assert:((n1 perform:'bitShift:' asSymbol with:2) printString = '400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1664
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1665
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1666
    self assert:((n1 bitShift:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1667
    self assert:((n1 bitShift:3) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1668
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1669
    self assert:((n1 perform:'bitShift:' asSymbol with:3) printString = '800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1670
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1671
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1672
    self assert:((n1 bitShift:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1673
    self assert:((n1 bitShift:4) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1674
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1675
    self assert:((n1 perform:'bitShift:' asSymbol with:4) printString = '1600000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1676
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1677
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1678
    self assert:((n1 bitShift:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1679
    self assert:((n1 bitShift:5) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1680
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1681
    self assert:((n1 perform:'bitShift:' asSymbol with:5) printString = '3200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1682
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1683
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1684
    self assert:((n1 bitShift:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1685
    self assert:((n1 bitShift:6) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1686
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1687
    self assert:((n1 perform:'bitShift:' asSymbol with:6) printString = '6400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1688
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1689
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1690
    self assert:((n1 bitShift:s) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1691
    self assert:((n1 bitShift:7) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1692
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1693
    self assert:((n1 perform:'bitShift:' asSymbol with:7) printString = '12800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1694
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1695
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1696
     self basicNew testIntegerShifts1
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1697
    "
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1698
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1699
    "Created: / 6.6.1999 / 14:47:51 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1700
    "Modified: / 9.6.1999 / 17:49:57 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1701
!
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1702
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1703
testIntegerShifts2
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1704
    "arithmetic tests.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1705
     Notice, the arithmetic tests are both performed via regular sends
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1706
     and via constructed performs. The reason is to test both inlined
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1707
     JIT-compiler code AND the regular methods code."
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1708
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1709
    |n1 s|
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1710
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1711
    n1 := 12800000.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1712
    s := -1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1713
    self assert:((n1 bitShift:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1714
    self assert:((n1 bitShift:-1) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1715
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1716
    self assert:((n1 perform:'bitShift:' asSymbol with:-1) printString = '6400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1717
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1718
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1719
    self assert:((n1 bitShift:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1720
    self assert:((n1 bitShift:-2) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1721
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1722
    self assert:((n1 perform:'bitShift:' asSymbol with:-2) printString = '3200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1723
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1724
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1725
    self assert:((n1 bitShift:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1726
    self assert:((n1 bitShift:-3) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1727
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1728
    self assert:((n1 perform:'bitShift:' asSymbol with:-3) printString = '1600000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1729
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1730
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1731
    self assert:((n1 bitShift:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1732
    self assert:((n1 bitShift:-4) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1733
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1734
    self assert:((n1 perform:'bitShift:' asSymbol with:-4) printString = '800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1735
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1736
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1737
    self assert:((n1 bitShift:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1738
    self assert:((n1 bitShift:-5) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1739
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1740
    self assert:((n1 perform:'bitShift:' asSymbol with:-5) printString = '400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1741
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1742
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1743
    self assert:((n1 bitShift:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1744
    self assert:((n1 bitShift:-6) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1745
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1746
    self assert:((n1 perform:'bitShift:' asSymbol with:-6) printString = '200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1747
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1748
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1749
    self assert:((n1 bitShift:s) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1750
    self assert:((n1 bitShift:-7) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1751
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1752
    self assert:((n1 perform:'bitShift:' asSymbol with:-7) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1753
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1754
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1755
    self assert:((n1 bitShift:s) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1756
    self assert:((n1 bitShift:-8) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1757
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1758
    self assert:((n1 perform:'bitShift:' asSymbol with:-8) printString = '50000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1759
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1760
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1761
    self assert:((n1 bitShift:s) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1762
    self assert:((n1 bitShift:-9) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1763
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1764
    self assert:((n1 perform:'bitShift:' asSymbol with:-9) printString = '25000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1765
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1766
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1767
    self assert:((n1 bitShift:s) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1768
    self assert:((n1 bitShift:-10) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1769
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1770
    self assert:((n1 perform:'bitShift:' asSymbol with:-10) printString = '12500').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1771
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1772
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1773
    self assert:((n1 bitShift:s) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1774
    self assert:((n1 bitShift:-11) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1775
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1776
    self assert:((n1 perform:'bitShift:' asSymbol with:-11) printString = '6250').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1777
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1778
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1779
     self basicNew testIntegerShifts2
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1780
    "
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1781
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1782
    "Created: / 6.6.1999 / 14:47:51 / cg"
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1783
    "Modified: / 9.6.1999 / 17:49:57 / cg"
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1784
!
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1785
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1786
testIntegerShifts3
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1787
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1788
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1789
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1790
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1791
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1792
    self assert:( self doConstantIntegerShift == 1).
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1793
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1794
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1795
     self basicNew testIntegerShifts3
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
  1796
    "
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
  1797
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1798
107
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1799
testIntegerShifts4
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1800
    "arithmetic tests.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1801
     Notice, the arithmetic tests are both performed via regular sends
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1802
     and via constructed performs. The reason is to test both inlined
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1803
     JIT-compiler code AND the regular methods code."
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1804
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1805
    |a|
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1806
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1807
    a := 16r1234.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1808
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1809
    self assert:( ((a bitShift:-4) bitAnd:16rFF) == 16r23 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1810
    self assert:( ((a bitShift:-8) bitAnd:16rFF) == 16r12 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1811
    self assert:( ((a bitShift:-12) bitAnd:16rFF) == 16r1 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1812
    self assert:( ((a bitShift:-16) bitAnd:16rFF) == 0 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1813
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1814
    "/ should not shift in any sign bits ...
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1815
    a := 16r1FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1816
    self assert:( (a bitShift:-4) == 16r1FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1817
    a := 16r3FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1818
    self assert:( (a bitShift:-4) == 16r3FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1819
    a := 16r7FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1820
    self assert:( (a bitShift:-4) == 16r7FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1821
    a := 16rFFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1822
    self assert:( (a bitShift:-4) == 16rFFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1823
    a := 16r1FFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1824
    self assert:( (a bitShift:-4) == 16r1FFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1825
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1826
    a := 16r1FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1827
    self assert:( (a bitShift:-8) == 16r1FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1828
    a := 16r3FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1829
    self assert:( (a bitShift:-8) == 16r3FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1830
    a := 16r7FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1831
    self assert:( (a bitShift:-8) == 16r7FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1832
    a := 16rFFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1833
    self assert:( (a bitShift:-8) == 16rFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1834
    a := 16r1FFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1835
    self assert:( (a bitShift:-8) == 16r1FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1836
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1837
    "
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1838
     self basicNew testIntegerShifts4
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1839
    "
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1840
!
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1841
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1842
testIsPowerOfTwo
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1843
    self assert:(1 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1844
    self assert:(2 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1845
    self assert:(4 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1846
    self assert:(3 isPowerOfTwo not).
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1847
    self assert:(16r100000000000000000000000 isPowerOfTwo).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1848
    self assert:(16r300000000000000000000000 isPowerOfTwo not).
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1849
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1850
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1851
     self basicNew testIsPowerOfTwo
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1852
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1853
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1854
    "Created: / 27-04-2010 / 10:35:36 / cg"
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1855
!
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1856
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1857
testLargeAddition
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1858
    "general conversion & arithmetic tests.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1859
     Notice, the arithmetic tests are both performed via regular sends
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1860
     and via constructed performs. The reason is to test both inlined
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1861
     JIT-compiler code AND the regular methods code."
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1862
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1863
    "Large + Large addition"
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1864
    self testReading1.
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1865
1315
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
  1866
    self assert:(20 factorial = 2432902008176640000).
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
  1867
    self assert:(20 factorial printString = '2432902008176640000').
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1868
    self assert:((20 factorial + 20 factorial) printString = '4865804016353280000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1869
    self assert:((20 factorial + 1) printString = '2432902008176640001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1870
    self assert:((20 factorial + 1000) printString = '2432902008176641000').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1871
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1872
    "Large + Small addition"
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1873
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1874
    self testLargeAddition1.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1875
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1876
    "Large + Large addition"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1877
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1878
    self testLargeAddition2.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1879
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1880
    "Large - small subtraction"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1881
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1882
    self testLargeAddition3.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1883
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1884
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1885
     self basicNew testLargeAddition
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1886
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1887
1315
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
  1888
    "Modified: / 26-02-2016 / 15:39:33 / cg"
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1889
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1890
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1891
testLargeAddition1
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1892
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1893
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1894
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1895
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1896
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1897
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1898
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1899
    "Large + Small addition"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1900
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1901
    n1 := 16r3FFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1902
    self assert:((n1 + n2 ) hexPrintString = '40000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1903
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1904
    n1 := 16r3FFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1905
    self assert:((n1 + n2 ) hexPrintString = '400000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1906
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1907
    n1 := 16r3FFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1908
    self assert:((n1 + n2 ) hexPrintString = '4000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1909
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1910
    n1 := 16r3FFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1911
    self assert:((n1 + n2 ) hexPrintString = '40000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1912
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1913
    n1 := 16r3FFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1914
    self assert:((n1 + n2 ) hexPrintString = '400000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1915
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1916
    n1 := 16r3FFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1917
    self assert:((n1 + n2 ) hexPrintString = '4000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1918
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1919
    n1 := 16r3FFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1920
    self assert:((n1 + n2 ) hexPrintString = '40000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1921
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1922
    n1 := 16r3FFFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1923
    self assert:((n1 + n2 ) hexPrintString = '400000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1924
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1925
    n1 := 16r3FFFFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1926
    self assert:((n1 + n2 ) hexPrintString = '4000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1927
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1928
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1929
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1930
     self basicNew testLargeAddition1
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1931
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1932
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1933
    "Modified: / 4.6.1999 / 15:26:55 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1934
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1935
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1936
testLargeAddition2
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1937
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1938
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1939
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1940
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1941
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1942
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1943
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1944
    "Large + Large addition"
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1945
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1946
    n1 := 16r100000000. n2 := 16r7FFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1947
    self assert:((n1 - n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1948
    self assert:((16r100000000 - n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1949
    self assert:((n1 - 16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1950
    self assert:((16r100000000 - 16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1951
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1952
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1953
    self assert:((n1 perform:'-' asSymbol with:16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1954
    self assert:((16r100000000 perform:'-' asSymbol with:16r7FFFFFFF ) hexPrintString = '80000001').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1955
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1956
    n1 := 16r100000000. n2 := 16r80000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1957
    self assert:((n1 - n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1958
    self assert:((16r100000000 - n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1959
    self assert:((n1 - 16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1960
    self assert:((16r100000000 - 16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1961
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1962
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1963
    self assert:((n1 perform:'-' asSymbol with:16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1964
    self assert:((16r100000000 perform:'-' asSymbol with:16r80000000 ) hexPrintString = '80000000').
17
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  1965
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  1966
    n1 := 16r100000000. n2 := 16rFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1967
    self assert:((n1 - n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1968
    self assert:((16r100000000 - n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1969
    self assert:((x := n1 - 16rFFFFFFFF) == 1).
17
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  1970
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1971
    self assert:((n1 - 16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1972
    self assert:((16r100000000 - 16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1973
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1974
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1975
    self assert:((n1 perform:'-' asSymbol with:16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1976
    self assert:((16r100000000 perform:'-' asSymbol with:16rFFFFFFFF ) hexPrintString = '1').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1977
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1978
    n1 := 16r100000000. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1979
    self assert:((n1 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1980
    self assert:((n1 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1981
    self assert:((16r100000000 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1982
    self assert:((n1 - 1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1983
    self assert:((16r100000000 - 1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1984
    self assert:((n1 perform:'-' asSymbol with:n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1985
    self assert:((16r100000000 perform:'-' asSymbol with:n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1986
    self assert:((n1 perform:'-' asSymbol with:1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1987
    self assert:((16r100000000 perform:'-' asSymbol with:1) hexPrintString = 'FFFFFFFF').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1988
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1989
    n1 := 16r100000000. n2 := 16r10000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1990
    self assert:((n1 - n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1991
    self assert:((16r100000000 - n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1992
    self assert:((n1 - 16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1993
    self assert:((16r100000000 - 16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1994
    self assert:((n1 perform:'-' asSymbol with:n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1995
    self assert:((16r100000000 perform:'-' asSymbol with:n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1996
    self assert:((n1 perform:'-' asSymbol with:16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1997
    self assert:((16r100000000 perform:'-' asSymbol with:16r10000000) hexPrintString = 'F0000000').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1998
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1999
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2000
     self basicNew testLargeAddition2
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2001
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2002
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2003
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2004
testLargeAddition3
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2005
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2006
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2007
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2008
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2009
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2010
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2011
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2012
    "Large - small subtraction"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2013
    self assert:((20 factorial + 20 factorial - 1) printString = '4865804016353279999').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2014
    self assert:((20 factorial - 10 factorial + 3628800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2015
    self assert:((20 factorial - 11 factorial + 39916800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2016
    self assert:((20 factorial - 12 factorial + 479001600) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2017
    self assert:((20 factorial - 13 factorial + 6227020800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2018
    self assert:((20 factorial - 14 factorial + 87178291200) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2019
    self assert:((20 factorial - 15 factorial + 1307674368000) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2020
    self assert:((20 factorial - 16 factorial + 20922789888000) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2021
    self assert:((20 factorial + 10 factorial - 3628800) printString = '2432902008176640000').
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2022
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2023
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2024
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2025
    n1 := n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2026
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2027
    n1 := n2 := 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2028
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2029
    n1 := n2 := 16rFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2030
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2031
    n1 := n2 := 16rFFFFFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2032
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2033
    n1 := n2 := 16rFFFFFFFFFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2034
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2035
    n1 := n2 := 1000 factorial.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2036
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2037
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2038
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2039
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2040
     self basicNew testLargeAddition3
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2041
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2042
52
544196f29bee *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 51
diff changeset
  2043
    "Modified: / 27.11.1999 / 16:41:54 / cg"
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2044
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2045
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2046
testLargeBitOperations
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2047
    "large bit operations test."
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2048
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2049
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFF) hexPrintString = '2211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2050
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFF) hexPrintString  = '332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2051
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFF) hexPrintString = '44332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2052
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFF) hexPrintString = '5544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2053
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFF) hexPrintString = '665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2054
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFF) hexPrintString = '77665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2055
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFF) hexPrintString = '8877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2056
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFF) hexPrintString = '998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2057
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'AA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2058
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'BBAA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2059
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'CCBBAA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2060
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2061
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFF) hexPrintString = 'FFEEDDCCBBAA99887766554433FFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2062
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFF) hexPrintString  = 'FFEEDDCCBBAA998877665544FFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2063
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA9988776655FFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2064
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA99887766FFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2065
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA998877FFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2066
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA9988FFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2067
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA99FFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2068
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAAFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2069
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2070
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCFFFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2071
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDFFFFFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2072
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  2073
    Time millisecondsToRun:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2074
	1000000 timesRepeat:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2075
	    (16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFFFF)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2076
	]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2077
    ].
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  2078
    "/ bitAnd inherited via Integer:  1638 1575 1576
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2079
    "/ bitAnd tuned in largeInteger:  172 171 172
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  2080
549
255a421653d4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 548
diff changeset
  2081
    Time millisecondsToRun:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2082
	1000000 timesRepeat:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2083
	    (16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFFFF)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2084
	]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2085
    ].
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  2086
    "/ bitOr inherited via Integer:  1903 1856 1856
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  2087
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2088
    "
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2089
     self basicNew testLargeBitOperations
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2090
    "
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2091
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2092
    "Modified: / 4.6.1999 / 15:26:55 / cg"
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2093
!
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2094
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2095
testLargeCompare
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2096
    "compare tests"
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2097
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2098
    #(
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2099
        ( 16r3fffffff 16r40000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2100
        ( 16r40000000 16r3fffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2101
        ( 16r40000000 16r40000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2102
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2103
        ( 16r40000000 16r40000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2104
        ( 16r40000001 16r40000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2105
        ( 16r40000001 16r40000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2106
        
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2107
        ( 16r3fffffffffffffff 16r4000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2108
        ( 16r4000000000000000 16r3fffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2109
        ( 16r4000000000000000 16r4000000000000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2110
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2111
        ( 16r4000000000000000 16r4000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2112
        ( 16r4000000000000001 16r4000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2113
        ( 16r4000000000000001 16r4000000000000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2114
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2115
        ( 16r3fffffffffffffffffffffff 16r400000000000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2116
        ( 16r400000000000000000000000 16r3fffffffffffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2117
        ( 16r400000000000000000000000 16r400000000000000000000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2118
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2119
        ( 16r400000000000000000000000 16r400000000000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2120
        ( 16r400000000000000000000001 16r400000000000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2121
        ( 16r400000000000000000000001 16r400000000000000000000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2122
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2123
        ( 16r3fffffff 16r400000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2124
        ( 16r400000000000 16r3fffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2125
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2126
        ( 16r40000000 16r400000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2127
        ( 16r400000000001 16r40000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2128
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2129
        ( 16r3fffffffffffffff 16r40000000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2130
        ( 16r40000000000000000000 16r3fffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2131
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2132
        ( 16r4000000000000000 16r40000000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2133
        ( 16r40000000000000000001 16r4000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2134
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2135
        ( 16r3fffffffffffffffffffffff 16r400000000000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2136
        ( 16r400000000000000000000000 16r3fffffffffffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2137
        ( 16r400000000000000000000000 16r400000000000000000000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2138
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2139
        ( 16r400000000000000000000000 16r400000000000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2140
        ( 16r400000000000000000000001 16r400000000000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2141
        ( 16r400000000000000000000001 16r400000000000000000000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2142
    ) do:[:triple |
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2143
        |v1 v2 expected rslt|
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2144
        
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2145
        v1 := triple at:1.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2146
        v2 := triple at:2.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2147
        expected := triple at:3.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2148
        expected == #less ifTrue:[
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2149
            self assert:(v1 < v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2150
            self assert:(v1 <= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2151
            self assert:(v1 > v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2152
            self assert:(v1 >= v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2153
            self assert:(v1 = v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2154
            self assert:(v1 ~= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2155
        ].    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2156
        expected == #greater ifTrue:[
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2157
            self assert:(v1 > v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2158
            self assert:(v1 >= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2159
            self assert:(v1 < v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2160
            self assert:(v1 <= v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2161
            self assert:(v1 = v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2162
            self assert:(v1 ~= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2163
        ].    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2164
        expected == #equal ifTrue:[
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2165
            self assert:(v1 > v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2166
            self assert:(v1 >= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2167
            self assert:(v1 < v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2168
            self assert:(v1 <= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2169
            self assert:(v1 = v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2170
            self assert:(v1 ~= v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2171
        ].    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2172
    ].
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2173
    self assert:(100 factorial < 101 factorial).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2174
    self assert:(100 factorial > 100 factorial negated).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2175
    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2176
    "
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2177
     self basicNew testLargeCompare
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2178
    "
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2179
!
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2180
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2181
testLargeCompression1
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2182
    |l nullBytes|
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2183
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2184
    #(
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2185
	#[ 1 ]          16r01
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2186
	#[ 1 2 ]        16r0201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2187
	#[ 1 2 3]       16r030201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2188
	#[ 1 2 3 4]     16r04030201
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2189
    ) pairWiseDo:[:bytes :expected |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2190
	0 to:16 do:[:nNullBytes |
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2191
	    nullBytes := ByteArray new:nNullBytes withAll:0.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2192
	    l := LargeInteger digitBytes:(bytes , nullBytes).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2193
	    self assert:( l compressed == expected ).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2194
	].
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2195
    ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2196
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2197
    #(
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2198
	#[ 1 2 3 4 5]       16r0504030201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2199
	#[ 1 2 3 4 5 6]     16r060504030201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2200
	#[ 1 2 3 4 5 6 7]   16r07060504030201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2201
	#[ 1 2 3 4 5 6 7 8] 16r0807060504030201
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2202
    ) pairWiseDo:[:bytes :expected |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2203
	0 to:16 do:[:nNullBytes |
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2204
	    nullBytes := ByteArray new:nNullBytes withAll:0.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2205
	    l := LargeInteger digitBytes:(bytes , nullBytes).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2206
	    ExternalAddress pointerSize == 8 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2207
		self assert:( l compressed == expected ).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2208
	    ] ifFalse:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2209
		self assert:( l compressed = expected ).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2210
	    ]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2211
	]
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2212
    ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2213
933
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2214
    #(
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2215
	#[ 1 2 3 4 5 6 7 8 9]       16r090807060504030201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2216
	#[ 1 2 3 4 5 6 7 8 9 10]    16r0a090807060504030201
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2217
	#[ 1 2 3 4 5 6 7 8 9 10 11] 16r0b0a090807060504030201
933
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2218
    ) pairWiseDo:[:bytes :expected |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2219
	0 to:16 do:[:nNullBytes |
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2220
	    nullBytes := ByteArray new:nNullBytes withAll:0.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2221
	    l := LargeInteger digitBytes:(bytes , nullBytes).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2222
	    self assert:( l compressed = expected ).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2223
	]
933
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2224
    ].
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2225
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2226
    "
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2227
     self basicNew testLargeCompression1
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2228
    "
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2229
!
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2230
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2231
testLargeDivision
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2232
    |t v a b|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2233
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2234
    "/ on a 64bit machine, this is actually a smallInteger!!
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2235
    t := 20 factorial.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2236
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2237
    self assert:(t printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2238
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2239
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2240
    self assert:(t printString = '243290200817664000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2241
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2242
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2243
    self assert:(t printString = '24329020081766400').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2244
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2245
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2246
    self assert:(t printString = '2432902008176640').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2247
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2248
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2249
    self assert:(t printString = '243290200817664').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2250
    self assert:(t \\ 10 == 4).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2251
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2252
    self assert:(t printString = '24329020081766').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2253
    self assert:(t \\ 10 == 6).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2254
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2255
    self assert:(t printString = '2432902008176').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2256
    self assert:(t \\ 10 == 6).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2257
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2258
    self assert:(t printString = '243290200817').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2259
    self assert:(t \\ 10 == 7).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2260
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2261
    self assert:(t printString = '24329020081').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2262
    self assert:(t \\ 10 == 1).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2263
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2264
    self assert:(t printString = '2432902008').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2265
    self assert:(t \\ 10 == 8).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2266
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2267
    self assert:(t printString = '243290200').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2268
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2269
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2270
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2271
    t := 20 factorial.
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2272
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2273
    self assert:(t printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2274
    self assert:(t \\ 1000 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2275
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2276
    self assert:(t printString = '2432902008176640').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2277
    self assert:(t \\ 1000 == 640).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2278
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2279
    self assert:(t printString = '2432902008176').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2280
    self assert:(t \\ 1000 == 176).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2281
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2282
    self assert:(t printString = '2432902008').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2283
    self assert:(t \\ 1000 == 8).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2284
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2285
    self assert:(t printString = '2432902').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2286
    self assert:(t \\ 1000 == 902).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2287
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2288
    self assert:(t printString = '2432').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2289
    self assert:(t \\ 1000 == 432).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2290
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2291
    self assert:(t == 2).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2292
    self assert:(t \\ 1000 == 2).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2293
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2294
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2295
    t := 20 factorial.
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2296
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2297
    "Large // SmallInt division"
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2298
    t := t // 20.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2299
    self assert:(t printString = 19 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2300
    t := t // 19.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2301
    self assert:(t printString = 18 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2302
    t := t // 18.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2303
    self assert:(t printString = 17 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2304
    t := t // 17.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2305
    self assert:(t printString = 16 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2306
    t := t // 16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2307
    self assert:(t printString = 15 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2308
    t := t // 15.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2309
    self assert:(t printString = 14 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2310
    t := t // 14.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2311
    self assert:(t printString = 13 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2312
    t := t // 13.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2313
    self assert:(t printString = 12 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2314
    t := t // 12.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2315
    self assert:(t printString = 11 factorial printString).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2316
    t := t // 11.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2317
    self assert:(t printString = 10 factorial printString).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2318
    self assert:(t == 10 factorial).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2319
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2320
    t := 20 factorial.
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2321
    t := t + 21 factorial.
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2322
    t absDestructiveSubtract:21 factorial.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2323
    self assert:(t compressed = 20 factorial).
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2324
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2325
    self assert:(
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2326
             [
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2327
               |v|
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2328
               v := 100 factorial copy.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2329
               v absDestructiveSubtract:99 factorial.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2330
               v compressed = (100 factorial - 99 factorial).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2331
             ] value).
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2332
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2333
    "Large // Large division"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2334
    self assert:((20 factorial // 19 factorial) == 20).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2335
    self assert:((20 factorial * 21 // 20 // 21) = (19 factorial)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2336
    self assert:((10000 factorial // 9999 factorial) == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2337
    self assert:((10000 factorial // 9999 factorial) == (10000 factorial / 9999 factorial)).
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2338
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2339
    a := 40 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2340
    b := 39 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2341
    self assert:(a // 40 = b).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2342
    self assert:(a / 40 = b).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2343
    self assert:(a // b = 40).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2344
    self assert:(a // b = 40).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2345
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2346
    "
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2347
     self basicNew testLargeDivision
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2348
    "
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2349
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2350
    "Modified: / 4.6.1999 / 23:54:57 / cg"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2351
!
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2352
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2353
testLargeDivision2
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2354
    |t|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2355
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2356
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2357
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2358
    self assert:(t printString = '265252859812191058636308480000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2359
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2360
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2361
    self assert:(t printString = '26525285981219105863630848000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2362
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2363
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2364
    self assert:(t printString = '2652528598121910586363084800000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2365
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2366
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2367
    self assert:(t printString = '265252859812191058636308480000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2368
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2369
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2370
    self assert:(t printString = '26525285981219105863630848000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2371
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2372
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2373
    self assert:(t printString = '2652528598121910586363084800').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2374
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2375
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2376
    self assert:(t printString = '265252859812191058636308480').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2377
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2378
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2379
    self assert:(t printString = '26525285981219105863630848').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2380
    self assert:(t \\ 10 == 8).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2381
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2382
    self assert:(t printString = '2652528598121910586363084').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2383
    self assert:(t \\ 10 == 4).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2384
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2385
    self assert:(t printString = '265252859812191058636308').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2386
    self assert:(t \\ 10 == 8).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2387
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2388
    self assert:(t printString = '26525285981219105863630').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2389
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2390
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2391
    self assert:(t printString = '2652528598121910586363').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2392
    self assert:(t \\ 10 == 3).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2393
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2394
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2395
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2396
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2397
    self assert:(t printString = '265252859812191058636308480000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2398
    self assert:(t \\ 1000 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2399
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2400
    self assert:(t printString = '265252859812191058636308480000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2401
    self assert:(t \\ 1000 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2402
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2403
    self assert:(t printString = '265252859812191058636308480').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2404
    self assert:(t \\ 1000 == 480).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2405
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2406
    self assert:(t printString = '265252859812191058636308').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2407
    self assert:(t \\ 1000 == 308).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2408
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2409
    self assert:(t printString = '265252859812191058636').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2410
    self assert:(t \\ 1000 == 636).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2411
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2412
    self assert:(t printString = '265252859812191058').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2413
    self assert:(t \\ 1000 == 058).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2414
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2415
    self assert:(t printString = '265252859812191').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2416
    self assert:(t \\ 1000 == 191).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2417
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2418
    self assert:(t printString = '265252859812').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2419
    self assert:(t \\ 1000 == 812).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2420
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2421
    self assert:(t printString = '265252859').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2422
    self assert:(t \\ 1000 == 859).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2423
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2424
    self assert:(t printString = '265252').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2425
    self assert:(t \\ 1000 == 252).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2426
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2427
    self assert:(t == 265).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2428
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2429
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2430
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2431
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2432
    "Large // SmallInt division"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2433
    t := t // 30.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2434
    self assert:(t printString = 29 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2435
    t := t // 29.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2436
    self assert:(t printString = 28 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2437
    t := t // 28.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2438
    self assert:(t printString = 27 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2439
    t := t // 27.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2440
    self assert:(t printString = 26 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2441
    t := t // 26.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2442
    self assert:(t printString = 25 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2443
    t := t // 25.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2444
    self assert:(t printString = 24 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2445
    t := t // 24.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2446
    self assert:(t printString = 23 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2447
    t := t // 23.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2448
    self assert:(t printString = 22 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2449
    t := t // 22.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2450
    self assert:(t printString = 21 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2451
    t := t // 21.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2452
    self assert:(t printString = 20 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2453
    self assert:(t = 20 factorial).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2454
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2455
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2456
    t := t + 31 factorial.
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2457
    t absDestructiveSubtract:31 factorial.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2458
    self assert:(t compressed = 30 factorial).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2459
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2460
    "Large // Large division"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2461
    self assert:((30 factorial // 29 factorial) == 30).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2462
    self assert:((30 factorial * 31 // 30 // 31) = (29 factorial)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2463
    self assert:((10000 factorial // 9999 factorial) == 10000).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2464
    self assert:((10000 factorial // 9999 factorial) == (10000 factorial / 9999 factorial)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2465
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2466
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2467
     self basicNew testLargeDivision
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2468
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2469
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2470
    "Modified: / 4.6.1999 / 23:54:57 / cg"
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2471
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2472
1305
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2473
testLargeDivision3
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2474
    |nr nrDiv divMod|
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2475
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2476
    nr := 7325642811050717153762789776988268826770436380599581066471363310499109217483708146717300025889347764783245287140288431825827761209734375227679364238973902481615726067110515609260483803343004535447652942957373994975597787908243354307547553217414840584715130217408586553614859382487727371958203670203728210853329589615550643569429545464633535838187607553120280274725090757329790353463095413523805494772650078306205912628165850732646863846576998277181504708528835125953362770982762908435490999280519117904719254192978414037497481935495547720579882482124362070304920033554421042496625143517677519951145301160506529078213700153962585026512916970185197699563558140876733107706727253226098498667726495707224022003616065672008153665539817928251568554484739745047105522527635187163056607022536498632737702947013365938133885169902714284727206577408496549992845715870018995222990562233528977494519678931256347544259771346247230580853991022721956676465120007969950427165372994323753297510475028095488055686092040724169139419916609256577729768013251303221252901814408489603855447556799027832316669978641359003225101118289255692054597992816505634077137939488367815415698567236171805308890522013024780344455911750571267472425322111576828023953254628842107966689828686941644594589250192289779894954314728890652959077550610325243691999405204222390497498029651468304746649735170207150423058209700682117896369093708787314191673370934168117103657952473409299633370355921652776795194998872621267955977007414487536764633556057244697184265399074262010357199308106519621332411646090881806679817777934087907609335095266207222734209276892672802559477129431290377781189460543831892579497032750130070072871363403749763492296712949034307352335981485523440716455874989554006840460427619480548908526831960007098095496673990791644237848915619019143304599320077794055989022733836402514795091748221758967378808917944360112901833917971660803687798356056419168537336005651674223355473407003283134339985506017270361538197141299934143152796116511007721239543588850520897247526805181747313555479146618959531019365744636489763407090552996809230736561767841333905734641055297321262233564674390961392651334871664325693448366323216336135114828870644061243807564587592658360508871312414270046251899865884799855978604603846784154676298841585915992392704588348304942478924343918975195923643629685241735276658813975572655538887395894943154837164154459809363283117923392993892589490540925513342593007784719441705148960453180301530851234688957032066907843949205120201720517233228017689397727501528654849506825446097709482577917667243321350295028575684178929416362809008034715382134959864428148337229371113753679702176851066723014671275176890295101957580814878664773530433540963808618303311433527685959104811072639265393597781952115276199443064654238529377585171747088279186943179071921057535680516445246724050154764542596741670850809674306935131178441317280401304117745258603320024189243969889899010725582438207015597258263941269730866138781215790257519260119642107850957073141852969214624609102867275022012968382626510150354544317157440551595548404866365232107076069108476859713524926579046999471537578555696823173917264727038317433492881860460533993043375675559974541501151536956388184229821825202783315175964857435121268159290087988520427001562311888903167219790907449246265211066597617404797684060743206718943066178740881680422221097537985644933108964245133276088549914210990590138516895520058065054329273143605806169872175805617483836108276041444751410352824841438522369961070941467306815885136393083146953817333717600651525643928410853518305074271285893483690402426110481100118592425979094825294009195497071244959721165805259378411459840402202432070097961411127831244002473025945590264209304535568932141934734427207643570840464365672020197014117057179828617184095466170277658012012082773008797284377020045199741711763429387654482036311118363550554573970722123056838391535176046275151704935927285776048526642046962416364731182508311665455959674818084140845113742927564214026026700188662967826830513695781752328070213377525743249206640596503567193612953686078368856837703275526312899731904806336662979992529567407592246922517958210869076841533625492899752157880746671555381617069359816751254049680535425407993431788796501484592904619815876395056294928500125620366251871965592128092071339931385778018271508366059428400618014316995088662886944531660310582304020782381824044296858444495836641436442114508798254022275527819884050205813610927392719427503886961325971042076759694523773397768263944949829047040250671591798699614674593280712438625552771672046770702177630021735604331681545328668356298896381196151818109965073540758004677376198693809341805742022883291609399453480948898873499293263877270932469009419431439504806048534024219695533951970768718607825512258459988039384671119861525055001257711440159711680468030006281596534069339905726514213495715578762483305792208439143804155140484955582807325734068361219604129672905439850247943374888325363536124220790929563183116800098259005080319976250005938202733026601423198594337116340040753176034747789519724367052821548790017492968600851467986834229393664397355394904449416596664697790294348115918027290369660030404309844866514596162383926922191583735197797285879017756435071691692579228371128194336880861331914026966533592778591975677047531809933445220376204094007852062763024256243247594908739310435742528343941136832141474614646195909007856979265090874937138653336279924669848945653923945059917473576073169113163591124139505027406426534299861184296286788678362064462571791247879481439224580152349380317895688368254981040713360197820623097965776497254219906627282182384583338997949322384688868753460332706063133692787241504223050921158385580293599957894628416295533076654622257184754535802725334290973325498566317654571663237347731966894722724226512101772153274798569796914026876025548743598732008731155930322538300118777605906397797200395073085079799720873331462360859558150294524673319774115422392855072805588331909034084940029643726834272412931634977220530411021804722158153773936709148601033954557711082063893472585895524019049770116104251942887519233166694790693305261370262098403931338638500460698273702483237833362913924748030573151235157079682103767162430861730648127306887340728587348584798432641373495081984444066017235036057867001084876034127575741046842705361078008658574057368371382290972551200828394402811129598512908406453163914133239324104176213439651911165723583312125404951908431958612444626832567425682382934966014402623844134480947328804898904457554990223633471152244935360846846872567395324752446056856314223580293777812792119222808747497257154119637357959526560095149732009525437166278985397825839476104252829701681188291604531178056187506204522297781410939426743458996516122417016297219533676135442588829970042448233678230743338567376323339403790517471808179478793371414460742848940080957249583920379222819120854583169254001656959488520268941651760355412230878512385792248057484840320339298745595785121144213305506256309005073307733101215537859103057428564045191401917751767528573372312728646224212563853090004301461656398621398256865950301741795030996394898498315685734194500204859005200129895914605961077480028024084166201706521017250564954091090761794215977943552136119569181253389728669786275631589077849217875992600354179303147875039054389958249338829071558805071696036014384280708136310202474257546110256018595074859205169417210438407668235772264489532840927011474245787805040250578989944089804487191960609374291147892392946334697862368311103975946562702804600592135283262705727886790284962999933595950396917187809872807890634995550768965917896649379618770995853018273642527941803602373748201162016424346818539699731541437191051272370389920430963850766457735997487836796190622801454117965803454310147963735891677695932780724907240409219933741153684518942237155171214800428187139788975348112515841498442346521529922874142809101317753813000222213844775530569928492214119218158311069973450417965826021228115913570997832587000507462134261658894622095296948660838891202843909918507703517052932194777950892934484326759830164241347516373904518928184219267625128730631587594616533889734599461176472989484051646992794549374972941033191680237511998366596928478133425687348377402191597183609913275115410415042943874922013282223036797766687562234708717228407526539793707192821641982045304637501898951672018353203243730498439561247010157326717850275842340724013349962837828262281859810432128342491502593655870623723538391476208736312646369716279126909024702322290468430221078966596856226868416199720051530940142548869537531144513871342122033366003412041325058744123643998708546094783795853752878277029993558821508050352135005532898315183427096073809860479404735696155895314871310840383963606002446025854182161994409438676534109631384937889800633421957669306238761422314292556501189945069931744515842623180008335951569700303152755271126472218857847432207385749882000533990024894030463892512867955227542394178393580753618051116929938385425024087970203342497063966957812547691207822897841681320712411054476647899997427503220523868363438443638138602058216412755412543898409102222405369299283907058054142505144252800800871766217740818073224044997682418836667094039746104705778772576150819423984585572854317991749574311863090200042587643440109185515699468359875803740167627895880258372380256331670270263041712499710565984020613035159213277572556237587993858247481402455200866484793496257416259856493587482957111225529071072537348695594958918648771418745755086539672404243468435455614922691041334875071267875391058155493338089472329161793182872605415502672937446879754623263952587889465083012515482974024506303700547794278667536739029569027539204865836091781842095979099980597464896983833312033418068148036099416870991217256675646972777065922275910262922486960982071022004929591359754288008776666205314556217272149643659129541170220989690332246883597290512968292817547469960138932109624850558843703432530540563548458251740803818389916128884564107380377927554030955090368431293751439829748472706494577940655099832463005901756121683476039133485795695397208495963616009088796806461291782584789937456739904233218852673930490171837518542422869715022557300014464253539379770130907001828679637745393742942924263739420939777245314275120477043103602195417941946982309000073013714022977049299652046646160515486071522858510125026538512532826758076756521229686019516236643861044256103454896600270127497654777352626796048814315579753595410684034930492848275912546385929478301905388366502770922904296261409762621660749049443869640676686234525730982815147070574292105084954509636183802284297900263494202277262106346273298509408501260925964163271527969153455344760075934784461266832139952514330249768607822250546116328645082232537397149287150870610226985594932674312703921712201689647303170983692623648013718537633610994267304884724686274443142818383020753736848287437672619884752757520891254092091290347766004298705684071656448745211379292411880056341949058778325139319915468910315101214860880624074088224739933628426458311629373094570056389962892015767941405606261884441947643048736689186423401799688135324726895945036118240150307617274590470074687290086181786558717205596918177872025497599170920256707122647400323893910027358803516743974239059498348001168404511372867956344817513606052060286270870628439157590311659998045156965274784647124177936899464082765921232150928558673393867832500877514025700053617920434533154013622992297424683989961395195164544773940494933482997619656975002955401823151470278628829447890583331692520608980058918604588771018141614644472760830547004909601105353723205204277054858100220843067696044358489288417053911779777636685862530733028148648527058888734952577662015452662713320998042221873897730242685299799949020919872610901220937556378878376264157771582659279927771096081291387570641227589263660184974304328800241026371644634693496152671628907116378044361348718616751343481441762999387959144794856149633766264287145359338550543502403574450566297906658227167549659449971682569731597042976899648193306364796761430963500027369518502867183892521528424714258941396654757315537208349927345921504783438385098575904450316533205383619867919490492230433428758373474687945215479480124116968494047912748080744896623860514834802919426785508712839994810630938135518361550388522230840646638453183986357427908650074058682630364404843361587964015212755669857078199544466122571728060539385378015602874360055774274800826080107259485947478571241263310480273433269041612018874608869206907030535684348688412466809171164973900200423516515617084359168072722684263238409355982984938645447365604915324694040110296398069636366148511098339986168750667254777835619946102408620138809371209811284079984973613416027249191446901665098739727142152623855284808133782852451728093569697499517366796585724689797742669468565268872539798878428345541861849015666331916000495956355163844447408071342491131776963020645656976892893787238149867119449591069976736262537015469780716243982143936721917630178728713247937607546958966361901328145570841011084562097642232937625937354868187273321107873039743053276603671355685099229683453605499731141681728718378187532065603510822624958972165532522593635204874376810200781275036766022437927240950798250024393364045682189134704845812286037422441193122739522406536732573140710828441743539780377865147861896193389749380659879327866275653179078947651387828111930396337490811270697985089816201218037506115014234142814682385102523425972998593072640770790725982414228544633029642995101682258901254287806742301366208828162477387463756687281252994501452908836547072102623355315709902776432554014376309587952657925497621653825666951796394661574770097931615332475671105408244630930525159146961999288995770715582728242072913256023911103584836889339253743344246510506913924657087924098478903888180830049760169862122162975453447015711932604661405562458098481070408233950340734255196874895090512289072552940802931818483030211719516961595929768810347559895680375914216324687844321700032530945151286243597286377866371612859700311552506351798213870409353454490411358344277477826150792145755992594822938766358675158288011584257616710623663101210097323109887979417370263612584058408561358753317231537698348461655660755380659581072178207477288688962757072265160490600631588197174512903146276684731753628694529596685824595885678007158393374747938101982904430961928841395951711676378080535123188351635638375470401478450523224920448602818895251564437834189202441655076943081483367064127416752887771318611109757781248425601474160571124303096368062074727513104959974456229598353065136721943994007941337054705132775534896527968122420469283611331960766006310601910252893459785872191278971330399395239110974562830357605556211522784691991561501390889806743958122904782088893727818201559345083867749044489168363772143703073453861134806218832960790409704879310579717552309996536217584965576262756407451564345833758720479629349944383529092132517915571954489963418248400511019703249483828204180370506184025113885649509409399769397711510007228728095574770224464446547044693015123777262159249799920884371538510122463960052058020131241942783200854033288826257878667417602086305216692912715536488620698053698022459949861565969545496357876743594887244566194824704556438285754633336308260058711894417742350590911910751979319176563052975803605412148165461044329096028626360061282229073291691883497842134279789428389371821455228942452798912977912958394511561774867405616536174458495043002980673610932445441383719655132197637184668163335110303541471123350976668674100112488910955928337286996714611124366551465792608110489076815010708899544256516556491056127346270833501757113609337499406611359404510795587423010608098938597650459332997781990621787924888569110021893517402845363268426339706716754389272990470513536737039987732318209821574773158004394368361313988432686443321166887644602545565041603076909330007914163941559127137026301018995229723135409029401064752864596947271438965582579277147631406637452843077049145457341837232159559730366551507472354953899625929803225701422561284852163965527957074334769617150236291205879362139935058355563169747778333904452955956839634568402701244925016745087651928608816736896469987882537309453244944834414373262938906464005059484038244572034326521612529650748538305485316521177247308396706868465169508059682590492304730955362364037150109353102703539473481458183308919847959243679572900240943426756852783203732123528501086255095826959561188972056318497725974188808836112899288753036602467405834455922655584156707363544433003151873583632491497489084045609299373141002646109273485527932587471790254082751973899027694147514158739383819684253034890946834373388441862051909883719721456276038041023850094627569248404828269211588662076341724107938139304211383814235573153888420922122069650074118928661037695827085823059008478593607756083868239999584244123010713329522790683394908267830112016051994957975600649644301974822906420255696156580630141761950629199586872747965112569565095469854869800403281833556388965700255873755860649520760282097467209698862605898434981759137733994266863639515406534007603175251563989668595260982955865634557781963224702857431711084062719151650997813779049906730415588122420262881103439896718580338498764211791089444646113690306378896098332737896635627635707772111276121536695313757806801348052118367819007399440960078665432399602377589467171594166195848994511848676342889852715337165791189020515662167204773204943614199127918332127383021743482576248998849902385077500814075914415851227356664528451616748460466665152976847232020446712913142880265960029344991220490001756182292717800761425879396636844902717038165543316666346164629380858250514747045491468395622679634227153126619733161441602334688751330958487543155598758421785605951110820924317190126071560389113736027517764010449768122991989484777981503183676348308768180078944633796744764632437921469707222455070766402087305156639658996955592139453843175790298794847443059643374415249421787873000204116964718653377159672324783600759484527475614449099007219842795509953657219555506013243218552996721200522560495144292673408433365706761513733674234568711615287301193667910837956568423438400639397963485968493623913712571443662496434067716848785221486690871940013498223030548187623888628374477709165936052912242994609169592340209437745724218818144600119064099826714575548308046604766436374108048400515726390133789845668096714784867008407173380319008417622029995593936143909536352013256938215644416531080180324802324618594097721172967615098799962908130441684305713015684547786299489529752824756501155428933939409296205517218276045889777478407568327206299474573691014209950666820875099905758278156965131476983278829571931391277816150330174477625273228440900552716318825768863185688529954386089451175385273662218329372749649446918354724443567025222349254449500617488028496361898409264103494905512190685896563250346346478211054441208028146386655248314336718654702652948137658435253312869829785373710193043688043958388972024841165561464326457180133203136125912400081649557668375744383899632969559862047404192319326563366004043695206668245499093118179837855729834168890145742251325448274416525637217013782454651636292195303239600214499858171679843470201696427000689391939448538191864553657744525021360343641380208086955930529022030426160885726040281673029309222840802065136346172382864319126701138148007706597835132695333947879760079153539055868548576156789850188497064536338026379929631234929007846807334812010645525172679991044333308985640292227558092752377643275995472992776698475790987837268792851399292228646489527461685929270374165049749069600603160046531920796900241727037869527459596145880819238533080519265651802795555015701064625591610129446123733504319175294781249602732333862539881844001174584054522255651608769617444327599828563581084600909669099440890092395641857086470399143117454131045827055159803551495132022116760892488889653153960587625841910867118206599437776258771080930144854653198726857646093716759295479410273617910942457821712732399190660866650490310710185557517394324308553105747144650750856879369349462377069251837917999202072251775088629659288184803660320127706626903128184146348671588370808814878328754655521943032817668859558325837576523141169778965733166386323397421920651468704737017814665502038341659575691927370030081718281672624943907725801459555157666049437494098603486817488433976626337340941222390329751486891908768166184463762670896534403352931457546379158595470562519774115429755212992688771218914551662191667783721153049023035595877690703411366361819400655202920269631805916454568041073107237253371890381490738743213309620059159993003849604331778047563116240972981607042015453452120068390822980655208034481099171665126640420489382675390866694573945421665672978524248517728079136569669375989021101850354217557422960696302555361297444201614660760149578194625887224649588332477042831119096972466903323569062428962777789251193844890660811230501531481978959612097815608680381821610023703044066176422964276045425566045824291045559057543333711029208777182180667218083104949199239136505834286628001776139959001219218905737418785641440851285017285337841944056173947452985842634788119839741235296336597559262487718554614436546822943903751831157623580674824591472930566041078221877158999849916636775398181102018674052880692512951698697513480517091515255566537032339412246743208266441707025164363377133880339650825219697569785046171337552332893545340847276858565496437706766030630722861762469516812573460899602135044490222233011994495526330459680983366359908902306295944044245771154099378936054217933392621460294966444315839619038214146393712002594553326031581417561314908364002486755770223569034363166238351234653984593425868697240971720773578144266846388819244504828181776390586079945560272760789021959416347716506857324409906002813134675432442066171228067068885528419141038131029179667706526774372963054478099683768936725773364000366960379562118197023510329482012107157344155875448591161595391919815262096502829728473187341874733253651529919979538531811286641534627778595530733985639584783830665988435302841891713116049103963675865435203124837066057645535281252657153315351003929269787455814660826997441903167459298690397042785489023802967671956590687562052329368827775864424049524191769265315949730487923955413049297486674195881931530552325062629106937559254886715285149290376041517510254575017089126238369735731441459908323625000391457129028083634733044760593008952189043595506011162821891237685214611886906091274976179324857590706091796406177625733347163004518021058299015360077008619141355691143129132531858006034134859471413635076801228545121952706746023220117837638086686354108957435599629954680243222435069621658931397374328297390779950081057015375721056239174253648058468325719338788133801151936515595963203703897529311280939274519350260938124229883720011888795447147955456430451126315978438040080489704091830058887795299872925112565712154018417162739997545058930991575800581788972727456060664226272478064852420923999507537882444320718854395590876566227281632171045068514052351501673709403201037188250295301734415546890351185372093093868842689894001551600934381797141922487365311721131325628216317486392434826534327444835813827040146040623702648032380447448136154616398503109030818895785037281436914811186726407883525589623745784053150256537820204779390766220428603926382471986845043607824571153400160052404381575056198801845131518390346351149303614811547311242885120974347678264504367422058114110590584616857433600543740991959073794058140903494097716255074997440636144720728479858818431649567101409884610735460498756656979805396736031128522080195025672224591817816046577402276820084711291274356314869576152330615815241767096386124487945441087050607753895420887678873857176400381643559607194474756870418606846938092225072149441622787084691405251105866384641135662322242739576886322176214547207279725762284255464168735963793003697380346821240816624664408301727144025359059144838660419650159844461274414337264603692360330829781038559372304769177150910295526218586671075425593440499090198871740910802116275754099660717081809348908577040588631693074984232662360693119209505027983812508319223671439887199802525968038619436452231817179841365769913890926114871474823986102558248984056751171047487920908703881344710413315117402556245735859539904885030456237268421343054705364347991234047913856137332488820079750762203668981258672591585746354112878783999551179429905553595428779319618205955760109855092613527644960822047320473227114766963811143741244543560984456111125291941526870369848525824391192559998244670495612381361646167116316134254469202262396491358927397506005317375010817174654504297216767011458286649844846972401675100964256583057423372220731293103426957596949490693959409243387593122271779730186895385509002372128203913747196497707222954185403205774019431819289117303305570247189365499173945821877882947041265338660691701329332190962248344273179360681417405107489124186407998243259234573342968597256163713209217434289027957190422218111924387788256131382512827800678950844810180746534889923898689642780000177422130718538953322034407815417934026037724751662822483375107800778896663583289121202278023801612863043235964927529347161048346388661293376210119688831516982901549177542348947159080101505257893914409911057786247888178114455119581370181777267188461192806263311755813332788407091502471672700680467132633477533561142293966656214747737409578555062844314602141692485230285966094671781847301987395271366469630767558062112328885393287218169191308218491026790992185940472657740498984495459678622709378403150335318468905992328881663104160804687882440812818881405288046436227297457076591968843740953385063083343962623712923639380484489819982491016361780280276169822287192392447562183004485125881771767301867399126196483636819125433619352232936820141550863954332722336201898117119322617189636537779715466381486919126946687930671216141452922541147106709679828617423994874259063229649123229518230937878691439874612244954074507844778683128526476317639118125371158467622560854714456375919537991303413072742967677940130456040692658489636525122293276481109808057346731810379189856938253679165389325994448637996699383494712921721075102752165363287472411045626443402092824653856031130579486630852299223562415803848929872524176136572203720259791428116844323532933588350929434768591652396279151377056649946904423876773164294300631366488764834105010682185485963623493414811764796197305673062714223556389869461430429375897012606458055194019727119699064615147436243860806192462008343479759672764808835547065006227356966938579183385683242312914357531439848379226427244818697458161912778146111681862542149788668492334979217146007920768310239137555938899242435302928517891968231720891496735372779516584037533540785957755005709202109126682981133492715169216867882096335742028123146922474139806442352071726795065748233286421357136259478075789617951692483512515306524891863357257717679489398290018317806682896210611402661100160374226086537049073243154990027642836396613193310176604504810534893772428808909650946232081171095067517581083996381726077971297100787766219854892974450821766776476654920958360090137474327967048906416972057811898669752411033820021430818244474866948828089694542481365682716635711181667411943506580099933345985254871356053492593961261410022611611638590502797062851727396497071058602567774355094747163736356397095850006997424923531112267182732864620909866113824820058603582958531094555020510236027027614431361800988521200399586673119547081726414690946264630190526634425644735734369461310520499007520355499508585543263341743900683573459238052117903500693000834091101712801538465402378378788144062565678935408582810427199506747176661448934111477635429452999529543080018774599929511274133290665853831807027349385053891990116923477073601573652090791807519295421039777391917621497541985415302633144183175238454215017098774097235275853537209261772618306543730724023082803885507581143607139751832537169456162439207812666381128402696526892293998914258723768720017499847984266585234913600117422675602853831759174426206891377825107340342701248119230213445536811698998359038183296563935302499327006034285845728896557943782923399556727004316890263067394203880281380073469638121484580199160819715617289728021829847401418693279991820133854136572587461373226302598594529298221390370775366987990983177009324833219732528831629990421797299223802093648161616663879975810476101783579393868468502081257564874766384664501509001183842063196032638224612125668482059082665228528142159069942060893915606313181707310505441794055294071663547920016602694400545595432136470930681411209271045562029874387463078108850054385998584637189771275294132908369193659781957985776433491190297689914665426509472196522411323928378195300561602310224530015347222547875758340039768542111436297653638278662369121460476330673013642837634923317515965253459144537815213719135592442299298816576373126634138038960909820457612677675783457258671339723120179633081955516804990831567693301696939699672015449317249971642551286584808129342788832029436801657018628358004798080608105909323093198784846845645325386979597398678978830345672780153323968476179576140696425471821998947380199201341358406139850774495886929512793237490160142870088261156365616557904316857668388922739833923102142619761438181312790544717406255524534509231320343527106989160031768626195806563471881286599066109601085681638916394858229430951462409147214901977476398310691648884105776491098520166157330063939443875435796943355719969632950102186397143687779839736579836206933338819143959159363406579332971362010077679786530037433544098847138689261158878246792507024969634114253622560056328316234987527324602651240456647339013865004249242977561395674701577956969389900249185989776680415380350732334128309923836114711035017617747769595002949511282687656602753426366555822017768660677216237740216507472925748667967000999718713527274444690963987157522627787202354721060271353729547313866987732075979117079846732413636459165812839433882317207155027374226318776368857252794717448645253705770992655896057862954179644123532323636460584760744250739359102987786758637467637353356965608822802371506831339109050545031443083639828791912591491173211826408402061094497140550687518456511418634831704222491420398551252188798829570316127890035938622709348295255719221696461602749283552993638948947540135681555161478489620846449605430044941872799703773058974361817501697061476133321363775760636069455030846228779531268123378895993835780337827038608856140980413745864293745914406340229750270769504339465352030356216744024238713735806990797168008854280945697224613839870090197940155282712750709172194380153634146926816676024515823584088231400463312382777203125668639972061892098691453960817235720605917593037228214044515858127191970494660211930516466145592663099310492447409876759547267269546121606395117066909754582947520241309163725053673240679714256180891234020254453276258233353933830411269188099460453101101892000756745988828048282222284444127415763956898935615592190117456834504468742950360516492684416298793335152967766928852074366733814540857573444455528985644845185065034346112640402659226060116640258934520978930605038249624160204759818066247093333611839083145229529279417098896841881437979538519201155777645178826287972935358996390354906995489934248530800713546948968183148003843919015314165041496161557496179086007896577579617867935268933548581362341854451994408726034928832137826659990639338937799609636453283954242809205539456878416214070953644356943389856818432600837207778616720748676938374167354667834832060534863893167858537784770073045535612859851873945303743454718296695298634664951824381963669712257445362562336753508214174025503527830539500054913297955051787866102185934642635331258792400637526092515185350299170488147855128705105659867618088688753087658254737196930525115823965358676681318054168230606026317957031887517498191886041759009170380803971677533808855847935963302413449922868960528689064335811771892647412655405511386556297232825727620645847030173878179578724353115411237535609238689560816107970307741703445451087116907161445232553198068240181847253666995114428407076706548882661985472194213910892387669936605281007133618963508657753133705642673696817486635123227343786590893113124229529397388254617250179612431485026422687552078010821860291619515171241168065674667610207596394151847581338526738718950716228321620075816773740443990198310650129401028199155101511828634637136915354619277160368249371381078808111483113736277999666680765128118757290998894150630894070077301710464719965589744182899605947453537434325424659568476976257807998688140297038415134478560327804024687366732279706746035700937983217159762314919697722630018306620851175305234116716106843307138903094060632759586446063354844094943376435539651295604866223836562905109269402588222614796293798277799468218379916416521276024309764723016595827980045529911394304000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2477
    nrDiv := nr // 1099511627776.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2478
    self assert:(nrDiv = 6662633323731567683137463770425046119972136130490599558899123904210782000048955657546048338089665562423074595372134746708823296293971339062117626089251555169190147414256458077270948527569093617282899634080762548342679827245086339014549187793286219479991932728270136570804297100483133701307636938694238970905034502371154888869049996596580545736458232161676533246213776471749761506965201454953608385742563840091139275162427885091025804146353946887012629948484423153743921621737866106228003445067333011961381320536910074258682909144677567128910488902078543169686709037300189304457148994986416728307763424855244492462783182558234861995982025264479668930619989751791520673311176554512802339256928913261821455310942897696812136624011889515033152342298071512274969356920005509130584511715402639886394993433908317400104247253605275804809213311644722625708569208536590845345008858415466399942051501903967025595429523806385287189963483817993580193128873368523227715891492147715101325512000610702205499988933334611073532341758081435343892524554804643431682872519021193151143459141893825137519042963177852473768417547297991124700818539000925406141630391619735578765993129524005603624473698812857747129288247152154569878280492149839872603436792477479782943819217222827905602197688669811923223236876518868169077065932115442814112611272507112872060586623457737282248353708537440207167545131324624997338441147538821782465377847014831893014759727951431431968895008978190868943052008828655078064891320004323949219391175626919627742850388198587106996637256185312818463363915808151256605758842792136336001326613101088899142459264924284800653801657455269721850699589180141531487149252598219454805868157021677473942233257684196639595334983355790828424192909541992782433644995416653317905481191664882406344528748368967757631115924249587936451097739407299792209435266919538221186568760660301420447293747151306991237865002378076318280180526977727975952198908682179738530497531431395267954927026964715297743348074891340859860789456898608224255025187495012594124570391779113664193099927268994661989714354273464562908966902793335276088839025616229178681024727936638794047725854753445121469971920000103358186939952444241621483187255438734831666410707469056761064049453502111688296190428340923841441148946475354163955033838270461267159320949165980839533335114464512294874697208511171752685785408153217445523193778985790372496161721264624578255386880658073907934058789510812259862184677985571129419404726995982428753663670210728075205992308115237575948883416665937774630699551861339250087280966997886464539913201627606531742484162972849780468425532497380768638445224373234076062753384679812079141062759905910765766089004401051262864330797018433052954090763672692099410879958238807338698107808012778508416688011598376942350173207376910229491087872782626788596807338691230630211536158864622893956734099080442020613927228902807774992144293064849356703912470587347365098361451500658414011543243947940570486265588687939149293725873385717495020907919850152172396648759758331493330026994294732515271227954608685062834699381201564024694020978463624585016140470976879181330265581934326720818333847725464851389246839097102050339237267017355400679094305414741521873249018386912379564657226367474609265595843167030823823815888307326919859008114043629727548060061462134640542960003237935595902000153006810199318514370026314665866355006060662101944184764882516982242954519270451909066555817897156024927674610449508845588002992024015689920157493765829176802821931631590241487238873985285696003426340287794076918847820343809440277189797464887583441187676629382340618054613952244943532083179065762391482344807692465983310435881557512776871445023245934926397204809407259057481926925852885928369964436177662848362828687829863675543005561550690069465524227034464836091588464269332378546107140912689644468971000647070233491616299386491375149772573753171449947304356213004974407827081491882519644546780260294370715784722926779399796198511750540506872925851061282487638657519313905164405423591836522816111495281603995252289872385086476469229310711401528527506301257816056801709876959217865896545758738590541706792036682061363760042257088762989112039152701520742768623568505674079807810875863485081257794882308576605276750150366298371039105968353284329219873078273054143543278652910514327315532991571113396292522800982678225773832322663106505081384006672724636320985174081562785472030426212309827534624166323291136226564299729779926610904852724095137745669038747074706380810381924397482883612399986254740569208516035970744086352728731611278556045932012031400560563908745853060950689115708469515692155527082269323865892247308760070844077451853262294943617058144830374014063090229211365020886204814145346309426230627122487421279225644442725951826590928222475412083281764588227804815128066475027958454121524220172577508201782648035333837955540129683619410765000534937610139700875341476734142047589998542737528010306112593043148198988006188165170845763794500602249285494318364329213288147091824616909725569939842842543596840734083524325194154098463289461537667911688662904500980902221288027220544655818218265475837746996472010236584007176738575972462375026150791464142148497925800115687265675808142920616038812782060447067014154305466101224458342793123964105995474584535180862955288460196781648553085262219550209211207588026816531112456709030305544360916191463216584932837523535301571859795009182479596217471466926212940178314362383320867455900637582040017075517949772956047275866807594416084072169300543338235271482325223007196166301392848144570452154384977210957293114632528390739972304218279369363788615170503593817472053417243282259131772615839858816679000902088506393860091327261674653574046859271748229366456048072374228952936986954461812960776844852566037819383835600381330161020048169786575176406335437161125603009418044684750306284400745015540086325935345626867567751378481969009868769532841174689642757402653727086965191901579737800170435839185407005418578658287140871751975359929956215389060409882342023572364751463302859267203670036848697371716329102635164492370580294469523800234173695676967556158058431931901118142098589725146905128352892769397385982936860912089503320533289229159009276510219167066390676852427014511459354368805077084042375052908754180535991959079169140810351777905505393392636393431646479931302422033114524318678899414743110703321665415570194813338103931163016485158053150293320176682849865950119830732697413244124732414049420578484034599229592065444814927955090765319822680007274309290373729622349451338071624805845426576853103003370567780916419402325897239482929120438541569564424943334867982370378410776501847576669342499380514197733899878037687667052618283223365943911896105902249524831410057706578101179674765029139049616899153094252341846800968999185743059608692632244338477301941908375137612702490034105885096135690595893486578406810583373575282511613130846721636016131016419385094668786170270105099382118058667752659173909237179323408143996490057471550438372565855669568075707259687274506958695435449557449093301254608165917100788931501161845710670470989502338362996305132945287246866702609436316376008925088459078082627911685321128243349354229036144786259708802466926683070160849866228958572801968143008687496651087821709717221337749533437341262096267973190948389492727237032475272862079136719557335553937772424498412907282167253204658036522663912861489967343545754246593032273458846618876337536007203682712249257269146062576546910876450005243718339617735736623482032784880126505138707551223982569305519703270511483547382579404918839636852647345161672956598447115365954967174398002999413589275624553356118459301663295512883021676137652660825734676124215499674882903247218052630206577642084012432827740455157014364420171474367291740649414319526344397807373512379561085192818359161938505367228336721095291925155065811136228538259401638220286361061736441517811291787368531134060596121120227508274377982866581596616462970013543016021749257061326685130571812001938788851323431118096288750404400065801469551796490885764071976072881177700325727466583683008951024461863889728341965881114787320729126972054716702704109258400053128328990837507682205316986695881175358221798319366772405548254243978588753267948484911744969711778505544859566371008691126381031647673694280468482450520966964802539436922158737077121750002067704209950517947895275485187950536800011107737855580525830416272726621826086807998163498280837268646635732040394769166712960660791026071702275406585969427586620725056827465122411839751932641129741050664123546627575912560511096417077652349819389991841973046133599693459503547277028739085889123201599430748088793537859468190507211174911898362104739455512577053830969074103537490200197207200049611998015566197237458603889177541028426143550097544365997852341124263498329937465890381606795295955418098232523840580315613869908469965450988802338848428525762122401606821882953426082028665593848700047602082113394220896647213988097023709581111850996949900598384480808761859793798146684096848272987669550104826786271426406384927141254967004421494402774831090228439159876359957377770662840899979305879736692449207314353197306703720694762653242964236415719707807709474598662585817690053244256584634094675588772387320728876893030232700378159568564796767815881221577040003142829035992250009683957501514432958745506657813505062455380239289536840908567419834056655066010679741591568523506419291023346414842722152449355047334627139443779463897483726315136235890415753009343093216483474653995240946721005159273994166538118965875301947867114969329009355586236318538876250685609005070430253377255824432219814984476455677020466705546834887611998078233503929866669094433324734408933206886290341422947478206056966064334662828420717990695296446636482902339973289591596091373182364602203890422888673967906434865718458245218781812358691248643177646331019984492877159627032179896760671627209600850253346391553616574626603287596419349597318213312704240279836597936499176049259238779919659359224267409788742546907956321200282485507559458481839743848993694568980420138364844893768971338467175415458491804391538574796876754405099255829357011671106608209724284478263756619062561946992484466017881479781226530089273673529323906138417286165020182482970033492405254420136568337797393833604513114189281093733322434044566828573546466011111351374026204357974607838989739784779000309310988838440677460786200468664461583688408649555734386828226224795341890764896222022843007212559090108162021383514450324833808323442944564068880379969871474643609232099524672432072065066171371327688290179617734777653046940553660629197979241904416814835983950855274272068765736863745858963201045536085042989062938403688763487261963686964428476887533136063512074332363974690948558717214002383604926898703662000671308292653459533824119645680367911743181294681283019279375110761642291430932623265766493454469257647709146798421760001872528500721048437772780065726775583559870942098046438397119753740490868306016527691410327914835147693629474332656459501972550133927210561728079422781253432105249315186092695867012382237378862014890057147969807959315163943016544546298690088701484361031394763122216597928194997139212034462694811542459062553095389537586038839071235015814370056111693269389352305878495387099950893625189881278100442169827936555834473905275492197948797975758169884639129722925686252861191664712463696502617916924251331904225415709036855212464161811580220910449150251619842632875245719603685469328376161861492205183767960018924893683703862737234341532850039837857211248675033249758162682137534755933837705941315666354487585368176046276495167470532765222994435005694159229340308269782771538682076344939357692679425354738694430715010693246526855161993822050738084109068988456669010456828514452172338697819097988850645322196559280542955237043845644875480294191294243671628138352015652035502147832020273418517146314693212385602848033983824623687143092609964470596861648812591181885313558137704270635608088146327043933109509820109861326543893172335781445926340867738481148623616697386431217916074089554450405103150269058917608330277763824073839949907229906564057762087349990311778587768856946330357372471841275187565424737767435082996992995284357197931917849454730570975669701554500305138158088651708126085216389971524685018121085532248742434165580153047378399460873550609161599238566767462611149933427772707403493393907424627064456087353573406713733285621911399526086839253252364920421564239246508902633182467505840796787479557927720879016862471757675729538193109452262750608872435631538942265160767804915408866767719853735545879556628651112971951932782255758506758251945975744362293034679502078243875384929350503323125647362412515669719705455290178369806457412764733465715860119591022250156219106181326562931513112569640527774437694546186046408836197585138256444950223039512425447239856838567382824787147773363964308297000112321579912390413854219643773041550014586978847525545364794414262966819887507035652321303620752105217176216667343339142387440168685055366893363995549376670079553282967791356972668015843949376745456315682701891383756331415264006206237965084878941733844343257714837038003432752137257495692759685719124680847167412614538657367006068680166919216423380951198784933649947788603088487475981482143383660343066401239813051800174000533422015517445025423914324655725411380579191151076329105654312915546930776739081083130851209560307261559808003595454190858699636192994182698489579919753682299765480387055479694566268008903344458287769365183187828409240957337041346594822068020495286153916970285888477298328581357959138997929436797741893882044055962890321491207955092531472430580766283693859646215925564679002104430854098259562738959271344578729377212911592288946202639427352171631575468303031833703338256634096377869121483169247318904967557580606897753481360433243071165788807886349764388293820695191793366944295901792867034972217834675333738411495592200037471295720880155324101436263128307034059249353748610108195767389020979150086248268345752906071488861276742315827848748423651031498876866413731293699920942666225974254628767337160594389199237190034723264888058437168327407572709723914804838989858772126647736411522980570465381410084236050678330973124991667963023842876969302469279748200467545110485810034399278411447631362160061302813940661759884034612358568237683981191908865801458121853442888039446172937851735631594598045659655670606785063854069117622544099869154206792904842994724111936422163524033921205447454737571280459967114554653337916325943852925554693909749040789538931789414251732580009709193386661331220447753688008685205153591603394795178887882480498680277349305852539404087412513732493890167379734424193689730774421124197396598209807938986005281190551806069183559876875280125104661004987176879496554550976559950467476559304258484634527452519381498017040813588033614753804422807393056528398772163482132360711680090004176924055583698960466571152646455948292335532725821865747613587236595247530568040947130838943692837511089697894954146145800686471738817451943314160624802839788362893581912928352442591061642144413099049343949783668458733212864946888676178097687428090333954322728693913329532371868758870453268823927363537857721619750427589553115439726294751268818431424046653951176908373270894803348106787107152478615187412606784084264974789511303754855340051658833679689870263545431979424720394747263593027757345678621399456268980783872231272861374648345111361698362447451983621128788960537508008651496314069548689924381907425158401685801106563911310636385954732278263100830980578484843580473312548144610442900203565265247985546564550976724435723289297624666247935684674418868117603325806261281593378413719037238943924955877274085741135966282362763193106721357060382514254442887152906589877023423856680625901166776450727839358966536601644959153609144391132902459862060242188807417448009183469264503039581145496052228654052676496725272553819319933882997243226530495493561285061107687030878215808993975387490670647281729045828867173573105303000586136076645167624071720961141090470782549551314716665078642257836261666920413308268644174214574267682237346033030519874726249630752547960543633630157639983049125491329584885469201996544958519723770711888804039467535780543824274815473477301096898595071283422404678758221733495070552923171978588751150443266365227380501603502573111410088460947042358483807313590240913510077173949793948813061142184688143009613447113936857687916497981028674162941533323818450350080181784482364317988060883443497947703206051150533242121659128958857349455686882605353850969092935960402982618118713619556828483369397811281916611054914712416483805731465976494964146531569215799109721805847028410300528694173153527532373153045249500878187581518800314615156447564073770740022098961439234138937750297512946800381652855912829289926467970595537813845166063837126428330597144158673094574735851632185151893903271146216711815228383779829505875249782822697691614321461835203609216607002918525904157716238810383010391065426897393809125134642778347338844701765770751671444268397042348815101706901167231064172608725124761680162478484393439069367788364606593491099359158275214720362749380640577721088524470104995681138292437981278208476931579225731985482925571630931097842007340469617197091896460102706347332362145513466773659918337317572988046499916670479070806370253529002190952670353070666744678967350036570834703676333309881112517065360307108417452733002563964433340667896821473681133465222881870547446871335962511010619755236243761374511519456442193793333594411207392794004105476372366726747732579235992618924015878318955393497608385365476617805871466249190595260047214394069820212568325902033965922654033888417912286484711896882467251228378354183552293400075258206316865187130275079433360393164503976387026629881917025668725831325016331687957472029777811248536434487962818526601321326034011639998240520767133091723253262191478889477732161417549504821178703052409631566820999340775276726216946712534308446072712286153652680439930352040093862145659622442078648977666579419037446128195327816883541805521638906205222812059694261274802822911995857217067861269000490423940129053596411898677534589257055289125128765042939890889550610075923551852304168673133714809214526655242363576702244447943074362796222547671711899207308354482159297375955786574385854460819445028523296167863099823730022352090642566296479684850099511564373087943558717295760938927621289992360634932091140965012523878555060864106373640658546915478306374170806816257322333143836404972687537427918835335849909537778979043364004415979697596187929554163161291338782947874465678267621156819384376292481035494619822724135714643080670449194349117313575477023852251462157100442647234811207590910430078679631359082941846933243892425583167722406828385000563844537531315125606281753470690926728570451420660194661881586853830856879082022622614444211189862027995955847075720472590981636180405264920542673876523908199231895835194289372937814963109185400558429783080140339774478333285537556699238361330987736558384436762855693888604544252644467982372255364280010369297262804435889271193485633563494271128632242998571978869071398448928214066950611845110439059878457358040260838872377738188879643075650321115830111195188171223607598166789592316367410292281897474240707780500277373863291840300035279288645802844513739755083609307623251094215604446493961519719176201768010830924261149752008240975627953538656464432802892397239873841558197762448235088987744283265644123580215828629229847756497333042088017137113845417927907308370118694686418872787249521013870679592265695912127418059324065039553961809510883312277292682811136302844531110387585647794846826942508306109847156295035588893190647972929310585300837929143605036855209909095078529616878524697187949533912616220353861101335179781717322334159325535950830348702683903956713848030991031789277686038206518291309335679266186892665696297646824642372383904924530689265908078515046434592113144186677137514316332139654331264735125017720528644967462490620083319716124344933995590200417291717086036610960506908963278468132327493231742534480298990695134370300218432020485190379781750952733353355873678374453180937874211107688414514621736824496909620169986303101752871651896892513684703338313893053933255183789081818233099194429728174343667583800232334087537030361427268946243458842786771044962553296095536703477989698602508257697525945310759504846774891475733740196021161653485418777347759620656145992080798847727381685645525539961559324870188895773727580412516237803781935982581716437412611301343261776643304819481868619659753341516913182720637517474858444413157832505693243741288479267641371737999729095261543591838054428973561736725472157668326318183044945915784847874576066830414147706853941955038585159805208300597749734377901157203392876608064388184267818682399190422948501056958194837938391733278658784527755984424606731034448309440295924193353554895405585796132948214826002362174122627776551327343879146573828709566085927128207558802117131623323460157076665769242068403665185141160275937828400136620241192456176652835846834240452613661806597521514177023165047302341679295555551508051653415609814912335474376911818568116936865517199968267319797266790612855146314008776741341483924545019506352746861761799184869747515293258290656922190388865397288264923207565564444569202307046632552992848187855320763025731448044322626818272002953585947000990139604564002024944509293877714454845365556042038716302410519861492901060742979671634076805703004367909180382050303746373376482562884571531258606847571505895674729168873404018309675988438701948374926299395721307787395239134493403106002139242002160785480851729136172763278326205183918096527325878045633695581592505417560999763617198587755156744222535295963451807660480724900277337461447992209534969141734072233109797259073570248716353319773293544532922325041060565932210392148625152030199085590108347217176792108238881854901342897723225511945547225075822119388548782819368313852606548106078809355851189880251783054363594122321357531048537249744113050418065369091565603073630514273403592269082568082618298317632108493592673811785028807085323208525403120854794483676644319669608513326174279234197287824669726834966393161538408455310478065279133231953852910635361742906178576755214111517056327801824696461817882594873856805222646175203300964795337063208197930123387100035611442898962537621189321957513145288545491320961201783084023485230318684859529665194381535043030992718697406456699814963178889130392858728202451771804840042186083208062615168997950766084371341242335363877881080966617516431705681821487035566981405152551846308469495319182057575043059043266754766612593919342214655158708509550193047862153144017813642739949190337390404536833912770771422453449645873712360457151269709782651006515869206669914944100670221090425818628601774379853413256806505273043406959924949474450066150399316439803729716402849663145119931714415440906395699971756190018053547116471909246270169142909777111146276158913184245342769165725317045526866422285400296863663896924113569981788011574855928342975415991851606735244243464910312696061102300896479291942510255551582184891858463744530673406535967971578872825659092205865479824130931221984452835683846238511093397524783198334851506279344401387929443807027481880885621453705681630631089489476296770158650928120354413431647606394294397787931502924588063599432632004248814905232532874069922767722869190218991066223241787471443921552795301565594166172669223986011515539182639311651756170781133603153285133649653252244928860946768958545104628751685086750644332576921314119710268248219481287934045631571968130610735349124325810882583205080365791756610466151484981561971003167210505449761394244116973473697036540303439437127913553092230911492056676149949338521015670614036534613837352259788911948678049240902575683723282770265260665156443670989248071839321931056089748674072520359193076479425403027075088844834493105461097317694330573999345150061096450395197333950671837028176159805717611029046806473790966566257139710214116625838120990838702278978040950346826860768941596869691912534837789531369798770098970462048699643710814263334282244825464986836886245787380161175413667682434097411896621020758210415293844773093205586852281989095832718586711802332595251072220032029846195189676026260605198977294380817877532759426557768078860163274145878332404258531245748591785784732434092195479770525481182815991797959825445637531042041590611915627213811517825520630848877424983543969674297016002608547715519350568204779042177473285067882211063589224482812938087537556266733962298371253557488669907498202166954216996752726405369916819110824141254269240923809780103852072731728780585669680264810684354097106594938306148015694140288412584934322450220045927342286585818050261340652821302794356397253238260769202499770588659806660140473202066417966673912609639439160027102210101993702837140062159911232700217576203854458672769125159295245759720586896200403026721146586614053545788918421075536183109733062570888899435174093277080789621706770150853469920781327693942173755821341587589068464271704145993398599584907221853546360342946465638677014265280400684536972824228071999739587025848471588041430734190747718105615643467867746521139598415490025819320522905508995637789651392767316376511141387782210136045154208122686266311800762358065599182356318289546167933132158219689983303226956912482902682742562956882890951086189973976745290171180581408168481701573057620693909613412402204890864681757904552161551141827082091941308643128752309062650317371816701150436066224566268088838544515729608051056365801398632700878033879524508762180929699446191226165581504065642383358322411410368865560901282689855037225200599153216302477288730118415860928953243258084527371265976649892602187894583446506824661341966822666806639851892328985271557775491086085232594029385055865408461916306201785026239230612752353078156174629354046816769484345684696264666983054596622557352665971692310835346574330345201496241524653879367068558567438787799759733850664614404312057082568243566243264611755532824513206338793606426398858650893765086655494206257608941685693604563423189826136067320528442662007709432015815995036214543984892269361804846433637715492042002645350444584698809568222374258222855882789968774096068488352877738383142437491050195487809265738698926470769757932536635347362729215411426989493149132973739280148089755991263176726327550836049914656986188523756036995278451253055657993910940418752312028175505678115214204318754518113471033399453567830296130632358712878292350291176995772240851095811885600382819425746733946859746508324478039308526824527611422610279849667882833495985958014136406544044904587156035768010650365190466997906703837332597903821402668562989161094199987830477977441561503597197569903604778604440785745969156513821971317777734960593729892222534437766021930681857290367110308403828050424387397529924995329948939921686795128871033695479567097677596871009758030829941780656916571404797474936364060896633110223920424892718562704497565532610704069917480058569081099089548670722155086358551588683391157320485122061215935067590527729478682246827509303529818583205679553217829813233875900878129084480249700435621359221893555421656631016079536513126020731283339909012365473738538062828153338806425078848354593519707062428992917258579885576722482493469235679741940285114466917413417283111876766818175178154974443863226366736031059196645787709286298438367096300335933725467680069467499909440931418935197607639590412522403641379231449900907670483429271445608187324020277292393554157047806016393560149763762182381033522232890923572325247499885048067389323525383500510263730424495499130718179426732948176129997648391216839998908481381658481720639121202961279302722168225045179081535042109498981072896761625693992602288769693937005187754145411851890095543833095500128837825669543033101870261359674246173474451228851808299126983017321230451884981315322155989426954244248673352579392307130099271620208255400787072330291414290702789609332401962725750210933255324797504516682254234045089348533324403979456676711927551725019997708120073528175550873441080737501788656523364635812866580670909840195177187069318284588267347979941912802844784345831364593611297335034936808260937486987558839356538174069247197363090244587530678334043312764406429614731545495099078344877149268175885053368093750005550979938553594526646815969088249884254428243750041746556055016888568949674554438216069776702697157696519299935296262333182662282071313712716657449342194593759461100188202234751465974594013604537342017369078900004007398193157716190449076813514282475822804094059889026022698518255021018566613789118518865859608084164256119389391264701034534732838558655538866932858543792259691591598582535802657208941556924876214292388229473818284170474930333525978514942722320793145416739308926751303841482388060395770004407198042502238999916987737347202218320069564664408185847098410976119863674399888748702288385011759248916565214546843591360560021875820058954120036097112067812578695283900444351683579270658485758109768365219991018268073673245141452415153257605271035668837906171755807778795902163789814583104706779368230557138443440606785024625551792656071322197883437365090995952783614348640636205281691939705970217021667929894789600090514708714961369322666305228197508897774024661140458911672537766440222671471229951151624033617881679464177246524344329265010491386519425837542838886652005593924469815109793867033638413339131777000951938840890851243026333877482047177068521520544305276389089112946918609981082936282961399989478134865584383041240801873372522978899733132202333335987926642791396387737460062342731173436754915777886939051823043272012214390567646298815125607368226168423465650669620628282859526350836831070319248452496846476074443081172225109466966238064479543952636729745422601763049244880363951554887868547504711176462185190973960030994451631839790904451546992926093730097537412791241442962734438292246577722247574954339022031246782698069255135790093514932928713132636296283824008266832812586268454522044334878454397088449487448684427415958411238210941094006226613223371481809171527041133037308679802333566255552440291287322458475809170568522887554612352531686985995739790461654054890515084932431410095449297397334371300261611842343335002853735931084493419009859313463150746745937117993181979237854420065153129725284950418550289719097671413347458337380367124698634870313774680629978154230863821318174197007261464601533093656004192580013539666996526642684130218028293355797487475150542981549502578133197157285640759714023684275189549422742879177088739931596862486920921838596493421040431594601794077020970428521385813104989350571619913186328653424264834109846015474715734651184107559529340562123342071075931760092972222917153919505120979479996210276995493277547148424188113124421851635354366780917880121039406318342668232723614810087913563184193944074400000020651241097090115446220825337562270086194397603167464030037171560664411210284016084866369808922429203707401145416737524009418498819459380189832249442354578023256629134645025981931351423342611135080339166792819794476094517020997632103158198364641168737218921911389876768461303546227036899870881483511952646784326359096061070739854717639472509669848383820755259857413438295366884308513205076426798185817815788056573628577324171420253648601799962441876999872888804170580893843687132338423914822285568896284471765223814674175029590016487790058849831286477480407475595110497851792057602582603288109754011617841039164041788939682140507881575497413757336997711464163036851800068102118379858493913037721693270703130811009983095221159466631384296982518861383773854535925194635985429767708644654123929591836266094263942708064706075219923980783237358798820516481950692318906711800446498751709909979900020671710215406281991004707258633142090505396170787878142555678201300875442645229957683266757709158189715737432850344877702847733425342431295550047738114568208344247343496544929502270432466561338343828440563277268125158467734124526783241545350253573063926687226489187301386880367871743773831272945217558791867709670520632159570091273556679942194188558690863824371652669539531915581994312990167794769961244737657221122396671143145348339888308788106472726956314213678731306378350284933844004198724531538225392232209225298926342191000074318091592696527655035644027580633217085239808870166459729569875652231485870496109437295505607599301574917545303951011217758746262472258090053525770922187145661490148423928147902289750267060551777528126663244728440341531399236037845248645045749494529414359698587668031857404946489919370523756221679157359175122237772519306540269608674683717879240004803893267340482396305758047458143591664086334293012096942379962669398733948440446637417238944756499755791140482728310365361208405057637360065404060663154368075449918453718779613880795113316906626929645900669151442129735202430154440704000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2479
    self assert:(nrDiv * 1099511627776 = nr).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2480
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2481
    divMod := nr divMod: 1099511627776.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2482
    self assert:((divMod at:1) = nrDiv).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2483
    self assert:((divMod at:2) = 0).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2484
    
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2485
    divMod := nr divMod: 1099511627775.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2486
    self assert:((divMod at:1) = (nr // 1099511627775)).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2487
    self assert:((divMod at:2) = (nr \\ 1099511627775)).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2488
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2489
    self assert:((divMod at:1) * 1099511627775 + (divMod at:2) = nr).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2490
    
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2491
    "
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2492
     self basicNew testLargeDivision3
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2493
    "
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2494
!
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2495
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2496
testLargeDivision4
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2497
    self assert:(9000000000 \\ 4000000000)    = (900 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2498
    self assert:(-9000000000 \\ 4000000000)   = (-900 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2499
    self assert:(9000000000 \\ -4000000000)   = (900 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2500
    self assert:(-9000000000 \\ -4000000000)  = (-900 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2501
    self assert:(16000000000 \\ 4000000000)   = (1600 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2502
    self assert:(-16000000000 \\ 4000000000)  = (-1600 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2503
    self assert:(16000000000 \\ -4000000000)  = (1600 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2504
    self assert:(-16000000000 \\ -4000000000) = (-1600 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2505
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2506
    self assert:(9000000000000000000 \\ 4000000000000000000)    = (900 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2507
    self assert:(-9000000000000000000 \\ 4000000000000000000)   = (-900 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2508
    self assert:(9000000000000000000 \\ -4000000000000000000)   = (900 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2509
    self assert:(-9000000000000000000 \\ -4000000000000000000)  = (-900 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2510
    self assert:(16000000000000000000 \\ 4000000000000000000)   = (1600 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2511
    self assert:(-16000000000000000000 \\ 4000000000000000000)  = (-1600 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2512
    self assert:(16000000000000000000 \\ -4000000000000000000)  = (1600 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2513
    self assert:(-16000000000000000000 \\ -4000000000000000000) = (-1600 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2514
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2515
    self assert:(9000000000 \\ 7) = 5.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2516
    self assert:(-9000000000 \\ 7) = 2.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2517
    self assert:(9000000000 \\ -7) = -2.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2518
    self assert:(-9000000000 \\ -7) = -5.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2519
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2520
    self assert:(900 rem: 400) = 100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2521
    self assert:(-900 rem: 400) = -100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2522
    self assert:(900 rem: -400) = 100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2523
    self assert:(-900 rem: -400) = -100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2524
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2525
    self assert:(9000000000 rem: 4000000000) = 1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2526
    self assert:(-9000000000 rem: 4000000000) = -1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2527
    self assert:(9000000000 rem: -4000000000) = 1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2528
    self assert:(-9000000000 rem: -4000000000) = -1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2529
    
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2530
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2531
     self basicNew testLargeDivision4
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2532
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2533
!
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2534
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2535
testLargeDivision5
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2536
    self assert:(9000000000 quo: 4000000000)    = ((900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2537
    self assert:(-9000000000 quo: 4000000000)   = ((-900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2538
    self assert:(9000000000 quo: -4000000000)   = ((900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2539
    self assert:(-9000000000 quo: -4000000000)  = ((-900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2540
    self assert:(16000000000 quo: 4000000000)   = ((1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2541
    self assert:(-16000000000 quo: 4000000000)  = ((-1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2542
    self assert:(16000000000 quo: -4000000000)  = ((1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2543
    self assert:(-16000000000 quo: -4000000000) = ((-1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2544
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2545
    self assert:(9000000000000000000 quo: 4000000000000000000)    = ((900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2546
    self assert:(-9000000000000000000 quo: 4000000000000000000)   = ((-900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2547
    self assert:(9000000000000000000 quo: -4000000000000000000)   = ((900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2548
    self assert:(-9000000000000000000 quo: -4000000000000000000)  = ((-900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2549
    self assert:(16000000000000000000 quo: 4000000000000000000)   = ((1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2550
    self assert:(-16000000000000000000 quo: 4000000000000000000)  = ((-1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2551
    self assert:(16000000000000000000 quo: -4000000000000000000)  = ((1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2552
    self assert:(-16000000000000000000 quo: -4000000000000000000) = ((-1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2553
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2554
    self assert:(9000000000 quo: 7) = 1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2555
    self assert:(-9000000000 quo: 7) = -1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2556
    self assert:(9000000000 quo: -7) = -1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2557
    self assert:(-9000000000 quo: -7) = 1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2558
    
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2559
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2560
     self basicNew testLargeDivision5
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2561
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2562
!
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2563
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2564
testLargeIntegerHelpers
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2565
    |t1 t2|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2566
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2567
    "/ mul2
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2568
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2569
    t1 := 16r12345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2570
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2571
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2572
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2573
    t1 := 16r1234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2574
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2575
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2576
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2577
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2578
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2579
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2580
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2581
    t1 := 16r12345678901234567890123456789012345678901234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2582
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2583
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2584
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2585
    t1 := 10000 factorial.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2586
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2587
    self assert:(t2 mul2 = (t1 * 2)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2588
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2589
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2590
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2591
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2592
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2593
"/    t1 := 1000 factorial.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2594
"/    t := Time millisecondsToRun:[ 100000 timesRepeat:[ t1 mul2. ] ].
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2595
"/    Transcript showCR:t.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2596
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2597
    "/ div2
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2598
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2599
    t1 := 16r12345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2600
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2601
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2602
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2603
    "/ do not compare t2 = t1 // x, because t2 may be unnormalized
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2604
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2605
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2606
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2607
    self assert:(t2 printStringRadix:16) = ((t1 // 4) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2608
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2609
    self assert:(t2 printStringRadix:16) = ((t1 // 8) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2610
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2611
    self assert:(t2 printStringRadix:16) = ((t1 // 16) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2612
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2613
    self assert:(t2 printStringRadix:16) = ((t1 // 32) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2614
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2615
    self assert:(t2 printStringRadix:16) = ((t1 // 64) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2616
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2617
    self assert:(t2 printStringRadix:16) = ((t1 // 128) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2618
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2619
    self assert:(t2 printStringRadix:16) = ((t1 // 256) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2620
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2621
    self assert:(t2 printStringRadix:16) = ((t1 // 512) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2622
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2623
    self assert:(t2 printStringRadix:16) = ((t1 // 1024) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2624
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2625
    t1 := 16r1234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2626
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2627
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2628
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2629
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2630
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2631
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2632
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2633
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2634
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2635
    t1 := 16r12345678901234567890123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2636
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2637
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2638
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2639
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2640
    self assert:(t2 printStringRadix:16) = ((t1 // 4) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2641
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2642
    self assert:(t2 printStringRadix:16) = ((t1 // 8) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2643
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2644
    self assert:(t2 printStringRadix:16) = ((t1 // 16) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2645
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2646
    t1 := 10000 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2647
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2648
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2649
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2650
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2651
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2652
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2653
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2654
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2655
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2656
    t1 := 12345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2657
    t2 := t1 divMod:1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2658
    self assert:(t2 at:1) = 12345678901234567.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2659
    self assert:(t2 at:2) = 890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2660
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2661
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2662
    "
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2663
     self basicNew testLargeIntegerHelpers
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2664
    "
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2665
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2666
    "Modified: / 20.5.1999 / 09:41:19 / cg"
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2667
!
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2668
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2669
testLargeIntegerHelpers2
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2670
    |t1 r|
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2671
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2672
    "/ absSubtract:
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2673
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2674
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2675
    r := t1 absDestructiveSubtract:16r00ffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2676
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2677
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2678
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2679
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2680
    r := t1 absDestructiveSubtract:16r010000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2681
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2682
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2683
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2684
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2685
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2686
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2687
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2688
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2689
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2690
    r := t1 absDestructiveSubtract:16r01000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2691
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2692
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2693
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2694
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2695
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2696
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2697
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2698
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2699
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2700
    r := t1 absDestructiveSubtract:16r0100000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2701
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2702
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2703
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2704
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2705
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2706
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2707
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2708
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2709
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2710
    r := t1 absDestructiveSubtract:16r010000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2711
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2712
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2713
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2714
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2715
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2716
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2717
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2718
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2719
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2720
    r := t1 absDestructiveSubtract:16r01000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2721
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2722
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2723
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2724
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2725
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2726
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2727
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2728
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2729
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2730
    r := t1 absDestructiveSubtract:16r0100000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2731
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2732
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2733
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2734
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2735
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2736
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2737
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2738
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2739
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2740
    r := t1 absDestructiveSubtract:16r010000000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2741
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2742
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2743
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2744
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2745
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2746
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2747
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2748
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2749
    t1 := LargeInteger digitBytes:#[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r01 ] copy sign:1.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2750
    r := t1 absDestructiveSubtract:16r01000000000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2751
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2752
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2753
    "
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2754
     self basicNew testLargeIntegerHelpers2
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2755
    "
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2756
!
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2757
1314
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2758
testLargeIntegerHelpers3
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2759
    "/ absDivMod:
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2760
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2761
     self assert:(9000000000000000000 absDivMod: 4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2762
     self assert:(-9000000000000000000 absDivMod: 4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2763
     self assert:(9000000000000000000 absDivMod: -4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2764
     self assert:(-9000000000000000000 absDivMod: -4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2765
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2766
     self assert:(9000000000000000001 absDivMod: 4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2767
     self assert:(-9000000000000000001 absDivMod: 4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2768
     self assert:(9000000000000000001 absDivMod: -4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2769
     self assert:(-9000000000000000001 absDivMod: -4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2770
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2771
     self assert:(9000000000000000000 absDivMod: 40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2772
     self assert:(-9000000000000000000 absDivMod: 40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2773
     self assert:(9000000000000000000 absDivMod: -40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2774
     self assert:(-9000000000000000000 absDivMod: -40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2775
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2776
     self assert:(9000000000000000000 absDivMod: 400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2777
     self assert:(-9000000000000000000 absDivMod: 400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2778
     self assert:(9000000000000000000 absDivMod: -400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2779
     self assert:(-9000000000000000000 absDivMod: -400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2780
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2781
     self assert:(9000000000000000000 absDivMod: 4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2782
     self assert:(-9000000000000000000 absDivMod: 4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2783
     self assert:(9000000000000000000 absDivMod: -4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2784
     self assert:(-9000000000000000000 absDivMod: -4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2785
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2786
     self assert:(9000000000000000000 absDivMod: 40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2787
     self assert:(-9000000000000000000 absDivMod: 40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2788
     self assert:(9000000000000000000 absDivMod: -40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2789
     self assert:(-9000000000000000000 absDivMod: -40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2790
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2791
     self assert:(9000000000000000000 absDivMod: 400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2792
     self assert:(-9000000000000000000 absDivMod: 400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2793
     self assert:(9000000000000000000 absDivMod: -400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2794
     self assert:(-9000000000000000000 absDivMod: -400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2795
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2796
     self assert:(9000000000000000000 absDivMod: 4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2797
     self assert:(-9000000000000000000 absDivMod: 4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2798
     self assert:(9000000000000000000 absDivMod: -4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2799
     self assert:(-9000000000000000000 absDivMod: -4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2800
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2801
     self assert:(9000000000000000000 absDivMod: 40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2802
     self assert:(-9000000000000000000 absDivMod: 40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2803
     self assert:(9000000000000000000 absDivMod: -40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2804
     self assert:(-9000000000000000000 absDivMod: -40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2805
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2806
     self assert:(9000000000000000000 absDivMod: 400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2807
     self assert:(-9000000000000000000 absDivMod: 400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2808
     self assert:(9000000000000000000 absDivMod: -400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2809
     self assert:(-9000000000000000000 absDivMod: -400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2810
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2811
     self assert:(9000000000000000000 absDivMod: 4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2812
     self assert:(-9000000000000000000 absDivMod: 4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2813
     self assert:(9000000000000000000 absDivMod: -4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2814
     self assert:(-9000000000000000000 absDivMod: -4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2815
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2816
     self assert:(9000000000000000000 absDivMod: 40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2817
     self assert:(-9000000000000000000 absDivMod: 40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2818
     self assert:(9000000000000000000 absDivMod: -40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2819
     self assert:(-9000000000000000000 absDivMod: -40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2820
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2821
     self assert:(9000000000000000000 absDivMod: 400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2822
     self assert:(-9000000000000000000 absDivMod: 400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2823
     self assert:(9000000000000000000 absDivMod: -400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2824
     self assert:(-9000000000000000000 absDivMod: -400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2825
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2826
     self assert:(9000000000000000000 absDivMod: 4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2827
     self assert:(-9000000000000000000 absDivMod: 4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2828
     self assert:(9000000000000000000 absDivMod: -4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2829
     self assert:(-9000000000000000000 absDivMod: -4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2830
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2831
     self assert:(9000000000000000000 absDivMod: 4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2832
     self assert:(-9000000000000000000 absDivMod: 4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2833
     self assert:(9000000000000000000 absDivMod: -4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2834
     self assert:(-9000000000000000000 absDivMod: -4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2835
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2836
    "
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2837
     self basicNew testLargeIntegerHelpers3
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2838
    "
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2839
!
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  2840
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2841
testLargeMultiplication
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2842
    |t1 t2|
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2843
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2844
    "multiplication"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2845
    t1 := 100.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2846
    self assert:(t1 * t1 == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2847
    self assert:((t1 perform:'*' asSymbol with:t1) == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2848
    self assert:((t1 * t1) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2849
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2850
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2851
    t1 := 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2852
    self assert:(t1 * t1 == 1000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2853
    self assert:((t1 perform:'*' asSymbol with:t1) == 1000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2854
    self assert:((t1 * t1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2855
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2856
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2857
    t1 := 10000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2858
    self assert:(t1 * t1 == 100000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2859
    self assert:((t1 perform:'*' asSymbol with:t1) == 100000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2860
    self assert:((t1 * t1) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2861
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '100000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2862
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2863
    t1 := 100000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2864
    SmallInteger maxBytes == 4 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2865
	self assert:(t1 * t1 = 10000000000).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2866
	self assert:((t1 perform:'*' asSymbol with:t1) = 10000000000).
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2867
    ].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2868
    SmallInteger maxBytes == 8 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2869
	self assert:(t1 * t1 == 10000000000).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2870
	self assert:((t1 perform:'*' asSymbol with:t1) == 10000000000).
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2871
    ].
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
  2872
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2873
    self assert:((t1 * t1) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2874
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2875
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2876
    t1 := 1000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2877
    self assert:((t1 * t1) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2878
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2879
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2880
    t1 := 10000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2881
    self assert:((t1 * t1) printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2882
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '100000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2883
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2884
    t1 := 100000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2885
    self assert:((t1 * t1) printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2886
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2887
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2888
    t1 := 1000000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2889
    self assert:((t1 * t1) printString = '1000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2890
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2891
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2892
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2893
    "Large * SmallInt multiplication"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2894
    self assert:(10 factorial printString = '3628800').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2895
    self assert:(20 factorial printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2896
    self assert:(100 factorial printString = '93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2897
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2898
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2899
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2900
    t2 := 100000000000000000.                   "/ large on 32bit; small on 64bt machines
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2901
    self assert:(t1 * t2) = 10000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2902
    self assert:(t2 * t1) = 10000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2903
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2904
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2905
    t2 := 1000000000000000000.                  "/ large on 32bit; small on 64bt machines
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2906
    self assert:(t1 * t2) = 100000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2907
    self assert:(t2 * t1) = 100000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2908
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2909
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2910
    t2 := 10000000000000000000.                 "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2911
    self assert:(t1 * t2) = 1000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2912
    self assert:(t2 * t1) = 1000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2913
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2914
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2915
    t2 := 100000000000000000000.                "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2916
    self assert:(t1 * t2) = 10000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2917
    self assert:(t2 * t1) = 10000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2918
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2919
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2920
    t2 := 1000000000000000000000.               "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2921
    self assert:(t1 * t2) = 100000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2922
    self assert:(t2 * t1) = 100000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2923
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2924
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2925
    t2 := 10000000000000000000000.              "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2926
    self assert:(t1 * t2) = 1000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2927
    self assert:(t2 * t1) = 1000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2928
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2929
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2930
    t2 := 100000000000000000000000.             "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2931
    self assert:(t1 * t2) = 10000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2932
    self assert:(t2 * t1) = 10000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2933
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2934
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2935
    t2 := 1000000000000000000000000.            "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2936
    self assert:(t1 * t2) = 100000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2937
    self assert:(t2 * t1) = 100000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2938
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2939
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2940
    t2 := 10000000000000000000000000.           "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2941
    self assert:(t1 * t2) = 1000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2942
    self assert:(t2 * t1) = 1000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2943
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2944
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2945
    t2 := 100000000000000000000000000.          "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2946
    self assert:(t1 * t2) = 10000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2947
    self assert:(t2 * t1) = 10000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2948
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2949
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2950
    t2 := 1000000000000000000000000000.         "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2951
    self assert:(t1 * t2) = 100000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2952
    self assert:(t2 * t1) = 100000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2953
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2954
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2955
    t2 := 10000000000000000000000000000.        "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2956
    self assert:(t1 * t2) = 1000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2957
    self assert:(t2 * t1) = 1000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2958
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2959
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2960
    t2 := 100000000000000000000000000000.       "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2961
    self assert:(t1 * t2) = 10000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2962
    self assert:(t2 * t1) = 10000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2963
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2964
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2965
    t2 := 1000000000000000000000000000000.      "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2966
    self assert:(t1 * t2) = 100000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2967
    self assert:(t2 * t1) = 100000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2968
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2969
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2970
    t2 := 10000000000000000000000000000000.     "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2971
    self assert:(t1 * t2) = 1000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2972
    self assert:(t2 * t1) = 1000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2973
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2974
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2975
    t2 := 100000000000000000000000000000000.    "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2976
    self assert:(t1 * t2) = 10000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2977
    self assert:(t2 * t1) = 10000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2978
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2979
    "Large * Large multiplication"
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  2980
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2981
    self assert:((16r3FFF * 16r3FFF) hexPrintString = 'FFF8001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2982
    self assert:((16r7FFF * 16r7FFF) hexPrintString = '3FFF0001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2983
    self assert:((16rFFFF * 16rFFFF) hexPrintString = 'FFFE0001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2984
    self assert:((16r3FFFFF * 16r3FFFFF) hexPrintString = 'FFFFF800001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2985
    self assert:((16r7FFFFF * 16r7FFFFF) hexPrintString = '3FFFFF000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2986
    self assert:((16rFFFFFF * 16rFFFFFF) hexPrintString = 'FFFFFE000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2987
    self assert:((16r3FFFFFFF * 16r3FFFFFFF) hexPrintString = 'FFFFFFF80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2988
    self assert:((16r7FFFFFFF * 16r7FFFFFFF) hexPrintString = '3FFFFFFF00000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2989
    self assert:((16rFFFFFFFF * 16rFFFFFFFF) hexPrintString = 'FFFFFFFE00000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2990
    self assert:((16r3FFFFFFFFF * 16r3FFFFFFFFF) hexPrintString = 'FFFFFFFFF8000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2991
    self assert:((16r7FFFFFFFFF * 16r7FFFFFFFFF) hexPrintString = '3FFFFFFFFF0000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2992
    self assert:((16rFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFE0000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2993
    self assert:((20 factorial * 20 factorial) printString = '5919012181389927685417441689600000000').
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2994
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  2995
    self assert:((16rFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  2996
    self assert:((16rFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFF0000000001').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  2997
    self assert:((t1 := 16rFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFF0000000001').
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  2998
    self assert:((16rFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFFFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  2999
    self assert:((16rFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFFFFFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3000
    self assert:((16rFFFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFFFFFFFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3001
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3002
    self assert:((16rFFFFFFFFFFFF * 16rFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFE000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3003
    self assert:((16rFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFE00000000000001').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3004
    self assert:((t2 := (t1 := 16rFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFF) hexPrintString) = 'FFFFFFFFFFFFFFFE0000000000000001').
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3005
    self assert:((16rFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFE0000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3006
    self assert:((16rFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFFFE000000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3007
    self assert:((16rFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFFFFFE00000000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3008
    self assert:((16rFFFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFFFFFFFE0000000000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3009
1024
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3010
    t1 := 699697179634740272935560322271216335182775596927422865716399200802062765682314102885264570100200211251370690926108604161579425545019863369232209949922751354278329212124724267803033599595114924195721823679025053720850308776953208134469115885358619139670731195605237506312288263327925364912720266772715929600.
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3011
    self assert:(t1 printString = '699697179634740272935560322271216335182775596927422865716399200802062765682314102885264570100200211251370690926108604161579425545019863369232209949922751354278329212124724267803033599595114924195721823679025053720850308776953208134469115885358619139670731195605237506312288263327925364912720266772715929600').
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3012
    self assert:((t1 * t1) = 489576143188809998144298426641311496989165214458056165805143410866108690058261346129614030084813851082564698610174813898740525406243367146120734370570458429364167811695064904353093506532695086211301649001517008746471464304183710723162864634442619484210170532881759249266026059786349673031239277666195699357198366128286910123306594912484590029738722281929300359929462301099981920256369394887701755497894820998573896950238852994224811101315810851671448056042419257789317787959570728520197146733902575090480065597582292177085754523686580725860228636039424698638422538988050350726807943014483010988455057592156160000).
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3013
    self assert:((t1 * t1) printString = '489576143188809998144298426641311496989165214458056165805143410866108690058261346129614030084813851082564698610174813898740525406243367146120734370570458429364167811695064904353093506532695086211301649001517008746471464304183710723162864634442619484210170532881759249266026059786349673031239277666195699357198366128286910123306594912484590029738722281929300359929462301099981920256369394887701755497894820998573896950238852994224811101315810851671448056042419257789317787959570728520197146733902575090480065597582292177085754523686580725860228636039424698638422538988050350726807943014483010988455057592156160000').
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3014
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3015
    #(
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3016
	16rFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3017
	16rFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3018
	16rFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3019
	16rFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3020
	16rFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3021
	16rFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3022
	16rFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3023
	16rFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3024
	16rFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3025
	16rFFFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3026
	16rFFFFFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3027
	16rFFFFFFFFFFFFFFFFFFFFFFFF
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3028
    ) do:[:eachFactor1 |
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3029
	#(
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3030
	    16rFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3031
	    16rFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3032
	    16rFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3033
	    16rFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3034
	    16rFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3035
	    16rFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3036
	    16rFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3037
	    16rFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3038
	    16rFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3039
	    16rFFFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3040
	    16rFFFFFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3041
	    16rFFFFFFFFFFFFFFFFFFFFFFFF
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3042
	) do:[:eachFactor2 |
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3043
	    |t3|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3044
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3045
	    t1 := (eachFactor1 * eachFactor2).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3046
	    t2 := (eachFactor2 * eachFactor1).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3047
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3048
	    self assert:(t1 = t2).
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3049
t1 = 20203181441155852828228393631745 ifTrue:[
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3050
 eachFactor1 = 1099511627775 ifTrue:[
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3051
self halt
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3052
]].
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3053
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3054
	    self assert:(t1 / eachFactor1) = eachFactor2.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3055
	    self assert:(t1 / eachFactor2) = eachFactor1.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3056
	    t3 := (eachFactor1 asLargeInteger * eachFactor2 asLargeInteger).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3057
	    self assert: t1 = t3.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3058
	].
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3059
    ].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3060
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3061
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3062
     self basicNew testLargeMultiplication
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3063
    "
10
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
  3064
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3065
    "Modified: / 02-12-2013 / 15:45:39 / cg"
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3066
!
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3067
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3068
testLargeMultiplication2
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3069
    "tests many divisions and multiplications (of largeInts by smallInts)"
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3070
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3071
    |n n2|
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3072
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3073
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3074
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3075
    n := 1000 factorial.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3076
    1000 to:2 by:-1 do:[:d |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3077
	n2 := n / d.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3078
	self assert:((d-1) factorial = n2).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3079
	(Integer readFrom:n2 printString) * d = n.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3080
	n := n2.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3081
    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3082
!
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3083
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3084
testLargeMultiplicationHelpers1
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3085
    |t1 t2 r|
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3086
1030
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3087
    t1 := LargeInteger digitBytes:#[ 16r00 16rE1 16rF5 16r05 ].
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3088
    t2 := LargeInteger digitBytes:#[ 16r00 16r00 16r40 16rB2 16rBA 16rC9 16rE0 16r19 16r1E 16r02].
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3089
    r := t1 absMul:t2.
1031
247174c321e3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1030
diff changeset
  3090
    self assert:(r printString = '1000000000000000000000000000000').
247174c321e3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1030
diff changeset
  3091
    self assert:(r hexPrintString = 'C9F2C9CD04674EDEA40000000').
1030
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3092
1032
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3093
    t1 := LargeInteger digitBytes:#[ 16r00 16rE1 16rF5 16r05 ].
1034
19a7bdfbe204 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1033
diff changeset
  3094
    t2 := LargeInteger digitBytes:#[ 16r00 16r00 16rA0 16rDE   16rC5 16rAD 16rC9 16r35   16r36].
1032
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3095
    r := t1 absMul:t2.
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3096
    self assert:(r printString = '100000000000000000000000000000').
1033
5ec3c1764111 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1032
diff changeset
  3097
    self assert:(r hexPrintString = '1431E0FAE6D7217CAA0000000').
1032
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3098
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3099
    "/ -----
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3100
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3101
    t1 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF].
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3102
    t2 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 0 0 0 0].
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3103
    r := t1 absMul:t2.
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3104
    self assert:(r hexPrintString = 'FFFFFFFEFFFFFFFF00000001').
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3105
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3106
    t1 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF].
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3107
    t2 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3108
    r := t1 absMul:t2.
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3109
    self assert:(r printString = '20282409603633223678774030106625').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3110
    self assert:(r hexPrintString = 'FFFFFFFFFEFFFFFF0000000001').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3111
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3112
    t1 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3113
    t2 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3114
    r := t1 absMul:t2.
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3115
    self assert:(r printString = '5192296858534809181504947642957825').
1029
daa98cf43cf0 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1028
diff changeset
  3116
    self assert:(r hexPrintString = 'FFFFFFFFFFFEFFFF000000000001').
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3117
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3118
    t1 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF].
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3119
    t2 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 0].
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3120
    r := t1 absMul:t2.
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3121
    self assert:(r printString = '1329227995784915854385005392532865025').
1029
daa98cf43cf0 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1028
diff changeset
  3122
    self assert:(r hexPrintString = 'FFFFFFFFFFFFFEFF00000000000001').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3123
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3124
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3125
     self basicNew testLargeMultiplicationHelpers1
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3126
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3127
1033
5ec3c1764111 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1032
diff changeset
  3128
    "Modified: / 02-12-2013 / 18:48:00 / cg"
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3129
!
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3130
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3131
testLargeMultiplicationHelpers2
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3132
    |t1 t2 r|
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3133
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3134
    "/ testing internal multiplication method
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3135
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3136
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3137
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3138
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3139
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3140
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3141
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3142
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3143
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3144
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3145
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3146
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3147
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3148
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3149
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3150
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3151
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3152
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3153
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3154
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3155
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11 12].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3156
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3157
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3158
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3159
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3160
    "/ --------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3161
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3162
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3163
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3164
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3165
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3166
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3167
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3168
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3169
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3170
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3171
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3172
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3173
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3174
    r := t1 absMul:t2.
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3175
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3176
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3177
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3178
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3179
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3180
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3181
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3182
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11 12].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3183
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3184
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3185
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3186
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3187
    "/ --------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3188
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3189
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3190
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3191
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3192
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3193
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3194
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3195
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3196
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3197
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3198
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3199
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3200
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 ].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3201
    r := t1 absMul:t2.
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3202
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3203
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3204
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3205
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3206
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3207
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3208
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3209
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11 12].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3210
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3211
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3212
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3213
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3214
    "/ --------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3215
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3216
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3217
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3218
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3219
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3220
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3221
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3222
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3223
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3224
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3225
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3226
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3227
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3228
    r := t1 absMul:t2.
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3229
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3230
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3231
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3232
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3233
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3234
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3235
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3236
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8 9 10 11 12].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3237
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3238
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3239
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3240
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3241
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3242
    "/ ==================0
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3243
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3244
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3245
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3246
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3247
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3248
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3249
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3250
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3251
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3252
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3253
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3254
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3255
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3256
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3257
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3258
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3259
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3260
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3261
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3262
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3263
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3264
    "/ ---------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3265
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3266
    t1 := LargeInteger digitBytes:#[ 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3267
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3268
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3269
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3270
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3271
    t1 := LargeInteger digitBytes:#[ 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3272
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3273
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3274
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3275
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3276
    t1 := LargeInteger digitBytes:#[ 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3277
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3278
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3279
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3280
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3281
    t1 := LargeInteger digitBytes:#[ 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3282
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3283
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3284
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3285
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3286
    "/ ---------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3287
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3288
    t1 := LargeInteger digitBytes:#[ 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3289
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3290
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3291
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3292
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3293
    t1 := LargeInteger digitBytes:#[ 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3294
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3295
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3296
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3297
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3298
    t1 := LargeInteger digitBytes:#[ 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3299
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3300
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3301
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3302
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3303
    t1 := LargeInteger digitBytes:#[ 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3304
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3305
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3306
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3307
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3308
    "/ ---------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3309
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3310
    t1 := LargeInteger digitBytes:#[ 0 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3311
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3312
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3313
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3314
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3315
    t1 := LargeInteger digitBytes:#[ 0 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3316
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3317
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3318
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3319
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3320
    t1 := LargeInteger digitBytes:#[ 0 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3321
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3322
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3323
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3324
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3325
    t1 := LargeInteger digitBytes:#[ 0 0 0 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3326
    t2 := LargeInteger digitBytes:#[ 2 0 0 0 0 0 0 0 0 0 0].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3327
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3328
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3329
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3330
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3331
     self basicNew testLargeMultiplicationHelpers2
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3332
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3333
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3334
    "Modified: / 02-12-2013 / 15:45:39 / cg"
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3335
!
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3336
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3337
testLargeSubtraction1
336
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3338
    |a1 a2 a b1 b2 b c1 c2 c|
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3339
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3340
    "/ on 32bit machines - these lead to smallint overflow
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3341
    self assert:((2770568 + 2770568) printString = '5541136').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3342
    self assert:((2770568 - 2770568) printString = '0').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3343
    self assert:((2770568 negated + 2770568 negated) printString = '-5541136').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3344
    self assert:((5541136 negated - 2770568 negated) printString = '-2770568').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3345
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3346
    "Large - small subtraction"
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3347
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3348
    self assert:((2770568900 + 2770568900) printString = '5541137800').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3349
    self assert:((2770568900 - 2770568900) printString = '0').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3350
    self assert:((2770568900 negated + 2770568900 negated) printString = '-5541137800').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3351
    self assert:((5541137800 negated - 2770568900 negated) printString = '-2770568900').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3352
    self assert:((2770568900 negated - 5541137800 negated) printString = '2770568900').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3353
336
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3354
    a1 := -2770568900. a2 := 59049.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3355
    a := (a1 / a2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3356
    b1 := -5872025600. b2 := 59049.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3357
    b := (b1 / b2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3358
    c1 := 344606300. c2 := 6561.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3359
    c := (c1 / c2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3360
    self assert:(a - b closeTo: c).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3361
    self assert:((a - b) asFloat closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3362
    self assert:((a asFloat - b) closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3363
    self assert:((a - b asFloat) closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3364
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3365
    a := -10.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3366
    b := -12.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3367
    self assert:(a - b = 2).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3368
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3369
    a := -10000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3370
    b := -12000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3371
    self assert:(a - b = 2000000).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3372
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3373
    a := -100000000000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3374
    b := -120000000000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3375
    self assert:(a - b = 20000000000000).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3376
337
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3377
    "smallInteger - largeInteger"
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3378
    self assert:(-1000000000 - -2000000000 = 1000000000).
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3379
    "largeInteger - smallInteger"
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3380
    self assert:(-2000000000 - -1000000000 = -1000000000).
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3381
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3382
    a := 40 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3383
    b := 39 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3384
    self assert:(a - b + b = a).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3385
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3386
    "
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3387
     self basicNew testLargeSubtraction1
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3388
    "
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3389
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3390
    "Modified: / 27.11.1999 / 16:41:54 / cg"
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3391
!
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3392
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3393
testLargeSubtraction2
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3394
    "/ on 64bit machines - these lead to smallint overflow
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3395
    self assert:((16r3FFFFFFFFFFFFFFF negated - 1 - 1) printString = '-4611686018427387905').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3396
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3397
    "
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3398
     self basicNew testLargeSubtraction2
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3399
    "
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3400
!
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3401
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3402
testLiteralNumbers
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3403
    self assert:(self num_00000000000010000 hexPrintString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3404
    self assert:(self num_00000000000100000 hexPrintString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3405
    self assert:(self num_00000000001000000 hexPrintString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3406
    self assert:(self num_00000000010000000 hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3407
    self assert:(self num_00000000100000000 hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3408
    self assert:(self num_00000001000000000 hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3409
    self assert:(self num_00000010000000000 hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3410
    self assert:(self num_00000100000000000 hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3411
    self assert:(self num_00001000000000000 hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3412
    self assert:(self num_00010000000000000 hexPrintString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3413
    self assert:(self num_00100000000000000 hexPrintString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3414
    self assert:(self num_01000000000000000 hexPrintString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3415
    self assert:(self num_10000000000000000 hexPrintString = '10000000000000000').
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3416
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3417
    self assert:(self num_00000000000007FFF hexPrintString = '7FFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3418
    self assert:(self num_00000000000008000 hexPrintString = '8000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3419
    self assert:(self num_0000000000000FFFF hexPrintString = 'FFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3420
    self assert:(self num_000000000007FFFFF hexPrintString = '7FFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3421
    self assert:(self num_00000000000800000 hexPrintString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3422
    self assert:(self num_00000000000FFFFFF hexPrintString = 'FFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3423
    self assert:(self num_0000000007FFFFFFF hexPrintString = '7FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3424
    self assert:(self num_00000000080000000 hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3425
    self assert:(self num_000000000FFFFFFFF hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3426
    self assert:(self num_0000000FFFFFFFFFF hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3427
    self assert:(self num_00000FFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3428
    self assert:(self num_000FFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3429
    self assert:(self num_0FFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3430
    self assert:(self num_1FFFFFFFFFFFFFFFF hexPrintString = '1FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3431
    self assert:(self num_20000000000000000 hexPrintString = '20000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3432
    self assert:(self num_3FFFFFFFFFFFFFFFF hexPrintString = '3FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3433
    self assert:(self num_40000000000000000 hexPrintString = '40000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3434
    self assert:(self num_7FFFFFFFFFFFFFFFF hexPrintString = '7FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3435
    self assert:(self num_80000000000000000 hexPrintString = '80000000000000000').
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
  3436
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3437
    self assert:(self num_00000FFFFFFFFFFFE hexPrintString = 'FFFFFFFFFFFE').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3438
    self assert:(self num_00000FFFFFFFFFFFC hexPrintString = 'FFFFFFFFFFFC').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3439
    self assert:(self num_00000FFFFFFFFFFF8 hexPrintString = 'FFFFFFFFFFF8').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3440
    self assert:(self num_00000FFFFFFFFFFF0 hexPrintString = 'FFFFFFFFFFF0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3441
    self assert:(self num_00000FFFFFFFFFFE0 hexPrintString = 'FFFFFFFFFFE0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3442
    self assert:(self num_00000FFFFFFFFFFC0 hexPrintString = 'FFFFFFFFFFC0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3443
    self assert:(self num_00000FFFFFFFFFF80 hexPrintString = 'FFFFFFFFFF80').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3444
    self assert:(self num_00000FFFFFFFFFF00 hexPrintString = 'FFFFFFFFFF00').
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3445
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3446
    self assert:(self num_0000000000FFF0000 hexPrintString = 'FFF0000').
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
  3447
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3448
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3449
     self basicNew testLiteralNumbers
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3450
    "
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3451
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
  3452
    "Modified: / 4.6.1999 / 18:41:09 / cg"
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3453
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3454
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3455
testModulu
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3456
    |a b op|
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3457
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3458
    op := #\\.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3459
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3460
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3461
    self assert:(-1 \\ 8 == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3462
    self assert:(a \\ 8 == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3463
    self assert:(-1 \\ b == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3464
    self assert:(a \\ b == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3465
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3466
    self assert:((-1 perform:op with: 8) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3467
    self assert:((a perform:op with: 8) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3468
    self assert:((-1 perform:op with: b) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3469
    self assert:((a perform:op with: b) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3470
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3471
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3472
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3473
    self assert:(1 \\ -8 == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3474
    self assert:(a \\ -8 == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3475
    self assert:(1 \\ b == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3476
    self assert:(a \\ b == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3477
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3478
    self assert:((1 perform:op with: -8) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3479
    self assert:((a perform:op with: -8) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3480
    self assert:((1 perform:op with: b) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3481
    self assert:((a perform:op with: b) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3482
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3483
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3484
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3485
    self assert:(-1 \\ -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3486
    self assert:(a \\ -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3487
    self assert:(-1 \\ b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3488
    self assert:(a \\ b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3489
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3490
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3491
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3492
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3493
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3494
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3495
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3496
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3497
    self assert:(1 \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3498
    self assert:(a \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3499
    self assert:(1 \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3500
    self assert:(a \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3501
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3502
    self assert:((1 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3503
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3504
    self assert:((1 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3505
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3506
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3507
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3508
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3509
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3510
    self assert:(-17 \\ 8 == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3511
    self assert:(a \\ 8 == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3512
    self assert:(-17 \\ b == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3513
    self assert:(a \\ b == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3514
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3515
    self assert:((-17 perform:op with: 8) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3516
    self assert:((a perform:op with: 8) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3517
    self assert:((-17 perform:op with: b) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3518
    self assert:((a perform:op with: b) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3519
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3520
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3521
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3522
    self assert:(17 \\ -8 == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3523
    self assert:(a \\ -8 == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3524
    self assert:(17 \\ b == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3525
    self assert:(a \\ b == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3526
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3527
    self assert:((17 perform:op with: -8) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3528
    self assert:((a perform:op with: -8) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3529
    self assert:((17 perform:op with: b) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3530
    self assert:((a perform:op with: b) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3531
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3532
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3533
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3534
    self assert:(-17 \\ -8 == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3535
    self assert:(a \\ -8 == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3536
    self assert:(-17 \\ b == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3537
    self assert:(a \\ b == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3538
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3539
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3540
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3541
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3542
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3543
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3544
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3545
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3546
    self assert:(17 \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3547
    self assert:(a \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3548
    self assert:(17 \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3549
    self assert:(a \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3550
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3551
    self assert:((17 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3552
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3553
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3554
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3555
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3556
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3557
    op := #rem:.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3558
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3559
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3560
    self assert:((-1 rem: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3561
    self assert:((a rem: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3562
    self assert:((-1 rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3563
    self assert:((a rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3564
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3565
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3566
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3567
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3568
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3569
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3570
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3571
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3572
    self assert:((1 rem: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3573
    self assert:((a rem: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3574
    self assert:((1 rem: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3575
    self assert:((a rem: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3576
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3577
    self assert:((1 perform:op with: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3578
    self assert:((a perform:op with: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3579
    self assert:((1 perform:op with: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3580
    self assert:((a perform:op with: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3581
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3582
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3583
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3584
    self assert:((-1 rem: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3585
    self assert:((a rem: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3586
    self assert:((-1 rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3587
    self assert:((a rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3588
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3589
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3590
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3591
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3592
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3593
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3594
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3595
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3596
    self assert:((1 rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3597
    self assert:((a rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3598
    self assert:((1 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3599
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3600
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3601
    self assert:((1 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3602
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3603
    self assert:((1 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3604
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3605
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3606
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3607
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3608
    self assert:((-17 rem: 8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3609
    self assert:((a rem: 8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3610
    self assert:((-17 rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3611
    self assert:((a rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3612
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3613
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3614
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3615
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3616
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3617
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3618
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3619
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3620
    self assert:((17 rem: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3621
    self assert:((a rem: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3622
    self assert:((17 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3623
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3624
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3625
    self assert:((17 perform:op with: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3626
    self assert:((a perform:op with: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3627
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3628
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3629
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3630
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3631
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3632
    self assert:((-17 rem: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3633
    self assert:((a rem: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3634
    self assert:((-17 rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3635
    self assert:((a rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3636
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3637
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3638
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3639
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3640
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3641
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3642
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3643
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3644
    self assert:((17 rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3645
    self assert:((a rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3646
    self assert:((17 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3647
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3648
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3649
    self assert:((17 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3650
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3651
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3652
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3653
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3654
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3655
     self basicNew testModulu
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3656
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3657
!
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3658
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3659
testPrinting1
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3660
    self assert:(10 printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3661
    self assert:(100 printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3662
    self assert:(1000 printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3663
    self assert:(10000 printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3664
    self assert:(100000 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3665
    self assert:(1000000 printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3666
    self assert:(10000000 printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3667
    self assert:(100000000 printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3668
    self assert:(1000000000 printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3669
    self assert:(10000000000 printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3670
    self assert:(100000000000 printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3671
    self assert:(1000000000000 printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3672
    self assert:(10000000000000 printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3673
    self assert:(100000000000000 printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3674
    self assert:(1000000000000000 printString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3675
    self assert:(10000000000000000 printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3676
    self assert:(100000000000000000 printString = '100000000000000000').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3677
    self assert:(1000000000000000000 printString = '1000000000000000000').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3678
    self assert:(10000000000000000000 printString = '10000000000000000000').
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3679
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3680
    self assert:(16rF hexPrintString = 'F').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3681
    self assert:(16rFF hexPrintString = 'FF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3682
    self assert:(16rFFF hexPrintString = 'FFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3683
    self assert:(16rFFFF hexPrintString = 'FFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3684
    self assert:(16rFFFFF hexPrintString = 'FFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3685
    self assert:(16rFFFFFF hexPrintString = 'FFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3686
    self assert:(16rFFFFFFF hexPrintString = 'FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3687
    self assert:(16rFFFFFFFF hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3688
    self assert:(16rFFFFFFFFF hexPrintString = 'FFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3689
    self assert:(16rFFFFFFFFFF hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3690
    self assert:(16rFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3691
    self assert:(16rFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3692
    self assert:(16rFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3693
    self assert:(16rFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3694
    self assert:(16rFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3695
    self assert:(16rFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3696
    self assert:(16rFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3697
    self assert:(16rFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3698
    self assert:(16rFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3699
    self assert:(16rFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFF').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3700
    self assert:(16rFFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFFF').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3701
    self assert:(16rFFFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFFFF').
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  3702
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3703
    self assert:(16r10 hexPrintString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3704
    self assert:(16r100 hexPrintString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3705
    self assert:(16r1000 hexPrintString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3706
    self assert:(16r10000 hexPrintString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3707
    self assert:(16r100000 hexPrintString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3708
    self assert:(16r1000000 hexPrintString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3709
    self assert:(16r10000000 hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3710
    self assert:(16r100000000 hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3711
    self assert:(16r1000000000 hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3712
    self assert:(16r10000000000 hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3713
    self assert:(16r100000000000 hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3714
    self assert:(16r1000000000000 hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3715
    self assert:(16r10000000000000 hexPrintString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3716
    self assert:(16r100000000000000 hexPrintString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3717
    self assert:(16r1000000000000000 hexPrintString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3718
    self assert:(16r10000000000000000 hexPrintString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3719
    self assert:(16r100000000000000000 hexPrintString = '100000000000000000').
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  3720
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3721
    self assert:(126 printString) = '126'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3722
    self assert:(127 printString) = '127'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3723
    self assert:(128 printString) = '128'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3724
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3725
    self assert:(255 printString) = '255'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3726
    self assert:(256 printString) = '256'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3727
    self assert:(257 printString) = '257'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3728
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3729
    self assert:(32767 printString) = '32767'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3730
    self assert:(32768 printString) = '32768'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3731
    self assert:(32769 printString) = '32769'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3732
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3733
    self assert:(65535 printString) = '65535'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3734
    self assert:(65536 printString) = '65536'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3735
    self assert:(65537 printString) = '65537'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3736
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3737
    self assert:(2147483647 printString) = '2147483647'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3738
    self assert:(2147483648 printString) = '2147483648'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3739
    self assert:(2147483649 printString) = '2147483649'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3740
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3741
    self assert:(4294967295 printString) = '4294967295'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3742
    self assert:(4294967296 printString) = '4294967296'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3743
    self assert:(4294967297 printString) = '4294967297'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3744
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3745
    self assert:(127 printStringRadix:16) = '7F'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3746
    self assert:(123 printStringRadix:12) = 'A3'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3747
    self assert:(123 printStringRadix:10) = '123'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3748
    self assert:(123 printStringRadix:8 ) = '173'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3749
    self assert:(123 printStringRadix:3 ) = '11120'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3750
    self assert:(123 printStringRadix:2 ) = '1111011'.
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3751
    self should:[ 123 printStringRadix:1 ] raise:Error.
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3752
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3753
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3754
     self basicNew testPrinting1
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3755
    "
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  3756
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  3757
    "Modified: / 26.10.1999 / 22:01:35 / stefan"
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3758
!
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3759
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3760
testReading1
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3761
    |t|
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3762
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3763
    self assert:((Integer readFrom:'4865804016353280000') printString = '4865804016353280000').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3764
    self assert:((Integer readFrom:'4294967295') printString = '4294967295').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3765
    self assert:((Integer readFrom:'4294967295') = 4294967295).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3766
    self assert:((Integer readFrom:'4294967296') printString = '4294967296').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3767
    self assert:((Integer readFrom:'4294967296') = 4294967296).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3768
    self assert:((Integer readFrom:'4294967297') printString = '4294967297').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3769
    self assert:((Integer readFrom:'4294967297') = 4294967297).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3770
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3771
    self assert:((Integer readFrom:'FFFFFFFF' radix:16) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3772
    self assert:((Integer readFrom:'FFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3773
    self assert:((Integer readFrom:'FFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3774
    self assert:((Integer readFrom:'FFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3775
    self assert:((Integer readFrom:'FFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3776
    self assert:((Integer readFrom:'FFFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3777
    self assert:((Integer readFrom:'FFFFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFFFF').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3778
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3779
    self assert:((Integer readFrom:'10000000' radix:16) hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3780
    self assert:((Integer readFrom:'100000000' radix:16) hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3781
    self assert:((Integer readFrom:'1000000000' radix:16) hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3782
    self assert:((Integer readFrom:'10000000000' radix:16) hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3783
    self assert:((Integer readFrom:'100000000000' radix:16) hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3784
    self assert:((Integer readFrom:'1000000000000' radix:16) hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3785
    self assert:((Integer readFrom:'10000000000000' radix:16) hexPrintString = '10000000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3786
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3787
    t := Integer readFrom:'FFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3788
    self assert:((t + 1) hexPrintString = '100000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3789
    t := Integer readFrom:'FFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3790
    self assert:((t + 1) hexPrintString = '1000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3791
    t := Integer readFrom:'FFFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3792
    self assert:((t + 1) hexPrintString = '10000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3793
    t := Integer readFrom:'FFFFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3794
    self assert:((t + 1) hexPrintString = '100000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3795
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3796
    t := Integer readFrom:'10000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3797
    self assert:((t + 1) hexPrintString = '10000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3798
    t := Integer readFrom:'100000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3799
    self assert:((t + 1) hexPrintString = '100000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3800
    t := Integer readFrom:'1000000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3801
    self assert:((t + 1) hexPrintString = '1000000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3802
    t := Integer readFrom:'10000000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3803
    self assert:((t + 1) hexPrintString = '10000000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  3804
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3805
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3806
     self basicNew testReading1
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3807
    "
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3808
!
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3809
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3810
testReadingPrinting1
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3811
    |nr inString outString|
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3812
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3813
    #(2 3 4 5 8 10 16) do:[:radix |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3814
        Transcript showCR:('testing radix %1...' bindWith:radix).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3815
        1 to:1000 do:[:len |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3816
            inString := '1',(String new:len withAll:$0).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3817
            nr := Integer readFrom:inString radix:radix.
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3818
            outString := nr printStringRadix:radix.
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3819
            self assert:(outString = inString).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3820
        ].    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3821
    ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3822
    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3823
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3824
     self basicNew testReadingPrinting1
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3825
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3826
!
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  3827
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3828
testSmallIntegerArithmetic
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3829
    "arithmetic tests.
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3830
     Notice, the arithmetic tests are both performed via regular sends
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3831
     and via constructed performs. The reason is to test both inlined
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3832
     JIT-compiler code AND the regular methods code."
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3833
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3834
    |s n1 n2 t|
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3835
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3836
    "/ test division and modulu ...
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3837
    self assert:(1 printString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3838
    self assert:(10 printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3839
    self assert:(100 printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3840
    self assert:(1000 printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3841
    self assert:(10000 printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3842
    self assert:(100000 printString = '100000').
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3843
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3844
    "addition with overflow"
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3845
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3846
    SmallInteger maxBytes == 4 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3847
	n1 := 16r3FFFFFFF.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3848
	n2 := -16r40000000.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3849
    ] ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3850
	n1 := 16r3FFFFFFFFFFFFFFF.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3851
	n2 := -16r4000000000000000.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3852
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3853
    self assert:(n1 class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3854
    self assert:(n2 class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3855
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3856
    self assert:((n1 + 1) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3857
    t := n1 + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3858
    self assert:((t - 1) class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3859
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3860
    self assert:((n2 - 1) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3861
    t := n2 - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3862
    self assert:((t + 1) class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3863
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3864
    self assert:((n1 negated) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3865
    self assert:((n2 negated) class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3866
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3867
    self assert:((n2 perform:'negated' asSymbol) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3868
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3869
    self assert:((n1 abs == n1)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3870
    self assert:((n2 abs = n2 negated)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3871
    self assert:((n1 perform:'abs' asSymbol) == n1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3872
    self assert:((n2 perform:'abs' asSymbol) = n2 negated).
28
fca649220051 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 27
diff changeset
  3873
38
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  3874
    self testSmallIntegerMultiplication1.
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  3875
    self testSmallIntegerMultiplication1b.
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  3876
    self testSmallIntegerMultiplication2.
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3877
    self testSmallIntegerDivision1.
38
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  3878
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3879
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3880
     self basicNew testSmallIntegerArithmetic
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3881
    "
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3882
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  3883
    "Created: / 6.6.1999 / 14:47:51 / cg"
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3884
    "Modified: / 9.6.1999 / 17:49:57 / cg"
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3885
!
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3886
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3887
testSmallIntegerDivision1
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3888
    "division tests.
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3889
     Notice, the arithmetic tests are both performed via regular sends
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3890
     and via constructed performs. The reason is to test both inlined
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3891
     JIT-compiler code AND the regular methods code."
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3892
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3893
    |s n1 n2 t|
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3894
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3895
    n1 := 1000.
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3896
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3897
    "/ truncation towards...
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3898
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3899
    "/ ... negative infinity
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3900
    n2 := 3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3901
    self assert:((n1 // n2) == 333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3902
    self assert:((n1 // n2) printString = '333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3903
    self assert:((n1 perform:'//' asSymbol with:n2) == 333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3904
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3905
    n2 := -3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3906
    self assert:((n1 // n2) == -334).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3907
    self assert:((n1 // n2) printString = '-334').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3908
    self assert:((n1 perform:'//' asSymbol with:n2) == -334).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3909
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3910
    n2 := 3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3911
    self assert:((n1 // n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3912
    self assert:((n1 // n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3913
    self assert:((n1 perform:'//' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3914
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3915
    n2 := -3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3916
    self assert:((n1 // n2) == -1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3917
    self assert:((n1 // n2) printString = '-1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3918
    self assert:((n1 perform:'//' asSymbol with:n2) == -1).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3919
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3920
    "/ ... zero
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3921
    n2 := 3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3922
    self assert:((n1 quo: n2) == 333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3923
    self assert:((n1 quo: n2) printString = '333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3924
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3925
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3926
    n2 := -3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3927
    self assert:((n1 quo: n2) == -333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3928
    self assert:((n1 quo: n2) printString = '-333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3929
    self assert:((n1 perform:'quo:' asSymbol with:n2) == -333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3930
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3931
    n2 := 3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3932
    self assert:((n1 quo: n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3933
    self assert:((n1 quo: n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3934
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3935
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3936
    n2 := -3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3937
    self assert:((n1 quo: n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3938
    self assert:((n1 quo: n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3939
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3940
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3941
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3942
     self basicNew testSmallIntegerDivision1
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3943
    "
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3944
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3945
    "Modified: / 9.6.1999 / 17:47:56 / cg"
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3946
    "Created: / 9.6.1999 / 17:49:45 / cg"
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3947
!
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3948
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3949
testSmallIntegerMultiplication1
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3950
    "multiply tests (var * const).
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3951
     Notice, the arithmetic tests are both performed via regular sends
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3952
     and via constructed performs. The reason is to test both inlined
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3953
     JIT-compiler code AND the regular methods code."
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3954
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3955
    |s n1 n2 t|
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3956
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3957
    n1 := 100000.
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3958
    n2 := n1 negated.
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3959
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3960
    self assert:(n1 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3961
    self assert:(n2 printString = '-100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3962
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3963
    self assert:((n1 * 0) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3964
    self assert:((n1 perform:'*' asSymbol with:0) printString = '0').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3965
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3966
    self assert:((n1 * 1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3967
    self assert:((n1 perform:'*' asSymbol with:1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3968
    self assert:((n2 * 1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3969
    self assert:((n2 perform:'*' asSymbol with:1) printString = '-100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3970
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3971
    self assert:((n1 * -1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3972
    self assert:((n1 perform:'*' asSymbol with:-1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3973
    self assert:((n2 * -1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3974
    self assert:((n2 perform:'*' asSymbol with:-1) printString = '100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3975
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3976
    self assert:((n1 * 2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3977
    self assert:((n1 perform:'*' asSymbol with:2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3978
    self assert:((n1 * 3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3979
    self assert:((n1 perform:'*' asSymbol with:3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3980
    self assert:((n1 * 4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3981
    self assert:((n1 perform:'*' asSymbol with:4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3982
    self assert:((n1 * 5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3983
    self assert:((n1 perform:'*' asSymbol with:5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3984
    self assert:((n1 * 6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3985
    self assert:((n1 perform:'*' asSymbol with:6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3986
    self assert:((n1 * 7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3987
    self assert:((n1 perform:'*' asSymbol with:7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3988
    self assert:((n1 * 8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3989
    self assert:((n1 perform:'*' asSymbol with:8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3990
    self assert:((n1 * 9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3991
    self assert:((n1 perform:'*' asSymbol with:9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3992
    self assert:((n1 * 10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3993
    self assert:((n1 perform:'*' asSymbol with:10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3994
    self assert:((n1 * 11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3995
    self assert:((n1 perform:'*' asSymbol with:11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3996
    self assert:((n1 * 12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3997
    self assert:((n1 perform:'*' asSymbol with:12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3998
    self assert:((n1 * 13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3999
    self assert:((n1 perform:'*' asSymbol with:13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4000
    self assert:((n1 * 14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4001
    self assert:((n1 perform:'*' asSymbol with:14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4002
    self assert:((n1 * 15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4003
    self assert:((n1 perform:'*' asSymbol with:15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4004
    self assert:((n1 * 16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4005
    self assert:((n1 perform:'*' asSymbol with:16) printString = '1600000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4006
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4007
    n1 := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4008
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4009
    self assert:((n1 * n2) printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4010
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4011
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4012
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4013
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4014
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4015
    self assert:((n1 * n2) printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4016
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4017
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4018
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4019
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4020
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4021
    self assert:((n1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4022
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4023
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4024
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4025
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4026
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4027
    self assert:((n1 * n2) printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4028
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4029
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4030
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4031
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4032
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4033
    self assert:((n1 * n2) printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4034
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4035
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4036
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4037
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4038
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4039
    self assert:((n1 * n2) printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4040
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4041
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4042
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4043
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4044
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4045
    self assert:((n1 * n2) printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4046
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4047
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4048
    n1 := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4049
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4050
    self assert:((n1 * n2) printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4051
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4052
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4053
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4054
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4055
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4056
    self assert:((n1 * n2) printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4057
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4058
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4059
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4060
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4061
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4062
    self assert:((n1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4063
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4064
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4065
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4066
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4067
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4068
    self assert:((n1 * n2) printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4069
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4070
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4071
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4072
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4073
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4074
    self assert:((n1 * n2) printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4075
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4076
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4077
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4078
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4079
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4080
    self assert:((n1 * n2) printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4081
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4082
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4083
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4084
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4085
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4086
    self assert:((n1 * n2) printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4087
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4088
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4089
    n1 := 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4090
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4091
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4092
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4093
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4094
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4095
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4096
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4097
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4098
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4099
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4100
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4101
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4102
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4103
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4104
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4105
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4106
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4107
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4108
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4109
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4110
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4111
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4112
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4113
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4114
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4115
    self assert:((n1 * n2) printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4116
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4117
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4118
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4119
    self assert:((n1 * n2) printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4120
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4121
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4122
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4123
    self assert:((n1 * n2) printString = '1000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4124
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4125
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4126
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4127
    self assert:((n1 * n2) printString = '100000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4128
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4129
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4130
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4131
    self assert:((n1 * n2) printString = '10000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4132
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4133
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4134
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4135
    self assert:((n1 * n2) printString = '1000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4136
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4137
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4138
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4139
    self assert:((n1 * n2) printString = '100000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4140
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4141
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4142
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4143
     self basicNew testSmallIntegerMultiplication1
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4144
    "
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4145
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
  4146
    "Modified: / 9.6.1999 / 17:47:56 / cg"
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4147
    "Created: / 9.6.1999 / 17:49:45 / cg"
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4148
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4149
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4150
testSmallIntegerMultiplication1b
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4151
    "multiply tests (const * var).
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4152
     Notice, the arithmetic tests are both performed via regular sends
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4153
     and via constructed performs. The reason is to test both inlined
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4154
     JIT-compiler code AND the regular methods code."
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4155
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4156
    |s n1 n2 t|
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4157
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4158
    n1 := 100000.
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4159
    n2 := n1 negated.
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4160
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4161
    self assert:((0 * n1) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4162
    self assert:((0 perform:'*' asSymbol with:n1) printString = '0').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4163
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4164
    self assert:((1 * n1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4165
    self assert:((1 perform:'*' asSymbol with:n1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4166
    self assert:((1 * n2) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4167
    self assert:((1 perform:'*' asSymbol with:n2) printString = '-100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4168
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4169
    self assert:((-1 * n1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4170
    self assert:((-1 perform:'*' asSymbol with:n1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4171
    self assert:((-1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4172
    self assert:((-1 perform:'*' asSymbol with:n2) printString = '100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4173
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4174
    self assert:((2 * n1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4175
    self assert:((2 perform:'*' asSymbol with:n1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4176
    self assert:((3 * n1) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4177
    self assert:((3 perform:'*' asSymbol with:n1) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4178
    self assert:((4 * n1) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4179
    self assert:((4 perform:'*' asSymbol with:n1) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4180
    self assert:((5 * n1) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4181
    self assert:((5 perform:'*' asSymbol with:n1) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4182
    self assert:((6 * n1) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4183
    self assert:((6 perform:'*' asSymbol with:n1) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4184
    self assert:((7 * n1) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4185
    self assert:((7 perform:'*' asSymbol with:n1) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4186
    self assert:((8 * n1) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4187
    self assert:((8 perform:'*' asSymbol with:n1) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4188
    self assert:((9 * n1) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4189
    self assert:((9 perform:'*' asSymbol with:n1) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4190
    self assert:((10 * n1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4191
    self assert:((10 perform:'*' asSymbol with:n1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4192
    self assert:((11 * n1) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4193
    self assert:((11 perform:'*' asSymbol with:n1) printString = '1100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4194
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4195
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4196
     self basicNew testSmallIntegerMultiplication1b
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4197
    "
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4198
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4199
    "Modified: / 9.6.1999 / 17:47:56 / cg"
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4200
    "Created: / 9.6.1999 / 17:49:45 / cg"
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4201
!
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4202
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4203
testSmallIntegerMultiplication2
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4204
    "multiply tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4205
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4206
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4207
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4208
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4209
    |s n1 n2 t|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4210
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4211
    n1 := 100000.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4212
    n2 := n1 negated.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4213
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4214
    self assert:((n1 * 2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4215
    self assert:((n1 perform:'*' asSymbol with:2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4216
    self assert:((n1 * 3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4217
    self assert:((n1 perform:'*' asSymbol with:3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4218
    self assert:((n1 * 4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4219
    self assert:((n1 perform:'*' asSymbol with:4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4220
    self assert:((n1 * 5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4221
    self assert:((n1 perform:'*' asSymbol with:5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4222
    self assert:((n1 * 6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4223
    self assert:((n1 perform:'*' asSymbol with:6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4224
    self assert:((n1 * 7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4225
    self assert:((n1 perform:'*' asSymbol with:7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4226
    self assert:((n1 * 8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4227
    self assert:((n1 perform:'*' asSymbol with:8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4228
    self assert:((n1 * 9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4229
    self assert:((n1 perform:'*' asSymbol with:9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4230
    self assert:((n1 * 10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4231
    self assert:((n1 perform:'*' asSymbol with:10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4232
    self assert:((n1 * 11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4233
    self assert:((n1 perform:'*' asSymbol with:11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4234
    self assert:((n1 * 12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4235
    self assert:((n1 perform:'*' asSymbol with:12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4236
    self assert:((n1 * 13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4237
    self assert:((n1 perform:'*' asSymbol with:13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4238
    self assert:((n1 * 14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4239
    self assert:((n1 perform:'*' asSymbol with:14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4240
    self assert:((n1 * 15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4241
    self assert:((n1 perform:'*' asSymbol with:15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4242
    self assert:((n1 * 16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4243
    self assert:((n1 perform:'*' asSymbol with:16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4244
    self assert:((n1 * 17) printString = '1700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4245
    self assert:((n1 perform:'*' asSymbol with:17) printString = '1700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4246
    self assert:((n1 * 18) printString = '1800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4247
    self assert:((n1 perform:'*' asSymbol with:18) printString = '1800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4248
    self assert:((n1 * 19) printString = '1900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4249
    self assert:((n1 perform:'*' asSymbol with:19) printString = '1900000').
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4250
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4251
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4252
     self basicNew testSmallIntegerMultiplication2
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4253
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4254
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4255
    "Modified: / 9.6.1999 / 17:47:56 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4256
    "Created: / 9.6.1999 / 17:49:45 / cg"
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4257
!
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4258
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4259
testSmallIntegerMultiplication3
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4260
    "multiply tests.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4261
     Notice, the arithmetic tests are both performed via regular sends
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4262
     and via constructed performs. The reason is to test both inlined
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4263
     JIT-compiler code AND the regular methods code."
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4264
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4265
    |s n1 n2 t|
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4266
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4267
    n1 := 16rFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4268
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4269
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4270
    self assert:((n1 * 2) printString = '131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4271
    self assert:((n1 perform:'*' asSymbol with:2) printString = '131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4272
    self assert:((n2 * 2) printString = '-131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4273
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-131070').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4274
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4275
    n1 := 16rFFFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4276
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4277
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4278
    self assert:((n1 * 2) printString = '33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4279
    self assert:((n1 perform:'*' asSymbol with:2) printString = '33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4280
    self assert:((n2 * 2) printString = '-33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4281
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-33554430').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4282
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4283
    n1 := 16r3FFFFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4284
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4285
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4286
    self assert:((n1 * 2) printString = '2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4287
    self assert:((n1 perform:'*' asSymbol with:2) printString = '2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4288
    self assert:((n2 * 2) printString = '-2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4289
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-2147483646').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4290
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4291
    SmallInteger maxBytes == 4 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4292
	n1 := 16r3FFFFFFF.
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4293
    ] ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4294
	n1 := 16r3FFFFFFFFFFFFFFF.
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4295
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4296
    self assert:(n1 class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4297
    self assert:((n1 * 2) class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4298
    self assert:((n1 perform:'*' asSymbol with:2) class == LargeInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4299
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4300
    n1 := SmallInteger maxVal // 11.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4301
    self assert:((n1 * 11) class == SmallInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4302
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4303
    n1 := n1 + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4304
    self assert:((n1 * 11) class == LargeInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4305
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4306
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4307
     self basicNew testSmallIntegerMultiplication3
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4308
    "
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4309
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4310
    "Modified: / 9.6.1999 / 17:47:56 / cg"
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4311
    "Created: / 9.6.1999 / 17:49:45 / cg"
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4312
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4313
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4314
!IntegerTest methodsFor:'tests-class protocol'!
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4315
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4316
testCreationFromBytes1
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4317
  "self run: #testCreationFromBytes1"
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4318
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4319
  " it is illegal for a LargeInteger to be less than SmallInteger maxVal."
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4320
  " here we test that Integer>>byte!!byte2:byte3:byte4: reconstructs SmallInteger maxVal as an instance of SmallInteger. "
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4321
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4322
   | maxSmallInt hexString
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4323
     byte1 byte2 byte3 byte4
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4324
     byte5 byte6 byte7 byte8
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4325
     builtInteger builtIntegerH builtIntegerL|
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4326
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4327
    maxSmallInt := SmallInteger maxVal.
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4328
    hexString := maxSmallInt printStringHex.
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4329
    ExternalAddress pointerSize == 8 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4330
	self assert: hexString size = 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4331
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4332
	byte8 := Integer readFrom: (hexString copyFrom: 1 to: 2) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4333
	byte7 := Integer readFrom: (hexString copyFrom: 3 to: 4) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4334
	byte6 := Integer readFrom: (hexString copyFrom: 5 to: 6) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4335
	byte5 := Integer readFrom: (hexString copyFrom: 7 to: 8) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4336
	byte4 := Integer readFrom: (hexString copyFrom: 9 to: 10) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4337
	byte3 := Integer readFrom: (hexString copyFrom: 11 to: 12) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4338
	byte2 := Integer readFrom: (hexString copyFrom: 13 to: 14) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4339
	byte1 := Integer readFrom: (hexString copyFrom: 15 to: 16) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4340
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4341
	builtIntegerH := Integer byte1: byte5 byte2: byte6 byte3: byte7 byte4: byte8.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4342
	builtIntegerL := Integer byte1: byte1 byte2: byte2 byte3: byte3 byte4: byte4.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4343
	builtInteger := (builtIntegerH bitShift:32) bitOr:builtIntegerL.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4344
	self assert: builtInteger = maxSmallInt.
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4345
    ] ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4346
	self assert: hexString size = 8.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4347
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4348
	byte4 := Integer readFrom: (hexString copyFrom: 1 to: 2) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4349
	byte3 := Integer readFrom: (hexString copyFrom: 3 to: 4) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4350
	byte2 := Integer readFrom: (hexString copyFrom: 5 to: 6) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4351
	byte1 := Integer readFrom: (hexString copyFrom: 7 to: 8) base: 16.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4352
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4353
	builtInteger := Integer byte1: byte1 byte2: byte2 byte3: byte3 byte4: byte4.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4354
	self assert: builtInteger = maxSmallInt.
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4355
    ].
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4356
    self assert: builtInteger class = SmallInteger
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4357
! !
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4358
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4359
!IntegerTest methodsFor:'tests-concrete bugs'!
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4360
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4361
a_rack:rack subrack:subr board:slot port:port channel:chn typeId:aTypeOrSymbol
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4362
    "create an Idn from the given arguments
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4363
    "
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4364
    |hgEnc typ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4365
     eqEnc "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4366
     oid   "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4367
     IDN|
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4368
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4369
    IDN := self class.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4370
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4371
    eqEnc := rack.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4372
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4373
    eqEnc > 0 ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4374
		 eqEnc < 0    ifTrue:[idn := #Dontcare]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4375
	ifFalse:[port == 256  ifTrue:[idn := #NWNode]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4376
	ifFalse:[ idn := #Unspecified ]].
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4377
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4378
      ^ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4379
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4380
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4381
    eqEnc >= 255 ifTrue:[       "/ is a logical resource
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4382
	eqEnc > 255 ifTrue:[ ^ #Unspecified ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4383
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4384
	slot == 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4385
	    subr == 1 ifTrue:[ ^ #ConnectManager ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4386
	    subr == 2 ifTrue:[ ^ #ClockManager   ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4387
	].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4388
	oid := 4.                               "/ logical resource
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4389
    ] ifFalse:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4390
	oid := 2.                               "/ equipment
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4391
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4392
    hgEnc := 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4393
    typ   := aTypeOrSymbol.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4394
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4395
    subr ~~ 0 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4396
	subr > 16r0f  ifTrue:[ ^ #Unspecified ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4397
	eqEnc := eqEnc bitOr:(subr bitShift: 8).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4398
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4399
	slot ~~ 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4400
	    slot > 16rff  ifTrue:[ ^ #Unspecified ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4401
	    eqEnc := eqEnc bitOr:(slot bitShift:12).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4402
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4403
	    port ~~ 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4404
		port > 16rff  ifTrue:[ ^ #Unspecified ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4405
		eqEnc := eqEnc bitOr:(port bitShift:20).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4406
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4407
		chn ~~ 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4408
		    chn > 16rfff  ifTrue:[ ^ #Unspecified ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4409
		    oid   := 3.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4410
		    typ   := aTypeOrSymbol ? 0.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4411
		    hgEnc := chn.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4412
		]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4413
	    ]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4414
	]
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4415
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4416
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4417
    typ notNil ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4418
	typ isSymbol ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4419
	    typ := 0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4420
	].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4421
	hgEnc := hgEnc bitOr:(typ bitShift:12).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4422
	hgEnc := hgEnc bitOr:(oid bitShift:20).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4423
    ].
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4424
    ^ #ok.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4425
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4426
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4427
self basicNew rack:1 subrack:3 board:5 port:33 channel:8 typeId:7
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4428
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4429
!
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4430
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4431
rack:rack subrack:subr board:slot port:port channel:chn typeId:aTypeOrSymbol
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4432
    "create an Idn from the given arguments
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4433
    "
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4434
    |hgEnc typ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4435
     eqEnc "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4436
     oid   "{ Class:SmallInteger }"|
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4437
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4438
    eqEnc := rack.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4439
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4440
"/    eqEnc > 0 ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4441
"/                 eqEnc < 0    ifTrue:[idn := IDN Dontcare]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4442
"/        ifFalse:[port == 256  ifTrue:[idn := IDN NWNode]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4443
"/        ifFalse:[ idn := IDN Unspecified ]].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4444
"/
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4445
"/      ^ self fromIdn:idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4446
"/    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4447
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4448
"/    eqEnc >= 255 ifTrue:[       "/ is a logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4449
"/        eqEnc > 255 ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4450
"/
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4451
"/        slot == 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4452
"/            subr == 1 ifTrue:[ ^ self fromIdn:(IDN ConnectManager) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4453
"/            subr == 2 ifTrue:[ ^ self fromIdn:(IDN ClockManager)   ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4454
"/        ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4455
"/        oid := 4.                               "/ logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4456
"/    ] ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4457
"/        oid := 2.                               "/ equipment
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4458
"/    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4459
"/    hgEnc := 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4460
"/    typ   := aTypeOrSymbol.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4461
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4462
    subr ~~ 0 ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4463
	subr > 16r0f  ifTrue:[ ^ nil "self fromIdn:(IDN Unspecified)" ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4464
	eqEnc := eqEnc bitOr:(subr bitShift: 8).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4465
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4466
	slot ~~ 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4467
	    slot > 16rff  ifTrue:[ ^ nil "self fromIdn:(IDN Unspecified)" ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4468
	    eqEnc := eqEnc bitOr:(slot bitShift:12).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4469
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4470
	    port ~~ 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4471
		port > 16rff  ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4472
		eqEnc := eqEnc bitOr:(port bitShift:20).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4473
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4474
		chn ~~ 0 ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4475
		    chn > 16rfff  ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4476
		    oid   := 3.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4477
		    typ   := aTypeOrSymbol ? 0.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4478
		    hgEnc := chn.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4479
		]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4480
	    ]
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4481
	]
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4482
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4483
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4484
    typ notNil ifTrue:[
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4485
	typ isSymbol ifTrue:[
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4486
	    typ := (MDT::MDTCType asNumberType:typ) ? 0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4487
	].
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4488
	hgEnc := hgEnc bitOr:(typ bitShift:12).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4489
	hgEnc := hgEnc bitOr:(oid bitShift:20).
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4490
    ].
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4491
    ^ self basicNew eqEncode:eqEnc hgEncode:hgEnc.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4492
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4493
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4494
self basicNew rack:1 subrack:3 board:5 port:33 channel:8 typeId:7
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4495
"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4496
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4497
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4498
test_gcdBug1
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4499
    |theBase theMersenne theRest theGcd theOldRest theOldGcd|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4500
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4501
    theBase := 2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4502
    132 to:135 do:[:theOrder |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4503
	false " <<<< here i replaced some piece of code by false just to reproduce the error without having to ship all my code >>>>" ifFalse:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4504
	    theRest := ((theBase raisedTo:theOrder) - 1) / (theBase - 1).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4505
	    30 "theOrder - 1" to:67 do:[:theFactorOrder |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4506
		"/Transcript show:theOrder; space.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4507
		"/Transcript showCR:theFactorOrder.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4508
		(theOrder \\ theFactorOrder) = 0 ifTrue:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4509
		    " <<<< is a divisor of the order >>>>"
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4510
		    self assert:theFactorOrder ~= 131 description:'131 ist kein Teiler von 132'.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4511
		    self assert:(theOrder / theFactorOrder) isFraction not.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4512
		    theMersenne := ((theBase raisedTo:theFactorOrder) - 1) / (theBase - 1).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4513
		    theGcd := theRest gcd:theMersenne.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4514
		    [ theGcd > 1 ] whileTrue:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4515
			self assert:theFactorOrder < 129.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4516
			theOldRest := theRest asString.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4517
			theOldGcd := theGcd asString.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4518
			theRest := theRest / theGcd.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4519
			theGcd := theGcd gcd:theRest.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4520
			self assert:((theRest \\ theGcd) = 0).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4521
			self assert:(theRest / theGcd) isFraction not.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4522
		    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4523
		].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4524
	    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4525
	    self assert:theRest ~= 1
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4526
		description:'there is no prime factor of order theOrder'
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4527
	].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4528
    ].
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4529
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4530
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4531
     self new test_gcdBug1
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4532
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  4533
    "Modified: / 27-04-2010 / 00:02:02 / cg"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4534
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4535
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4536
test_gcdBug2
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4537
    |theBase theMersenne theRest theGcd theOldRest theOldGcd|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4538
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4539
    theBase := 2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4540
    132 to:135 do:[:theOrder |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4541
	false " <<<< here i replaced some piece of code by false just to
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4542
	 reproduce the error without having to ship all my code >>>>"
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4543
		ifFalse:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4544
		    theRest := ((theBase raisedTo:theOrder) - 1) / (theBase - 1).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4545
		    60 "theOrder - 1" to:67 do:[:theFactorOrder |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4546
			"/Transcript show:theOrder; space.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4547
			"/Transcript showCR:theFactorOrder.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4548
			(theOrder \\ theFactorOrder) = 0 ifTrue:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4549
			    " <<<< is a divisor of the order >>>>"
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4550
			    self assert:theFactorOrder ~= 131 description:'131 ist kein Teiler von 132'.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4551
			    self assert:(theOrder / theFactorOrder) isFraction not.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4552
			    theMersenne := ((theBase raisedTo:theFactorOrder) - 1) / (theBase - 1).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4553
			    theGcd := theRest gcd:theMersenne.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4554
			    [ theGcd > 1 ] whileTrue:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4555
				self assert:theFactorOrder < 129.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4556
				theOldRest := theRest asString.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4557
				theOldGcd := theGcd asString.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4558
				theRest := theRest / theGcd.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4559
				theGcd := theGcd gcd:theRest.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4560
				self assert:((theRest \\ theGcd) = 0).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4561
				self assert:(theRest / theGcd) isFraction not.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4562
			    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4563
			].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4564
		    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4565
		    self assert:theRest ~= 1
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4566
			description:'there is no prime factor of order theOrder'
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4567
		].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4568
    ].
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4569
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4570
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4571
     self new test_gcdBug2
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4572
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  4573
    "Modified: / 27-04-2010 / 00:02:09 / cg"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4574
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4575
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4576
test_gcdBug3
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4577
    |theBase theMersenne theRest theGcd theOldRest theOldGcd|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4578
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4579
    theBase := 2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4580
    132 to:135 do:[:theOrder |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4581
	false " <<<< here i replaced some piece of code by false just to
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4582
	 reproduce the error without having to ship all my code >>>>"
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4583
		ifFalse:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4584
		    theRest := ((theBase raisedTo:theOrder) - 1) / (theBase - 1).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4585
		    2 to:theOrder - 1 do:[:theFactorOrder |
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4586
			"/Transcript show:theOrder; space.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4587
			"/Transcript showCR:theFactorOrder.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4588
			(theOrder \\ theFactorOrder) = 0 ifTrue:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4589
			    " <<<< is a divisor of the order >>>>"
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4590
			    self assert:theFactorOrder ~= 131 description:'131 ist kein Teiler von 132'.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4591
			    self assert:(theOrder / theFactorOrder) isFraction not.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4592
			    theMersenne := ((theBase raisedTo:theFactorOrder) - 1) / (theBase - 1).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4593
			    theGcd := theRest gcd:theMersenne.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4594
			    [ theGcd > 1 ] whileTrue:[
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4595
				self assert:theFactorOrder < 129.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4596
				theOldRest := theRest asString.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4597
				theOldGcd := theGcd asString.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4598
				theRest := theRest / theGcd.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4599
				theGcd := theGcd gcd:theRest.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4600
				self assert:((theRest \\ theGcd) = 0).
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4601
				self assert:(theRest / theGcd) isFraction not.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4602
			    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4603
			].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4604
		    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4605
		    self assert:theRest ~= 1
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4606
			description:'there is no prime factor of order theOrder'
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4607
		].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4608
    ].
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4609
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4610
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4611
     self new test_gcdBug3
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4612
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  4613
    "Modified: / 27-04-2010 / 00:02:15 / cg"
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4614
! !
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4615
1298
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4616
!IntegerTest methodsFor:'tests-misc'!
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4617
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4618
test_primes
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4619
    self 
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4620
        assert: ((1 to: 30) select: [:i | i isPrime] as:Array) 
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4621
                            = #(2 3 5 7 11 13 17 19 23 29);
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4622
        assert: ((0 to: 30) collect: [:i | i nextPrime] as:Array)
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4623
                            = #(2 2 3 5 5 7 7 11 11 11 11 13 13 17 17 17 17 19 19 23 23 23 23 29 29 29 29 29 29 31 31).
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4624
! !
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4625
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4626
!IntegerTest class methodsFor:'documentation'!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4627
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4628
version
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4629
    ^ '$Header$'
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4630
!
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4631
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4632
version_CVS
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4633
    ^ '$Header$'
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4634
! !
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4635