RegressionTests__IntegerTest.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Thu, 30 Jun 2016 09:02:08 +0100
branchjv
changeset 1500 d406a10b2965
parent 1499 26a16a04219b
parent 1431 c916f28b79db
child 1539 5206114410f7
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1499
26a16a04219b Package renamed from exept:regression to stx:goodies/regression. Hooray!
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1497
diff changeset
     1
"{ Package: 'stx:goodies/regression' }"
56
77f5ad522f18 category
Claus Gittinger <cg@exept.de>
parents: 54
diff changeset
     2
70
c677f96c4a0b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
     3
"{ NameSpace: RegressionTests }"
c677f96c4a0b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
     4
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
     5
TestCase subclass:#IntegerTest
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
     6
	instanceVariableNames:''
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
     7
	classVariableNames:''
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
     8
	poolDictionaries:''
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
     9
	category:'tests-Regression-Numbers'
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    13
!IntegerTest methodsFor:'misc'!
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    14
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    15
doMul0_a:arg
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    16
    ^ arg * 0
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    17
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    18
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    19
     (self doMul0_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    20
     (self doMul0_a:1) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    21
     (self doMul0_a:SmallInteger maxVal) == 0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    22
     (self doMul0_a:SmallInteger minVal) == 0
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    23
    "
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    24
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    25
    "Created: / 9.6.1999 / 15:50:48 / cg"
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
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    28
doMul1_a:arg
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    29
    ^ arg * 1
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    30
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    31
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    32
     (self doMul1_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    33
     (self doMul1_a:1) ==   1
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    34
     (self doMul1_a:SmallInteger maxVal) == SmallInteger maxVal
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    35
     (self doMul1_a:SmallInteger minVal) == SmallInteger minVal
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    36
    "
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    37
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
    38
    "Created: / 9.6.1999 / 15:49:09 / cg"
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
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    41
doMul2_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    42
    ^ arg * 2
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    43
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    44
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    45
     (self doMul2_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    46
     (self doMul2_a:1) ==   2
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    47
     (self doMul2_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    48
     (self doMul2_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal)
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    49
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    50
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    51
    "Modified: / 9.6.1999 / 16:57:20 / cg"
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
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    54
doMul3_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    55
    ^ arg * 3
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    56
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    57
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    58
     (self doMul3_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    59
     (self doMul3_a:1) ==   3
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    60
     (self doMul3_a:-1) ==  -3
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    61
     (self doMul3_a:10000) ==   30000
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    62
     (self doMul3_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    63
     (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
    64
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    65
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    66
    "Created: / 9.6.1999 / 16:57:47 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    67
    "Modified: / 9.6.1999 / 17:35:34 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    68
!
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    69
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    70
doMul4_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    71
    ^ arg * 4
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    72
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    73
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    74
     (self doMul4_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    75
     (self doMul4_a:1) ==   4
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    76
     (self doMul4_a:-1) ==  -4
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    77
     (self doMul4_a:10000) ==   40000
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    78
     (self doMul4_a:SmallInteger maxVal//4) == 4611686018427387900
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    79
     (self doMul4_a:SmallInteger maxVal//4+1) = 4611686018427387904
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    80
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    81
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    82
    "Created: / 9.6.1999 / 16:57:47 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    83
    "Modified: / 9.6.1999 / 17:37:36 / cg"
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    84
!
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    85
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    86
doMul5_a:arg
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    87
    ^ arg * 5
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    88
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    89
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    90
     (self doMul5_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    91
     (self doMul5_a:1) ==   5
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    92
     (self doMul5_a:-1) ==  -5
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    93
     (self doMul5_a:10000) ==   50000
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    94
     (self doMul5_a:SmallInteger maxVal//5) == 4611686018427387900
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
    95
     (self doMul5_a:SmallInteger maxVal//4+1) = 4611686018427387905
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    96
    "
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    97
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
    98
    "Created: / 9.6.1999 / 17:38:17 / cg"
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
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   101
doMulM1_a:arg
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   102
    ^ arg * -1
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   103
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   104
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   105
     (self doMulM1_a:0) ==   0
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   106
     (self doMulM1_a:1) ==   -1
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   107
     (self doMulM1_a:SmallInteger maxVal) == (SmallInteger minVal + 1)
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   108
     (self doMulM1_a:SmallInteger minVal) = (SmallInteger maxVal + 1)
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   109
    "
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   110
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
   111
    "Modified: / 9.6.1999 / 16:54:02 / cg"
31
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   112
!
4738d31a625e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 29
diff changeset
   113
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   114
doPlus1_a:arg
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   115
    ^ arg + 1
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   116
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   117
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   118
     (self doPlus1_a:SmallInteger maxVal) =   1073741824
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   119
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   120
!
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
doPlus1_b:arg
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   123
    ^ arg perform:#+ with:1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   124
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   125
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   126
     (self doPlus1_b:SmallInteger maxVal) ==   1073741824
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   127
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   128
!
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
testMul0
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   131
    self assert: ( (self doMul0_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   132
    self assert: ( (self doMul0_a:1) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   133
    self assert: ( (self doMul0_a:SmallInteger maxVal) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   134
    self assert: ( (self doMul0_a:SmallInteger minVal) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   135
    self assert: ( (self doMul0_a:SmallInteger maxVal+1) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   136
    self assert: ( (self doMul0_a:SmallInteger minVal-1) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   137
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   138
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   139
     self basicNew testMul0
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
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   142
    "Created: / 9.6.1999 / 15:50:48 / cg"
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
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   145
testMul1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   146
    self assert: ( (self doMul1_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   147
    self assert: ( (self doMul1_a:1) == 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   148
    self assert: ( (self doMul1_a:SmallInteger maxVal) == SmallInteger maxVal ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   149
    self assert: ( (self doMul1_a:SmallInteger minVal) == SmallInteger minVal ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   150
    self assert: ( (self doMul1_a:SmallInteger maxVal+1) = (SmallInteger maxVal+1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   151
    self assert: ( (self doMul1_a:SmallInteger minVal-1) = (SmallInteger minVal-1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   152
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   153
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   154
     self basicNew testMul1
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   155
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   156
!
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   157
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   158
testMul2
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   159
    self assert: ( (self doMul2_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   160
    self assert: ( (self doMul2_a:1) == 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   161
    self assert: ( (self doMul2_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   162
    self assert: ( (self doMul2_a:SmallInteger minVal) = (SmallInteger minVal + SmallInteger minVal) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   163
    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
   164
    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
   165
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   166
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   167
     self basicNew testMul2
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
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   170
    "Modified: / 9.6.1999 / 16:57:20 / cg"
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
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   173
testMul3
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   174
    self assert: ( (self doMul3_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   175
    self assert: ( (self doMul3_a:1) == 3 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   176
    self assert: ( (self doMul3_a:-1) == -3 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   177
    self assert: ( (self doMul3_a:10000) == 30000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   178
    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
   179
    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
   180
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   181
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   182
     self basicNew testMul3
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
!
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
testMul4
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   187
    self assert: ( (self doMul4_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   188
    self assert: ( (self doMul4_a:1) == 4 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   189
    self assert: ( (self doMul4_a:-1) == -4 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   190
    self assert: ( (self doMul4_a:10000) == 40000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   191
    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
   192
    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
   193
    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
   194
    self assert: ( (self doMul4_a:SmallInteger minVal//4) = (SmallInteger minVal) ).
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   195
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   196
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   197
     self basicNew testMul4
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   198
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   199
!
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
testMul5
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   202
    self assert: ( (self doMul5_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   203
    self assert: ( (self doMul5_a:1) == 5 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   204
    self assert: ( (self doMul5_a:-1) == -5 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   205
    self assert: ( (self doMul5_a:10000) == 50000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   206
    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
   207
    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
   208
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   209
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   210
     self basicNew testMul5
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
!
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
testMulM1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   215
    self assert: ( (self doMulM1_a:0) == 0 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   216
    self assert: ( (self doMulM1_a:1) == -1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   217
    self assert: ( (self doMulM1_a:-1) == 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   218
    self assert: ( (self doMulM1_a:10000) == -10000 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   219
    self assert: ( (self doMulM1_a:SmallInteger maxVal) = (SmallInteger minVal + 1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   220
    self assert: ( (self doMulM1_a:SmallInteger minVal) = (SmallInteger maxVal + 1) ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   221
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   222
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   223
     self basicNew testMulM1
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   224
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   225
!
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
testPlus1
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   228
    self assert: ( (self doPlus1_a:0) = 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   229
    self assert: ( (self doPlus1_a:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   230
    self assert: ( (self doPlus1_a:-1) = 0 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   231
    ExternalAddress pointerSize == 8 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   232
	self assert: ( (self doPlus1_a:SmallInteger maxVal) = 4611686018427387904).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   233
	self assert: ( (self doPlus1_a:SmallInteger minVal) = -4611686018427387903 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   234
    ] ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   235
	self assert: ( (self doPlus1_a:SmallInteger maxVal) = 1073741824).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   236
	self assert: ( (self doPlus1_a:SmallInteger minVal) = -1073741823 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   237
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   238
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   239
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   240
     self basicNew testPlus1
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
!
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
testPlus1perform
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   245
    self assert: ( (self doPlus1_b:0) = 1 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   246
    self assert: ( (self doPlus1_b:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   247
    self assert: ( (self doPlus1_b:-1) = 0 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   248
    ExternalAddress pointerSize == 8 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   249
	self assert: ( (self doPlus1_b:SmallInteger maxVal) = 4611686018427387904).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   250
	self assert: ( (self doPlus1_b:SmallInteger minVal) = -4611686018427387903 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   251
    ] ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   252
	self assert: ( (self doPlus1_b:SmallInteger maxVal) = 1073741824).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   253
	self assert: ( (self doPlus1_b:SmallInteger minVal) = -1073741823 ).
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   254
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   255
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   256
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   257
     self basicNew testPlus1perform
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   258
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   259
! !
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   260
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   261
!IntegerTest methodsFor:'private'!
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   263
absPlusOneOf:arg
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   264
			|local1|
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   265
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   266
			local1 := arg.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
   267
			^ local1 abs + 1
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   268
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   269
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   270
"
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   271
 self absPlusOneOf:-1
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
   272
 self absPlusOneOf:-1.0
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   273
"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   274
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   275
    "Created: / 31.10.2000 / 20:21:52 / cg"
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
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   278
alwaysTrue
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   279
    ^ true.
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   280
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   281
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   282
checkIsInteger:arg
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   283
    ^ arg isInteger
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   284
!
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   285
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   286
doConstantIntegerShift
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   287
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   288
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   289
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   290
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   291
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   292
    |flags|
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 := self flagsSlot.
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
    self alwaysTrue ifFalse:[self halt].
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   297
    ^ flags bitShift:-1.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   298
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   299
    "
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   300
     self testIntegerShifts3
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
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   303
    "Created: / 6.6.1999 / 14:47:51 / cg"
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   304
    "Modified: / 9.6.1999 / 17:49:57 / cg"
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   305
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   306
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   307
flagsSlot
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   308
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   309
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   310
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   311
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   312
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   313
    ^ 2.
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
    "
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   316
     self testIntegerShifts3
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
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   319
    "Created: / 6.6.1999 / 14:47:51 / cg"
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   320
    "Modified: / 9.6.1999 / 17:49:57 / cg"
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
   321
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
   322
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   323
num_00000000000007FFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   324
    ^ 16r00000000000007FFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   325
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   326
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   327
    "Created: / 4.6.1999 / 15:34:12 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   328
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   329
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   330
num_00000000000008000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   331
    ^ 16r00000000000008000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   332
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   333
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   334
    "Created: / 4.6.1999 / 15:39:32 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   335
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   336
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   337
num_0000000000000FFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   338
    ^ 16r0000000000000FFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   339
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   340
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   341
    "Created: / 4.6.1999 / 15:34:26 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   342
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   343
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   344
num_00000000000010000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   345
    ^ 16r00000000000010000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   346
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   347
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   348
    "Created: / 4.6.1999 / 15:34:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   349
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   350
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   351
num_00000000000100000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   352
    ^ 16r00000000000100000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   353
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   354
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   355
    "Created: / 4.6.1999 / 15:34:36 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   356
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   357
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   358
num_000000000007FFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   359
    ^ 16r000000000007FFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   360
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   361
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   362
    "Created: / 4.6.1999 / 15:37:48 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   363
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   364
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   365
num_00000000000800000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   366
    ^ 16r00000000000800000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   367
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   368
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   369
    "Created: / 4.6.1999 / 15:39:43 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   370
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   371
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   372
num_00000000000FFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   373
    ^ 16r00000000000FFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   374
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   375
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   376
    "Created: / 4.6.1999 / 15:37:52 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   377
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   378
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   379
num_00000000001000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   380
    ^ 16r00000000001000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   381
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   382
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   383
    "Created: / 4.6.1999 / 15:34:42 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   384
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   385
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   386
num_0000000000FFF0000
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   387
    ^ 16r0000000000FFF0000
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   388
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   389
    "self num_0000000000FFF0000 hexPrintString"
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
    "Created: / 4.6.1999 / 17:44:26 / cg"
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   392
    "Modified: / 4.6.1999 / 18:40:47 / cg"
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   393
!
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
   394
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   395
num_00000000010000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   396
    ^ 16r00000000010000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   397
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   398
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   399
    "Created: / 4.6.1999 / 15:34:46 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   400
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   401
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   402
num_0000000007FFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   403
    ^ 16r0000000007FFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   404
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   405
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   406
    "Created: / 4.6.1999 / 15:37:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   407
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   408
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   409
num_00000000080000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   410
    ^ 16r00000000080000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   411
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   412
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   413
    "Created: / 4.6.1999 / 15:39:56 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   414
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   415
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   416
num_000000000FFFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   417
    ^ 16r000000000FFFFFFFF
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   418
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   419
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   420
    "Created: / 4.6.1999 / 15:36:16 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   421
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   422
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   423
num_00000000100000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   424
    ^ 16r00000000100000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   425
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   426
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   427
    "Created: / 4.6.1999 / 15:34:51 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   428
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   429
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   430
num_00000001000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   431
    ^ 16r00000001000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   432
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   433
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   434
    "Created: / 4.6.1999 / 15:34:57 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   435
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   436
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   437
num_0000000FFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   438
    ^ 16r0000000FFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   439
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   440
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   441
    "Created: / 4.6.1999 / 17:41:08 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   442
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   443
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   444
num_00000010000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   445
    ^ 16r00000010000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   446
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   447
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   448
    "Created: / 4.6.1999 / 15:35:03 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   449
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   450
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   451
num_00000100000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   452
    ^ 16r00000100000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   453
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   454
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   455
    "Created: / 4.6.1999 / 15:35:07 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   456
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   457
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   458
num_00000FFFFFFFFFF00
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   459
    ^ 16r00000FFFFFFFFFF00
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   460
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   461
    "self num_00000FFFFFFFFFF00"
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
    "Created: / 4.6.1999 / 17:44:26 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   464
    "Modified: / 4.6.1999 / 17:46:20 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   465
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   466
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   467
num_00000FFFFFFFFFF80
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   468
    ^ 16r00000FFFFFFFFFF80
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   469
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   470
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   471
    "Created: / 4.6.1999 / 17:44:23 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   472
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   473
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   474
num_00000FFFFFFFFFFC0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   475
    ^ 16r00000FFFFFFFFFFC0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   476
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   477
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   478
    "Created: / 4.6.1999 / 17:44:20 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   479
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   480
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   481
num_00000FFFFFFFFFFE0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   482
    ^ 16r00000FFFFFFFFFFE0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   483
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   484
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   485
    "Created: / 4.6.1999 / 17:44:16 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   486
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   487
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   488
num_00000FFFFFFFFFFF0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   489
    ^ 16r00000FFFFFFFFFFF0
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   490
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   491
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   492
    "Created: / 4.6.1999 / 17:44:12 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   493
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   494
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   495
num_00000FFFFFFFFFFF8
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   496
    ^ 16r00000FFFFFFFFFFF8
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   497
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   498
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   499
    "Created: / 4.6.1999 / 17:44:09 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   500
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   501
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   502
num_00000FFFFFFFFFFFC
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   503
    ^ 16r00000FFFFFFFFFFFC
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   504
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   505
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   506
    "Created: / 4.6.1999 / 17:44:05 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   507
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   508
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   509
num_00000FFFFFFFFFFFE
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   510
    ^ 16r00000FFFFFFFFFFFE
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   511
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   512
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   513
    "Created: / 4.6.1999 / 17:45:12 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   514
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   515
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   516
num_00000FFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   517
    ^ 16r00000FFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   518
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   519
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   520
    "Created: / 4.6.1999 / 17:41:22 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   521
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   522
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   523
num_00001000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   524
    ^ 16r00001000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   525
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   526
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   527
    "Created: / 4.6.1999 / 15:35:13 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   528
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   529
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   530
num_00010000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   531
    ^ 16r00010000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   532
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   533
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   534
    "Created: / 4.6.1999 / 15:35:18 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   535
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   536
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   537
num_000FFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   538
    ^ 16r000FFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   539
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   540
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   541
    "Created: / 4.6.1999 / 17:41:26 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   542
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   543
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   544
num_00100000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   545
    ^ 16r00100000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   546
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   547
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   548
    "Created: / 4.6.1999 / 15:35:22 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   549
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   550
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   551
num_01000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   552
    ^ 16r01000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   553
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   554
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   555
    "Created: / 4.6.1999 / 15:35:27 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   556
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   557
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   558
num_0FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   559
    ^ 16r0FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   560
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   561
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   562
    "Created: / 4.6.1999 / 17:41:30 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   563
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   564
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   565
num_10000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   566
    ^ 16r10000000000000000
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   567
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   568
    "Modified: / 4.6.1999 / 15:29:31 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   569
    "Created: / 4.6.1999 / 15:35:32 / cg"
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   570
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   571
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   572
num_16r80000000
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   573
    ^ 16r80000000
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   574
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   575
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   576
num_1FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   577
    ^ 16r1FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   578
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   579
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   580
    "Created: / 4.6.1999 / 17:41:51 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   581
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   582
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   583
num_20000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   584
    ^ 16r20000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   585
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   586
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   587
    "Created: / 4.6.1999 / 17:40:26 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   588
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   589
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   590
num_3FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   591
    ^ 16r3FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   592
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   593
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   594
    "Created: / 4.6.1999 / 17:42:07 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   595
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   596
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   597
num_40000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   598
    ^ 16r40000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   599
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   600
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   601
    "Created: / 4.6.1999 / 17:40:29 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   602
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   603
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   604
num_7FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   605
    ^ 16r7FFFFFFFFFFFFFFFF
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   606
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   607
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   608
    "Created: / 4.6.1999 / 17:42:24 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   609
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   610
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   611
num_80000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   612
    ^ 16r80000000000000000
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   613
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   614
    "Modified: / 4.6.1999 / 15:29:31 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   615
    "Created: / 4.6.1999 / 17:40:33 / cg"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   616
!
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   617
20
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   618
num_smallInt_maxVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   619
    ^ SmallInteger maxVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   620
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   621
    "self num_smallInt_maxVal"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   622
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   623
    "Modified: / 4.6.1999 / 17:33:22 / cg"
20
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   624
!
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   625
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   626
num_smallInt_minVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   627
    ^ SmallInteger minVal
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   628
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   629
    "self num_smallInt_minVal"
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   630
20
c6b0a35e5bc7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 19
diff changeset
   631
    "Created: / 4.6.1999 / 16:26:05 / cg"
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
   632
    "Modified: / 4.6.1999 / 17:34:31 / cg"
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   633
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   634
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   635
!IntegerTest methodsFor:'tests'!
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   636
362
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   637
doCompare:a againstEqual:b
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   638
    self assert:(a < b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   639
    self assert:(a <= b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   640
    self assert:(a = b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   641
    self assert:(a ~= b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   642
    self assert:(a > b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   643
    self assert:(a >= b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   644
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   645
    self assert:(a perform:#<   with:b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   646
    self assert:(a perform:#<=  with:b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   647
    self assert:(a perform:#=   with:b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   648
    self assert:(a perform:#~=  with:b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   649
    self assert:(a perform:#>   with:b) not.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   650
    self assert:(a perform:#>=  with:b).
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   651
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   652
    "
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   653
     self basicNew doCompare:12 againstEqual:12
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
!
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   656
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   657
doCompare:a againstGreater:b
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   658
    self assert:(a < b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   659
    self assert:(a <= b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   660
    self assert:(a = b) not.
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) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   666
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   667
    self assert:(a perform:#<   with:b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   668
    self assert:(a perform:#<=  with:b).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   669
    self assert:(a perform:#=   with:b) not.
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) not.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   675
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   676
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   677
     self basicNew doCompare:12 againstGreater:16r80000000
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
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   680
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   681
doTestAll
10
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   682
    "general conversion & arithmetic tests.
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   683
     Notice, the arithmetic tests are both performed via regular sends
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   684
     and via constructed performs. The reason is to test both inlined
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
   685
     JIT-compiler code AND the regular methods code."
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   686
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
   687
    self testInteger1.
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   688
    self testILC.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
   689
    self testSmallIntegerArithmetic.
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
   690
    self testLiteralNumbers.
15
99df9ea7f146 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 14
diff changeset
   691
    self testLargeAddition.
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   692
    self testLargeMultiplication.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   693
    self testLargeDivision.
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
   694
    self testLargeBitOperations.
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
   695
    self testIntegerShifts.
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
   696
    self testEncodeDecode.
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
   697
    self testIntegerMisc.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   698
    self testInline1
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   699
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   700
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   701
     self basicNew doTestAll
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   702
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   703
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   704
    "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
   705
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
   706
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   707
testBinco
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   708
     self assert: (10 binomialCoefficient:5) = (10 factorial / (5 factorial * 5 factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   709
     self assert: (100 binomialCoefficient:78) = (100 factorial / (78 factorial * (100-78) factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   710
     self assert: (1000 binomialCoefficient:5) = (1000 factorial / (5 factorial * (1000-5) factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   711
     self assert: (10000 binomialCoefficient:78) = (10000 factorial / (78 factorial * (10000-78) factorial)).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   712
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   713
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   714
     self basicNew testBinco
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   715
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   716
!
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
   717
1039
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   718
testByteSwap
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   719
    "/ <testedMethods: #( (Integer >> #byteSwapped32) (Integer >> #byteSwapped64)) >
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   720
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   721
    self assert:(16r1122 byteSwapped16) = 16r2211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   722
    self assert:(16r2211 byteSwapped16) = 16r1122.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   723
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   724
    self assert:(16r11223344 byteSwapped32) = 16r44332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   725
    self assert:(16r44332211 byteSwapped32) = 16r11223344.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   726
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   727
    self assert:(16r11223344 byteSwapped64) = 16r4433221100000000.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   728
    self assert:(16r44332211 byteSwapped64) = 16r1122334400000000.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   729
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   730
    self assert:(16r8877665544332211 byteSwapped64) = 16r1122334455667788.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   731
    self assert:(16r1122334455667788 byteSwapped64) = 16r8877665544332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   732
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   733
    "/ higher bits are ignored!!
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   734
    self assert:(16r33441122 byteSwapped16) = 16r2211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   735
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   736
    self assert:(16r9911223344 byteSwapped32) = 16r44332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   737
    self assert:(16r8877665544332211 byteSwapped32) = 16r11223344.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   738
    self assert:(16r998877665544332211 byteSwapped64) = 16r1122334455667788.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   739
    self assert:(16r991122334455667788 byteSwapped64) = 16r8877665544332211.
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   740
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   741
    "
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   742
     self basicNew testByteSwap
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
!
f57e739387f5 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1034
diff changeset
   745
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   746
testComparing
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   747
    |a b|
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   748
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   749
    a := 12.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   750
    b := 16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   751
    self doCompare:a againstGreater:b.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   752
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   753
    a := 12.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   754
    b := 16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   755
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   756
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   757
    a := 0.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   758
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   759
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   760
    a := -1.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   761
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   762
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   763
    a := 16r-80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   764
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   765
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   766
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   767
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   768
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   769
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   770
    self doCompare:a againstGreater:16r40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   771
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   772
    a := 16r-3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   773
    self doCompare:a againstGreater:16r3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   774
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   775
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   776
    self doCompare:a againstGreater:16r3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   777
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   778
    a := 16r-3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   779
    self doCompare:a againstGreater:16r40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   780
362
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   781
    "/ smallint-largeInt boundaries
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   782
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   783
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   784
    self doCompare:a againstEqual:16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   785
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   786
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   787
    self doCompare:a againstGreater:16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   788
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   789
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   790
    self doCompare:a againstGreater:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   791
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   792
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   793
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   794
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   795
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   796
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   797
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   798
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   799
    self doCompare:a againstEqual:16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   800
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   801
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   802
    self doCompare:a againstGreater:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   803
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   804
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   805
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   806
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   807
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   808
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   809
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   810
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   811
    self doCompare:a againstEqual:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   812
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   813
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   814
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   815
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   816
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   817
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   818
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   819
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   820
    self doCompare:a againstEqual:16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   821
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   822
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   823
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   824
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   825
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   826
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   827
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   828
    a := 16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   829
    self doCompare:a againstEqual:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   830
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   831
    a := 16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   832
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   833
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   834
    a := 16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   835
    self doCompare:a againstEqual:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   836
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   837
    a := 16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   838
    self doCompare:a againstGreater:16r100000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   839
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   840
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   841
     self basicNew testComparing
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
!
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
testConstants
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   846
    |t|
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   847
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   848
    self assert:((t := self num_16r80000000) > 0).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   849
    self assert:((t := self num_16r80000000) = 16r80000000).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   850
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   851
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   852
     self basicNew testConstants
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
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   855
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
   856
testDivision1
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   857
    |a b op rslt|
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   858
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   859
    "/ 10 divMod:3       -> #(3 1)   because 3*3 + 1 = 10
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   860
    "/ 10 divMod:-3      -> #(-4 -2) because -4*-3 + (-2) = 10
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   861
    "/ -10 divMod:3      -> #(-4 2)  because -4*3 + 3 = -10   
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   862
    "/ -10 divMod:-3     -> #(3 -1)  because -3*3 + (-1) = -10
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   863
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   864
    #(
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   865
        ((10 3)      // 3            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   866
        ((10 -3)     // -4           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   867
        ((-10 3)     // -4           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   868
        ((-10 -3)    // 3            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   869
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   870
        ((10 3)      \\ 1            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   871
        ((10 -3)     \\ -2           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   872
        ((-10 3)     \\ 2            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   873
        ((-10 -3)    \\ -1           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   874
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   875
        ((10 3)      divMod: (3 1)   )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   876
        ((10 -3)     divMod: (-4 -2) )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   877
        ((-10 3)     divMod: (-4 2)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   878
        ((-10 -3)    divMod: (3 -1)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   879
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   880
        ((100000000000000000000 3)      // 33333333333333333333            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   881
        ((100000000000000000000 -3)     // -33333333333333333334           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   882
        ((-100000000000000000000 3)     // -33333333333333333334           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   883
        ((-100000000000000000000 -3)    // 33333333333333333333            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   884
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   885
        ((100000000000000000000 3)      \\ 1            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   886
        ((100000000000000000000 -3)     \\ -2           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   887
        ((-100000000000000000000 3)     \\ 2            )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   888
        ((-100000000000000000000 -3)    \\ -1           )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   889
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   890
        ((100000000000000000000 3)      divMod: (33333333333333333333 1)   )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   891
        ((100000000000000000000 -3)     divMod: (-33333333333333333334 -2) )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   892
        ((-100000000000000000000 3)     divMod: (-33333333333333333334 2)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   893
        ((-100000000000000000000 -3)    divMod: (33333333333333333333 -1)  )
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   894
    ) do:[:each |
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   895
        |inValues rcvr arg op expectedRslt gotRslt|
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   896
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   897
        inValues := each first.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   898
        op := each second.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   899
        expectedRslt := each third.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   900
        rcvr := inValues first.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   901
        arg := inValues second.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   902
        gotRslt := rcvr perform:op with:arg.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   903
        self 
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   904
            assert:(gotRslt = expectedRslt) 
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   905
            description:('%1 %2 %3 - expected:%4 got:%5' 
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   906
                            bindWith:rcvr with:op with:arg
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   907
                            with:expectedRslt with:gotRslt).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   908
    ].
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   909
        
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   910
    op := #//.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   911
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   912
    b := 8.
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   913
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   914
    "/ to check for both compiler-constant folded and actually computed
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   915
    "/ values, these checks are done also with #perform.
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   916
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   917
    self assert:(-1 // 8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   918
    self assert:(a // 8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   919
    self assert:(-1 // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   920
    self assert:(a // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   921
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   922
    self assert:((rslt := -1 perform:op with: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   923
    self assert:((rslt := a perform:op with: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   924
    self assert:((rslt := -1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   925
    self assert:((rslt := a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   926
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   927
    self assert:((rslt := -1 perform:#// with: 8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   928
    self assert:((rslt := a perform:#// with: 8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   929
    self assert:((rslt := -1 perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   930
    self assert:((rslt := a perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   931
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   932
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   933
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   934
    self assert:(1 // -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   935
    self assert:(a // -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   936
    self assert:(1 // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   937
    self assert:(a // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   938
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   939
    self assert:((rslt := 1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   940
    self assert:((rslt := a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   941
    self assert:((rslt := 1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   942
    self assert:((rslt := a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   943
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   944
    self assert:((rslt := 1 perform:#// with: -8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   945
    self assert:((rslt := a perform:#// with: -8) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   946
    self assert:((rslt := 1 perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   947
    self assert:((rslt := a perform:#// with: b) == -1).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   948
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   949
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   950
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   951
    self assert:(-1 // -8 == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   952
    self assert:(a // -8 == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   953
    self assert:(-1 // b == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   954
    self assert:(a // b == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   955
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   956
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   957
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   958
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   959
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   960
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   961
    self assert:((rslt := -1 perform:#// with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   962
    self assert:((rslt := a perform:#// with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   963
    self assert:((rslt := -1 perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   964
    self assert:((rslt := a perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   965
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   966
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   967
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   968
    self assert:(1 // 8 == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   969
    self assert:(a // 8 == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   970
    self assert:(1 // b == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   971
    self assert:(a // b == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   972
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   973
    self assert:((rslt := 1 perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   974
    self assert:((rslt := a perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   975
    self assert:((rslt := 1 perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   976
    self assert:((rslt := a perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   977
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   978
    self assert:((rslt := 1 perform:#// with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   979
    self assert:((rslt := a perform:#// with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   980
    self assert:((rslt := 1 perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   981
    self assert:((rslt := a perform:#// with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   982
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   983
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   984
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   985
    self assert:(-16 // 8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   986
    self assert:(a // 8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   987
    self assert:(-16 // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   988
    self assert:(a // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   989
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   990
    self assert:((rslt := -16 perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   991
    self assert:((rslt := a perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   992
    self assert:((rslt := -16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   993
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   994
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   995
    self assert:((rslt := -16 perform:#// with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   996
    self assert:((rslt := a perform:#// with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   997
    self assert:((rslt := -16 perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   998
    self assert:((rslt := a perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
   999
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1000
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1001
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1002
    self assert:(16 // -8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1003
    self assert:(a // -8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1004
    self assert:(16 // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1005
    self assert:(a // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1006
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1007
    self assert:((rslt := 16 perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1008
    self assert:((rslt := a perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1009
    self assert:((rslt := 16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1010
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1011
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1012
    self assert:((rslt := 16 perform:#// with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1013
    self assert:((rslt := a perform:#// with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1014
    self assert:((rslt := 16 perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1015
    self assert:((rslt := a perform:#// with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1016
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1017
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1018
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1019
    self assert:(-16 // -8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1020
    self assert:(a // -8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1021
    self assert:(-16 // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1022
    self assert:(a // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1023
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1024
    self assert:((rslt := -16 perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1025
    self assert:((rslt := a perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1026
    self assert:((rslt := -16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1027
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1028
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1029
    self assert:((rslt := -16 perform:#// with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1030
    self assert:((rslt := a perform:#// with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1031
    self assert:((rslt := -16 perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1032
    self assert:((rslt := a perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1033
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1034
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1035
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1036
    self assert:(16 // 8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1037
    self assert:(a // 8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1038
    self assert:(16 // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1039
    self assert:(a // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1040
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1041
    self assert:((rslt := 16 perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1042
    self assert:((rslt := a perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1043
    self assert:((rslt := 16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1044
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1045
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1046
    self assert:((rslt := 16 perform:#// with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1047
    self assert:((rslt := a perform:#// with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1048
    self assert:((rslt := 16 perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1049
    self assert:((rslt := a perform:#// with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1050
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1051
    op := #quo:.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1052
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1053
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1054
    self assert:((rslt := -1 quo: 8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1055
    self assert:((rslt := a quo: 8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1056
    self assert:((rslt := -1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1057
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1058
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1059
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1060
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1061
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1062
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1063
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1064
    self assert:((rslt := -1 perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1065
    self assert:((rslt := a perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1066
    self assert:((rslt := -1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1067
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1068
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1069
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1070
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1071
    self assert:((rslt := 1 quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1072
    self assert:((rslt := a quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1073
    self assert:((rslt := 1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1074
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1075
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1076
    self assert:((rslt := 1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1077
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1078
    self assert:((rslt := 1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1079
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1080
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1081
    self assert:((rslt := 1 perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1082
    self assert:((rslt := a perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1083
    self assert:((rslt := 1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1084
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1085
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1086
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1087
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1088
    self assert:((rslt := -1 quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1089
    self assert:((rslt := a quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1090
    self assert:((rslt := -1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1091
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1092
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1093
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1094
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1095
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1096
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1097
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1098
    self assert:((rslt := -1 perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1099
    self assert:((rslt := a perform:#quo: with: -8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1100
    self assert:((rslt := -1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1101
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1102
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1103
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1104
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1105
    self assert:((rslt := 1 quo: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1106
    self assert:((rslt := a quo: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1107
    self assert:((rslt := 1 quo: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1108
    self assert:((rslt := a quo: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1109
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1110
    self assert:((rslt := 1 perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1111
    self assert:((rslt := a perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1112
    self assert:((rslt := 1 perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1113
    self assert:((rslt := a perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1114
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1115
    self assert:((rslt := 1 perform:#quo: with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1116
    self assert:((rslt := a perform:#quo: with: 8) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1117
    self assert:((rslt := 1 perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1118
    self assert:((rslt := a perform:#quo: with: b) == 0).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1119
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1120
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1121
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1122
    self assert:((rslt := -16 quo: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1123
    self assert:((rslt := a quo: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1124
    self assert:((rslt := -16 quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1125
    self assert:((rslt := a quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1126
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1127
    self assert:((rslt := -16 perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1128
    self assert:((rslt := a perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1129
    self assert:((rslt := -16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1130
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1131
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1132
    self assert:((rslt := -16 perform:#quo: with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1133
    self assert:((rslt := a perform:#quo: with: 8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1134
    self assert:((rslt := -16 perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1135
    self assert:((rslt := a perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1136
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1137
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1138
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1139
    self assert:((rslt := 16 quo: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1140
    self assert:((rslt := a quo: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1141
    self assert:((rslt := 16 quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1142
    self assert:((rslt := a quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1143
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1144
    self assert:((rslt := 16 perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1145
    self assert:((rslt := a perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1146
    self assert:((rslt := 16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1147
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1148
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1149
    self assert:((rslt := 16 perform:#quo: with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1150
    self assert:((rslt := a perform:#quo: with: -8) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1151
    self assert:((rslt := 16 perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1152
    self assert:((rslt := a perform:#quo: with: b) == -2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1153
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1154
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1155
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1156
    self assert:((rslt := -16 quo: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1157
    self assert:((rslt := a quo: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1158
    self assert:((rslt := -16 quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1159
    self assert:((rslt := a quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1160
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1161
    self assert:((rslt := -16 perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1162
    self assert:((rslt := a perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1163
    self assert:((rslt := -16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1164
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1165
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1166
    self assert:((rslt := -16 perform:#quo: with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1167
    self assert:((rslt := a perform:#quo: with: -8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1168
    self assert:((rslt := -16 perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1169
    self assert:((rslt := a perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1170
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1171
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1172
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1173
    self assert:((rslt := 16 quo: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1174
    self assert:((rslt := a quo: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1175
    self assert:((rslt := 16 quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1176
    self assert:((rslt := a quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1177
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1178
    self assert:((rslt := 16 perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1179
    self assert:((rslt := a perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1180
    self assert:((rslt := 16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1181
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1182
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1183
    self assert:((rslt := 16 perform:#quo: with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1184
    self assert:((rslt := a perform:#quo: with: 8) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1185
    self assert:((rslt := 16 perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1186
    self assert:((rslt := a perform:#quo: with: b) == 2).
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  1187
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1188
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1189
     self basicNew testDivision
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
!
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1192
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1193
testDivision2
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1194
    |nr|
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1195
    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1196
    2 to:17 do:[:m |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1197
        nr := 1.
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1198
        1 to:1000 do:[:n |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1199
            nr := nr * m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1200
        ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1201
        1 to:1000 do:[:n |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1202
            nr := nr / m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1203
        ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1204
        self assert:(nr == 1).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1205
    ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1206
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1207
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1208
     self new testDivision2
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1209
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1210
!
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1211
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1212
testDivision3
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1213
    |nr|
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1214
    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1215
    #( 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1216
        16r00000000000000003F 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1217
        16r000000000000003FFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1218
        16r0000000000003FFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1219
        16r00000000003FFFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1220
        16r000000003FFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1221
        16r0000003FFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1222
        16r00003FFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1223
        16r003FFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1224
        16r3FFFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1225
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1226
        16r000000000000000040 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1227
        16r0000000000000040FF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1228
        16r00000000000040FFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1229
        16r000000000040FFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1230
        16r0000000040FFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1231
        16r00000040FFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1232
        16r000040FFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1233
        16r0040FFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1234
        16r40FFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1235
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1236
        16r00000000000000007F 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1237
        16r000000000000007FFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1238
        16r0000000000007FFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1239
        16r00000000007FFFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1240
        16r000000007FFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1241
        16r0000007FFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1242
        16r00007FFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1243
        16r007FFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1244
        16r7FFFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1245
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1246
        16r0000000000000000FF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1247
        16r00000000000000FFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1248
        16r000000000000FFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1249
        16r0000000000FFFFFFFF 
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1250
        16r00000000FFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1251
        16r000000FFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1252
        16r0000FFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1253
        16r00FFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1254
        16rFFFFFFFFFFFFFFFFFF
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1255
    ) do:[:m |
1365
c3b631cb0688 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1323
diff changeset
  1256
        "/ Transcript showCR:m.
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1257
        nr := 1.
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1258
        1 to:100 do:[:n |
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1259
            nr := nr * m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1260
        ].
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1261
        1 to:100 do:[:n |
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1262
            nr := nr / m
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1263
        ].
1365
c3b631cb0688 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1323
diff changeset
  1264
        self assert:(nr == 1) description:('failed in division of ',m printString).
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1265
    ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1266
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1267
    "
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1268
     self new testDivision3
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1269
     Time millisecondsToRun:[ self new testDivision3 ] 14440
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  1270
     MessageTally spyOn:[ self new testDivision3 ] 
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1271
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1272
!
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  1273
1320
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1274
testDivision4
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1275
    "boundary conditions, wehre smallInts should be returned"
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1276
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1277
    |n1 n2 r|
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1278
    
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1279
    n1 := 1152921504606846976.  "/ 16r1000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1280
    n2 := -1073741824.          "/ 16r40000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1281
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1282
    self assert:(r = -1073741824).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1283
    self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1284
    self assert:(r == -1073741824).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1285
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1286
    n1 := 1152921504606846976.  "/ 16r1000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1287
    n2 := 1073741824.           "/ 16r40000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1288
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1289
    self assert:(r = 1073741824).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1290
    SmallInteger maxBytes == 8 ifTrue:[
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1291
        self assert:(r class == SmallInteger).
1322
6925e7f2eaf3 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1320
diff changeset
  1292
        self assert:(r == 1073741824).
1320
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1293
    ].
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1294
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1295
    n1 := 1152921504606846976.  "/ 16r1000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1296
    n2 := -536870912.           "/ 16r20000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1297
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1298
    self assert:(r = -2147483648).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1299
    SmallInteger maxBytes == 8 ifTrue:[
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1300
        self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1301
        self assert:(r == -2147483648).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1302
    ].
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1303
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1304
    n1 := 1152921504606846976.  "/ 16r1000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1305
    n2 := 536870912.            "/ 16r20000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1306
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1307
    self assert:(r = 2147483648).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1308
    SmallInteger maxBytes == 8 ifTrue:[
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1309
        self assert:(r class == SmallInteger).
1322
6925e7f2eaf3 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1320
diff changeset
  1310
        self assert:(r == 2147483648).
1320
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1311
    ].
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1312
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1313
    n1 := 1152921504606846976.  "/ 16r1000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1314
    n2 := -2147483648.          "/ 16r80000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1315
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1316
    self assert:(r = -536870912).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1317
    self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1318
    self assert:(r == -536870912).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1319
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1320
    n1 := 1152921504606846976.  "/ 16r1000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1321
    n2 := 2147483648.           "/ 16r80000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1322
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1323
    self assert:(r = 536870912).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1324
    self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1325
    self assert:(r == 536870912).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1326
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1327
    n1 := 21267647932558653966460912964485513216.  "/ 16r10000000000000000000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1328
    n2 := -4611686018427387904.                    "/ 16r4000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1329
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1330
    self assert:(r = -4611686018427387904).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1331
    SmallInteger maxBytes == 8 ifTrue:[
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1332
        self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1333
        self assert:(r == -4611686018427387904).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1334
    ].
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1335
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1336
    n1 := 21267647932558653966460912964485513216.  "/ 16r10000000000000000000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1337
    n2 := 4611686018427387904.                     "/ 16r4000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1338
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1339
    self assert:(r = 4611686018427387904).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1340
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1341
    n1 := 21267647932558653966460912964485513216.  "/ 16r10000000000000000000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1342
    n2 := -2305843009213693952.                    "/ 16r2000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1343
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1344
    self assert:(r = -9223372036854775808).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1345
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1346
    n1 := 21267647932558653966460912964485513216.  "/ 16r10000000000000000000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1347
    n2 := 2305843009213693952.                     "/ 16r2000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1348
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1349
    self assert:(r = 9223372036854775808).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1350
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1351
    n1 := 21267647932558653966460912964485513216.  "/ 16r10000000000000000000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1352
    n2 := -9223372036854775808.                    "/ 16r8000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1353
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1354
    self assert:(r = -2305843009213693952).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1355
    SmallInteger maxBytes == 8 ifTrue:[
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1356
        self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1357
        self assert:(r == -2305843009213693952).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1358
    ].
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1359
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1360
    n1 := 21267647932558653966460912964485513216.  "/ 16r10000000000000000000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1361
    n2 := 9223372036854775808.                     "/ 16r8000000000000000
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1362
    r := n1 / n2.
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1363
    self assert:(r = 2305843009213693952).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1364
    SmallInteger maxBytes == 8 ifTrue:[
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1365
        self assert:(r class == SmallInteger).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1366
        self assert:(r == 2305843009213693952).
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1367
    ].
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1368
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1369
    "
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1370
     self new testDivision4
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1371
    "
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1372
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1373
    "Created: / 26-02-2016 / 20:21:47 / cg"
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1374
!
c591f48b955d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1319
diff changeset
  1375
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1376
testEncodeDecode
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1377
    self assert:(1 encodeAsBCD hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1378
    self assert:(12 encodeAsBCD hexPrintString = '12').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1379
    self assert:(123 encodeAsBCD hexPrintString = '123').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1380
    self assert:(1234 encodeAsBCD hexPrintString = '1234').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1381
    self assert:(12345 encodeAsBCD hexPrintString = '12345').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1382
    self assert:(123456 encodeAsBCD hexPrintString = '123456').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1383
    self assert:(1234567 encodeAsBCD hexPrintString = '1234567').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1384
    self assert:(12345678 encodeAsBCD hexPrintString = '12345678').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1385
    self assert:(123456789 encodeAsBCD hexPrintString = '123456789').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1386
    self assert:(1234567890 encodeAsBCD hexPrintString = '1234567890').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1387
    self assert:(12345678901 encodeAsBCD hexPrintString = '12345678901').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1388
    self assert:(123456789012 encodeAsBCD hexPrintString = '123456789012').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1389
    self assert:(1234567890123 encodeAsBCD hexPrintString = '1234567890123').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1390
    self assert:(12345678901234 encodeAsBCD hexPrintString = '12345678901234').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1391
    self assert:(123456789012345 encodeAsBCD hexPrintString = '123456789012345').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1392
    self assert:(1234567890123456 encodeAsBCD hexPrintString = '1234567890123456').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1393
    self assert:(12345678901234567 encodeAsBCD hexPrintString = '12345678901234567').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1394
    self assert:(123456789012345678 encodeAsBCD hexPrintString = '123456789012345678').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1395
    self assert:(1234567890123456789 encodeAsBCD hexPrintString = '1234567890123456789').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1396
    self assert:(12345678901234567890 encodeAsBCD hexPrintString = '12345678901234567890').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1397
    self assert:(4611686018427387902 encodeAsBCD hexPrintString = '4611686018427387902').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1398
    self assert:(4611686018427387903 encodeAsBCD hexPrintString = '4611686018427387903').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1399
    self assert:(4611686018427387904 encodeAsBCD hexPrintString = '4611686018427387904').
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1400
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1401
    self assert:(16r1 decodeFromBCD = 1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1402
    self assert:(16r12 decodeFromBCD = 12).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1403
    self assert:(16r123 decodeFromBCD = 123).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1404
    self assert:(16r1234 decodeFromBCD = 1234).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1405
    self assert:(16r12345 decodeFromBCD = 12345).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1406
    self assert:(16r123456 decodeFromBCD = 123456).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1407
    self assert:(16r1234567 decodeFromBCD = 1234567).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1408
    self assert:(16r12345678 decodeFromBCD = 12345678).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1409
    self assert:(16r123456789 decodeFromBCD = 123456789).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1410
    self assert:(16r1234567890 decodeFromBCD = 1234567890).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1411
    self assert:(16r12345678901 decodeFromBCD = 12345678901).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1412
    self assert:(16r123456789012 decodeFromBCD = 123456789012).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1413
    self assert:(16r1000000000000 decodeFromBCD = 1000000000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1414
    self assert:(16r0000500000000 decodeFromBCD = 500000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1415
    self assert:(16r1234500000000 decodeFromBCD = 1234500000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1416
    self assert:(16r1234567890000 decodeFromBCD = 1234567890000).
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1417
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1418
    self assert:(16r1234567890123 decodeFromBCD = 1234567890123).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1419
    self assert:(16r12345678901234 decodeFromBCD = 12345678901234).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1420
    self assert:(16r123456789012345 decodeFromBCD = 123456789012345).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1421
    self assert:(16r1234567890123456 decodeFromBCD = 1234567890123456).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1422
    self assert:(16r12345678901234567 decodeFromBCD = 12345678901234567).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1423
    self assert:(16r123456789012345678 decodeFromBCD = 123456789012345678).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1424
    self assert:(16r1234567890123456789 decodeFromBCD = 1234567890123456789).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1425
    self assert:(16r12345678901234567890 decodeFromBCD = 12345678901234567890).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1426
    self assert:(16r4611686018427387902 decodeFromBCD = 4611686018427387902).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1427
    self assert:(16r4611686018427387903 decodeFromBCD = 4611686018427387903).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1428
    self assert:(16r4611686018427387904 decodeFromBCD = 4611686018427387904).
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1429
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1430
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1431
     self basicNew testEncodeDecode
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1432
    "
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1433
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1434
    "Modified: / 26.10.1999 / 22:01:35 / stefan"
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1435
!
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1436
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1437
testFactorial
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1438
    "/ <testedMethods: #( (Integer >> #factorial) (Integer >> #*) ) >
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1439
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1440
    self assert:(1 factorial = 1).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1441
    self assert:(2 factorial = 2).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1442
    self assert:(10 factorial = 3628800).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1443
    self assert:(11 factorial = 39916800).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1444
    self assert:(12 factorial = 479001600).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1445
    self assert:(13 factorial digitBytes = #[0 204 40 115 1]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1446
    self assert:(13 factorial = 6227020800).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1447
    self assert:(14 factorial digitBytes = #[0 40 59 76 20]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1448
    self assert:(14 factorial = 87178291200).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1449
    self assert:(15 factorial digitBytes = #[0 88 119 119 48 1]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1450
    self assert:(15 factorial = 1307674368000).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1451
    self assert:(16 factorial digitBytes = #[0 128 117 119 7 19]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1452
    self assert:(16 factorial = 20922789888000).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1453
    self assert:(17 factorial digitBytes = #[0 128 205 238 126 67 1]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1454
    self assert:(17 factorial = 355687428096000).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1455
    self assert:(18 factorial digitBytes = #[0 0 115 202 236 190 22]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1456
    self assert:(18 factorial = 6402373705728000).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1457
    self assert:(19 factorial digitBytes = #[0 0 137 6 147 43 176 1]).
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  1458
    self assert:(19 factorial = 121645100408832000).
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1459
    self assert:(20 factorial digitBytes = #[0 0 180 130 124 103 195 33]).
1316
25e2988d4e60 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1315
diff changeset
  1460
    self assert:(20 factorial = 2432902008176640000).
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1461
    self assert:(50 factorial = 30414093201713378043612608166064768844377641568960512000000000000).
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1462
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1463
    "
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1464
     self basicNew testFactorial
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1465
    "
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1466
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1467
    "Created: / 24-04-2010 / 13:52:23 / cg"
1316
25e2988d4e60 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1315
diff changeset
  1468
    "Modified: / 26-02-2016 / 15:43:16 / cg"
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1469
!
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1470
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1471
testGCD
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1472
    "/ <testedMethods: #( (Integer >> #gcd:) ) >
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1473
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1474
    self assert:(9 gcd:6) = 3.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1475
    self assert:(6 gcd:9) = 3.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1476
    self assert:(2 gcd:0) = 2.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1477
    self assert:(0 gcd:2) = 2.
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1478
    self assert:(20 factorial gcd:(5*6*7)) = (5*6*7).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  1479
    self assert:(20 factorial gcd:(20 factorial / 20)) = (19 factorial).
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1480
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1481
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1482
     self basicNew testGCD
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1483
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1484
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1485
    "Created: / 27-04-2010 / 09:49:31 / cg"
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1486
!
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1487
1394
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1488
testHighBitLowBit
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1489
    self assert:( 2r0 highBit == 0).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1490
    self assert:( 2r1 highBit == 1).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1491
    self assert:( 2r10 highBit == 2).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1492
    self assert:( 2r100 highBit == 3).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1493
    self assert:( 2r1000 highBit == 4).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1494
    self assert:( 16r10 highBit == 5).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1495
    self assert:( 16r100 highBit == 9).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1496
    self assert:( 16r1000 highBit == 13).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1497
    self assert:( 16r10000 highBit == 17).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1498
    self assert:( 16r100000 highBit == 21).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1499
    self assert:( 16r1000000 highBit == 25).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1500
    self assert:( 16r10000000 highBit == 29).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1501
    self assert:( 16r100000000 highBit == 33).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1502
    self assert:( 16r1000000000 highBit == 37).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1503
    self assert:( 16r10000000000 highBit == 41).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1504
    self assert:( 16r100000000000 highBit == 45).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1505
    self assert:( 16r1000000000000 highBit == 49).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1506
    self assert:( 16r10000000000000 highBit == 53).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1507
    self assert:( 16r100000000000000 highBit == 57).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1508
    self assert:( 16r1000000000000000 highBit == 61).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1509
    self assert:( 16r10000000000000000 highBit == 65).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1510
    self assert:( (1 bitShift:1000) highBit == 1001).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1511
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1512
    self assert:( 2r0 lowBit == 0).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1513
    self assert:( 2r1 lowBit == 1).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1514
    self assert:( 2r10 lowBit == 2).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1515
    self assert:( 2r100 lowBit == 3).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1516
    self assert:( 2r1000 lowBit == 4).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1517
    self assert:( 16r10 lowBit == 5).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1518
    self assert:( 16r100 lowBit == 9).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1519
    self assert:( 16r1000 lowBit == 13).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1520
    self assert:( 16r10000 lowBit == 17).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1521
    self assert:( 16r100000 lowBit == 21).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1522
    self assert:( 16r1000000 lowBit == 25).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1523
    self assert:( 16r10000000 lowBit == 29).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1524
    self assert:( 16r100000000 lowBit == 33).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1525
    self assert:( 16r1000000000 lowBit == 37).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1526
    self assert:( 16r10000000000 lowBit == 41).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1527
    self assert:( 16r100000000000 lowBit == 45).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1528
    self assert:( 16r1000000000000 lowBit == 49).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1529
    self assert:( 16r10000000000000 lowBit == 53).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1530
    self assert:( 16r100000000000000 lowBit == 57).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1531
    self assert:( 16r1000000000000000 lowBit == 61).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1532
    self assert:( 16r10000000000000000 lowBit == 65).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1533
    self assert:( (1 bitShift:1000) lowBit == 1001).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1534
    
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1535
    self assert:(( 2r1 bitOr: 16r10000000000) lowBit = 1).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1536
    self assert:(( 2r10 bitOr: 16r10000000000) lowBit = 2).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1537
    self assert:(( 2r100 bitOr: 16r10000000000) lowBit = 3).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1538
    self assert:(( 2r1000 bitOr: 16r10000000000) lowBit = 4).  
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1539
    self assert:(( 16r10 bitOr: 16r10000000000) lowBit = 5).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1540
    self assert:(( 16r100 bitOr: 16r10000000000) lowBit = 9).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1541
    self assert:(( 16r1000 bitOr: 16r10000000000) lowBit = 13).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1542
    self assert:(( 16r10000 bitOr: 16r10000000000) lowBit = 17).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1543
    self assert:(( 16r100000 bitOr: 16r10000000000) lowBit = 21).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1544
    self assert:(( 16r1000000 bitOr: 16r10000000000) lowBit = 25).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1545
    self assert:(( 16r10000000 bitOr: 16r10000000000) lowBit = 29).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1546
    self assert:(( 16r100000000 bitOr: 16r10000000000) lowBit = 33).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1547
    self assert:(( 16r1000000000 bitOr: 16r10000000000) lowBit = 37).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1548
    self assert:(( 16r10000000000 bitOr: 16r10000000000) lowBit = 41).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1549
    self assert:(( 16r100000000000 bitOr: 16r100000000000) lowBit = 45).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1550
    self assert:(( 16r1000000000000 bitOr: 16r1000000000000) lowBit = 49).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1551
    self assert:(( 16r10000000000000 bitOr: 16r10000000000000) lowBit = 53).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1552
    self assert:(( 16r100000000000000 bitOr: 16r100000000000000) lowBit = 57).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1553
    self assert:(( 16r1000000000000000 bitOr: 16r1000000000000000) lowBit = 61).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1554
    self assert:(( 16r10000000000000000 bitOr: 16r10000000000000000) lowBit = 65).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1555
    self assert:(( (1 bitShift:1000) bitOr: (1 bitShift:1001)) lowBit = 1001).
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1556
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1557
    "
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1558
     self basicNew testHighBitLowBit
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1559
    "
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1560
!
26de106a37e1 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1366
diff changeset
  1561
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1562
testILC
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1563
    "inline-cache"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1564
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1565
    self assert:((self checkIsInteger:1) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1566
    self assert:((self checkIsInteger:nil) == false).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1567
    self assert:((self checkIsInteger:1) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1568
    self assert:((self checkIsInteger:nil) == false).
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1569
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1570
    self assert:((self checkIsInteger:0) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1571
    self assert:((self checkIsInteger:nil) == false).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1572
    self assert:((self checkIsInteger:0) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1573
    self assert:((self checkIsInteger:nil) == false).
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1574
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1575
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1576
     self basicNew testILC
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1577
    "
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1578
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1579
    "Created: / 6.6.1999 / 14:47:51 / cg"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1580
    "Modified: / 9.6.1999 / 17:49:57 / cg"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1581
!
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1582
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1583
testInline1
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1584
    "inlined tests.
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1585
     Notice, the arithmetic tests are both performed via regular sends
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1586
     and via constructed performs. The reason is to test both inlined
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1587
     JIT-compiler code AND the regular methods code."
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1588
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1589
    self assert:( (self absPlusOneOf:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1590
    self assert:( (self absPlusOneOf:-1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1591
    self assert:( (self absPlusOneOf:1.0) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1592
    self assert:( (self absPlusOneOf:-1.0) = 2 ).
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1593
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1594
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1595
     self basicNew testInline1
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1596
    "
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1597
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1598
    "Created: / 31.10.2000 / 20:22:48 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1599
    "Modified: / 31.10.2000 / 20:23:06 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1600
!
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1601
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1602
testInteger1
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1603
    "general conversion & arithmetic tests.
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1604
     Notice, the arithmetic tests are both performed via regular sends
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1605
     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
  1606
     JIT-compiler code AND the regular method's code."
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1607
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1608
    |minVal maxVal maxValPlus1 minValMinus1 halfMin halfMax t|
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1609
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1610
    minVal := SmallInteger perform:('minVal' asSymbol).
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1611
    maxVal := SmallInteger perform:('maxVal' asSymbol).
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1612
1431
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1613
    self assert:(minVal class == SmallInteger).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1614
    self assert:(maxVal class == SmallInteger).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1615
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1616
    self assert:(minVal == self num_smallInt_minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1617
    self assert:(maxVal == self num_smallInt_maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1618
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1619
    self assert:(minVal == SmallInteger minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1620
    self assert:(maxVal == SmallInteger maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1621
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1622
    t := SmallInteger perform:('maxBytes' asSymbol).
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1623
    self assert:(t == SmallInteger maxBytes).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1624
    t := SmallInteger perform:('maxBits' asSymbol).
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1625
    self assert:(t == SmallInteger maxBits).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1626
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1627
    self testPrinting1.
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1628
935
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1629
    self assert:(SmallInteger maxBytes == ExternalAddress pointerSize).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1630
    "/ again, preventing inlining by compiler
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1631
    self assert:(SmallInteger perform:#maxBytes) == (ExternalAddress perform:#pointerSize).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1632
    self assert:(SmallInteger perform:'maxBytes' asSymbol) == (ExternalAddress perform:'pointerSize' asSymbol).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1633
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1634
    SmallInteger maxBytes == 4 ifTrue:[
1431
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1635
        self assert:(minVal hexPrintString = '-40000000').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1636
        self assert:(maxVal hexPrintString = '3FFFFFFF').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1637
        self assert:(minVal == -1073741824).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1638
        self assert:(maxVal == 1073741823).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1639
        maxValPlus1 := 1073741824.
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1640
        minValMinus1 := -1073741825.
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1641
        self assert:(minValMinus1 hexPrintString = '-40000001').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1642
        self assert:(maxValPlus1 hexPrintString = '40000000').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1643
        halfMin := -16r20000000.
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1644
        halfMax := 16r20000000.
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1645
    ].
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1646
    SmallInteger maxBytes == 8 ifTrue:[
1431
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1647
        self assert:(minVal hexPrintString = '-4000000000000000').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1648
        self assert:(maxVal hexPrintString = '3FFFFFFFFFFFFFFF').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1649
        self assert:(minVal == -4611686018427387904).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1650
        self assert:(maxVal == 4611686018427387903).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1651
        maxValPlus1 := 4611686018427387904.
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1652
        minValMinus1 := -4611686018427387905.
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1653
        self assert:(minValMinus1 hexPrintString = '-4000000000000001').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1654
        self assert:(maxValPlus1 hexPrintString = '4000000000000000').
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1655
        halfMin := -16r2000000000000000.
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1656
        halfMax := 16r2000000000000000.
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1657
    ].
1431
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1658
    
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1659
    self assert:(minValMinus1 class == LargeInteger).
c916f28b79db #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  1660
    self assert:(maxValPlus1 class == LargeInteger).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1661
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1662
    "arithmetic overFlow checks"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1663
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1664
"/    self assert:((maxVal + 1) inspect.maxValPlus1 inspect. true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1665
    self assert:((maxVal perform:'+' asSymbol with:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1666
    self assert:((maxVal + 1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1667
    self assert:((minVal perform:'-' asSymbol with:1) = minValMinus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1668
    self assert:((minVal - 1) = minValMinus1).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1669
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1670
    self assert:((halfMax perform:'+' asSymbol with:halfMax) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1671
    self assert:((halfMax + halfMax) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1672
    self assert:((halfMin perform:'+' asSymbol with:halfMin) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1673
    self assert:((halfMin + halfMin) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1674
    self assert:((halfMax perform:'*' asSymbol with:2) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1675
    self assert:((halfMax * 2) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1676
    self assert:((halfMin perform:'*' asSymbol with:2) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1677
    self assert:((halfMin * 2) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1678
    self assert:((maxValPlus1 perform:'//' asSymbol with:2) == halfMax).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1679
    self assert:((maxValPlus1 // 2) == halfMax).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1680
    self assert:((halfMax perform:'bitShift:' asSymbol with:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1681
    self assert:((halfMin perform:'bitShift:' asSymbol with:1) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1682
    self assert:((halfMax bitShift:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1683
    self assert:((halfMin bitShift:1) == minVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1684
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1685
    "LargeInt op -> SmallInt result"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1686
    t := maxVal + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1687
    self assert:(t - 1 == maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1688
    t := minVal - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1689
    self assert:(t + 1 == minVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1690
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1691
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1692
     self basicNew testInteger1
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1693
    "
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1694
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1695
    "Modified: / 6.6.1999 / 14:46:11 / cg"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1696
!
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1697
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1698
testIntegerMisc
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1699
    "misc tests.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1700
     Notice, the arithmetic tests are both performed via regular sends
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1701
     and via constructed performs. The reason is to test both inlined
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1702
     JIT-compiler code AND the regular methods code."
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1703
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1704
    |n1 n2 s|
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1705
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1706
    n1 := 100000.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1707
    n2 := n1 negated.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1708
    s := 1.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1709
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1710
    self assert:(n1 printString = '100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1711
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1712
    self assert:(n1 negated printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1713
    self assert:((n1 perform:'negated' asSymbol) printString = '-100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1714
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1715
    self assert:(n1 negated abs printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1716
    self assert:((n1 perform:'negated' asSymbol) abs printString = '100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1717
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1718
    self assert:(n1 abs negated printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1719
    self assert:((n1 perform:'abs' asSymbol) negated printString = '-100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1720
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1721
    n1 := SmallInteger maxVal.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1722
    self assert:(n1 negated class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1723
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1724
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1725
    n1 := SmallInteger minVal.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1726
    self assert:(n1 negated class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1727
    self assert:((n1 perform:'negated' asSymbol) class == LargeInteger).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1728
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1729
    n1 := SmallInteger minVal negated - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1730
    self assert:(n1 negated class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1731
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1732
    self assert:(n1 == SmallInteger maxVal).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1733
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1734
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1735
     self basicNew testIntegerMisc
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1736
    "
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1737
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1738
    "Created: / 6.6.1999 / 14:47:51 / cg"
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1739
    "Modified: / 9.6.1999 / 17:49:57 / cg"
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1740
!
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1741
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1742
testIntegerMisc2
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1743
    "misc tests.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1744
     Notice, the arithmetic tests are both performed via regular sends
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1745
     and via constructed performs. The reason is to test both inlined
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1746
     JIT-compiler code AND the regular methods code."
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1747
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1748
    |n sel|
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1749
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1750
    "/ fib is optional
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1751
    (0 respondsTo:#fib) ifFalse:[^ self].
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1752
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1753
    self assert:(0 fib == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1754
    self assert:(1 fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1755
    self assert:(2 fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1756
    self assert:(3 fib == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1757
    self assert:(4 fib == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1758
    self assert:(5 fib == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1759
    self assert:(6 fib == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1760
    self assert:(7 fib == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1761
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1762
    n := 0.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1763
    self assert:(n fib == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1764
    n := 1.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1765
    self assert:(n fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1766
    n := 2.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1767
    self assert:(n fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1768
    n := 3.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1769
    self assert:(n fib == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1770
    n := 4.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1771
    self assert:(n fib == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1772
    n := 5.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1773
    self assert:(n fib == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1774
    n := 6.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1775
    self assert:(n fib == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1776
    n := 7.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1777
    self assert:(n fib == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1778
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1779
    #(0 1 2 3 4 5 6 7)
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1780
    with:#(0 1 1 2 3 5 8 13)
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1781
    do:[:n :rslt |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1782
	self assert:(n fib == rslt).
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1783
    ].
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1784
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  1785
"/    #(0 1 2 3 4 5 6 7)
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1786
"/    with:#(0 1 1 2 3 5 8 13)
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1787
"/    do:[:n :rslt |
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1788
"/        self assert:(n fib_recursive == rslt).
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1789
"/    ].
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1790
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1791
    sel := #fib.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1792
    self assert:((0 perform:sel) == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1793
    self assert:((1 perform:sel) == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1794
    self assert:((2 perform:sel) == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1795
    self assert:((3 perform:sel) == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1796
    self assert:((4 perform:sel) == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1797
    self assert:((5 perform:sel) == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1798
    self assert:((6 perform:sel) == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1799
    self assert:((7 perform:sel) == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1800
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1801
    "
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1802
     self basicNew testIntegerMisc2
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1803
    "
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1804
!
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1805
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1806
testIntegerShifts
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1807
    "arithmetic tests.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1808
     Notice, the arithmetic tests are both performed via regular sends
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1809
     and via constructed performs. The reason is to test both inlined
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1810
     JIT-compiler code AND the regular methods code."
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1811
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1812
    self testIntegerShifts1.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1813
    self testIntegerShifts2.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1814
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1815
    self assert:(
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1816
     (((0 to:64) collect:[:s | 1 bitShift:s])
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1817
	collect:[:n | n highBit]) = (1 to:65)
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1818
    ).
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1819
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1820
    1 to:10000 do:[:s |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1821
	self assert:( (1 bitShift:s) highBit == (s+1) )
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1822
    ].
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1823
    1 to:10000 do:[:s |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  1824
	self assert:( ((1 bitShift:s) - 1) highBit == s )
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1825
    ].
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1826
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1827
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1828
     self basicNew testIntegerShifts
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1829
    "
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1830
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1831
    "Created: / 6.6.1999 / 14:47:51 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1832
    "Modified: / 9.6.1999 / 17:49:57 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1833
!
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1834
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1835
testIntegerShifts1
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1836
    "arithmetic tests.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1837
     Notice, the arithmetic tests are both performed via regular sends
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1838
     and via constructed performs. The reason is to test both inlined
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1839
     JIT-compiler code AND the regular methods code."
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1840
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1841
    |n1 n2 s|
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1842
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1843
    n1 := 100000.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1844
    n2 := n1 negated.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1845
    s := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1846
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1847
    self assert:(n1 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1848
    self assert:(n2 printString = '-100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1849
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1850
    self assert:((n1 bitShift:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1851
    self assert:((n1 bitShift:1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1852
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1853
    self assert:((n1 perform:'bitShift:' asSymbol with:1) printString = '200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1854
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1855
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1856
    self assert:((n1 bitShift:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1857
    self assert:((n1 bitShift:2) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1858
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1859
    self assert:((n1 perform:'bitShift:' asSymbol with:2) printString = '400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1860
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1861
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1862
    self assert:((n1 bitShift:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1863
    self assert:((n1 bitShift:3) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1864
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1865
    self assert:((n1 perform:'bitShift:' asSymbol with:3) printString = '800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1866
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1867
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1868
    self assert:((n1 bitShift:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1869
    self assert:((n1 bitShift:4) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1870
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1871
    self assert:((n1 perform:'bitShift:' asSymbol with:4) printString = '1600000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1872
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1873
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1874
    self assert:((n1 bitShift:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1875
    self assert:((n1 bitShift:5) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1876
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1877
    self assert:((n1 perform:'bitShift:' asSymbol with:5) printString = '3200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1878
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1879
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1880
    self assert:((n1 bitShift:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1881
    self assert:((n1 bitShift:6) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1882
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1883
    self assert:((n1 perform:'bitShift:' asSymbol with:6) printString = '6400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1884
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1885
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1886
    self assert:((n1 bitShift:s) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1887
    self assert:((n1 bitShift:7) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1888
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1889
    self assert:((n1 perform:'bitShift:' asSymbol with:7) printString = '12800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1890
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1891
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1892
     self basicNew testIntegerShifts1
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1893
    "
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1894
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1895
    "Created: / 6.6.1999 / 14:47:51 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1896
    "Modified: / 9.6.1999 / 17:49:57 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1897
!
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1898
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1899
testIntegerShifts2
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1900
    "arithmetic tests.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1901
     Notice, the arithmetic tests are both performed via regular sends
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1902
     and via constructed performs. The reason is to test both inlined
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1903
     JIT-compiler code AND the regular methods code."
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1904
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1905
    |n1 s|
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1906
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1907
    n1 := 12800000.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1908
    s := -1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1909
    self assert:((n1 bitShift:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1910
    self assert:((n1 bitShift:-1) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1911
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1912
    self assert:((n1 perform:'bitShift:' asSymbol with:-1) printString = '6400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1913
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1914
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1915
    self assert:((n1 bitShift:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1916
    self assert:((n1 bitShift:-2) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1917
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1918
    self assert:((n1 perform:'bitShift:' asSymbol with:-2) printString = '3200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1919
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1920
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1921
    self assert:((n1 bitShift:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1922
    self assert:((n1 bitShift:-3) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1923
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1924
    self assert:((n1 perform:'bitShift:' asSymbol with:-3) printString = '1600000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1925
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1926
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1927
    self assert:((n1 bitShift:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1928
    self assert:((n1 bitShift:-4) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1929
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1930
    self assert:((n1 perform:'bitShift:' asSymbol with:-4) printString = '800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1931
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1932
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1933
    self assert:((n1 bitShift:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1934
    self assert:((n1 bitShift:-5) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1935
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1936
    self assert:((n1 perform:'bitShift:' asSymbol with:-5) printString = '400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1937
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1938
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1939
    self assert:((n1 bitShift:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1940
    self assert:((n1 bitShift:-6) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1941
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1942
    self assert:((n1 perform:'bitShift:' asSymbol with:-6) printString = '200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1943
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1944
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1945
    self assert:((n1 bitShift:s) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1946
    self assert:((n1 bitShift:-7) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1947
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1948
    self assert:((n1 perform:'bitShift:' asSymbol with:-7) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1949
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1950
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1951
    self assert:((n1 bitShift:s) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1952
    self assert:((n1 bitShift:-8) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1953
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1954
    self assert:((n1 perform:'bitShift:' asSymbol with:-8) printString = '50000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1955
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1956
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1957
    self assert:((n1 bitShift:s) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1958
    self assert:((n1 bitShift:-9) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1959
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1960
    self assert:((n1 perform:'bitShift:' asSymbol with:-9) printString = '25000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1961
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1962
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1963
    self assert:((n1 bitShift:s) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1964
    self assert:((n1 bitShift:-10) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1965
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1966
    self assert:((n1 perform:'bitShift:' asSymbol with:-10) printString = '12500').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1967
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1968
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1969
    self assert:((n1 bitShift:s) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1970
    self assert:((n1 bitShift:-11) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1971
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1972
    self assert:((n1 perform:'bitShift:' asSymbol with:-11) printString = '6250').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1973
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1974
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1975
     self basicNew testIntegerShifts2
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1976
    "
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1977
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1978
    "Created: / 6.6.1999 / 14:47:51 / cg"
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1979
    "Modified: / 9.6.1999 / 17:49:57 / cg"
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1980
!
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1981
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1982
testIntegerShifts3
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1983
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1984
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1985
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1986
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1987
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1988
    self assert:( self doConstantIntegerShift == 1).
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1989
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1990
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1991
     self basicNew testIntegerShifts3
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
  1992
    "
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
  1993
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1994
107
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1995
testIntegerShifts4
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1996
    "arithmetic tests.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1997
     Notice, the arithmetic tests are both performed via regular sends
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1998
     and via constructed performs. The reason is to test both inlined
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1999
     JIT-compiler code AND the regular methods code."
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2000
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2001
    |a|
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2002
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2003
    a := 16r1234.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2004
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2005
    self assert:( ((a bitShift:-4) bitAnd:16rFF) == 16r23 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2006
    self assert:( ((a bitShift:-8) bitAnd:16rFF) == 16r12 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2007
    self assert:( ((a bitShift:-12) bitAnd:16rFF) == 16r1 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2008
    self assert:( ((a bitShift:-16) bitAnd:16rFF) == 0 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2009
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2010
    "/ should not shift in any sign bits ...
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2011
    a := 16r1FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2012
    self assert:( (a bitShift:-4) == 16r1FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2013
    a := 16r3FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2014
    self assert:( (a bitShift:-4) == 16r3FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2015
    a := 16r7FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2016
    self assert:( (a bitShift:-4) == 16r7FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2017
    a := 16rFFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2018
    self assert:( (a bitShift:-4) == 16rFFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2019
    a := 16r1FFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2020
    self assert:( (a bitShift:-4) == 16r1FFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2021
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2022
    a := 16r1FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2023
    self assert:( (a bitShift:-8) == 16r1FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2024
    a := 16r3FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2025
    self assert:( (a bitShift:-8) == 16r3FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2026
    a := 16r7FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2027
    self assert:( (a bitShift:-8) == 16r7FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2028
    a := 16rFFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2029
    self assert:( (a bitShift:-8) == 16rFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2030
    a := 16r1FFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2031
    self assert:( (a bitShift:-8) == 16r1FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2032
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2033
    "
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2034
     self basicNew testIntegerShifts4
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2035
    "
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2036
!
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  2037
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2038
testIsPowerOfTwo
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2039
    self assert:(1 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2040
    self assert:(2 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2041
    self assert:(4 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2042
    self assert:(3 isPowerOfTwo not).
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2043
    self assert:(16r100000000000000000000000 isPowerOfTwo).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2044
    self assert:(16r300000000000000000000000 isPowerOfTwo not).
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2045
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2046
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2047
     self basicNew testIsPowerOfTwo
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2048
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2049
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2050
    "Created: / 27-04-2010 / 10:35:36 / cg"
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2051
!
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  2052
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2053
testLargeAddition
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2054
    "general conversion & arithmetic tests.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2055
     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
  2056
     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
  2057
     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
  2058
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2059
    "Large + Large addition"
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2060
    self testReading1.
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2061
1315
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
  2062
    self assert:(20 factorial = 2432902008176640000).
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
  2063
    self assert:(20 factorial printString = '2432902008176640000').
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2064
    self assert:((20 factorial + 20 factorial) printString = '4865804016353280000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2065
    self assert:((20 factorial + 1) printString = '2432902008176640001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2066
    self assert:((20 factorial + 1000) printString = '2432902008176641000').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2067
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2068
    "Large + Small addition"
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2069
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2070
    self testLargeAddition1.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2071
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2072
    "Large + Large addition"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2073
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2074
    self testLargeAddition2.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2075
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2076
    "Large - small subtraction"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2077
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2078
    self testLargeAddition3.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2079
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2080
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2081
     self basicNew testLargeAddition
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2082
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2083
1315
624d2643334a #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1314
diff changeset
  2084
    "Modified: / 26-02-2016 / 15:39:33 / cg"
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2085
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2086
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2087
testLargeAddition1
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2088
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2089
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2090
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2091
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2092
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2093
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2094
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2095
    "Large + Small addition"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2096
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2097
    n1 := 16r3FFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2098
    self assert:((n1 + n2 ) hexPrintString = '40000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2099
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2100
    n1 := 16r3FFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2101
    self assert:((n1 + n2 ) hexPrintString = '400000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2102
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2103
    n1 := 16r3FFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2104
    self assert:((n1 + n2 ) hexPrintString = '4000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2105
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2106
    n1 := 16r3FFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2107
    self assert:((n1 + n2 ) hexPrintString = '40000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2108
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2109
    n1 := 16r3FFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2110
    self assert:((n1 + n2 ) hexPrintString = '400000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2111
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2112
    n1 := 16r3FFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2113
    self assert:((n1 + n2 ) hexPrintString = '4000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2114
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2115
    n1 := 16r3FFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2116
    self assert:((n1 + n2 ) hexPrintString = '40000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2117
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2118
    n1 := 16r3FFFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2119
    self assert:((n1 + n2 ) hexPrintString = '400000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2120
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2121
    n1 := 16r3FFFFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2122
    self assert:((n1 + n2 ) hexPrintString = '4000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2123
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2124
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2125
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2126
     self basicNew testLargeAddition1
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2127
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2128
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2129
    "Modified: / 4.6.1999 / 15:26:55 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2130
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2131
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2132
testLargeAddition2
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2133
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2134
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2135
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2136
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2137
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2138
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2139
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  2140
    "Large + Large addition"
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2141
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2142
    n1 := 16r100000000. n2 := 16r7FFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2143
    self assert:((n1 - n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2144
    self assert:((16r100000000 - n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2145
    self assert:((n1 - 16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2146
    self assert:((16r100000000 - 16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2147
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2148
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2149
    self assert:((n1 perform:'-' asSymbol with:16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2150
    self assert:((16r100000000 perform:'-' asSymbol with:16r7FFFFFFF ) hexPrintString = '80000001').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2151
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2152
    n1 := 16r100000000. n2 := 16r80000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2153
    self assert:((n1 - n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2154
    self assert:((16r100000000 - n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2155
    self assert:((n1 - 16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2156
    self assert:((16r100000000 - 16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2157
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2158
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2159
    self assert:((n1 perform:'-' asSymbol with:16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2160
    self assert:((16r100000000 perform:'-' asSymbol with:16r80000000 ) hexPrintString = '80000000').
17
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  2161
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  2162
    n1 := 16r100000000. n2 := 16rFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2163
    self assert:((n1 - n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2164
    self assert:((16r100000000 - n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2165
    self assert:((x := n1 - 16rFFFFFFFF) == 1).
17
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  2166
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2167
    self assert:((n1 - 16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2168
    self assert:((16r100000000 - 16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2169
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2170
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2171
    self assert:((n1 perform:'-' asSymbol with:16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2172
    self assert:((16r100000000 perform:'-' asSymbol with:16rFFFFFFFF ) hexPrintString = '1').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2173
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2174
    n1 := 16r100000000. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2175
    self assert:((n1 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2176
    self assert:((n1 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2177
    self assert:((16r100000000 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2178
    self assert:((n1 - 1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2179
    self assert:((16r100000000 - 1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2180
    self assert:((n1 perform:'-' asSymbol with:n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2181
    self assert:((16r100000000 perform:'-' asSymbol with:n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2182
    self assert:((n1 perform:'-' asSymbol with:1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2183
    self assert:((16r100000000 perform:'-' asSymbol with:1) hexPrintString = 'FFFFFFFF').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2184
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2185
    n1 := 16r100000000. n2 := 16r10000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2186
    self assert:((n1 - n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2187
    self assert:((16r100000000 - n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2188
    self assert:((n1 - 16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2189
    self assert:((16r100000000 - 16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2190
    self assert:((n1 perform:'-' asSymbol with:n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2191
    self assert:((16r100000000 perform:'-' asSymbol with:n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2192
    self assert:((n1 perform:'-' asSymbol with:16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2193
    self assert:((16r100000000 perform:'-' asSymbol with:16r10000000) hexPrintString = 'F0000000').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2194
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2195
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2196
     self basicNew testLargeAddition2
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2197
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2198
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2199
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2200
testLargeAddition3
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2201
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2202
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2203
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2204
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2205
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2206
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  2207
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  2208
    "Large - small subtraction"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2209
    self assert:((20 factorial + 20 factorial - 1) printString = '4865804016353279999').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2210
    self assert:((20 factorial - 10 factorial + 3628800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2211
    self assert:((20 factorial - 11 factorial + 39916800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2212
    self assert:((20 factorial - 12 factorial + 479001600) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2213
    self assert:((20 factorial - 13 factorial + 6227020800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2214
    self assert:((20 factorial - 14 factorial + 87178291200) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2215
    self assert:((20 factorial - 15 factorial + 1307674368000) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2216
    self assert:((20 factorial - 16 factorial + 20922789888000) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2217
    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
  2218
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2219
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2220
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2221
    n1 := n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2222
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2223
    n1 := n2 := 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2224
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2225
    n1 := n2 := 16rFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2226
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2227
    n1 := n2 := 16rFFFFFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2228
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2229
    n1 := n2 := 16rFFFFFFFFFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2230
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2231
    n1 := n2 := 1000 factorial.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2232
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2233
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  2234
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2235
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2236
     self basicNew testLargeAddition3
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2237
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2238
52
544196f29bee *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 51
diff changeset
  2239
    "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
  2240
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2241
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2242
testLargeBitOperations
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2243
    "large bit operations test."
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2244
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2245
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFF) hexPrintString = '2211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2246
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFF) hexPrintString  = '332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2247
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFF) hexPrintString = '44332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2248
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFF) hexPrintString = '5544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2249
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFF) hexPrintString = '665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2250
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFF) hexPrintString = '77665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2251
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFF) hexPrintString = '8877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2252
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFF) hexPrintString = '998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2253
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'AA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2254
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'BBAA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2255
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'CCBBAA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2256
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2257
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFF) hexPrintString = 'FFEEDDCCBBAA99887766554433FFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2258
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFF) hexPrintString  = 'FFEEDDCCBBAA998877665544FFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2259
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA9988776655FFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2260
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA99887766FFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2261
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA998877FFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2262
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA9988FFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2263
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA99FFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2264
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAAFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2265
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2266
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCFFFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2267
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDFFFFFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2268
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  2269
    Time millisecondsToRun:[
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2270
        1000000 timesRepeat:[
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2271
            (16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFFFF)
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2272
        ]
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2273
    ].
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  2274
    "/ bitAnd inherited via Integer:  1638 1575 1576
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2275
    "/ bitAnd tuned in largeInteger:  172 171 172
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  2276
549
255a421653d4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 548
diff changeset
  2277
    Time millisecondsToRun:[
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2278
        1000000 timesRepeat:[
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2279
            (16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFFFF)
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2280
        ]
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2281
    ].
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  2282
    "/ bitOr inherited via Integer:  1903 1856 1856
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  2283
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2284
    self assert:( 16r800008 signExtendedFromBit:4 ) = -8. 
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2285
    self assert:( 16r7FFF07 signExtendedFromBit:4 ) = 7.     
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2286
    self assert:( 16r7FFF0F signExtendedFromBit:4 ) = -1.    
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2287
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2288
    self assert:( 16rFFFFFF signExtendedFromBit:8 ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2289
    self assert:( 16rFFFF7F signExtendedFromBit:8 ) = 16r7F.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2290
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2291
    self assert:( 16rFFFFFF signExtendedByteValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2292
    self assert:( 16rFFFF7F signExtendedByteValue ) = 16r7F.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2293
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2294
    self assert:( 16rFFFF signExtendedShortValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2295
    self assert:( 16r7FFF signExtendedShortValue ) = 16r7FFF.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2296
    self assert:( 16rFFFFFFFF signExtendedShortValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2297
    self assert:( 16rFFFF7FFF signExtendedShortValue ) = 16r7FFF.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2298
    self assert:( 16rFFFFFFFFFF signExtendedShortValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2299
    self assert:( 16rFFFFFF7FFF signExtendedShortValue ) = 16r7FFF.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2300
    self assert:( 16rFFFFFFFFFFFF signExtendedShortValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2301
    self assert:( 16rFFFFFFFF7FFF signExtendedShortValue ) = 16r7FFF.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2302
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2303
    self assert:( 16rFFFFFFFF signExtendedLongValue ) = -1.   
1323
a15b1d326f23 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2304
    self assert:( 16r7FFFFFFF signExtendedLongValue ) = 2147483647.   
a15b1d326f23 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2305
    self assert:( 16r80000000 signExtendedLongValue ) = -2147483648.   
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2306
    self assert:( 16rFFFFFFFFFFFF signExtendedLongValue ) = -1.   
1323
a15b1d326f23 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2307
    self assert:( 16rFFFF7FFFFFFF signExtendedLongValue ) = 2147483647.   
a15b1d326f23 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2308
    self assert:( 16rFFFF80000000 signExtendedLongValue ) = -2147483648.   
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2309
    self assert:( 16rFFFFFFFFFFFFFFFF signExtendedLongValue ) = -1.   
1323
a15b1d326f23 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2310
    self assert:( 16rFFFFFFFF7FFFFFFF signExtendedLongValue ) = 2147483647.   
a15b1d326f23 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2311
    self assert:( 16rFFFFFFFF80000000 signExtendedLongValue ) = -2147483648.   
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2312
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2313
    self assert:( 16rFFFFFFFFFFFFFFFF signExtendedLongLongValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2314
    self assert:( 16r7FFFFFFFFFFFFFFF signExtendedLongLongValue ) = 16r7FFFFFFFFFFFFFFF.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2315
    self assert:( 16rFFFFFFFFFFFFFFFFFFFF signExtendedLongLongValue ) = -1.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2316
    self assert:( 16rFFFF7FFFFFFFFFFFFFFF signExtendedLongLongValue ) = 16r7FFFFFFFFFFFFFFF.   
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2317
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2318
    "
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2319
     self basicNew testLargeBitOperations
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2320
    "
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2321
1319
df8bc748b1f4 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1318
diff changeset
  2322
    "Modified: / 26-02-2016 / 19:47:25 / cg"
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2323
!
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2324
1304
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2325
testLargeCompare
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2326
    "compare tests"
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2327
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2328
    #(
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2329
        ( 16r3fffffff 16r40000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2330
        ( 16r40000000 16r3fffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2331
        ( 16r40000000 16r40000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2332
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2333
        ( 16r40000000 16r40000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2334
        ( 16r40000001 16r40000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2335
        ( 16r40000001 16r40000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2336
        
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2337
        ( 16r3fffffffffffffff 16r4000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2338
        ( 16r4000000000000000 16r3fffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2339
        ( 16r4000000000000000 16r4000000000000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2340
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2341
        ( 16r4000000000000000 16r4000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2342
        ( 16r4000000000000001 16r4000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2343
        ( 16r4000000000000001 16r4000000000000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2344
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2345
        ( 16r3fffffffffffffffffffffff 16r400000000000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2346
        ( 16r400000000000000000000000 16r3fffffffffffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2347
        ( 16r400000000000000000000000 16r400000000000000000000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2348
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2349
        ( 16r400000000000000000000000 16r400000000000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2350
        ( 16r400000000000000000000001 16r400000000000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2351
        ( 16r400000000000000000000001 16r400000000000000000000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2352
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2353
        ( 16r3fffffff 16r400000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2354
        ( 16r400000000000 16r3fffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2355
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2356
        ( 16r40000000 16r400000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2357
        ( 16r400000000001 16r40000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2358
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2359
        ( 16r3fffffffffffffff 16r40000000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2360
        ( 16r40000000000000000000 16r3fffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2361
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2362
        ( 16r4000000000000000 16r40000000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2363
        ( 16r40000000000000000001 16r4000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2364
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2365
        ( 16r3fffffffffffffffffffffff 16r400000000000000000000000 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2366
        ( 16r400000000000000000000000 16r3fffffffffffffffffffffff #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2367
        ( 16r400000000000000000000000 16r400000000000000000000000 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2368
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2369
        ( 16r400000000000000000000000 16r400000000000000000000001 #less )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2370
        ( 16r400000000000000000000001 16r400000000000000000000000 #greater )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2371
        ( 16r400000000000000000000001 16r400000000000000000000001 #equal )
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2372
    ) do:[:triple |
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2373
        |v1 v2 expected rslt|
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2374
        
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2375
        v1 := triple at:1.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2376
        v2 := triple at:2.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2377
        expected := triple at:3.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2378
        expected == #less ifTrue:[
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2379
            self assert:(v1 < v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2380
            self assert:(v1 <= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2381
            self assert:(v1 > v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2382
            self assert:(v1 >= v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2383
            self assert:(v1 = v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2384
            self assert:(v1 ~= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2385
        ].    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2386
        expected == #greater ifTrue:[
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2387
            self assert:(v1 > v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2388
            self assert:(v1 >= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2389
            self assert:(v1 < v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2390
            self assert:(v1 <= v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2391
            self assert:(v1 = v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2392
            self assert:(v1 ~= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2393
        ].    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2394
        expected == #equal ifTrue:[
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2395
            self assert:(v1 > v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2396
            self assert:(v1 >= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2397
            self assert:(v1 < v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2398
            self assert:(v1 <= v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2399
            self assert:(v1 = v2).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2400
            self assert:(v1 ~= v2) not.
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2401
        ].    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2402
    ].
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2403
    self assert:(100 factorial < 101 factorial).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2404
    self assert:(100 factorial > 100 factorial negated).
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2405
    
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2406
    "
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2407
     self basicNew testLargeCompare
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2408
    "
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2409
!
7d2a27f4e21a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1298
diff changeset
  2410
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2411
testLargeCompression1
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2412
    |l nullBytes|
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2413
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2414
    #(
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2415
	#[ 1 ]          16r01
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2416
	#[ 1 2 ]        16r0201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2417
	#[ 1 2 3]       16r030201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2418
	#[ 1 2 3 4]     16r04030201
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2419
    ) pairWiseDo:[:bytes :expected |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2420
	0 to:16 do:[:nNullBytes |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2421
	    nullBytes := ByteArray new:nNullBytes withAll:0.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2422
	    l := LargeInteger digitBytes:(bytes , nullBytes).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2423
	    self assert:( l compressed == expected ).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2424
	].
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2425
    ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2426
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2427
    #(
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2428
	#[ 1 2 3 4 5]       16r0504030201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2429
	#[ 1 2 3 4 5 6]     16r060504030201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2430
	#[ 1 2 3 4 5 6 7]   16r07060504030201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2431
	#[ 1 2 3 4 5 6 7 8] 16r0807060504030201
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2432
    ) pairWiseDo:[:bytes :expected |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2433
	0 to:16 do:[:nNullBytes |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2434
	    nullBytes := ByteArray new:nNullBytes withAll:0.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2435
	    l := LargeInteger digitBytes:(bytes , nullBytes).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2436
	    ExternalAddress pointerSize == 8 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2437
		self assert:( l compressed == expected ).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2438
	    ] ifFalse:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2439
		self assert:( l compressed = expected ).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2440
	    ]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2441
	]
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2442
    ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2443
933
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2444
    #(
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2445
	#[ 1 2 3 4 5 6 7 8 9]       16r090807060504030201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2446
	#[ 1 2 3 4 5 6 7 8 9 10]    16r0a090807060504030201
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2447
	#[ 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
  2448
    ) pairWiseDo:[:bytes :expected |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2449
	0 to:16 do:[:nNullBytes |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2450
	    nullBytes := ByteArray new:nNullBytes withAll:0.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2451
	    l := LargeInteger digitBytes:(bytes , nullBytes).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2452
	    self assert:( l compressed = expected ).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  2453
	]
933
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2454
    ].
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  2455
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2456
    "
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2457
     self basicNew testLargeCompression1
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2458
    "
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2459
!
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  2460
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2461
testLargeDivision
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2462
    |t v a b|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2463
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2464
    "/ 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
  2465
    t := 20 factorial.
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 assert:(t printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2468
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2469
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2470
    self assert:(t printString = '243290200817664000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2471
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2472
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2473
    self assert:(t printString = '24329020081766400').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2474
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2475
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2476
    self assert:(t printString = '2432902008176640').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2477
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2478
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2479
    self assert:(t printString = '243290200817664').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2480
    self assert:(t \\ 10 == 4).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2481
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2482
    self assert:(t printString = '24329020081766').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2483
    self assert:(t \\ 10 == 6).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2484
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2485
    self assert:(t printString = '2432902008176').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2486
    self assert:(t \\ 10 == 6).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2487
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2488
    self assert:(t printString = '243290200817').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2489
    self assert:(t \\ 10 == 7).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2490
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2491
    self assert:(t printString = '24329020081').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2492
    self assert:(t \\ 10 == 1).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2493
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2494
    self assert:(t printString = '2432902008').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2495
    self assert:(t \\ 10 == 8).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2496
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2497
    self assert:(t printString = '243290200').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2498
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2499
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2500
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2501
    t := 20 factorial.
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2502
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2503
    self assert:(t printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2504
    self assert:(t \\ 1000 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2505
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2506
    self assert:(t printString = '2432902008176640').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2507
    self assert:(t \\ 1000 == 640).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2508
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2509
    self assert:(t printString = '2432902008176').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2510
    self assert:(t \\ 1000 == 176).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2511
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2512
    self assert:(t printString = '2432902008').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2513
    self assert:(t \\ 1000 == 8).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2514
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2515
    self assert:(t printString = '2432902').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2516
    self assert:(t \\ 1000 == 902).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2517
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2518
    self assert:(t printString = '2432').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2519
    self assert:(t \\ 1000 == 432).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2520
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2521
    self assert:(t == 2).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2522
    self assert:(t \\ 1000 == 2).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2523
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2524
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2525
    t := 20 factorial.
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  2526
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2527
    "Large // SmallInt division"
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2528
    t := t // 20.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2529
    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
  2530
    t := t // 19.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2531
    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
  2532
    t := t // 18.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2533
    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
  2534
    t := t // 17.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2535
    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
  2536
    t := t // 16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2537
    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
  2538
    t := t // 15.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2539
    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
  2540
    t := t // 14.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2541
    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
  2542
    t := t // 13.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2543
    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
  2544
    t := t // 12.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2545
    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
  2546
    t := t // 11.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2547
    self assert:(t printString = 10 factorial printString).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2548
    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
  2549
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2550
    t := 20 factorial.
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2551
    t := t + 21 factorial.
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2552
    t absDestructiveSubtract:21 factorial.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2553
    self assert:(t compressed = 20 factorial).
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2554
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2555
    self assert:(
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2556
             [
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2557
               |v|
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2558
               v := 100 factorial copy.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2559
               v absDestructiveSubtract:99 factorial.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2560
               v compressed = (100 factorial - 99 factorial).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2561
             ] value).
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2562
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2563
    "Large // Large division"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2564
    self assert:((20 factorial // 19 factorial) == 20).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2565
    self assert:((20 factorial * 21 // 20 // 21) = (19 factorial)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2566
    self assert:((10000 factorial // 9999 factorial) == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2567
    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
  2568
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2569
    a := 40 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2570
    b := 39 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2571
    self assert:(a // 40 = b).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2572
    self assert:(a / 40 = b).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2573
    self assert:(a // b = 40).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2574
    self assert:(a // b = 40).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2575
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2576
    "
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2577
     self basicNew testLargeDivision
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2578
    "
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2579
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2580
    "Modified: / 4.6.1999 / 23:54:57 / cg"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2581
!
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2582
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2583
testLargeDivision2
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2584
    |t|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2585
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2586
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2587
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2588
    self assert:(t printString = '265252859812191058636308480000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2589
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2590
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2591
    self assert:(t printString = '26525285981219105863630848000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2592
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2593
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2594
    self assert:(t printString = '2652528598121910586363084800000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2595
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2596
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2597
    self assert:(t printString = '265252859812191058636308480000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2598
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2599
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2600
    self assert:(t printString = '26525285981219105863630848000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2601
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2602
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2603
    self assert:(t printString = '2652528598121910586363084800').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2604
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2605
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2606
    self assert:(t printString = '265252859812191058636308480').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2607
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2608
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2609
    self assert:(t printString = '26525285981219105863630848').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2610
    self assert:(t \\ 10 == 8).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2611
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2612
    self assert:(t printString = '2652528598121910586363084').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2613
    self assert:(t \\ 10 == 4).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2614
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2615
    self assert:(t printString = '265252859812191058636308').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2616
    self assert:(t \\ 10 == 8).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2617
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2618
    self assert:(t printString = '26525285981219105863630').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2619
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2620
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2621
    self assert:(t printString = '2652528598121910586363').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2622
    self assert:(t \\ 10 == 3).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2623
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
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2626
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2627
    self assert:(t printString = '265252859812191058636308480000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2628
    self assert:(t \\ 1000 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2629
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2630
    self assert:(t printString = '265252859812191058636308480000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2631
    self assert:(t \\ 1000 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2632
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2633
    self assert:(t printString = '265252859812191058636308480').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2634
    self assert:(t \\ 1000 == 480).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2635
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2636
    self assert:(t printString = '265252859812191058636308').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2637
    self assert:(t \\ 1000 == 308).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2638
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2639
    self assert:(t printString = '265252859812191058636').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2640
    self assert:(t \\ 1000 == 636).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2641
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2642
    self assert:(t printString = '265252859812191058').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2643
    self assert:(t \\ 1000 == 058).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2644
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2645
    self assert:(t printString = '265252859812191').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2646
    self assert:(t \\ 1000 == 191).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2647
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2648
    self assert:(t printString = '265252859812').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2649
    self assert:(t \\ 1000 == 812).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2650
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2651
    self assert:(t printString = '265252859').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2652
    self assert:(t \\ 1000 == 859).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2653
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2654
    self assert:(t printString = '265252').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2655
    self assert:(t \\ 1000 == 252).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2656
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2657
    self assert:(t == 265).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2658
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2659
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2660
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2661
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2662
    "Large // SmallInt division"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2663
    t := t // 30.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2664
    self assert:(t printString = 29 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2665
    t := t // 29.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2666
    self assert:(t printString = 28 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2667
    t := t // 28.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2668
    self assert:(t printString = 27 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2669
    t := t // 27.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2670
    self assert:(t printString = 26 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2671
    t := t // 26.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2672
    self assert:(t printString = 25 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2673
    t := t // 25.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2674
    self assert:(t printString = 24 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2675
    t := t // 24.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2676
    self assert:(t printString = 23 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2677
    t := t // 23.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2678
    self assert:(t printString = 22 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2679
    t := t // 22.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2680
    self assert:(t printString = 21 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2681
    t := t // 21.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2682
    self assert:(t printString = 20 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2683
    self assert:(t = 20 factorial).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2684
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2685
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2686
    t := t + 31 factorial.
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2687
    t absDestructiveSubtract:31 factorial.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2688
    self assert:(t compressed = 30 factorial).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2689
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2690
    "Large // Large division"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2691
    self assert:((30 factorial // 29 factorial) == 30).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2692
    self assert:((30 factorial * 31 // 30 // 31) = (29 factorial)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2693
    self assert:((10000 factorial // 9999 factorial) == 10000).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2694
    self assert:((10000 factorial // 9999 factorial) == (10000 factorial / 9999 factorial)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2695
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2696
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2697
     self basicNew testLargeDivision
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2698
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2699
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2700
    "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
  2701
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2702
1305
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2703
testLargeDivision3
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2704
    |nr nrDiv divMod|
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2705
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2706
    nr := 7325642811050717153762789776988268826770436380599581066471363310499109217483708146717300025889347764783245287140288431825827761209734375227679364238973902481615726067110515609260483803343004535447652942957373994975597787908243354307547553217414840584715130217408586553614859382487727371958203670203728210853329589615550643569429545464633535838187607553120280274725090757329790353463095413523805494772650078306205912628165850732646863846576998277181504708528835125953362770982762908435490999280519117904719254192978414037497481935495547720579882482124362070304920033554421042496625143517677519951145301160506529078213700153962585026512916970185197699563558140876733107706727253226098498667726495707224022003616065672008153665539817928251568554484739745047105522527635187163056607022536498632737702947013365938133885169902714284727206577408496549992845715870018995222990562233528977494519678931256347544259771346247230580853991022721956676465120007969950427165372994323753297510475028095488055686092040724169139419916609256577729768013251303221252901814408489603855447556799027832316669978641359003225101118289255692054597992816505634077137939488367815415698567236171805308890522013024780344455911750571267472425322111576828023953254628842107966689828686941644594589250192289779894954314728890652959077550610325243691999405204222390497498029651468304746649735170207150423058209700682117896369093708787314191673370934168117103657952473409299633370355921652776795194998872621267955977007414487536764633556057244697184265399074262010357199308106519621332411646090881806679817777934087907609335095266207222734209276892672802559477129431290377781189460543831892579497032750130070072871363403749763492296712949034307352335981485523440716455874989554006840460427619480548908526831960007098095496673990791644237848915619019143304599320077794055989022733836402514795091748221758967378808917944360112901833917971660803687798356056419168537336005651674223355473407003283134339985506017270361538197141299934143152796116511007721239543588850520897247526805181747313555479146618959531019365744636489763407090552996809230736561767841333905734641055297321262233564674390961392651334871664325693448366323216336135114828870644061243807564587592658360508871312414270046251899865884799855978604603846784154676298841585915992392704588348304942478924343918975195923643629685241735276658813975572655538887395894943154837164154459809363283117923392993892589490540925513342593007784719441705148960453180301530851234688957032066907843949205120201720517233228017689397727501528654849506825446097709482577917667243321350295028575684178929416362809008034715382134959864428148337229371113753679702176851066723014671275176890295101957580814878664773530433540963808618303311433527685959104811072639265393597781952115276199443064654238529377585171747088279186943179071921057535680516445246724050154764542596741670850809674306935131178441317280401304117745258603320024189243969889899010725582438207015597258263941269730866138781215790257519260119642107850957073141852969214624609102867275022012968382626510150354544317157440551595548404866365232107076069108476859713524926579046999471537578555696823173917264727038317433492881860460533993043375675559974541501151536956388184229821825202783315175964857435121268159290087988520427001562311888903167219790907449246265211066597617404797684060743206718943066178740881680422221097537985644933108964245133276088549914210990590138516895520058065054329273143605806169872175805617483836108276041444751410352824841438522369961070941467306815885136393083146953817333717600651525643928410853518305074271285893483690402426110481100118592425979094825294009195497071244959721165805259378411459840402202432070097961411127831244002473025945590264209304535568932141934734427207643570840464365672020197014117057179828617184095466170277658012012082773008797284377020045199741711763429387654482036311118363550554573970722123056838391535176046275151704935927285776048526642046962416364731182508311665455959674818084140845113742927564214026026700188662967826830513695781752328070213377525743249206640596503567193612953686078368856837703275526312899731904806336662979992529567407592246922517958210869076841533625492899752157880746671555381617069359816751254049680535425407993431788796501484592904619815876395056294928500125620366251871965592128092071339931385778018271508366059428400618014316995088662886944531660310582304020782381824044296858444495836641436442114508798254022275527819884050205813610927392719427503886961325971042076759694523773397768263944949829047040250671591798699614674593280712438625552771672046770702177630021735604331681545328668356298896381196151818109965073540758004677376198693809341805742022883291609399453480948898873499293263877270932469009419431439504806048534024219695533951970768718607825512258459988039384671119861525055001257711440159711680468030006281596534069339905726514213495715578762483305792208439143804155140484955582807325734068361219604129672905439850247943374888325363536124220790929563183116800098259005080319976250005938202733026601423198594337116340040753176034747789519724367052821548790017492968600851467986834229393664397355394904449416596664697790294348115918027290369660030404309844866514596162383926922191583735197797285879017756435071691692579228371128194336880861331914026966533592778591975677047531809933445220376204094007852062763024256243247594908739310435742528343941136832141474614646195909007856979265090874937138653336279924669848945653923945059917473576073169113163591124139505027406426534299861184296286788678362064462571791247879481439224580152349380317895688368254981040713360197820623097965776497254219906627282182384583338997949322384688868753460332706063133692787241504223050921158385580293599957894628416295533076654622257184754535802725334290973325498566317654571663237347731966894722724226512101772153274798569796914026876025548743598732008731155930322538300118777605906397797200395073085079799720873331462360859558150294524673319774115422392855072805588331909034084940029643726834272412931634977220530411021804722158153773936709148601033954557711082063893472585895524019049770116104251942887519233166694790693305261370262098403931338638500460698273702483237833362913924748030573151235157079682103767162430861730648127306887340728587348584798432641373495081984444066017235036057867001084876034127575741046842705361078008658574057368371382290972551200828394402811129598512908406453163914133239324104176213439651911165723583312125404951908431958612444626832567425682382934966014402623844134480947328804898904457554990223633471152244935360846846872567395324752446056856314223580293777812792119222808747497257154119637357959526560095149732009525437166278985397825839476104252829701681188291604531178056187506204522297781410939426743458996516122417016297219533676135442588829970042448233678230743338567376323339403790517471808179478793371414460742848940080957249583920379222819120854583169254001656959488520268941651760355412230878512385792248057484840320339298745595785121144213305506256309005073307733101215537859103057428564045191401917751767528573372312728646224212563853090004301461656398621398256865950301741795030996394898498315685734194500204859005200129895914605961077480028024084166201706521017250564954091090761794215977943552136119569181253389728669786275631589077849217875992600354179303147875039054389958249338829071558805071696036014384280708136310202474257546110256018595074859205169417210438407668235772264489532840927011474245787805040250578989944089804487191960609374291147892392946334697862368311103975946562702804600592135283262705727886790284962999933595950396917187809872807890634995550768965917896649379618770995853018273642527941803602373748201162016424346818539699731541437191051272370389920430963850766457735997487836796190622801454117965803454310147963735891677695932780724907240409219933741153684518942237155171214800428187139788975348112515841498442346521529922874142809101317753813000222213844775530569928492214119218158311069973450417965826021228115913570997832587000507462134261658894622095296948660838891202843909918507703517052932194777950892934484326759830164241347516373904518928184219267625128730631587594616533889734599461176472989484051646992794549374972941033191680237511998366596928478133425687348377402191597183609913275115410415042943874922013282223036797766687562234708717228407526539793707192821641982045304637501898951672018353203243730498439561247010157326717850275842340724013349962837828262281859810432128342491502593655870623723538391476208736312646369716279126909024702322290468430221078966596856226868416199720051530940142548869537531144513871342122033366003412041325058744123643998708546094783795853752878277029993558821508050352135005532898315183427096073809860479404735696155895314871310840383963606002446025854182161994409438676534109631384937889800633421957669306238761422314292556501189945069931744515842623180008335951569700303152755271126472218857847432207385749882000533990024894030463892512867955227542394178393580753618051116929938385425024087970203342497063966957812547691207822897841681320712411054476647899997427503220523868363438443638138602058216412755412543898409102222405369299283907058054142505144252800800871766217740818073224044997682418836667094039746104705778772576150819423984585572854317991749574311863090200042587643440109185515699468359875803740167627895880258372380256331670270263041712499710565984020613035159213277572556237587993858247481402455200866484793496257416259856493587482957111225529071072537348695594958918648771418745755086539672404243468435455614922691041334875071267875391058155493338089472329161793182872605415502672937446879754623263952587889465083012515482974024506303700547794278667536739029569027539204865836091781842095979099980597464896983833312033418068148036099416870991217256675646972777065922275910262922486960982071022004929591359754288008776666205314556217272149643659129541170220989690332246883597290512968292817547469960138932109624850558843703432530540563548458251740803818389916128884564107380377927554030955090368431293751439829748472706494577940655099832463005901756121683476039133485795695397208495963616009088796806461291782584789937456739904233218852673930490171837518542422869715022557300014464253539379770130907001828679637745393742942924263739420939777245314275120477043103602195417941946982309000073013714022977049299652046646160515486071522858510125026538512532826758076756521229686019516236643861044256103454896600270127497654777352626796048814315579753595410684034930492848275912546385929478301905388366502770922904296261409762621660749049443869640676686234525730982815147070574292105084954509636183802284297900263494202277262106346273298509408501260925964163271527969153455344760075934784461266832139952514330249768607822250546116328645082232537397149287150870610226985594932674312703921712201689647303170983692623648013718537633610994267304884724686274443142818383020753736848287437672619884752757520891254092091290347766004298705684071656448745211379292411880056341949058778325139319915468910315101214860880624074088224739933628426458311629373094570056389962892015767941405606261884441947643048736689186423401799688135324726895945036118240150307617274590470074687290086181786558717205596918177872025497599170920256707122647400323893910027358803516743974239059498348001168404511372867956344817513606052060286270870628439157590311659998045156965274784647124177936899464082765921232150928558673393867832500877514025700053617920434533154013622992297424683989961395195164544773940494933482997619656975002955401823151470278628829447890583331692520608980058918604588771018141614644472760830547004909601105353723205204277054858100220843067696044358489288417053911779777636685862530733028148648527058888734952577662015452662713320998042221873897730242685299799949020919872610901220937556378878376264157771582659279927771096081291387570641227589263660184974304328800241026371644634693496152671628907116378044361348718616751343481441762999387959144794856149633766264287145359338550543502403574450566297906658227167549659449971682569731597042976899648193306364796761430963500027369518502867183892521528424714258941396654757315537208349927345921504783438385098575904450316533205383619867919490492230433428758373474687945215479480124116968494047912748080744896623860514834802919426785508712839994810630938135518361550388522230840646638453183986357427908650074058682630364404843361587964015212755669857078199544466122571728060539385378015602874360055774274800826080107259485947478571241263310480273433269041612018874608869206907030535684348688412466809171164973900200423516515617084359168072722684263238409355982984938645447365604915324694040110296398069636366148511098339986168750667254777835619946102408620138809371209811284079984973613416027249191446901665098739727142152623855284808133782852451728093569697499517366796585724689797742669468565268872539798878428345541861849015666331916000495956355163844447408071342491131776963020645656976892893787238149867119449591069976736262537015469780716243982143936721917630178728713247937607546958966361901328145570841011084562097642232937625937354868187273321107873039743053276603671355685099229683453605499731141681728718378187532065603510822624958972165532522593635204874376810200781275036766022437927240950798250024393364045682189134704845812286037422441193122739522406536732573140710828441743539780377865147861896193389749380659879327866275653179078947651387828111930396337490811270697985089816201218037506115014234142814682385102523425972998593072640770790725982414228544633029642995101682258901254287806742301366208828162477387463756687281252994501452908836547072102623355315709902776432554014376309587952657925497621653825666951796394661574770097931615332475671105408244630930525159146961999288995770715582728242072913256023911103584836889339253743344246510506913924657087924098478903888180830049760169862122162975453447015711932604661405562458098481070408233950340734255196874895090512289072552940802931818483030211719516961595929768810347559895680375914216324687844321700032530945151286243597286377866371612859700311552506351798213870409353454490411358344277477826150792145755992594822938766358675158288011584257616710623663101210097323109887979417370263612584058408561358753317231537698348461655660755380659581072178207477288688962757072265160490600631588197174512903146276684731753628694529596685824595885678007158393374747938101982904430961928841395951711676378080535123188351635638375470401478450523224920448602818895251564437834189202441655076943081483367064127416752887771318611109757781248425601474160571124303096368062074727513104959974456229598353065136721943994007941337054705132775534896527968122420469283611331960766006310601910252893459785872191278971330399395239110974562830357605556211522784691991561501390889806743958122904782088893727818201559345083867749044489168363772143703073453861134806218832960790409704879310579717552309996536217584965576262756407451564345833758720479629349944383529092132517915571954489963418248400511019703249483828204180370506184025113885649509409399769397711510007228728095574770224464446547044693015123777262159249799920884371538510122463960052058020131241942783200854033288826257878667417602086305216692912715536488620698053698022459949861565969545496357876743594887244566194824704556438285754633336308260058711894417742350590911910751979319176563052975803605412148165461044329096028626360061282229073291691883497842134279789428389371821455228942452798912977912958394511561774867405616536174458495043002980673610932445441383719655132197637184668163335110303541471123350976668674100112488910955928337286996714611124366551465792608110489076815010708899544256516556491056127346270833501757113609337499406611359404510795587423010608098938597650459332997781990621787924888569110021893517402845363268426339706716754389272990470513536737039987732318209821574773158004394368361313988432686443321166887644602545565041603076909330007914163941559127137026301018995229723135409029401064752864596947271438965582579277147631406637452843077049145457341837232159559730366551507472354953899625929803225701422561284852163965527957074334769617150236291205879362139935058355563169747778333904452955956839634568402701244925016745087651928608816736896469987882537309453244944834414373262938906464005059484038244572034326521612529650748538305485316521177247308396706868465169508059682590492304730955362364037150109353102703539473481458183308919847959243679572900240943426756852783203732123528501086255095826959561188972056318497725974188808836112899288753036602467405834455922655584156707363544433003151873583632491497489084045609299373141002646109273485527932587471790254082751973899027694147514158739383819684253034890946834373388441862051909883719721456276038041023850094627569248404828269211588662076341724107938139304211383814235573153888420922122069650074118928661037695827085823059008478593607756083868239999584244123010713329522790683394908267830112016051994957975600649644301974822906420255696156580630141761950629199586872747965112569565095469854869800403281833556388965700255873755860649520760282097467209698862605898434981759137733994266863639515406534007603175251563989668595260982955865634557781963224702857431711084062719151650997813779049906730415588122420262881103439896718580338498764211791089444646113690306378896098332737896635627635707772111276121536695313757806801348052118367819007399440960078665432399602377589467171594166195848994511848676342889852715337165791189020515662167204773204943614199127918332127383021743482576248998849902385077500814075914415851227356664528451616748460466665152976847232020446712913142880265960029344991220490001756182292717800761425879396636844902717038165543316666346164629380858250514747045491468395622679634227153126619733161441602334688751330958487543155598758421785605951110820924317190126071560389113736027517764010449768122991989484777981503183676348308768180078944633796744764632437921469707222455070766402087305156639658996955592139453843175790298794847443059643374415249421787873000204116964718653377159672324783600759484527475614449099007219842795509953657219555506013243218552996721200522560495144292673408433365706761513733674234568711615287301193667910837956568423438400639397963485968493623913712571443662496434067716848785221486690871940013498223030548187623888628374477709165936052912242994609169592340209437745724218818144600119064099826714575548308046604766436374108048400515726390133789845668096714784867008407173380319008417622029995593936143909536352013256938215644416531080180324802324618594097721172967615098799962908130441684305713015684547786299489529752824756501155428933939409296205517218276045889777478407568327206299474573691014209950666820875099905758278156965131476983278829571931391277816150330174477625273228440900552716318825768863185688529954386089451175385273662218329372749649446918354724443567025222349254449500617488028496361898409264103494905512190685896563250346346478211054441208028146386655248314336718654702652948137658435253312869829785373710193043688043958388972024841165561464326457180133203136125912400081649557668375744383899632969559862047404192319326563366004043695206668245499093118179837855729834168890145742251325448274416525637217013782454651636292195303239600214499858171679843470201696427000689391939448538191864553657744525021360343641380208086955930529022030426160885726040281673029309222840802065136346172382864319126701138148007706597835132695333947879760079153539055868548576156789850188497064536338026379929631234929007846807334812010645525172679991044333308985640292227558092752377643275995472992776698475790987837268792851399292228646489527461685929270374165049749069600603160046531920796900241727037869527459596145880819238533080519265651802795555015701064625591610129446123733504319175294781249602732333862539881844001174584054522255651608769617444327599828563581084600909669099440890092395641857086470399143117454131045827055159803551495132022116760892488889653153960587625841910867118206599437776258771080930144854653198726857646093716759295479410273617910942457821712732399190660866650490310710185557517394324308553105747144650750856879369349462377069251837917999202072251775088629659288184803660320127706626903128184146348671588370808814878328754655521943032817668859558325837576523141169778965733166386323397421920651468704737017814665502038341659575691927370030081718281672624943907725801459555157666049437494098603486817488433976626337340941222390329751486891908768166184463762670896534403352931457546379158595470562519774115429755212992688771218914551662191667783721153049023035595877690703411366361819400655202920269631805916454568041073107237253371890381490738743213309620059159993003849604331778047563116240972981607042015453452120068390822980655208034481099171665126640420489382675390866694573945421665672978524248517728079136569669375989021101850354217557422960696302555361297444201614660760149578194625887224649588332477042831119096972466903323569062428962777789251193844890660811230501531481978959612097815608680381821610023703044066176422964276045425566045824291045559057543333711029208777182180667218083104949199239136505834286628001776139959001219218905737418785641440851285017285337841944056173947452985842634788119839741235296336597559262487718554614436546822943903751831157623580674824591472930566041078221877158999849916636775398181102018674052880692512951698697513480517091515255566537032339412246743208266441707025164363377133880339650825219697569785046171337552332893545340847276858565496437706766030630722861762469516812573460899602135044490222233011994495526330459680983366359908902306295944044245771154099378936054217933392621460294966444315839619038214146393712002594553326031581417561314908364002486755770223569034363166238351234653984593425868697240971720773578144266846388819244504828181776390586079945560272760789021959416347716506857324409906002813134675432442066171228067068885528419141038131029179667706526774372963054478099683768936725773364000366960379562118197023510329482012107157344155875448591161595391919815262096502829728473187341874733253651529919979538531811286641534627778595530733985639584783830665988435302841891713116049103963675865435203124837066057645535281252657153315351003929269787455814660826997441903167459298690397042785489023802967671956590687562052329368827775864424049524191769265315949730487923955413049297486674195881931530552325062629106937559254886715285149290376041517510254575017089126238369735731441459908323625000391457129028083634733044760593008952189043595506011162821891237685214611886906091274976179324857590706091796406177625733347163004518021058299015360077008619141355691143129132531858006034134859471413635076801228545121952706746023220117837638086686354108957435599629954680243222435069621658931397374328297390779950081057015375721056239174253648058468325719338788133801151936515595963203703897529311280939274519350260938124229883720011888795447147955456430451126315978438040080489704091830058887795299872925112565712154018417162739997545058930991575800581788972727456060664226272478064852420923999507537882444320718854395590876566227281632171045068514052351501673709403201037188250295301734415546890351185372093093868842689894001551600934381797141922487365311721131325628216317486392434826534327444835813827040146040623702648032380447448136154616398503109030818895785037281436914811186726407883525589623745784053150256537820204779390766220428603926382471986845043607824571153400160052404381575056198801845131518390346351149303614811547311242885120974347678264504367422058114110590584616857433600543740991959073794058140903494097716255074997440636144720728479858818431649567101409884610735460498756656979805396736031128522080195025672224591817816046577402276820084711291274356314869576152330615815241767096386124487945441087050607753895420887678873857176400381643559607194474756870418606846938092225072149441622787084691405251105866384641135662322242739576886322176214547207279725762284255464168735963793003697380346821240816624664408301727144025359059144838660419650159844461274414337264603692360330829781038559372304769177150910295526218586671075425593440499090198871740910802116275754099660717081809348908577040588631693074984232662360693119209505027983812508319223671439887199802525968038619436452231817179841365769913890926114871474823986102558248984056751171047487920908703881344710413315117402556245735859539904885030456237268421343054705364347991234047913856137332488820079750762203668981258672591585746354112878783999551179429905553595428779319618205955760109855092613527644960822047320473227114766963811143741244543560984456111125291941526870369848525824391192559998244670495612381361646167116316134254469202262396491358927397506005317375010817174654504297216767011458286649844846972401675100964256583057423372220731293103426957596949490693959409243387593122271779730186895385509002372128203913747196497707222954185403205774019431819289117303305570247189365499173945821877882947041265338660691701329332190962248344273179360681417405107489124186407998243259234573342968597256163713209217434289027957190422218111924387788256131382512827800678950844810180746534889923898689642780000177422130718538953322034407815417934026037724751662822483375107800778896663583289121202278023801612863043235964927529347161048346388661293376210119688831516982901549177542348947159080101505257893914409911057786247888178114455119581370181777267188461192806263311755813332788407091502471672700680467132633477533561142293966656214747737409578555062844314602141692485230285966094671781847301987395271366469630767558062112328885393287218169191308218491026790992185940472657740498984495459678622709378403150335318468905992328881663104160804687882440812818881405288046436227297457076591968843740953385063083343962623712923639380484489819982491016361780280276169822287192392447562183004485125881771767301867399126196483636819125433619352232936820141550863954332722336201898117119322617189636537779715466381486919126946687930671216141452922541147106709679828617423994874259063229649123229518230937878691439874612244954074507844778683128526476317639118125371158467622560854714456375919537991303413072742967677940130456040692658489636525122293276481109808057346731810379189856938253679165389325994448637996699383494712921721075102752165363287472411045626443402092824653856031130579486630852299223562415803848929872524176136572203720259791428116844323532933588350929434768591652396279151377056649946904423876773164294300631366488764834105010682185485963623493414811764796197305673062714223556389869461430429375897012606458055194019727119699064615147436243860806192462008343479759672764808835547065006227356966938579183385683242312914357531439848379226427244818697458161912778146111681862542149788668492334979217146007920768310239137555938899242435302928517891968231720891496735372779516584037533540785957755005709202109126682981133492715169216867882096335742028123146922474139806442352071726795065748233286421357136259478075789617951692483512515306524891863357257717679489398290018317806682896210611402661100160374226086537049073243154990027642836396613193310176604504810534893772428808909650946232081171095067517581083996381726077971297100787766219854892974450821766776476654920958360090137474327967048906416972057811898669752411033820021430818244474866948828089694542481365682716635711181667411943506580099933345985254871356053492593961261410022611611638590502797062851727396497071058602567774355094747163736356397095850006997424923531112267182732864620909866113824820058603582958531094555020510236027027614431361800988521200399586673119547081726414690946264630190526634425644735734369461310520499007520355499508585543263341743900683573459238052117903500693000834091101712801538465402378378788144062565678935408582810427199506747176661448934111477635429452999529543080018774599929511274133290665853831807027349385053891990116923477073601573652090791807519295421039777391917621497541985415302633144183175238454215017098774097235275853537209261772618306543730724023082803885507581143607139751832537169456162439207812666381128402696526892293998914258723768720017499847984266585234913600117422675602853831759174426206891377825107340342701248119230213445536811698998359038183296563935302499327006034285845728896557943782923399556727004316890263067394203880281380073469638121484580199160819715617289728021829847401418693279991820133854136572587461373226302598594529298221390370775366987990983177009324833219732528831629990421797299223802093648161616663879975810476101783579393868468502081257564874766384664501509001183842063196032638224612125668482059082665228528142159069942060893915606313181707310505441794055294071663547920016602694400545595432136470930681411209271045562029874387463078108850054385998584637189771275294132908369193659781957985776433491190297689914665426509472196522411323928378195300561602310224530015347222547875758340039768542111436297653638278662369121460476330673013642837634923317515965253459144537815213719135592442299298816576373126634138038960909820457612677675783457258671339723120179633081955516804990831567693301696939699672015449317249971642551286584808129342788832029436801657018628358004798080608105909323093198784846845645325386979597398678978830345672780153323968476179576140696425471821998947380199201341358406139850774495886929512793237490160142870088261156365616557904316857668388922739833923102142619761438181312790544717406255524534509231320343527106989160031768626195806563471881286599066109601085681638916394858229430951462409147214901977476398310691648884105776491098520166157330063939443875435796943355719969632950102186397143687779839736579836206933338819143959159363406579332971362010077679786530037433544098847138689261158878246792507024969634114253622560056328316234987527324602651240456647339013865004249242977561395674701577956969389900249185989776680415380350732334128309923836114711035017617747769595002949511282687656602753426366555822017768660677216237740216507472925748667967000999718713527274444690963987157522627787202354721060271353729547313866987732075979117079846732413636459165812839433882317207155027374226318776368857252794717448645253705770992655896057862954179644123532323636460584760744250739359102987786758637467637353356965608822802371506831339109050545031443083639828791912591491173211826408402061094497140550687518456511418634831704222491420398551252188798829570316127890035938622709348295255719221696461602749283552993638948947540135681555161478489620846449605430044941872799703773058974361817501697061476133321363775760636069455030846228779531268123378895993835780337827038608856140980413745864293745914406340229750270769504339465352030356216744024238713735806990797168008854280945697224613839870090197940155282712750709172194380153634146926816676024515823584088231400463312382777203125668639972061892098691453960817235720605917593037228214044515858127191970494660211930516466145592663099310492447409876759547267269546121606395117066909754582947520241309163725053673240679714256180891234020254453276258233353933830411269188099460453101101892000756745988828048282222284444127415763956898935615592190117456834504468742950360516492684416298793335152967766928852074366733814540857573444455528985644845185065034346112640402659226060116640258934520978930605038249624160204759818066247093333611839083145229529279417098896841881437979538519201155777645178826287972935358996390354906995489934248530800713546948968183148003843919015314165041496161557496179086007896577579617867935268933548581362341854451994408726034928832137826659990639338937799609636453283954242809205539456878416214070953644356943389856818432600837207778616720748676938374167354667834832060534863893167858537784770073045535612859851873945303743454718296695298634664951824381963669712257445362562336753508214174025503527830539500054913297955051787866102185934642635331258792400637526092515185350299170488147855128705105659867618088688753087658254737196930525115823965358676681318054168230606026317957031887517498191886041759009170380803971677533808855847935963302413449922868960528689064335811771892647412655405511386556297232825727620645847030173878179578724353115411237535609238689560816107970307741703445451087116907161445232553198068240181847253666995114428407076706548882661985472194213910892387669936605281007133618963508657753133705642673696817486635123227343786590893113124229529397388254617250179612431485026422687552078010821860291619515171241168065674667610207596394151847581338526738718950716228321620075816773740443990198310650129401028199155101511828634637136915354619277160368249371381078808111483113736277999666680765128118757290998894150630894070077301710464719965589744182899605947453537434325424659568476976257807998688140297038415134478560327804024687366732279706746035700937983217159762314919697722630018306620851175305234116716106843307138903094060632759586446063354844094943376435539651295604866223836562905109269402588222614796293798277799468218379916416521276024309764723016595827980045529911394304000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2707
    nrDiv := nr // 1099511627776.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2708
    self assert:(nrDiv = 6662633323731567683137463770425046119972136130490599558899123904210782000048955657546048338089665562423074595372134746708823296293971339062117626089251555169190147414256458077270948527569093617282899634080762548342679827245086339014549187793286219479991932728270136570804297100483133701307636938694238970905034502371154888869049996596580545736458232161676533246213776471749761506965201454953608385742563840091139275162427885091025804146353946887012629948484423153743921621737866106228003445067333011961381320536910074258682909144677567128910488902078543169686709037300189304457148994986416728307763424855244492462783182558234861995982025264479668930619989751791520673311176554512802339256928913261821455310942897696812136624011889515033152342298071512274969356920005509130584511715402639886394993433908317400104247253605275804809213311644722625708569208536590845345008858415466399942051501903967025595429523806385287189963483817993580193128873368523227715891492147715101325512000610702205499988933334611073532341758081435343892524554804643431682872519021193151143459141893825137519042963177852473768417547297991124700818539000925406141630391619735578765993129524005603624473698812857747129288247152154569878280492149839872603436792477479782943819217222827905602197688669811923223236876518868169077065932115442814112611272507112872060586623457737282248353708537440207167545131324624997338441147538821782465377847014831893014759727951431431968895008978190868943052008828655078064891320004323949219391175626919627742850388198587106996637256185312818463363915808151256605758842792136336001326613101088899142459264924284800653801657455269721850699589180141531487149252598219454805868157021677473942233257684196639595334983355790828424192909541992782433644995416653317905481191664882406344528748368967757631115924249587936451097739407299792209435266919538221186568760660301420447293747151306991237865002378076318280180526977727975952198908682179738530497531431395267954927026964715297743348074891340859860789456898608224255025187495012594124570391779113664193099927268994661989714354273464562908966902793335276088839025616229178681024727936638794047725854753445121469971920000103358186939952444241621483187255438734831666410707469056761064049453502111688296190428340923841441148946475354163955033838270461267159320949165980839533335114464512294874697208511171752685785408153217445523193778985790372496161721264624578255386880658073907934058789510812259862184677985571129419404726995982428753663670210728075205992308115237575948883416665937774630699551861339250087280966997886464539913201627606531742484162972849780468425532497380768638445224373234076062753384679812079141062759905910765766089004401051262864330797018433052954090763672692099410879958238807338698107808012778508416688011598376942350173207376910229491087872782626788596807338691230630211536158864622893956734099080442020613927228902807774992144293064849356703912470587347365098361451500658414011543243947940570486265588687939149293725873385717495020907919850152172396648759758331493330026994294732515271227954608685062834699381201564024694020978463624585016140470976879181330265581934326720818333847725464851389246839097102050339237267017355400679094305414741521873249018386912379564657226367474609265595843167030823823815888307326919859008114043629727548060061462134640542960003237935595902000153006810199318514370026314665866355006060662101944184764882516982242954519270451909066555817897156024927674610449508845588002992024015689920157493765829176802821931631590241487238873985285696003426340287794076918847820343809440277189797464887583441187676629382340618054613952244943532083179065762391482344807692465983310435881557512776871445023245934926397204809407259057481926925852885928369964436177662848362828687829863675543005561550690069465524227034464836091588464269332378546107140912689644468971000647070233491616299386491375149772573753171449947304356213004974407827081491882519644546780260294370715784722926779399796198511750540506872925851061282487638657519313905164405423591836522816111495281603995252289872385086476469229310711401528527506301257816056801709876959217865896545758738590541706792036682061363760042257088762989112039152701520742768623568505674079807810875863485081257794882308576605276750150366298371039105968353284329219873078273054143543278652910514327315532991571113396292522800982678225773832322663106505081384006672724636320985174081562785472030426212309827534624166323291136226564299729779926610904852724095137745669038747074706380810381924397482883612399986254740569208516035970744086352728731611278556045932012031400560563908745853060950689115708469515692155527082269323865892247308760070844077451853262294943617058144830374014063090229211365020886204814145346309426230627122487421279225644442725951826590928222475412083281764588227804815128066475027958454121524220172577508201782648035333837955540129683619410765000534937610139700875341476734142047589998542737528010306112593043148198988006188165170845763794500602249285494318364329213288147091824616909725569939842842543596840734083524325194154098463289461537667911688662904500980902221288027220544655818218265475837746996472010236584007176738575972462375026150791464142148497925800115687265675808142920616038812782060447067014154305466101224458342793123964105995474584535180862955288460196781648553085262219550209211207588026816531112456709030305544360916191463216584932837523535301571859795009182479596217471466926212940178314362383320867455900637582040017075517949772956047275866807594416084072169300543338235271482325223007196166301392848144570452154384977210957293114632528390739972304218279369363788615170503593817472053417243282259131772615839858816679000902088506393860091327261674653574046859271748229366456048072374228952936986954461812960776844852566037819383835600381330161020048169786575176406335437161125603009418044684750306284400745015540086325935345626867567751378481969009868769532841174689642757402653727086965191901579737800170435839185407005418578658287140871751975359929956215389060409882342023572364751463302859267203670036848697371716329102635164492370580294469523800234173695676967556158058431931901118142098589725146905128352892769397385982936860912089503320533289229159009276510219167066390676852427014511459354368805077084042375052908754180535991959079169140810351777905505393392636393431646479931302422033114524318678899414743110703321665415570194813338103931163016485158053150293320176682849865950119830732697413244124732414049420578484034599229592065444814927955090765319822680007274309290373729622349451338071624805845426576853103003370567780916419402325897239482929120438541569564424943334867982370378410776501847576669342499380514197733899878037687667052618283223365943911896105902249524831410057706578101179674765029139049616899153094252341846800968999185743059608692632244338477301941908375137612702490034105885096135690595893486578406810583373575282511613130846721636016131016419385094668786170270105099382118058667752659173909237179323408143996490057471550438372565855669568075707259687274506958695435449557449093301254608165917100788931501161845710670470989502338362996305132945287246866702609436316376008925088459078082627911685321128243349354229036144786259708802466926683070160849866228958572801968143008687496651087821709717221337749533437341262096267973190948389492727237032475272862079136719557335553937772424498412907282167253204658036522663912861489967343545754246593032273458846618876337536007203682712249257269146062576546910876450005243718339617735736623482032784880126505138707551223982569305519703270511483547382579404918839636852647345161672956598447115365954967174398002999413589275624553356118459301663295512883021676137652660825734676124215499674882903247218052630206577642084012432827740455157014364420171474367291740649414319526344397807373512379561085192818359161938505367228336721095291925155065811136228538259401638220286361061736441517811291787368531134060596121120227508274377982866581596616462970013543016021749257061326685130571812001938788851323431118096288750404400065801469551796490885764071976072881177700325727466583683008951024461863889728341965881114787320729126972054716702704109258400053128328990837507682205316986695881175358221798319366772405548254243978588753267948484911744969711778505544859566371008691126381031647673694280468482450520966964802539436922158737077121750002067704209950517947895275485187950536800011107737855580525830416272726621826086807998163498280837268646635732040394769166712960660791026071702275406585969427586620725056827465122411839751932641129741050664123546627575912560511096417077652349819389991841973046133599693459503547277028739085889123201599430748088793537859468190507211174911898362104739455512577053830969074103537490200197207200049611998015566197237458603889177541028426143550097544365997852341124263498329937465890381606795295955418098232523840580315613869908469965450988802338848428525762122401606821882953426082028665593848700047602082113394220896647213988097023709581111850996949900598384480808761859793798146684096848272987669550104826786271426406384927141254967004421494402774831090228439159876359957377770662840899979305879736692449207314353197306703720694762653242964236415719707807709474598662585817690053244256584634094675588772387320728876893030232700378159568564796767815881221577040003142829035992250009683957501514432958745506657813505062455380239289536840908567419834056655066010679741591568523506419291023346414842722152449355047334627139443779463897483726315136235890415753009343093216483474653995240946721005159273994166538118965875301947867114969329009355586236318538876250685609005070430253377255824432219814984476455677020466705546834887611998078233503929866669094433324734408933206886290341422947478206056966064334662828420717990695296446636482902339973289591596091373182364602203890422888673967906434865718458245218781812358691248643177646331019984492877159627032179896760671627209600850253346391553616574626603287596419349597318213312704240279836597936499176049259238779919659359224267409788742546907956321200282485507559458481839743848993694568980420138364844893768971338467175415458491804391538574796876754405099255829357011671106608209724284478263756619062561946992484466017881479781226530089273673529323906138417286165020182482970033492405254420136568337797393833604513114189281093733322434044566828573546466011111351374026204357974607838989739784779000309310988838440677460786200468664461583688408649555734386828226224795341890764896222022843007212559090108162021383514450324833808323442944564068880379969871474643609232099524672432072065066171371327688290179617734777653046940553660629197979241904416814835983950855274272068765736863745858963201045536085042989062938403688763487261963686964428476887533136063512074332363974690948558717214002383604926898703662000671308292653459533824119645680367911743181294681283019279375110761642291430932623265766493454469257647709146798421760001872528500721048437772780065726775583559870942098046438397119753740490868306016527691410327914835147693629474332656459501972550133927210561728079422781253432105249315186092695867012382237378862014890057147969807959315163943016544546298690088701484361031394763122216597928194997139212034462694811542459062553095389537586038839071235015814370056111693269389352305878495387099950893625189881278100442169827936555834473905275492197948797975758169884639129722925686252861191664712463696502617916924251331904225415709036855212464161811580220910449150251619842632875245719603685469328376161861492205183767960018924893683703862737234341532850039837857211248675033249758162682137534755933837705941315666354487585368176046276495167470532765222994435005694159229340308269782771538682076344939357692679425354738694430715010693246526855161993822050738084109068988456669010456828514452172338697819097988850645322196559280542955237043845644875480294191294243671628138352015652035502147832020273418517146314693212385602848033983824623687143092609964470596861648812591181885313558137704270635608088146327043933109509820109861326543893172335781445926340867738481148623616697386431217916074089554450405103150269058917608330277763824073839949907229906564057762087349990311778587768856946330357372471841275187565424737767435082996992995284357197931917849454730570975669701554500305138158088651708126085216389971524685018121085532248742434165580153047378399460873550609161599238566767462611149933427772707403493393907424627064456087353573406713733285621911399526086839253252364920421564239246508902633182467505840796787479557927720879016862471757675729538193109452262750608872435631538942265160767804915408866767719853735545879556628651112971951932782255758506758251945975744362293034679502078243875384929350503323125647362412515669719705455290178369806457412764733465715860119591022250156219106181326562931513112569640527774437694546186046408836197585138256444950223039512425447239856838567382824787147773363964308297000112321579912390413854219643773041550014586978847525545364794414262966819887507035652321303620752105217176216667343339142387440168685055366893363995549376670079553282967791356972668015843949376745456315682701891383756331415264006206237965084878941733844343257714837038003432752137257495692759685719124680847167412614538657367006068680166919216423380951198784933649947788603088487475981482143383660343066401239813051800174000533422015517445025423914324655725411380579191151076329105654312915546930776739081083130851209560307261559808003595454190858699636192994182698489579919753682299765480387055479694566268008903344458287769365183187828409240957337041346594822068020495286153916970285888477298328581357959138997929436797741893882044055962890321491207955092531472430580766283693859646215925564679002104430854098259562738959271344578729377212911592288946202639427352171631575468303031833703338256634096377869121483169247318904967557580606897753481360433243071165788807886349764388293820695191793366944295901792867034972217834675333738411495592200037471295720880155324101436263128307034059249353748610108195767389020979150086248268345752906071488861276742315827848748423651031498876866413731293699920942666225974254628767337160594389199237190034723264888058437168327407572709723914804838989858772126647736411522980570465381410084236050678330973124991667963023842876969302469279748200467545110485810034399278411447631362160061302813940661759884034612358568237683981191908865801458121853442888039446172937851735631594598045659655670606785063854069117622544099869154206792904842994724111936422163524033921205447454737571280459967114554653337916325943852925554693909749040789538931789414251732580009709193386661331220447753688008685205153591603394795178887882480498680277349305852539404087412513732493890167379734424193689730774421124197396598209807938986005281190551806069183559876875280125104661004987176879496554550976559950467476559304258484634527452519381498017040813588033614753804422807393056528398772163482132360711680090004176924055583698960466571152646455948292335532725821865747613587236595247530568040947130838943692837511089697894954146145800686471738817451943314160624802839788362893581912928352442591061642144413099049343949783668458733212864946888676178097687428090333954322728693913329532371868758870453268823927363537857721619750427589553115439726294751268818431424046653951176908373270894803348106787107152478615187412606784084264974789511303754855340051658833679689870263545431979424720394747263593027757345678621399456268980783872231272861374648345111361698362447451983621128788960537508008651496314069548689924381907425158401685801106563911310636385954732278263100830980578484843580473312548144610442900203565265247985546564550976724435723289297624666247935684674418868117603325806261281593378413719037238943924955877274085741135966282362763193106721357060382514254442887152906589877023423856680625901166776450727839358966536601644959153609144391132902459862060242188807417448009183469264503039581145496052228654052676496725272553819319933882997243226530495493561285061107687030878215808993975387490670647281729045828867173573105303000586136076645167624071720961141090470782549551314716665078642257836261666920413308268644174214574267682237346033030519874726249630752547960543633630157639983049125491329584885469201996544958519723770711888804039467535780543824274815473477301096898595071283422404678758221733495070552923171978588751150443266365227380501603502573111410088460947042358483807313590240913510077173949793948813061142184688143009613447113936857687916497981028674162941533323818450350080181784482364317988060883443497947703206051150533242121659128958857349455686882605353850969092935960402982618118713619556828483369397811281916611054914712416483805731465976494964146531569215799109721805847028410300528694173153527532373153045249500878187581518800314615156447564073770740022098961439234138937750297512946800381652855912829289926467970595537813845166063837126428330597144158673094574735851632185151893903271146216711815228383779829505875249782822697691614321461835203609216607002918525904157716238810383010391065426897393809125134642778347338844701765770751671444268397042348815101706901167231064172608725124761680162478484393439069367788364606593491099359158275214720362749380640577721088524470104995681138292437981278208476931579225731985482925571630931097842007340469617197091896460102706347332362145513466773659918337317572988046499916670479070806370253529002190952670353070666744678967350036570834703676333309881112517065360307108417452733002563964433340667896821473681133465222881870547446871335962511010619755236243761374511519456442193793333594411207392794004105476372366726747732579235992618924015878318955393497608385365476617805871466249190595260047214394069820212568325902033965922654033888417912286484711896882467251228378354183552293400075258206316865187130275079433360393164503976387026629881917025668725831325016331687957472029777811248536434487962818526601321326034011639998240520767133091723253262191478889477732161417549504821178703052409631566820999340775276726216946712534308446072712286153652680439930352040093862145659622442078648977666579419037446128195327816883541805521638906205222812059694261274802822911995857217067861269000490423940129053596411898677534589257055289125128765042939890889550610075923551852304168673133714809214526655242363576702244447943074362796222547671711899207308354482159297375955786574385854460819445028523296167863099823730022352090642566296479684850099511564373087943558717295760938927621289992360634932091140965012523878555060864106373640658546915478306374170806816257322333143836404972687537427918835335849909537778979043364004415979697596187929554163161291338782947874465678267621156819384376292481035494619822724135714643080670449194349117313575477023852251462157100442647234811207590910430078679631359082941846933243892425583167722406828385000563844537531315125606281753470690926728570451420660194661881586853830856879082022622614444211189862027995955847075720472590981636180405264920542673876523908199231895835194289372937814963109185400558429783080140339774478333285537556699238361330987736558384436762855693888604544252644467982372255364280010369297262804435889271193485633563494271128632242998571978869071398448928214066950611845110439059878457358040260838872377738188879643075650321115830111195188171223607598166789592316367410292281897474240707780500277373863291840300035279288645802844513739755083609307623251094215604446493961519719176201768010830924261149752008240975627953538656464432802892397239873841558197762448235088987744283265644123580215828629229847756497333042088017137113845417927907308370118694686418872787249521013870679592265695912127418059324065039553961809510883312277292682811136302844531110387585647794846826942508306109847156295035588893190647972929310585300837929143605036855209909095078529616878524697187949533912616220353861101335179781717322334159325535950830348702683903956713848030991031789277686038206518291309335679266186892665696297646824642372383904924530689265908078515046434592113144186677137514316332139654331264735125017720528644967462490620083319716124344933995590200417291717086036610960506908963278468132327493231742534480298990695134370300218432020485190379781750952733353355873678374453180937874211107688414514621736824496909620169986303101752871651896892513684703338313893053933255183789081818233099194429728174343667583800232334087537030361427268946243458842786771044962553296095536703477989698602508257697525945310759504846774891475733740196021161653485418777347759620656145992080798847727381685645525539961559324870188895773727580412516237803781935982581716437412611301343261776643304819481868619659753341516913182720637517474858444413157832505693243741288479267641371737999729095261543591838054428973561736725472157668326318183044945915784847874576066830414147706853941955038585159805208300597749734377901157203392876608064388184267818682399190422948501056958194837938391733278658784527755984424606731034448309440295924193353554895405585796132948214826002362174122627776551327343879146573828709566085927128207558802117131623323460157076665769242068403665185141160275937828400136620241192456176652835846834240452613661806597521514177023165047302341679295555551508051653415609814912335474376911818568116936865517199968267319797266790612855146314008776741341483924545019506352746861761799184869747515293258290656922190388865397288264923207565564444569202307046632552992848187855320763025731448044322626818272002953585947000990139604564002024944509293877714454845365556042038716302410519861492901060742979671634076805703004367909180382050303746373376482562884571531258606847571505895674729168873404018309675988438701948374926299395721307787395239134493403106002139242002160785480851729136172763278326205183918096527325878045633695581592505417560999763617198587755156744222535295963451807660480724900277337461447992209534969141734072233109797259073570248716353319773293544532922325041060565932210392148625152030199085590108347217176792108238881854901342897723225511945547225075822119388548782819368313852606548106078809355851189880251783054363594122321357531048537249744113050418065369091565603073630514273403592269082568082618298317632108493592673811785028807085323208525403120854794483676644319669608513326174279234197287824669726834966393161538408455310478065279133231953852910635361742906178576755214111517056327801824696461817882594873856805222646175203300964795337063208197930123387100035611442898962537621189321957513145288545491320961201783084023485230318684859529665194381535043030992718697406456699814963178889130392858728202451771804840042186083208062615168997950766084371341242335363877881080966617516431705681821487035566981405152551846308469495319182057575043059043266754766612593919342214655158708509550193047862153144017813642739949190337390404536833912770771422453449645873712360457151269709782651006515869206669914944100670221090425818628601774379853413256806505273043406959924949474450066150399316439803729716402849663145119931714415440906395699971756190018053547116471909246270169142909777111146276158913184245342769165725317045526866422285400296863663896924113569981788011574855928342975415991851606735244243464910312696061102300896479291942510255551582184891858463744530673406535967971578872825659092205865479824130931221984452835683846238511093397524783198334851506279344401387929443807027481880885621453705681630631089489476296770158650928120354413431647606394294397787931502924588063599432632004248814905232532874069922767722869190218991066223241787471443921552795301565594166172669223986011515539182639311651756170781133603153285133649653252244928860946768958545104628751685086750644332576921314119710268248219481287934045631571968130610735349124325810882583205080365791756610466151484981561971003167210505449761394244116973473697036540303439437127913553092230911492056676149949338521015670614036534613837352259788911948678049240902575683723282770265260665156443670989248071839321931056089748674072520359193076479425403027075088844834493105461097317694330573999345150061096450395197333950671837028176159805717611029046806473790966566257139710214116625838120990838702278978040950346826860768941596869691912534837789531369798770098970462048699643710814263334282244825464986836886245787380161175413667682434097411896621020758210415293844773093205586852281989095832718586711802332595251072220032029846195189676026260605198977294380817877532759426557768078860163274145878332404258531245748591785784732434092195479770525481182815991797959825445637531042041590611915627213811517825520630848877424983543969674297016002608547715519350568204779042177473285067882211063589224482812938087537556266733962298371253557488669907498202166954216996752726405369916819110824141254269240923809780103852072731728780585669680264810684354097106594938306148015694140288412584934322450220045927342286585818050261340652821302794356397253238260769202499770588659806660140473202066417966673912609639439160027102210101993702837140062159911232700217576203854458672769125159295245759720586896200403026721146586614053545788918421075536183109733062570888899435174093277080789621706770150853469920781327693942173755821341587589068464271704145993398599584907221853546360342946465638677014265280400684536972824228071999739587025848471588041430734190747718105615643467867746521139598415490025819320522905508995637789651392767316376511141387782210136045154208122686266311800762358065599182356318289546167933132158219689983303226956912482902682742562956882890951086189973976745290171180581408168481701573057620693909613412402204890864681757904552161551141827082091941308643128752309062650317371816701150436066224566268088838544515729608051056365801398632700878033879524508762180929699446191226165581504065642383358322411410368865560901282689855037225200599153216302477288730118415860928953243258084527371265976649892602187894583446506824661341966822666806639851892328985271557775491086085232594029385055865408461916306201785026239230612752353078156174629354046816769484345684696264666983054596622557352665971692310835346574330345201496241524653879367068558567438787799759733850664614404312057082568243566243264611755532824513206338793606426398858650893765086655494206257608941685693604563423189826136067320528442662007709432015815995036214543984892269361804846433637715492042002645350444584698809568222374258222855882789968774096068488352877738383142437491050195487809265738698926470769757932536635347362729215411426989493149132973739280148089755991263176726327550836049914656986188523756036995278451253055657993910940418752312028175505678115214204318754518113471033399453567830296130632358712878292350291176995772240851095811885600382819425746733946859746508324478039308526824527611422610279849667882833495985958014136406544044904587156035768010650365190466997906703837332597903821402668562989161094199987830477977441561503597197569903604778604440785745969156513821971317777734960593729892222534437766021930681857290367110308403828050424387397529924995329948939921686795128871033695479567097677596871009758030829941780656916571404797474936364060896633110223920424892718562704497565532610704069917480058569081099089548670722155086358551588683391157320485122061215935067590527729478682246827509303529818583205679553217829813233875900878129084480249700435621359221893555421656631016079536513126020731283339909012365473738538062828153338806425078848354593519707062428992917258579885576722482493469235679741940285114466917413417283111876766818175178154974443863226366736031059196645787709286298438367096300335933725467680069467499909440931418935197607639590412522403641379231449900907670483429271445608187324020277292393554157047806016393560149763762182381033522232890923572325247499885048067389323525383500510263730424495499130718179426732948176129997648391216839998908481381658481720639121202961279302722168225045179081535042109498981072896761625693992602288769693937005187754145411851890095543833095500128837825669543033101870261359674246173474451228851808299126983017321230451884981315322155989426954244248673352579392307130099271620208255400787072330291414290702789609332401962725750210933255324797504516682254234045089348533324403979456676711927551725019997708120073528175550873441080737501788656523364635812866580670909840195177187069318284588267347979941912802844784345831364593611297335034936808260937486987558839356538174069247197363090244587530678334043312764406429614731545495099078344877149268175885053368093750005550979938553594526646815969088249884254428243750041746556055016888568949674554438216069776702697157696519299935296262333182662282071313712716657449342194593759461100188202234751465974594013604537342017369078900004007398193157716190449076813514282475822804094059889026022698518255021018566613789118518865859608084164256119389391264701034534732838558655538866932858543792259691591598582535802657208941556924876214292388229473818284170474930333525978514942722320793145416739308926751303841482388060395770004407198042502238999916987737347202218320069564664408185847098410976119863674399888748702288385011759248916565214546843591360560021875820058954120036097112067812578695283900444351683579270658485758109768365219991018268073673245141452415153257605271035668837906171755807778795902163789814583104706779368230557138443440606785024625551792656071322197883437365090995952783614348640636205281691939705970217021667929894789600090514708714961369322666305228197508897774024661140458911672537766440222671471229951151624033617881679464177246524344329265010491386519425837542838886652005593924469815109793867033638413339131777000951938840890851243026333877482047177068521520544305276389089112946918609981082936282961399989478134865584383041240801873372522978899733132202333335987926642791396387737460062342731173436754915777886939051823043272012214390567646298815125607368226168423465650669620628282859526350836831070319248452496846476074443081172225109466966238064479543952636729745422601763049244880363951554887868547504711176462185190973960030994451631839790904451546992926093730097537412791241442962734438292246577722247574954339022031246782698069255135790093514932928713132636296283824008266832812586268454522044334878454397088449487448684427415958411238210941094006226613223371481809171527041133037308679802333566255552440291287322458475809170568522887554612352531686985995739790461654054890515084932431410095449297397334371300261611842343335002853735931084493419009859313463150746745937117993181979237854420065153129725284950418550289719097671413347458337380367124698634870313774680629978154230863821318174197007261464601533093656004192580013539666996526642684130218028293355797487475150542981549502578133197157285640759714023684275189549422742879177088739931596862486920921838596493421040431594601794077020970428521385813104989350571619913186328653424264834109846015474715734651184107559529340562123342071075931760092972222917153919505120979479996210276995493277547148424188113124421851635354366780917880121039406318342668232723614810087913563184193944074400000020651241097090115446220825337562270086194397603167464030037171560664411210284016084866369808922429203707401145416737524009418498819459380189832249442354578023256629134645025981931351423342611135080339166792819794476094517020997632103158198364641168737218921911389876768461303546227036899870881483511952646784326359096061070739854717639472509669848383820755259857413438295366884308513205076426798185817815788056573628577324171420253648601799962441876999872888804170580893843687132338423914822285568896284471765223814674175029590016487790058849831286477480407475595110497851792057602582603288109754011617841039164041788939682140507881575497413757336997711464163036851800068102118379858493913037721693270703130811009983095221159466631384296982518861383773854535925194635985429767708644654123929591836266094263942708064706075219923980783237358798820516481950692318906711800446498751709909979900020671710215406281991004707258633142090505396170787878142555678201300875442645229957683266757709158189715737432850344877702847733425342431295550047738114568208344247343496544929502270432466561338343828440563277268125158467734124526783241545350253573063926687226489187301386880367871743773831272945217558791867709670520632159570091273556679942194188558690863824371652669539531915581994312990167794769961244737657221122396671143145348339888308788106472726956314213678731306378350284933844004198724531538225392232209225298926342191000074318091592696527655035644027580633217085239808870166459729569875652231485870496109437295505607599301574917545303951011217758746262472258090053525770922187145661490148423928147902289750267060551777528126663244728440341531399236037845248645045749494529414359698587668031857404946489919370523756221679157359175122237772519306540269608674683717879240004803893267340482396305758047458143591664086334293012096942379962669398733948440446637417238944756499755791140482728310365361208405057637360065404060663154368075449918453718779613880795113316906626929645900669151442129735202430154440704000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2709
    self assert:(nrDiv * 1099511627776 = nr).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2710
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2711
    divMod := nr divMod: 1099511627776.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2712
    self assert:((divMod at:1) = nrDiv).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2713
    self assert:((divMod at:2) = 0).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2714
    
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2715
    divMod := nr divMod: 1099511627775.
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2716
    self assert:((divMod at:1) = (nr // 1099511627775)).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2717
    self assert:((divMod at:2) = (nr \\ 1099511627775)).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2718
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2719
    self assert:((divMod at:1) * 1099511627775 + (divMod at:2) = nr).
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2720
    
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2721
    "
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2722
     self basicNew testLargeDivision3
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2723
    "
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2724
!
d8800e68af7a #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  2725
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2726
testLargeDivision4
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2727
    self assert:(9000000000 \\ 4000000000)    = (900 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2728
    self assert:(-9000000000 \\ 4000000000)   = (-900 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2729
    self assert:(9000000000 \\ -4000000000)   = (900 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2730
    self assert:(-9000000000 \\ -4000000000)  = (-900 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2731
    self assert:(16000000000 \\ 4000000000)   = (1600 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2732
    self assert:(-16000000000 \\ 4000000000)  = (-1600 \\ 400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2733
    self assert:(16000000000 \\ -4000000000)  = (1600 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2734
    self assert:(-16000000000 \\ -4000000000) = (-1600 \\ -400 * 10000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2735
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2736
    self assert:(9000000000000000000 \\ 4000000000000000000)    = (900 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2737
    self assert:(-9000000000000000000 \\ 4000000000000000000)   = (-900 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2738
    self assert:(9000000000000000000 \\ -4000000000000000000)   = (900 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2739
    self assert:(-9000000000000000000 \\ -4000000000000000000)  = (-900 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2740
    self assert:(16000000000000000000 \\ 4000000000000000000)   = (1600 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2741
    self assert:(-16000000000000000000 \\ 4000000000000000000)  = (-1600 \\ 400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2742
    self assert:(16000000000000000000 \\ -4000000000000000000)  = (1600 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2743
    self assert:(-16000000000000000000 \\ -4000000000000000000) = (-1600 \\ -400 * 10000000000000000).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2744
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2745
    self assert:(9000000000 \\ 7) = 5.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2746
    self assert:(-9000000000 \\ 7) = 2.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2747
    self assert:(9000000000 \\ -7) = -2.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2748
    self assert:(-9000000000 \\ -7) = -5.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2749
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2750
    self assert:(900 rem: 400) = 100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2751
    self assert:(-900 rem: 400) = -100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2752
    self assert:(900 rem: -400) = 100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2753
    self assert:(-900 rem: -400) = -100.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2754
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2755
    self assert:(9000000000 rem: 4000000000) = 1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2756
    self assert:(-9000000000 rem: 4000000000) = -1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2757
    self assert:(9000000000 rem: -4000000000) = 1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2758
    self assert:(-9000000000 rem: -4000000000) = -1000000000.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2759
    
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2760
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2761
     self basicNew testLargeDivision4
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2762
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2763
!
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2764
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2765
testLargeDivision5
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2766
    self assert:(9000000000 quo: 4000000000)    = ((900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2767
    self assert:(-9000000000 quo: 4000000000)   = ((-900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2768
    self assert:(9000000000 quo: -4000000000)   = ((900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2769
    self assert:(-9000000000 quo: -4000000000)  = ((-900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2770
    self assert:(16000000000 quo: 4000000000)   = ((1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2771
    self assert:(-16000000000 quo: 4000000000)  = ((-1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2772
    self assert:(16000000000 quo: -4000000000)  = ((1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2773
    self assert:(-16000000000 quo: -4000000000) = ((-1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2774
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2775
    self assert:(9000000000000000000 quo: 4000000000000000000)    = ((900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2776
    self assert:(-9000000000000000000 quo: 4000000000000000000)   = ((-900 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2777
    self assert:(9000000000000000000 quo: -4000000000000000000)   = ((900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2778
    self assert:(-9000000000000000000 quo: -4000000000000000000)  = ((-900 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2779
    self assert:(16000000000000000000 quo: 4000000000000000000)   = ((1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2780
    self assert:(-16000000000000000000 quo: 4000000000000000000)  = ((-1600 quo: 400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2781
    self assert:(16000000000000000000 quo: -4000000000000000000)  = ((1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2782
    self assert:(-16000000000000000000 quo: -4000000000000000000) = ((-1600 quo: -400) ).
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2783
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2784
    self assert:(9000000000 quo: 7) = 1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2785
    self assert:(-9000000000 quo: 7) = -1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2786
    self assert:(9000000000 quo: -7) = -1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2787
    self assert:(-9000000000 quo: -7) = 1285714285.
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2788
    
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2789
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2790
     self basicNew testLargeDivision5
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2791
    "
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2792
!
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2793
1317
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2794
testLargeDivision6
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2795
    |t|
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2796
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2797
    t := 20 factorial.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2798
    self assert:(t = 2432902008176640000).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2799
    t := t / 20.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2800
    self assert:(t = 19 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2801
    self assert:(t = 121645100408832000).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2802
    
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2803
    t := t / 19.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2804
    self assert:(t = 18 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2805
    self assert:(t = 6402373705728000).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2806
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2807
    t := t / 18.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2808
    self assert:(t = 17 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2809
    self assert:(t = 355687428096000).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2810
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2811
    t := t / 17.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2812
    self assert:(t = 16 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2813
    self assert:(t = 20922789888000).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2814
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2815
    t := t / 16.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2816
    self assert:(t = 15 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2817
    self assert:(t = 1307674368000).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2818
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2819
    t := t / 15.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2820
    self assert:(t = 14 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2821
    self assert:(t = 87178291200).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2822
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2823
    t := t / 14.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2824
    self assert:(t = 13 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2825
    self assert:(t = 6227020800).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2826
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2827
    t := t / 13.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2828
    self assert:(t = 12 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2829
    self assert:(t = 479001600).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2830
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2831
    t := t / 12.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2832
    self assert:(t = 11 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2833
    self assert:(t = 39916800).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2834
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2835
    t := t / 11.
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2836
    self assert:(t = 10 factorial).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2837
    self assert:(t = 3628800).
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2838
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2839
    "
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2840
     self basicNew testLargeDivision6
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2841
    "
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2842
!
2efc23013a7b #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1316
diff changeset
  2843
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2844
testLargeIntegerHelpers
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2845
    |t1 t2|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2846
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2847
    "/ mul2
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2848
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2849
    t1 := 16r12345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2850
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2851
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2852
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2853
    t1 := 16r1234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2854
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2855
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2856
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2857
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2858
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2859
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2860
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2861
    t1 := 16r12345678901234567890123456789012345678901234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2862
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2863
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2864
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2865
    t1 := 10000 factorial.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2866
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2867
    self assert:(t2 mul2 = (t1 * 2)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2868
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2869
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2870
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2871
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2872
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2873
"/    t1 := 1000 factorial.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2874
"/    t := Time millisecondsToRun:[ 100000 timesRepeat:[ t1 mul2. ] ].
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2875
"/    Transcript showCR:t.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2876
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2877
    "/ div2
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2878
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2879
    t1 := 16r12345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2880
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2881
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2882
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2883
    "/ do not compare t2 = t1 // x, because t2 may be unnormalized
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2884
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2885
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2886
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2887
    self assert:(t2 printStringRadix:16) = ((t1 // 4) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2888
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2889
    self assert:(t2 printStringRadix:16) = ((t1 // 8) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2890
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2891
    self assert:(t2 printStringRadix:16) = ((t1 // 16) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2892
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2893
    self assert:(t2 printStringRadix:16) = ((t1 // 32) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2894
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2895
    self assert:(t2 printStringRadix:16) = ((t1 // 64) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2896
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2897
    self assert:(t2 printStringRadix:16) = ((t1 // 128) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2898
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2899
    self assert:(t2 printStringRadix:16) = ((t1 // 256) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2900
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2901
    self assert:(t2 printStringRadix:16) = ((t1 // 512) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2902
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2903
    self assert:(t2 printStringRadix:16) = ((t1 // 1024) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2904
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2905
    t1 := 16r1234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2906
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2907
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2908
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2909
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2910
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2911
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2912
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2913
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2914
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2915
    t1 := 16r12345678901234567890123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2916
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2917
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2918
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2919
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2920
    self assert:(t2 printStringRadix:16) = ((t1 // 4) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2921
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2922
    self assert:(t2 printStringRadix:16) = ((t1 // 8) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2923
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2924
    self assert:(t2 printStringRadix:16) = ((t1 // 16) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2925
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2926
    t1 := 10000 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2927
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2928
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2929
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2930
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2931
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2932
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2933
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2934
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2935
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2936
    t1 := 12345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2937
    t2 := t1 divMod:1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2938
    self assert:(t2 at:1) = 12345678901234567.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2939
    self assert:(t2 at:2) = 890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2940
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  2941
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2942
    "
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2943
     self basicNew testLargeIntegerHelpers
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2944
    "
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2945
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2946
    "Modified: / 20.5.1999 / 09:41:19 / cg"
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2947
!
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2948
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2949
testLargeIntegerHelpers2
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2950
    |t1 r|
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2951
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2952
    "/ absSubtract:
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2953
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2954
    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
  2955
    r := t1 absDestructiveSubtract:16r00ffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2956
    self assert:(t1 digitBytes = #[16r01 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2957
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2958
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2959
    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
  2960
    r := t1 absDestructiveSubtract:16r010000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2961
    self assert:(t1 digitBytes = #[16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 16r00 ]).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2962
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2963
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2964
    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
  2965
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2966
    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
  2967
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2968
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2969
    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
  2970
    r := t1 absDestructiveSubtract:16r01000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2971
    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
  2972
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2973
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2974
    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
  2975
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2976
    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
  2977
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2978
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2979
    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
  2980
    r := t1 absDestructiveSubtract:16r0100000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2981
    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
  2982
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2983
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2984
    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
  2985
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2986
    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
  2987
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2988
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2989
    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
  2990
    r := t1 absDestructiveSubtract:16r010000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2991
    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
  2992
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2993
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2994
    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
  2995
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2996
    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
  2997
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  2998
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  2999
    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
  3000
    r := t1 absDestructiveSubtract:16r01000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3001
    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
  3002
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3003
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  3004
    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
  3005
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3006
    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
  3007
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3008
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  3009
    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
  3010
    r := t1 absDestructiveSubtract:16r0100000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3011
    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
  3012
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3013
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  3014
    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
  3015
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3016
    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
  3017
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3018
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  3019
    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
  3020
    r := t1 absDestructiveSubtract:16r010000000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3021
    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
  3022
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3023
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  3024
    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
  3025
    r := t1 absDestructiveSubtract:16r00ffffffffffffffffffffffffffffff.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3026
    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
  3027
    self assert:(r == true).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3028
1313
fa1a08692b4d #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1312
diff changeset
  3029
    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
  3030
    r := t1 absDestructiveSubtract:16r01000000000000000000000000000000.
1312
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3031
    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
  3032
    self assert:(r == false).
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3033
    "
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3034
     self basicNew testLargeIntegerHelpers2
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3035
    "
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3036
!
b7172ac2c2bd #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1307
diff changeset
  3037
1314
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3038
testLargeIntegerHelpers3
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3039
    "/ absDivMod:
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3040
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3041
     self assert:(9000000000000000000 absDivMod: 4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3042
     self assert:(-9000000000000000000 absDivMod: 4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3043
     self assert:(9000000000000000000 absDivMod: -4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3044
     self assert:(-9000000000000000000 absDivMod: -4000) = #(2250000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3045
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3046
     self assert:(9000000000000000001 absDivMod: 4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3047
     self assert:(-9000000000000000001 absDivMod: 4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3048
     self assert:(9000000000000000001 absDivMod: -4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3049
     self assert:(-9000000000000000001 absDivMod: -4000) = #(2250000000000000 1).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3050
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3051
     self assert:(9000000000000000000 absDivMod: 40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3052
     self assert:(-9000000000000000000 absDivMod: 40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3053
     self assert:(9000000000000000000 absDivMod: -40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3054
     self assert:(-9000000000000000000 absDivMod: -40000) = #(225000000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3055
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3056
     self assert:(9000000000000000000 absDivMod: 400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3057
     self assert:(-9000000000000000000 absDivMod: 400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3058
     self assert:(9000000000000000000 absDivMod: -400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3059
     self assert:(-9000000000000000000 absDivMod: -400000) = #(22500000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3060
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3061
     self assert:(9000000000000000000 absDivMod: 4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3062
     self assert:(-9000000000000000000 absDivMod: 4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3063
     self assert:(9000000000000000000 absDivMod: -4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3064
     self assert:(-9000000000000000000 absDivMod: -4000000) = #(2250000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3065
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3066
     self assert:(9000000000000000000 absDivMod: 40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3067
     self assert:(-9000000000000000000 absDivMod: 40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3068
     self assert:(9000000000000000000 absDivMod: -40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3069
     self assert:(-9000000000000000000 absDivMod: -40000000) = #(225000000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3070
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3071
     self assert:(9000000000000000000 absDivMod: 400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3072
     self assert:(-9000000000000000000 absDivMod: 400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3073
     self assert:(9000000000000000000 absDivMod: -400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3074
     self assert:(-9000000000000000000 absDivMod: -400000000) = #(22500000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3075
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3076
     self assert:(9000000000000000000 absDivMod: 4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3077
     self assert:(-9000000000000000000 absDivMod: 4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3078
     self assert:(9000000000000000000 absDivMod: -4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3079
     self assert:(-9000000000000000000 absDivMod: -4000000000) = #(2250000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3080
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3081
     self assert:(9000000000000000000 absDivMod: 40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3082
     self assert:(-9000000000000000000 absDivMod: 40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3083
     self assert:(9000000000000000000 absDivMod: -40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3084
     self assert:(-9000000000000000000 absDivMod: -40000000000) = #(225000000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3085
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3086
     self assert:(9000000000000000000 absDivMod: 400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3087
     self assert:(-9000000000000000000 absDivMod: 400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3088
     self assert:(9000000000000000000 absDivMod: -400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3089
     self assert:(-9000000000000000000 absDivMod: -400000000000) = #(22500000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3090
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3091
     self assert:(9000000000000000000 absDivMod: 4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3092
     self assert:(-9000000000000000000 absDivMod: 4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3093
     self assert:(9000000000000000000 absDivMod: -4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3094
     self assert:(-9000000000000000000 absDivMod: -4000000000000) = #(2250000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3095
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3096
     self assert:(9000000000000000000 absDivMod: 40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3097
     self assert:(-9000000000000000000 absDivMod: 40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3098
     self assert:(9000000000000000000 absDivMod: -40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3099
     self assert:(-9000000000000000000 absDivMod: -40000000000000) = #(225000 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3100
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3101
     self assert:(9000000000000000000 absDivMod: 400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3102
     self assert:(-9000000000000000000 absDivMod: 400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3103
     self assert:(9000000000000000000 absDivMod: -400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3104
     self assert:(-9000000000000000000 absDivMod: -400000000000000) = #(22500 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3105
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3106
     self assert:(9000000000000000000 absDivMod: 4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3107
     self assert:(-9000000000000000000 absDivMod: 4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3108
     self assert:(9000000000000000000 absDivMod: -4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3109
     self assert:(-9000000000000000000 absDivMod: -4000000000000000) = #(2250 0).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3110
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3111
     self assert:(9000000000000000000 absDivMod: 4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3112
     self assert:(-9000000000000000000 absDivMod: 4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3113
     self assert:(9000000000000000000 absDivMod: -4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3114
     self assert:(-9000000000000000000 absDivMod: -4000000000000000000) = #(2 1000000000000000000).
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3115
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3116
    "
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3117
     self basicNew testLargeIntegerHelpers3
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3118
    "
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3119
!
b17d08bc2aef #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  3120
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  3121
testLargeMultiplication
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3122
    |t1 t2|
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  3123
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3124
    "multiplication"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3125
    t1 := 100.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3126
    self assert:(t1 * t1 == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3127
    self assert:((t1 perform:'*' asSymbol with:t1) == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3128
    self assert:((t1 * t1) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3129
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3130
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3131
    t1 := 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3132
    self assert:(t1 * t1 == 1000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3133
    self assert:((t1 perform:'*' asSymbol with:t1) == 1000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3134
    self assert:((t1 * t1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3135
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3136
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3137
    t1 := 10000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3138
    self assert:(t1 * t1 == 100000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3139
    self assert:((t1 perform:'*' asSymbol with:t1) == 100000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3140
    self assert:((t1 * t1) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3141
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '100000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3142
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3143
    t1 := 100000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3144
    SmallInteger maxBytes == 4 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3145
	self assert:(t1 * t1 = 10000000000).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3146
	self assert:((t1 perform:'*' asSymbol with:t1) = 10000000000).
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3147
    ].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3148
    SmallInteger maxBytes == 8 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3149
	self assert:(t1 * t1 == 10000000000).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3150
	self assert:((t1 perform:'*' asSymbol with:t1) == 10000000000).
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3151
    ].
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
  3152
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3153
    self assert:((t1 * t1) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3154
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3155
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3156
    t1 := 1000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3157
    self assert:((t1 * t1) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3158
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3159
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3160
    t1 := 10000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3161
    self assert:((t1 * t1) printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3162
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '100000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3163
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3164
    t1 := 100000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3165
    self assert:((t1 * t1) printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3166
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3167
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3168
    t1 := 1000000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3169
    self assert:((t1 * t1) printString = '1000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3170
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  3171
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3172
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3173
    "Large * SmallInt multiplication"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3174
    self assert:(10 factorial printString = '3628800').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3175
    self assert:(20 factorial printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3176
    self assert:(100 factorial printString = '93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3177
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3178
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3179
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3180
    t2 := 100000000000000000.                   "/ large on 32bit; small on 64bt machines
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3181
    self assert:(t1 * t2) = 10000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3182
    self assert:(t2 * t1) = 10000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3183
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3184
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3185
    t2 := 1000000000000000000.                  "/ large on 32bit; small on 64bt machines
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3186
    self assert:(t1 * t2) = 100000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3187
    self assert:(t2 * t1) = 100000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3188
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3189
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3190
    t2 := 10000000000000000000.                 "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3191
    self assert:(t1 * t2) = 1000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3192
    self assert:(t2 * t1) = 1000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3193
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3194
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3195
    t2 := 100000000000000000000.                "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3196
    self assert:(t1 * t2) = 10000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3197
    self assert:(t2 * t1) = 10000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3198
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3199
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3200
    t2 := 1000000000000000000000.               "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3201
    self assert:(t1 * t2) = 100000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3202
    self assert:(t2 * t1) = 100000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3203
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3204
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3205
    t2 := 10000000000000000000000.              "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3206
    self assert:(t1 * t2) = 1000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3207
    self assert:(t2 * t1) = 1000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3208
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3209
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3210
    t2 := 100000000000000000000000.             "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3211
    self assert:(t1 * t2) = 10000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3212
    self assert:(t2 * t1) = 10000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3213
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3214
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3215
    t2 := 1000000000000000000000000.            "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3216
    self assert:(t1 * t2) = 100000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3217
    self assert:(t2 * t1) = 100000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3218
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3219
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3220
    t2 := 10000000000000000000000000.           "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3221
    self assert:(t1 * t2) = 1000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3222
    self assert:(t2 * t1) = 1000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3223
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3224
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3225
    t2 := 100000000000000000000000000.          "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3226
    self assert:(t1 * t2) = 10000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3227
    self assert:(t2 * t1) = 10000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3228
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3229
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3230
    t2 := 1000000000000000000000000000.         "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3231
    self assert:(t1 * t2) = 100000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3232
    self assert:(t2 * t1) = 100000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3233
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3234
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3235
    t2 := 10000000000000000000000000000.        "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3236
    self assert:(t1 * t2) = 1000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3237
    self assert:(t2 * t1) = 1000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3238
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3239
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3240
    t2 := 100000000000000000000000000000.       "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3241
    self assert:(t1 * t2) = 10000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3242
    self assert:(t2 * t1) = 10000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3243
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3244
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3245
    t2 := 1000000000000000000000000000000.      "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3246
    self assert:(t1 * t2) = 100000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3247
    self assert:(t2 * t1) = 100000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3248
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3249
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3250
    t2 := 10000000000000000000000000000000.     "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3251
    self assert:(t1 * t2) = 1000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3252
    self assert:(t2 * t1) = 1000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3253
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3254
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3255
    t2 := 100000000000000000000000000000000.    "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3256
    self assert:(t1 * t2) = 10000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3257
    self assert:(t2 * t1) = 10000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3258
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  3259
    "Large * Large multiplication"
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3260
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3261
    self assert:((16r3FFF * 16r3FFF) hexPrintString = 'FFF8001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3262
    self assert:((16r7FFF * 16r7FFF) hexPrintString = '3FFF0001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3263
    self assert:((16rFFFF * 16rFFFF) hexPrintString = 'FFFE0001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3264
    self assert:((16r3FFFFF * 16r3FFFFF) hexPrintString = 'FFFFF800001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3265
    self assert:((16r7FFFFF * 16r7FFFFF) hexPrintString = '3FFFFF000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3266
    self assert:((16rFFFFFF * 16rFFFFFF) hexPrintString = 'FFFFFE000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3267
    self assert:((16r3FFFFFFF * 16r3FFFFFFF) hexPrintString = 'FFFFFFF80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3268
    self assert:((16r7FFFFFFF * 16r7FFFFFFF) hexPrintString = '3FFFFFFF00000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3269
    self assert:((16rFFFFFFFF * 16rFFFFFFFF) hexPrintString = 'FFFFFFFE00000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3270
    self assert:((16r3FFFFFFFFF * 16r3FFFFFFFFF) hexPrintString = 'FFFFFFFFF8000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3271
    self assert:((16r7FFFFFFFFF * 16r7FFFFFFFFF) hexPrintString = '3FFFFFFFFF0000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3272
    self assert:((16rFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFE0000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3273
    self assert:((20 factorial * 20 factorial) printString = '5919012181389927685417441689600000000').
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3274
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3275
    self assert:((16rFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3276
    self assert:((16rFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFF0000000001').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3277
    self assert:((t1 := 16rFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFF0000000001').
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3278
    self assert:((16rFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFFFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3279
    self assert:((16rFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFFFFFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3280
    self assert:((16rFFFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFEFFFFFFFFFFFF0000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3281
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3282
    self assert:((16rFFFFFFFFFFFF * 16rFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFE000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3283
    self assert:((16rFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFE00000000000001').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3284
    self assert:((t2 := (t1 := 16rFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFF) hexPrintString) = 'FFFFFFFFFFFFFFFE0000000000000001').
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3285
    self assert:((16rFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFE0000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3286
    self assert:((16rFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFFFE000000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3287
    self assert:((16rFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFFFFFE00000000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3288
    self assert:((16rFFFFFFFFFFFFFFFFFFFFFF * 16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFFFFFFFFFFFFFFFFFFFFE0000000000000000000001').
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3289
1024
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3290
    t1 := 699697179634740272935560322271216335182775596927422865716399200802062765682314102885264570100200211251370690926108604161579425545019863369232209949922751354278329212124724267803033599595114924195721823679025053720850308776953208134469115885358619139670731195605237506312288263327925364912720266772715929600.
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3291
    self assert:(t1 printString = '699697179634740272935560322271216335182775596927422865716399200802062765682314102885264570100200211251370690926108604161579425545019863369232209949922751354278329212124724267803033599595114924195721823679025053720850308776953208134469115885358619139670731195605237506312288263327925364912720266772715929600').
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3292
    self assert:((t1 * t1) = 489576143188809998144298426641311496989165214458056165805143410866108690058261346129614030084813851082564698610174813898740525406243367146120734370570458429364167811695064904353093506532695086211301649001517008746471464304183710723162864634442619484210170532881759249266026059786349673031239277666195699357198366128286910123306594912484590029738722281929300359929462301099981920256369394887701755497894820998573896950238852994224811101315810851671448056042419257789317787959570728520197146733902575090480065597582292177085754523686580725860228636039424698638422538988050350726807943014483010988455057592156160000).
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3293
    self assert:((t1 * t1) printString = '489576143188809998144298426641311496989165214458056165805143410866108690058261346129614030084813851082564698610174813898740525406243367146120734370570458429364167811695064904353093506532695086211301649001517008746471464304183710723162864634442619484210170532881759249266026059786349673031239277666195699357198366128286910123306594912484590029738722281929300359929462301099981920256369394887701755497894820998573896950238852994224811101315810851671448056042419257789317787959570728520197146733902575090480065597582292177085754523686580725860228636039424698638422538988050350726807943014483010988455057592156160000').
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  3294
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3295
    #(
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3296
	16rFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3297
	16rFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3298
	16rFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3299
	16rFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3300
	16rFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3301
	16rFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3302
	16rFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3303
	16rFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3304
	16rFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3305
	16rFFFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3306
	16rFFFFFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3307
	16rFFFFFFFFFFFFFFFFFFFFFFFF
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3308
    ) do:[:eachFactor1 |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3309
	#(
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3310
	    16rFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3311
	    16rFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3312
	    16rFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3313
	    16rFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3314
	    16rFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3315
	    16rFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3316
	    16rFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3317
	    16rFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3318
	    16rFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3319
	    16rFFFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3320
	    16rFFFFFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3321
	    16rFFFFFFFFFFFFFFFFFFFFFFFF
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3322
	) do:[:eachFactor2 |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3323
	    |t3|
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3324
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3325
	    t1 := (eachFactor1 * eachFactor2).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3326
	    t2 := (eachFactor2 * eachFactor1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3327
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3328
	    self assert:(t1 = t2).
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3329
t1 = 20203181441155852828228393631745 ifTrue:[
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3330
 eachFactor1 = 1099511627775 ifTrue:[
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3331
self halt
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3332
]].
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3333
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3334
	    self assert:(t1 / eachFactor1) = eachFactor2.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3335
	    self assert:(t1 / eachFactor2) = eachFactor1.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3336
	    t3 := (eachFactor1 asLargeInteger * eachFactor2 asLargeInteger).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3337
	    self assert: t1 = t3.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3338
	].
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3339
    ].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3340
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3341
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3342
     self basicNew testLargeMultiplication
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3343
    "
10
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
  3344
1025
1d694c9fd79d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
  3345
    "Modified: / 02-12-2013 / 15:45:39 / cg"
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3346
!
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3347
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3348
testLargeMultiplication2
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3349
    "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
  3350
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3351
    |n n2|
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3352
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3353
    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
  3354
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3355
    n := 1000 factorial.
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3356
    1000 to:2 by:-1 do:[:d |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3357
	n2 := n / d.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3358
	self assert:((d-1) factorial = n2).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3359
	(Integer readFrom:n2 printString) * d = n.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  3360
	n := n2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3361
    ].
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3362
!
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  3363
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3364
testLargeMultiplicationHelpers1
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3365
    |t1 t2 r|
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3366
1030
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3367
    t1 := LargeInteger digitBytes:#[ 16r00 16rE1 16rF5 16r05 ].
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3368
    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
  3369
    r := t1 absMul:t2.
1031
247174c321e3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1030
diff changeset
  3370
    self assert:(r printString = '1000000000000000000000000000000').
247174c321e3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1030
diff changeset
  3371
    self assert:(r hexPrintString = 'C9F2C9CD04674EDEA40000000').
1030
2115331b1845 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1029
diff changeset
  3372
1032
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3373
    t1 := LargeInteger digitBytes:#[ 16r00 16rE1 16rF5 16r05 ].
1034
19a7bdfbe204 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1033
diff changeset
  3374
    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
  3375
    r := t1 absMul:t2.
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3376
    self assert:(r printString = '100000000000000000000000000000').
1033
5ec3c1764111 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1032
diff changeset
  3377
    self assert:(r hexPrintString = '1431E0FAE6D7217CAA0000000').
1032
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3378
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3379
    "/ -----
ceff88dc3e56 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1031
diff changeset
  3380
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3381
    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
  3382
    t2 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 0 0 0 0].
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3383
    r := t1 absMul:t2.
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3384
    self assert:(r hexPrintString = 'FFFFFFFEFFFFFFFF00000001').
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3385
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3386
    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
  3387
    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
  3388
    r := t1 absMul:t2.
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3389
    self assert:(r printString = '20282409603633223678774030106625').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3390
    self assert:(r hexPrintString = 'FFFFFFFFFEFFFFFF0000000001').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3391
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3392
    t1 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3393
    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
  3394
    r := t1 absMul:t2.
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3395
    self assert:(r printString = '5192296858534809181504947642957825').
1029
daa98cf43cf0 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1028
diff changeset
  3396
    self assert:(r hexPrintString = 'FFFFFFFFFFFEFFFF000000000001').
1028
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3397
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3398
    t1 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF].
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3399
    t2 := LargeInteger digitBytes:#[ 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 0].
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3400
    r := t1 absMul:t2.
717c303547ca class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1027
diff changeset
  3401
    self assert:(r printString = '1329227995784915854385005392532865025').
1029
daa98cf43cf0 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1028
diff changeset
  3402
    self assert:(r hexPrintString = 'FFFFFFFFFFFFFEFF00000000000001').
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3403
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3404
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3405
     self basicNew testLargeMultiplicationHelpers1
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3406
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3407
1033
5ec3c1764111 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1032
diff changeset
  3408
    "Modified: / 02-12-2013 / 18:48:00 / cg"
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3409
!
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3410
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3411
testLargeMultiplicationHelpers2
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3412
    |t1 t2 r|
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3413
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3414
    "/ testing internal multiplication method
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3415
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3416
    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
  3417
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3418
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3419
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3420
    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
  3421
    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
  3422
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3423
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3424
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3425
    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
  3426
    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
  3427
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3428
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3429
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3430
    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
  3431
    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
  3432
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3433
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3434
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3435
    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
  3436
    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
  3437
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3438
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  3439
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3440
    "/ --------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3441
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3442
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3443
    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
  3444
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3445
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3446
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3447
    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
  3448
    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
  3449
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3450
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3451
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3452
    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
  3453
    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
  3454
    r := t1 absMul:t2.
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3455
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3456
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3457
    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
  3458
    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
  3459
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3460
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3461
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3462
    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
  3463
    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
  3464
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3465
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3466
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3467
    "/ --------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3468
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3469
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3470
    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
  3471
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3472
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3473
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3474
    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
  3475
    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
  3476
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3477
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3478
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3479
    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
  3480
    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
  3481
    r := t1 absMul:t2.
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3482
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3483
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3484
    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
  3485
    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
  3486
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3487
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3488
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3489
    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
  3490
    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
  3491
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3492
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3493
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3494
    "/ --------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3495
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3496
    t1 := LargeInteger digitBytes:#[ 1 2 3 4 5 6 7 8].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3497
    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
  3498
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3499
    self assert:(r hexPrintString = '100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3500
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3501
    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
  3502
    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
  3503
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3504
    self assert:(r hexPrintString = '12100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3505
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3506
    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
  3507
    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
  3508
    r := t1 absMul:t2.
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3509
    self assert:(r hexPrintString = '1412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3510
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3511
    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
  3512
    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
  3513
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3514
    self assert:(r hexPrintString = '161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3515
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3516
    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
  3517
    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
  3518
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3519
    self assert:(r hexPrintString = '18161412100E0C0A08060402').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3520
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3521
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3522
    "/ ==================0
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3523
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3524
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3525
    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
  3526
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3527
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3528
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3529
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3530
    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
  3531
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3532
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3533
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3534
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3535
    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
  3536
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3537
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3538
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3539
    t1 := LargeInteger digitBytes:#[ 128 1 1 1 1 1 1 1].
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3540
    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
  3541
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3542
    self assert:(r hexPrintString = '202020202020300').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3543
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3544
    "/ ---------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3545
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3546
    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
  3547
    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
  3548
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3549
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3550
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3551
    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
  3552
    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
  3553
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3554
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3555
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3556
    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
  3557
    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
  3558
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3559
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3560
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3561
    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
  3562
    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
  3563
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3564
    self assert:(r hexPrintString = '20202020202030000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3565
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3566
    "/ ---------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3567
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3568
    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
  3569
    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
  3570
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3571
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3572
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3573
    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
  3574
    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
  3575
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3576
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3577
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3578
    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
  3579
    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
  3580
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3581
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3582
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3583
    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
  3584
    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
  3585
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3586
    self assert:(r hexPrintString = '2020202020203000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3587
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3588
    "/ ---------
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3589
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3590
    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
  3591
    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
  3592
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3593
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3594
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3595
    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
  3596
    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
  3597
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3598
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3599
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3600
    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
  3601
    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
  3602
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3603
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3604
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3605
    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
  3606
    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
  3607
    r := t1 absMul:t2.
1026
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3608
    self assert:(r hexPrintString = '202020202020300000000').
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3609
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3610
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3611
     self basicNew testLargeMultiplicationHelpers2
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3612
    "
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3613
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3614
    "Modified: / 02-12-2013 / 15:45:39 / cg"
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3615
!
babb7ffa347e class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  3616
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3617
testLargeSubtraction1
336
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3618
    |a1 a2 a b1 b2 b c1 c2 c|
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3619
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3620
    "/ on 32bit machines - these lead to smallint overflow
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3621
    self assert:((2770568 + 2770568) printString = '5541136').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3622
    self assert:((2770568 - 2770568) printString = '0').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3623
    self assert:((2770568 negated + 2770568 negated) printString = '-5541136').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3624
    self assert:((5541136 negated - 2770568 negated) printString = '-2770568').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3625
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3626
    "Large - small subtraction"
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3627
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3628
    self assert:((2770568900 + 2770568900) printString = '5541137800').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3629
    self assert:((2770568900 - 2770568900) printString = '0').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3630
    self assert:((2770568900 negated + 2770568900 negated) printString = '-5541137800').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3631
    self assert:((5541137800 negated - 2770568900 negated) printString = '-2770568900').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3632
    self assert:((2770568900 negated - 5541137800 negated) printString = '2770568900').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3633
336
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3634
    a1 := -2770568900. a2 := 59049.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3635
    a := (a1 / a2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3636
    b1 := -5872025600. b2 := 59049.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3637
    b := (b1 / b2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3638
    c1 := 344606300. c2 := 6561.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3639
    c := (c1 / c2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3640
    self assert:(a - b closeTo: c).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3641
    self assert:((a - b) asFloat closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3642
    self assert:((a asFloat - b) closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3643
    self assert:((a - b asFloat) closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3644
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3645
    a := -10.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3646
    b := -12.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3647
    self assert:(a - b = 2).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3648
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3649
    a := -10000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3650
    b := -12000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3651
    self assert:(a - b = 2000000).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3652
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3653
    a := -100000000000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3654
    b := -120000000000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3655
    self assert:(a - b = 20000000000000).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  3656
337
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3657
    "smallInteger - largeInteger"
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3658
    self assert:(-1000000000 - -2000000000 = 1000000000).
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3659
    "largeInteger - smallInteger"
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3660
    self assert:(-2000000000 - -1000000000 = -1000000000).
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  3661
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3662
    a := 40 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3663
    b := 39 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3664
    self assert:(a - b + b = a).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  3665
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3666
    "
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3667
     self basicNew testLargeSubtraction1
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3668
    "
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3669
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3670
    "Modified: / 27.11.1999 / 16:41:54 / cg"
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3671
!
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  3672
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3673
testLargeSubtraction2
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3674
    "/ on 64bit machines - these lead to smallint overflow
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3675
    self assert:((16r3FFFFFFFFFFFFFFF negated - 1 - 1) printString = '-4611686018427387905').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3676
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3677
    "
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3678
     self basicNew testLargeSubtraction2
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3679
    "
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3680
!
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3681
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3682
testLiteralNumbers
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3683
    self assert:(self num_00000000000010000 hexPrintString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3684
    self assert:(self num_00000000000100000 hexPrintString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3685
    self assert:(self num_00000000001000000 hexPrintString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3686
    self assert:(self num_00000000010000000 hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3687
    self assert:(self num_00000000100000000 hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3688
    self assert:(self num_00000001000000000 hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3689
    self assert:(self num_00000010000000000 hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3690
    self assert:(self num_00000100000000000 hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3691
    self assert:(self num_00001000000000000 hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3692
    self assert:(self num_00010000000000000 hexPrintString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3693
    self assert:(self num_00100000000000000 hexPrintString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3694
    self assert:(self num_01000000000000000 hexPrintString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3695
    self assert:(self num_10000000000000000 hexPrintString = '10000000000000000').
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3696
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3697
    self assert:(self num_00000000000007FFF hexPrintString = '7FFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3698
    self assert:(self num_00000000000008000 hexPrintString = '8000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3699
    self assert:(self num_0000000000000FFFF hexPrintString = 'FFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3700
    self assert:(self num_000000000007FFFFF hexPrintString = '7FFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3701
    self assert:(self num_00000000000800000 hexPrintString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3702
    self assert:(self num_00000000000FFFFFF hexPrintString = 'FFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3703
    self assert:(self num_0000000007FFFFFFF hexPrintString = '7FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3704
    self assert:(self num_00000000080000000 hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3705
    self assert:(self num_000000000FFFFFFFF hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3706
    self assert:(self num_0000000FFFFFFFFFF hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3707
    self assert:(self num_00000FFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3708
    self assert:(self num_000FFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3709
    self assert:(self num_0FFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3710
    self assert:(self num_1FFFFFFFFFFFFFFFF hexPrintString = '1FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3711
    self assert:(self num_20000000000000000 hexPrintString = '20000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3712
    self assert:(self num_3FFFFFFFFFFFFFFFF hexPrintString = '3FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3713
    self assert:(self num_40000000000000000 hexPrintString = '40000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3714
    self assert:(self num_7FFFFFFFFFFFFFFFF hexPrintString = '7FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3715
    self assert:(self num_80000000000000000 hexPrintString = '80000000000000000').
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
  3716
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3717
    self assert:(self num_00000FFFFFFFFFFFE hexPrintString = 'FFFFFFFFFFFE').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3718
    self assert:(self num_00000FFFFFFFFFFFC hexPrintString = 'FFFFFFFFFFFC').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3719
    self assert:(self num_00000FFFFFFFFFFF8 hexPrintString = 'FFFFFFFFFFF8').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3720
    self assert:(self num_00000FFFFFFFFFFF0 hexPrintString = 'FFFFFFFFFFF0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3721
    self assert:(self num_00000FFFFFFFFFFE0 hexPrintString = 'FFFFFFFFFFE0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3722
    self assert:(self num_00000FFFFFFFFFFC0 hexPrintString = 'FFFFFFFFFFC0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3723
    self assert:(self num_00000FFFFFFFFFF80 hexPrintString = 'FFFFFFFFFF80').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3724
    self assert:(self num_00000FFFFFFFFFF00 hexPrintString = 'FFFFFFFFFF00').
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3725
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3726
    self assert:(self num_0000000000FFF0000 hexPrintString = 'FFF0000').
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
  3727
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3728
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3729
     self basicNew testLiteralNumbers
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3730
    "
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3731
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
  3732
    "Modified: / 4.6.1999 / 18:41:09 / cg"
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3733
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  3734
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3735
testModulu
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3736
    |a b op|
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3737
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3738
    op := #\\.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3739
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3740
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3741
    self assert:(-1 \\ 8 == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3742
    self assert:(a \\ 8 == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3743
    self assert:(-1 \\ b == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3744
    self assert:(a \\ b == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3745
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3746
    self assert:((-1 perform:op with: 8) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3747
    self assert:((a perform:op with: 8) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3748
    self assert:((-1 perform:op with: b) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3749
    self assert:((a perform:op with: b) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3750
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3751
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3752
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3753
    self assert:(1 \\ -8 == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3754
    self assert:(a \\ -8 == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3755
    self assert:(1 \\ b == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3756
    self assert:(a \\ b == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3757
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3758
    self assert:((1 perform:op with: -8) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3759
    self assert:((a perform:op with: -8) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3760
    self assert:((1 perform:op with: b) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3761
    self assert:((a perform:op with: b) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3762
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3763
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3764
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3765
    self assert:(-1 \\ -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3766
    self assert:(a \\ -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3767
    self assert:(-1 \\ b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3768
    self assert:(a \\ b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3769
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3770
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3771
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3772
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3773
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3774
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3775
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3776
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3777
    self assert:(1 \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3778
    self assert:(a \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3779
    self assert:(1 \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3780
    self assert:(a \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3781
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3782
    self assert:((1 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3783
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3784
    self assert:((1 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3785
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3786
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3787
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3788
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3789
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3790
    self assert:(-17 \\ 8 == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3791
    self assert:(a \\ 8 == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3792
    self assert:(-17 \\ b == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3793
    self assert:(a \\ b == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3794
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3795
    self assert:((-17 perform:op with: 8) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3796
    self assert:((a perform:op with: 8) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3797
    self assert:((-17 perform:op with: b) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3798
    self assert:((a perform:op with: b) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3799
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3800
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3801
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3802
    self assert:(17 \\ -8 == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3803
    self assert:(a \\ -8 == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3804
    self assert:(17 \\ b == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3805
    self assert:(a \\ b == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3806
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3807
    self assert:((17 perform:op with: -8) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3808
    self assert:((a perform:op with: -8) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3809
    self assert:((17 perform:op with: b) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3810
    self assert:((a perform:op with: b) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3811
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3812
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3813
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3814
    self assert:(-17 \\ -8 == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3815
    self assert:(a \\ -8 == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3816
    self assert:(-17 \\ b == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3817
    self assert:(a \\ b == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3818
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3819
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3820
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3821
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3822
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3823
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3824
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3825
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3826
    self assert:(17 \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3827
    self assert:(a \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3828
    self assert:(17 \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3829
    self assert:(a \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3830
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3831
    self assert:((17 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3832
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3833
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3834
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3835
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3836
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3837
    op := #rem:.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3838
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3839
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3840
    self assert:((-1 rem: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3841
    self assert:((a rem: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3842
    self assert:((-1 rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3843
    self assert:((a rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3844
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3845
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3846
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3847
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3848
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3849
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3850
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3851
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3852
    self assert:((1 rem: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3853
    self assert:((a rem: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3854
    self assert:((1 rem: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3855
    self assert:((a rem: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3856
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3857
    self assert:((1 perform:op with: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3858
    self assert:((a perform:op with: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3859
    self assert:((1 perform:op with: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3860
    self assert:((a perform:op with: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3861
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3862
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3863
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3864
    self assert:((-1 rem: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3865
    self assert:((a rem: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3866
    self assert:((-1 rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3867
    self assert:((a rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3868
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3869
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3870
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3871
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3872
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3873
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3874
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3875
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3876
    self assert:((1 rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3877
    self assert:((a rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3878
    self assert:((1 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3879
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3880
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3881
    self assert:((1 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3882
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3883
    self assert:((1 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3884
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3885
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3886
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3887
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3888
    self assert:((-17 rem: 8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3889
    self assert:((a rem: 8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3890
    self assert:((-17 rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3891
    self assert:((a rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3892
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3893
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3894
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3895
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3896
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3897
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3898
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3899
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3900
    self assert:((17 rem: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3901
    self assert:((a rem: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3902
    self assert:((17 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3903
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3904
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3905
    self assert:((17 perform:op with: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3906
    self assert:((a perform:op with: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3907
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3908
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3909
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3910
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3911
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3912
    self assert:((-17 rem: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3913
    self assert:((a rem: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3914
    self assert:((-17 rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3915
    self assert:((a rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3916
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3917
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3918
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3919
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3920
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3921
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3922
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3923
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3924
    self assert:((17 rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3925
    self assert:((a rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3926
    self assert:((17 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3927
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3928
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3929
    self assert:((17 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3930
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3931
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3932
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  3933
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3934
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3935
     self basicNew testModulu
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3936
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3937
!
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  3938
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3939
testPrinting1
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3940
    self assert:(10 printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3941
    self assert:(100 printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3942
    self assert:(1000 printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3943
    self assert:(10000 printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3944
    self assert:(100000 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3945
    self assert:(1000000 printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3946
    self assert:(10000000 printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3947
    self assert:(100000000 printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3948
    self assert:(1000000000 printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3949
    self assert:(10000000000 printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3950
    self assert:(100000000000 printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3951
    self assert:(1000000000000 printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3952
    self assert:(10000000000000 printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3953
    self assert:(100000000000000 printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3954
    self assert:(1000000000000000 printString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3955
    self assert:(10000000000000000 printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3956
    self assert:(100000000000000000 printString = '100000000000000000').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3957
    self assert:(1000000000000000000 printString = '1000000000000000000').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3958
    self assert:(10000000000000000000 printString = '10000000000000000000').
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  3959
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3960
    self assert:(16rF hexPrintString = 'F').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3961
    self assert:(16rFF hexPrintString = 'FF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3962
    self assert:(16rFFF hexPrintString = 'FFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3963
    self assert:(16rFFFF hexPrintString = 'FFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3964
    self assert:(16rFFFFF hexPrintString = 'FFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3965
    self assert:(16rFFFFFF hexPrintString = 'FFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3966
    self assert:(16rFFFFFFF hexPrintString = 'FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3967
    self assert:(16rFFFFFFFF hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3968
    self assert:(16rFFFFFFFFF hexPrintString = 'FFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3969
    self assert:(16rFFFFFFFFFF hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3970
    self assert:(16rFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3971
    self assert:(16rFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3972
    self assert:(16rFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3973
    self assert:(16rFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3974
    self assert:(16rFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3975
    self assert:(16rFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3976
    self assert:(16rFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3977
    self assert:(16rFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3978
    self assert:(16rFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3979
    self assert:(16rFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFF').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3980
    self assert:(16rFFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFFF').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  3981
    self assert:(16rFFFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFFFF').
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  3982
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3983
    self assert:(16r10 hexPrintString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3984
    self assert:(16r100 hexPrintString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3985
    self assert:(16r1000 hexPrintString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3986
    self assert:(16r10000 hexPrintString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3987
    self assert:(16r100000 hexPrintString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3988
    self assert:(16r1000000 hexPrintString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3989
    self assert:(16r10000000 hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3990
    self assert:(16r100000000 hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3991
    self assert:(16r1000000000 hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3992
    self assert:(16r10000000000 hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3993
    self assert:(16r100000000000 hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3994
    self assert:(16r1000000000000 hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3995
    self assert:(16r10000000000000 hexPrintString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3996
    self assert:(16r100000000000000 hexPrintString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3997
    self assert:(16r1000000000000000 hexPrintString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3998
    self assert:(16r10000000000000000 hexPrintString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3999
    self assert:(16r100000000000000000 hexPrintString = '100000000000000000').
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  4000
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4001
    self assert:(126 printString) = '126'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4002
    self assert:(127 printString) = '127'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4003
    self assert:(128 printString) = '128'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4004
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4005
    self assert:(255 printString) = '255'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4006
    self assert:(256 printString) = '256'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4007
    self assert:(257 printString) = '257'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4008
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4009
    self assert:(32767 printString) = '32767'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4010
    self assert:(32768 printString) = '32768'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4011
    self assert:(32769 printString) = '32769'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4012
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4013
    self assert:(65535 printString) = '65535'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4014
    self assert:(65536 printString) = '65536'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4015
    self assert:(65537 printString) = '65537'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4016
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4017
    self assert:(2147483647 printString) = '2147483647'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4018
    self assert:(2147483648 printString) = '2147483648'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4019
    self assert:(2147483649 printString) = '2147483649'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4020
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4021
    self assert:(4294967295 printString) = '4294967295'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4022
    self assert:(4294967296 printString) = '4294967296'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4023
    self assert:(4294967297 printString) = '4294967297'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4024
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4025
    self assert:(127 printStringRadix:16) = '7F'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4026
    self assert:(123 printStringRadix:12) = 'A3'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4027
    self assert:(123 printStringRadix:10) = '123'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4028
    self assert:(123 printStringRadix:8 ) = '173'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4029
    self assert:(123 printStringRadix:3 ) = '11120'.
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4030
    self assert:(123 printStringRadix:2 ) = '1111011'.
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4031
    self should:[ 123 printStringRadix:1 ] raise:Error.
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4032
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4033
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4034
     self basicNew testPrinting1
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4035
    "
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  4036
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  4037
    "Modified: / 26.10.1999 / 22:01:35 / stefan"
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4038
!
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4039
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4040
testReading1
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4041
    |t|
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  4042
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4043
    self assert:((Integer readFrom:'4865804016353280000') printString = '4865804016353280000').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4044
    self assert:((Integer readFrom:'4294967295') printString = '4294967295').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4045
    self assert:((Integer readFrom:'4294967295') = 4294967295).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4046
    self assert:((Integer readFrom:'4294967296') printString = '4294967296').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4047
    self assert:((Integer readFrom:'4294967296') = 4294967296).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4048
    self assert:((Integer readFrom:'4294967297') printString = '4294967297').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4049
    self assert:((Integer readFrom:'4294967297') = 4294967297).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  4050
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4051
    self assert:((Integer readFrom:'FFFFFFFF' radix:16) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4052
    self assert:((Integer readFrom:'FFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4053
    self assert:((Integer readFrom:'FFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4054
    self assert:((Integer readFrom:'FFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4055
    self assert:((Integer readFrom:'FFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4056
    self assert:((Integer readFrom:'FFFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4057
    self assert:((Integer readFrom:'FFFFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFFFF').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4058
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4059
    self assert:((Integer readFrom:'10000000' radix:16) hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4060
    self assert:((Integer readFrom:'100000000' radix:16) hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4061
    self assert:((Integer readFrom:'1000000000' radix:16) hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4062
    self assert:((Integer readFrom:'10000000000' radix:16) hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4063
    self assert:((Integer readFrom:'100000000000' radix:16) hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4064
    self assert:((Integer readFrom:'1000000000000' radix:16) hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4065
    self assert:((Integer readFrom:'10000000000000' radix:16) hexPrintString = '10000000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4066
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4067
    t := Integer readFrom:'FFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4068
    self assert:((t + 1) hexPrintString = '100000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4069
    t := Integer readFrom:'FFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4070
    self assert:((t + 1) hexPrintString = '1000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4071
    t := Integer readFrom:'FFFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4072
    self assert:((t + 1) hexPrintString = '10000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4073
    t := Integer readFrom:'FFFFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4074
    self assert:((t + 1) hexPrintString = '100000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4075
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4076
    t := Integer readFrom:'10000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4077
    self assert:((t + 1) hexPrintString = '10000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4078
    t := Integer readFrom:'100000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4079
    self assert:((t + 1) hexPrintString = '100000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4080
    t := Integer readFrom:'1000000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4081
    self assert:((t + 1) hexPrintString = '1000000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4082
    t := Integer readFrom:'10000000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4083
    self assert:((t + 1) hexPrintString = '10000000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  4084
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4085
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4086
     self basicNew testReading1
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4087
    "
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4088
!
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4089
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4090
testReadingPrinting1
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4091
    |nr inString outString|
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4092
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4093
    #(2 3 4 5 8 10 16) do:[:radix |
1366
099b96adfcf5 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1365
diff changeset
  4094
        "/ Transcript showCR:('testing radix %1...' bindWith:radix).
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4095
        1 to:1000 do:[:len |
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4096
            inString := '1',(String new:len withAll:$0).
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4097
            nr := Integer readFrom:inString radix:radix.
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4098
            outString := nr printStringRadix:radix.
1366
099b96adfcf5 #BUGFIX
Claus Gittinger <cg@exept.de>
parents: 1365
diff changeset
  4099
            self assert:(outString = inString) description:('read/print failed for radix ',radix printString).
1307
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4100
        ].    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4101
    ].
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4102
    
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4103
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4104
     self basicNew testReadingPrinting1
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4105
    "
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4106
!
f2b5a843d7df #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1305
diff changeset
  4107
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4108
testSmallIntegerArithmetic
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4109
    "arithmetic tests.
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4110
     Notice, the arithmetic tests are both performed via regular sends
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4111
     and via constructed performs. The reason is to test both inlined
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4112
     JIT-compiler code AND the regular methods code."
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4113
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4114
    |s n1 n2 t|
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4115
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4116
    "/ test division and modulu ...
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4117
    self assert:(1 printString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4118
    self assert:(10 printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4119
    self assert:(100 printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4120
    self assert:(1000 printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4121
    self assert:(10000 printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4122
    self assert:(100000 printString = '100000').
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4123
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4124
    "addition with overflow"
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4125
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4126
    SmallInteger maxBytes == 4 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4127
	n1 := 16r3FFFFFFF.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4128
	n2 := -16r40000000.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4129
    ] ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4130
	n1 := 16r3FFFFFFFFFFFFFFF.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4131
	n2 := -16r4000000000000000.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4132
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4133
    self assert:(n1 class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4134
    self assert:(n2 class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4135
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4136
    self assert:((n1 + 1) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4137
    t := n1 + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4138
    self assert:((t - 1) class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4139
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4140
    self assert:((n2 - 1) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4141
    t := n2 - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4142
    self assert:((t + 1) class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4143
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4144
    self assert:((n1 negated) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4145
    self assert:((n2 negated) class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4146
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4147
    self assert:((n2 perform:'negated' asSymbol) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4148
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4149
    self assert:((n1 abs == n1)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4150
    self assert:((n2 abs = n2 negated)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4151
    self assert:((n1 perform:'abs' asSymbol) == n1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4152
    self assert:((n2 perform:'abs' asSymbol) = n2 negated).
28
fca649220051 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 27
diff changeset
  4153
38
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  4154
    self testSmallIntegerMultiplication1.
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  4155
    self testSmallIntegerMultiplication1b.
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  4156
    self testSmallIntegerMultiplication2.
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4157
    self testSmallIntegerDivision1.
38
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  4158
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4159
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4160
     self basicNew testSmallIntegerArithmetic
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4161
    "
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4162
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  4163
    "Created: / 6.6.1999 / 14:47:51 / cg"
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4164
    "Modified: / 9.6.1999 / 17:49:57 / cg"
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4165
!
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4166
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4167
testSmallIntegerDivision1
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4168
    "division tests.
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4169
     Notice, the arithmetic tests are both performed via regular sends
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4170
     and via constructed performs. The reason is to test both inlined
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4171
     JIT-compiler code AND the regular methods code."
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4172
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4173
    |s n1 n2 t|
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4174
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4175
    n1 := 1000.
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4176
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4177
    "/ truncation towards...
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4178
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4179
    "/ ... negative infinity
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4180
    n2 := 3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4181
    self assert:((n1 // n2) == 333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4182
    self assert:((n1 // n2) printString = '333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4183
    self assert:((n1 perform:'//' asSymbol with:n2) == 333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4184
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4185
    n2 := -3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4186
    self assert:((n1 // n2) == -334).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4187
    self assert:((n1 // n2) printString = '-334').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4188
    self assert:((n1 perform:'//' asSymbol with:n2) == -334).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4189
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4190
    n2 := 3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4191
    self assert:((n1 // n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4192
    self assert:((n1 // n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4193
    self assert:((n1 perform:'//' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4194
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4195
    n2 := -3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4196
    self assert:((n1 // n2) == -1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4197
    self assert:((n1 // n2) printString = '-1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4198
    self assert:((n1 perform:'//' asSymbol with:n2) == -1).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4199
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4200
    "/ ... zero
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4201
    n2 := 3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4202
    self assert:((n1 quo: n2) == 333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4203
    self assert:((n1 quo: n2) printString = '333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4204
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4205
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4206
    n2 := -3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4207
    self assert:((n1 quo: n2) == -333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4208
    self assert:((n1 quo: n2) printString = '-333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4209
    self assert:((n1 perform:'quo:' asSymbol with:n2) == -333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4210
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4211
    n2 := 3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4212
    self assert:((n1 quo: n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4213
    self assert:((n1 quo: n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4214
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4215
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4216
    n2 := -3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4217
    self assert:((n1 quo: n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4218
    self assert:((n1 quo: n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4219
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4220
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4221
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4222
     self basicNew testSmallIntegerDivision1
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4223
    "
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4224
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4225
    "Modified: / 9.6.1999 / 17:47:56 / cg"
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4226
    "Created: / 9.6.1999 / 17:49:45 / cg"
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4227
!
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  4228
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4229
testSmallIntegerMultiplication1
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4230
    "multiply tests (var * const).
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4231
     Notice, the arithmetic tests are both performed via regular sends
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4232
     and via constructed performs. The reason is to test both inlined
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4233
     JIT-compiler code AND the regular methods code."
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4234
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4235
    |s n1 n2 t|
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4236
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4237
    n1 := 100000.
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4238
    n2 := n1 negated.
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4239
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4240
    self assert:(n1 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4241
    self assert:(n2 printString = '-100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4242
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4243
    self assert:((n1 * 0) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4244
    self assert:((n1 perform:'*' asSymbol with:0) printString = '0').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4245
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4246
    self assert:((n1 * 1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4247
    self assert:((n1 perform:'*' asSymbol with:1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4248
    self assert:((n2 * 1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4249
    self assert:((n2 perform:'*' asSymbol with:1) printString = '-100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4250
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4251
    self assert:((n1 * -1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4252
    self assert:((n1 perform:'*' asSymbol with:-1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4253
    self assert:((n2 * -1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4254
    self assert:((n2 perform:'*' asSymbol with:-1) printString = '100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4255
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4256
    self assert:((n1 * 2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4257
    self assert:((n1 perform:'*' asSymbol with:2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4258
    self assert:((n1 * 3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4259
    self assert:((n1 perform:'*' asSymbol with:3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4260
    self assert:((n1 * 4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4261
    self assert:((n1 perform:'*' asSymbol with:4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4262
    self assert:((n1 * 5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4263
    self assert:((n1 perform:'*' asSymbol with:5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4264
    self assert:((n1 * 6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4265
    self assert:((n1 perform:'*' asSymbol with:6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4266
    self assert:((n1 * 7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4267
    self assert:((n1 perform:'*' asSymbol with:7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4268
    self assert:((n1 * 8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4269
    self assert:((n1 perform:'*' asSymbol with:8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4270
    self assert:((n1 * 9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4271
    self assert:((n1 perform:'*' asSymbol with:9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4272
    self assert:((n1 * 10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4273
    self assert:((n1 perform:'*' asSymbol with:10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4274
    self assert:((n1 * 11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4275
    self assert:((n1 perform:'*' asSymbol with:11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4276
    self assert:((n1 * 12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4277
    self assert:((n1 perform:'*' asSymbol with:12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4278
    self assert:((n1 * 13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4279
    self assert:((n1 perform:'*' asSymbol with:13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4280
    self assert:((n1 * 14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4281
    self assert:((n1 perform:'*' asSymbol with:14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4282
    self assert:((n1 * 15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4283
    self assert:((n1 perform:'*' asSymbol with:15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4284
    self assert:((n1 * 16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4285
    self assert:((n1 perform:'*' asSymbol with:16) printString = '1600000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4286
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4287
    n1 := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4288
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4289
    self assert:((n1 * n2) printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4290
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4291
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4292
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4293
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4294
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4295
    self assert:((n1 * n2) printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4296
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4297
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4298
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4299
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4300
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4301
    self assert:((n1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4302
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4303
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4304
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4305
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4306
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4307
    self assert:((n1 * n2) printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4308
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4309
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4310
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4311
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4312
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4313
    self assert:((n1 * n2) printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4314
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4315
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4316
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4317
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4318
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4319
    self assert:((n1 * n2) printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4320
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4321
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4322
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4323
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4324
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4325
    self assert:((n1 * n2) printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4326
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4327
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4328
    n1 := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4329
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4330
    self assert:((n1 * n2) printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4331
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4332
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4333
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4334
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4335
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4336
    self assert:((n1 * n2) printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4337
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4338
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4339
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4340
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4341
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4342
    self assert:((n1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4343
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4344
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4345
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4346
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4347
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4348
    self assert:((n1 * n2) printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4349
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4350
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4351
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4352
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4353
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4354
    self assert:((n1 * n2) printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4355
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4356
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4357
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4358
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4359
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4360
    self assert:((n1 * n2) printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4361
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4362
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4363
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4364
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4365
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4366
    self assert:((n1 * n2) printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4367
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4368
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4369
    n1 := 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4370
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4371
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4372
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4373
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4374
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4375
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4376
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4377
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4378
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4379
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4380
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4381
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4382
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4383
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4384
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4385
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4386
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4387
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4388
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4389
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4390
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4391
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4392
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4393
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4394
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4395
    self assert:((n1 * n2) printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4396
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4397
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4398
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4399
    self assert:((n1 * n2) printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4400
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4401
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4402
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4403
    self assert:((n1 * n2) printString = '1000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4404
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4405
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4406
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4407
    self assert:((n1 * n2) printString = '100000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4408
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4409
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4410
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4411
    self assert:((n1 * n2) printString = '10000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4412
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4413
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4414
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4415
    self assert:((n1 * n2) printString = '1000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4416
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4417
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4418
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4419
    self assert:((n1 * n2) printString = '100000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4420
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  4421
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4422
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4423
     self basicNew testSmallIntegerMultiplication1
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4424
    "
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4425
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
  4426
    "Modified: / 9.6.1999 / 17:47:56 / cg"
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  4427
    "Created: / 9.6.1999 / 17:49:45 / cg"
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4428
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4429
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4430
testSmallIntegerMultiplication1b
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4431
    "multiply tests (const * var).
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4432
     Notice, the arithmetic tests are both performed via regular sends
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4433
     and via constructed performs. The reason is to test both inlined
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4434
     JIT-compiler code AND the regular methods code."
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4435
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4436
    |s n1 n2 t|
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4437
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4438
    n1 := 100000.
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4439
    n2 := n1 negated.
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4440
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4441
    self assert:((0 * n1) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4442
    self assert:((0 perform:'*' asSymbol with:n1) printString = '0').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4443
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4444
    self assert:((1 * n1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4445
    self assert:((1 perform:'*' asSymbol with:n1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4446
    self assert:((1 * n2) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4447
    self assert:((1 perform:'*' asSymbol with:n2) printString = '-100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4448
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4449
    self assert:((-1 * n1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4450
    self assert:((-1 perform:'*' asSymbol with:n1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4451
    self assert:((-1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4452
    self assert:((-1 perform:'*' asSymbol with:n2) printString = '100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4453
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4454
    self assert:((2 * n1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4455
    self assert:((2 perform:'*' asSymbol with:n1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4456
    self assert:((3 * n1) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4457
    self assert:((3 perform:'*' asSymbol with:n1) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4458
    self assert:((4 * n1) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4459
    self assert:((4 perform:'*' asSymbol with:n1) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4460
    self assert:((5 * n1) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4461
    self assert:((5 perform:'*' asSymbol with:n1) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4462
    self assert:((6 * n1) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4463
    self assert:((6 perform:'*' asSymbol with:n1) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4464
    self assert:((7 * n1) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4465
    self assert:((7 perform:'*' asSymbol with:n1) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4466
    self assert:((8 * n1) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4467
    self assert:((8 perform:'*' asSymbol with:n1) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4468
    self assert:((9 * n1) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4469
    self assert:((9 perform:'*' asSymbol with:n1) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4470
    self assert:((10 * n1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4471
    self assert:((10 perform:'*' asSymbol with:n1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4472
    self assert:((11 * n1) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4473
    self assert:((11 perform:'*' asSymbol with:n1) printString = '1100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4474
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4475
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4476
     self basicNew testSmallIntegerMultiplication1b
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4477
    "
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4478
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4479
    "Modified: / 9.6.1999 / 17:47:56 / cg"
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4480
    "Created: / 9.6.1999 / 17:49:45 / cg"
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4481
!
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  4482
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4483
testSmallIntegerMultiplication2
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4484
    "multiply tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4485
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4486
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4487
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4488
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4489
    |s n1 n2 t|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4490
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4491
    n1 := 100000.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4492
    n2 := n1 negated.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4493
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4494
    self assert:((n1 * 2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4495
    self assert:((n1 perform:'*' asSymbol with:2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4496
    self assert:((n1 * 3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4497
    self assert:((n1 perform:'*' asSymbol with:3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4498
    self assert:((n1 * 4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4499
    self assert:((n1 perform:'*' asSymbol with:4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4500
    self assert:((n1 * 5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4501
    self assert:((n1 perform:'*' asSymbol with:5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4502
    self assert:((n1 * 6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4503
    self assert:((n1 perform:'*' asSymbol with:6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4504
    self assert:((n1 * 7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4505
    self assert:((n1 perform:'*' asSymbol with:7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4506
    self assert:((n1 * 8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4507
    self assert:((n1 perform:'*' asSymbol with:8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4508
    self assert:((n1 * 9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4509
    self assert:((n1 perform:'*' asSymbol with:9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4510
    self assert:((n1 * 10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4511
    self assert:((n1 perform:'*' asSymbol with:10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4512
    self assert:((n1 * 11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4513
    self assert:((n1 perform:'*' asSymbol with:11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4514
    self assert:((n1 * 12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4515
    self assert:((n1 perform:'*' asSymbol with:12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4516
    self assert:((n1 * 13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4517
    self assert:((n1 perform:'*' asSymbol with:13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4518
    self assert:((n1 * 14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4519
    self assert:((n1 perform:'*' asSymbol with:14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4520
    self assert:((n1 * 15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4521
    self assert:((n1 perform:'*' asSymbol with:15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4522
    self assert:((n1 * 16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4523
    self assert:((n1 perform:'*' asSymbol with:16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4524
    self assert:((n1 * 17) printString = '1700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4525
    self assert:((n1 perform:'*' asSymbol with:17) printString = '1700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4526
    self assert:((n1 * 18) printString = '1800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4527
    self assert:((n1 perform:'*' asSymbol with:18) printString = '1800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4528
    self assert:((n1 * 19) printString = '1900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4529
    self assert:((n1 perform:'*' asSymbol with:19) printString = '1900000').
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4530
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4531
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4532
     self basicNew testSmallIntegerMultiplication2
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4533
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4534
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4535
    "Modified: / 9.6.1999 / 17:47:56 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  4536
    "Created: / 9.6.1999 / 17:49:45 / cg"
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4537
!
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4538
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4539
testSmallIntegerMultiplication3
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4540
    "multiply tests.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4541
     Notice, the arithmetic tests are both performed via regular sends
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4542
     and via constructed performs. The reason is to test both inlined
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4543
     JIT-compiler code AND the regular methods code."
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4544
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4545
    |s n1 n2 t|
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4546
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4547
    n1 := 16rFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4548
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4549
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4550
    self assert:((n1 * 2) printString = '131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4551
    self assert:((n1 perform:'*' asSymbol with:2) printString = '131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4552
    self assert:((n2 * 2) printString = '-131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4553
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-131070').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4554
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4555
    n1 := 16rFFFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4556
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4557
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4558
    self assert:((n1 * 2) printString = '33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4559
    self assert:((n1 perform:'*' asSymbol with:2) printString = '33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4560
    self assert:((n2 * 2) printString = '-33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4561
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-33554430').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4562
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4563
    n1 := 16r3FFFFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4564
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4565
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4566
    self assert:((n1 * 2) printString = '2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4567
    self assert:((n1 perform:'*' asSymbol with:2) printString = '2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4568
    self assert:((n2 * 2) printString = '-2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4569
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-2147483646').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4570
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4571
    SmallInteger maxBytes == 4 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4572
	n1 := 16r3FFFFFFF.
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4573
    ] ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4574
	n1 := 16r3FFFFFFFFFFFFFFF.
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4575
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4576
    self assert:(n1 class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4577
    self assert:((n1 * 2) class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4578
    self assert:((n1 perform:'*' asSymbol with:2) class == LargeInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4579
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4580
    n1 := SmallInteger maxVal // 11.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4581
    self assert:((n1 * 11) class == SmallInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4582
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4583
    n1 := n1 + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4584
    self assert:((n1 * 11) class == LargeInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4585
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4586
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  4587
     self basicNew testSmallIntegerMultiplication3
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4588
    "
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4589
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4590
    "Modified: / 9.6.1999 / 17:47:56 / cg"
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  4591
    "Created: / 9.6.1999 / 17:49:45 / cg"
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4592
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4593
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4594
!IntegerTest methodsFor:'tests-class protocol'!
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4595
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4596
testCreationFromBytes1
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4597
  "self run: #testCreationFromBytes1"
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4598
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4599
  " 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
  4600
  " 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
  4601
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4602
   | maxSmallInt hexString
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4603
     byte1 byte2 byte3 byte4
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4604
     byte5 byte6 byte7 byte8
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4605
     builtInteger builtIntegerH builtIntegerL|
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4606
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4607
    maxSmallInt := SmallInteger maxVal.
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4608
    hexString := maxSmallInt printStringHex.
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4609
    ExternalAddress pointerSize == 8 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4610
	self assert: hexString size = 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4611
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4612
	byte8 := Integer readFrom: (hexString copyFrom: 1 to: 2) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4613
	byte7 := Integer readFrom: (hexString copyFrom: 3 to: 4) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4614
	byte6 := Integer readFrom: (hexString copyFrom: 5 to: 6) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4615
	byte5 := Integer readFrom: (hexString copyFrom: 7 to: 8) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4616
	byte4 := Integer readFrom: (hexString copyFrom: 9 to: 10) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4617
	byte3 := Integer readFrom: (hexString copyFrom: 11 to: 12) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4618
	byte2 := Integer readFrom: (hexString copyFrom: 13 to: 14) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4619
	byte1 := Integer readFrom: (hexString copyFrom: 15 to: 16) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4620
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4621
	builtIntegerH := Integer byte1: byte5 byte2: byte6 byte3: byte7 byte4: byte8.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4622
	builtIntegerL := Integer byte1: byte1 byte2: byte2 byte3: byte3 byte4: byte4.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4623
	builtInteger := (builtIntegerH bitShift:32) bitOr:builtIntegerL.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4624
	self assert: builtInteger = maxSmallInt.
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  4625
    ] ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4626
	self assert: hexString size = 8.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4627
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4628
	byte4 := Integer readFrom: (hexString copyFrom: 1 to: 2) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4629
	byte3 := Integer readFrom: (hexString copyFrom: 3 to: 4) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4630
	byte2 := Integer readFrom: (hexString copyFrom: 5 to: 6) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4631
	byte1 := Integer readFrom: (hexString copyFrom: 7 to: 8) base: 16.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4632
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4633
	builtInteger := Integer byte1: byte1 byte2: byte2 byte3: byte3 byte4: byte4.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4634
	self assert: builtInteger = maxSmallInt.
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4635
    ].
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4636
    self assert: builtInteger class = SmallInteger
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4637
! !
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4638
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  4639
!IntegerTest methodsFor:'tests-concrete bugs'!
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4640
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4641
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
  4642
    "create an Idn from the given arguments
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4643
    "
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4644
    |hgEnc typ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4645
     eqEnc "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4646
     oid   "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4647
     IDN|
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4648
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4649
    IDN := self class.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4650
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4651
    eqEnc := rack.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4652
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4653
    eqEnc > 0 ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4654
		 eqEnc < 0    ifTrue:[idn := #Dontcare]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4655
	ifFalse:[port == 256  ifTrue:[idn := #NWNode]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4656
	ifFalse:[ idn := #Unspecified ]].
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4657
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4658
      ^ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4659
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4660
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4661
    eqEnc >= 255 ifTrue:[       "/ is a logical resource
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4662
	eqEnc > 255 ifTrue:[ ^ #Unspecified ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4663
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4664
	slot == 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4665
	    subr == 1 ifTrue:[ ^ #ConnectManager ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4666
	    subr == 2 ifTrue:[ ^ #ClockManager   ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4667
	].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4668
	oid := 4.                               "/ logical resource
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4669
    ] ifFalse:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4670
	oid := 2.                               "/ equipment
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4671
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4672
    hgEnc := 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4673
    typ   := aTypeOrSymbol.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4674
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4675
    subr ~~ 0 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4676
	subr > 16r0f  ifTrue:[ ^ #Unspecified ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4677
	eqEnc := eqEnc bitOr:(subr bitShift: 8).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4678
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4679
	slot ~~ 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4680
	    slot > 16rff  ifTrue:[ ^ #Unspecified ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4681
	    eqEnc := eqEnc bitOr:(slot bitShift:12).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4682
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4683
	    port ~~ 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4684
		port > 16rff  ifTrue:[ ^ #Unspecified ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4685
		eqEnc := eqEnc bitOr:(port bitShift:20).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4686
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4687
		chn ~~ 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4688
		    chn > 16rfff  ifTrue:[ ^ #Unspecified ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4689
		    oid   := 3.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4690
		    typ   := aTypeOrSymbol ? 0.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4691
		    hgEnc := chn.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4692
		]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4693
	    ]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4694
	]
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4695
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4696
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4697
    typ notNil ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4698
	typ isSymbol ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4699
	    typ := 0
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4700
	].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4701
	hgEnc := hgEnc bitOr:(typ bitShift:12).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4702
	hgEnc := hgEnc bitOr:(oid bitShift:20).
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4703
    ].
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4704
    ^ #ok.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4705
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4706
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4707
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
  4708
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4709
!
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4710
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4711
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
  4712
    "create an Idn from the given arguments
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4713
    "
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4714
    |hgEnc typ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4715
     eqEnc "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4716
     oid   "{ Class:SmallInteger }"|
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4717
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4718
    eqEnc := rack.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4719
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4720
"/    eqEnc > 0 ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4721
"/                 eqEnc < 0    ifTrue:[idn := IDN Dontcare]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4722
"/        ifFalse:[port == 256  ifTrue:[idn := IDN NWNode]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4723
"/        ifFalse:[ idn := IDN Unspecified ]].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4724
"/
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4725
"/      ^ self fromIdn:idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4726
"/    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4727
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4728
"/    eqEnc >= 255 ifTrue:[       "/ is a logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4729
"/        eqEnc > 255 ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4730
"/
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4731
"/        slot == 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4732
"/            subr == 1 ifTrue:[ ^ self fromIdn:(IDN ConnectManager) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4733
"/            subr == 2 ifTrue:[ ^ self fromIdn:(IDN ClockManager)   ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4734
"/        ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4735
"/        oid := 4.                               "/ logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4736
"/    ] ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4737
"/        oid := 2.                               "/ equipment
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4738
"/    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4739
"/    hgEnc := 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4740
"/    typ   := aTypeOrSymbol.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4741
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4742
    subr ~~ 0 ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4743
	subr > 16r0f  ifTrue:[ ^ nil "self fromIdn:(IDN Unspecified)" ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4744
	eqEnc := eqEnc bitOr:(subr bitShift: 8).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4745
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4746
	slot ~~ 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4747
	    slot > 16rff  ifTrue:[ ^ nil "self fromIdn:(IDN Unspecified)" ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4748
	    eqEnc := eqEnc bitOr:(slot bitShift:12).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4749
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4750
	    port ~~ 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4751
		port > 16rff  ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4752
		eqEnc := eqEnc bitOr:(port bitShift:20).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4753
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4754
		chn ~~ 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4755
		    chn > 16rfff  ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4756
		    oid   := 3.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4757
		    typ   := aTypeOrSymbol ? 0.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4758
		    hgEnc := chn.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4759
		]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4760
	    ]
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4761
	]
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4762
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4763
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4764
    typ notNil ifTrue:[
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4765
	typ isSymbol ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4766
	    typ := (MDT::MDTCType asNumberType:typ) ? 0
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4767
	].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4768
	hgEnc := hgEnc bitOr:(typ bitShift:12).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4769
	hgEnc := hgEnc bitOr:(oid bitShift:20).
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4770
    ].
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4771
    ^ self basicNew eqEncode:eqEnc hgEncode:hgEnc.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4772
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4773
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4774
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
  4775
"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4776
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4777
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4778
test_gcdBug1
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4779
    |theBase theMersenne theRest theGcd theOldRest theOldGcd|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4780
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4781
    theBase := 2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4782
    132 to:135 do:[:theOrder |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4783
	false " <<<< here i replaced some piece of code by false just to reproduce the error without having to ship all my code >>>>" ifFalse:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4784
	    theRest := ((theBase raisedTo:theOrder) - 1) / (theBase - 1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4785
	    30 "theOrder - 1" to:67 do:[:theFactorOrder |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4786
		"/Transcript show:theOrder; space.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4787
		"/Transcript showCR:theFactorOrder.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4788
		(theOrder \\ theFactorOrder) = 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4789
		    " <<<< is a divisor of the order >>>>"
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4790
		    self assert:theFactorOrder ~= 131 description:'131 ist kein Teiler von 132'.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4791
		    self assert:(theOrder / theFactorOrder) isFraction not.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4792
		    theMersenne := ((theBase raisedTo:theFactorOrder) - 1) / (theBase - 1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4793
		    theGcd := theRest gcd:theMersenne.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4794
		    [ theGcd > 1 ] whileTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4795
			self assert:theFactorOrder < 129.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4796
			theOldRest := theRest asString.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4797
			theOldGcd := theGcd asString.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4798
			theRest := theRest / theGcd.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4799
			theGcd := theGcd gcd:theRest.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4800
			self assert:((theRest \\ theGcd) = 0).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4801
			self assert:(theRest / theGcd) isFraction not.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4802
		    ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4803
		].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4804
	    ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4805
	    self assert:theRest ~= 1
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4806
		description:'there is no prime factor of order theOrder'
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4807
	].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4808
    ].
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4809
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4810
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4811
     self new test_gcdBug1
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4812
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  4813
    "Modified: / 27-04-2010 / 00:02:02 / cg"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4814
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4815
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4816
test_gcdBug2
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4817
    |theBase theMersenne theRest theGcd theOldRest theOldGcd|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4818
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4819
    theBase := 2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4820
    132 to:135 do:[:theOrder |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4821
	false " <<<< here i replaced some piece of code by false just to
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4822
	 reproduce the error without having to ship all my code >>>>"
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4823
		ifFalse:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4824
		    theRest := ((theBase raisedTo:theOrder) - 1) / (theBase - 1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4825
		    60 "theOrder - 1" to:67 do:[:theFactorOrder |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4826
			"/Transcript show:theOrder; space.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4827
			"/Transcript showCR:theFactorOrder.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4828
			(theOrder \\ theFactorOrder) = 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4829
			    " <<<< is a divisor of the order >>>>"
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4830
			    self assert:theFactorOrder ~= 131 description:'131 ist kein Teiler von 132'.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4831
			    self assert:(theOrder / theFactorOrder) isFraction not.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4832
			    theMersenne := ((theBase raisedTo:theFactorOrder) - 1) / (theBase - 1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4833
			    theGcd := theRest gcd:theMersenne.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4834
			    [ theGcd > 1 ] whileTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4835
				self assert:theFactorOrder < 129.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4836
				theOldRest := theRest asString.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4837
				theOldGcd := theGcd asString.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4838
				theRest := theRest / theGcd.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4839
				theGcd := theGcd gcd:theRest.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4840
				self assert:((theRest \\ theGcd) = 0).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4841
				self assert:(theRest / theGcd) isFraction not.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4842
			    ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4843
			].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4844
		    ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4845
		    self assert:theRest ~= 1
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4846
			description:'there is no prime factor of order theOrder'
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4847
		].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4848
    ].
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4849
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4850
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4851
     self new test_gcdBug2
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4852
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  4853
    "Modified: / 27-04-2010 / 00:02:09 / cg"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4854
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4855
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4856
test_gcdBug3
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4857
    |theBase theMersenne theRest theGcd theOldRest theOldGcd|
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4858
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4859
    theBase := 2.
1221
25d244f98de4 added factorial tests (tests largint * smallInt and largeInt / smallInt)
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  4860
    132 to:135 do:[:theOrder |
1318
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4861
	false " <<<< here i replaced some piece of code by false just to
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4862
	 reproduce the error without having to ship all my code >>>>"
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4863
		ifFalse:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4864
		    theRest := ((theBase raisedTo:theOrder) - 1) / (theBase - 1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4865
		    2 to:theOrder - 1 do:[:theFactorOrder |
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4866
			"/Transcript show:theOrder; space.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4867
			"/Transcript showCR:theFactorOrder.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4868
			(theOrder \\ theFactorOrder) = 0 ifTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4869
			    " <<<< is a divisor of the order >>>>"
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4870
			    self assert:theFactorOrder ~= 131 description:'131 ist kein Teiler von 132'.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4871
			    self assert:(theOrder / theFactorOrder) isFraction not.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4872
			    theMersenne := ((theBase raisedTo:theFactorOrder) - 1) / (theBase - 1).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4873
			    theGcd := theRest gcd:theMersenne.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4874
			    [ theGcd > 1 ] whileTrue:[
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4875
				self assert:theFactorOrder < 129.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4876
				theOldRest := theRest asString.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4877
				theOldGcd := theGcd asString.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4878
				theRest := theRest / theGcd.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4879
				theGcd := theGcd gcd:theRest.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4880
				self assert:((theRest \\ theGcd) = 0).
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4881
				self assert:(theRest / theGcd) isFraction not.
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4882
			    ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4883
			].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4884
		    ].
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4885
		    self assert:theRest ~= 1
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4886
			description:'there is no prime factor of order theOrder'
8c891b59469c #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 1317
diff changeset
  4887
		].
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4888
    ].
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4889
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4890
    "
1139
1dfea13c4d57 class: RegressionTests::IntegerTest
Stefan Vogel <sv@exept.de>
parents: 1069
diff changeset
  4891
     self new test_gcdBug3
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  4892
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  4893
    "Modified: / 27-04-2010 / 00:02:15 / cg"
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4894
! !
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  4895
1298
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4896
!IntegerTest methodsFor:'tests-misc'!
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4897
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4898
test_primes
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4899
    self 
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4900
        assert: ((1 to: 30) select: [:i | i isPrime] as:Array) 
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4901
                            = #(2 3 5 7 11 13 17 19 23 29);
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4902
        assert: ((0 to: 30) collect: [:i | i nextPrime] as:Array)
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4903
                            = #(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
  4904
! !
4a316075f201 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1234
diff changeset
  4905
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4906
!IntegerTest class methodsFor:'documentation'!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4907
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4908
version
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4909
    ^ '$Header$'
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4910
!
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4911
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4912
version_CVS
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  4913
    ^ '$Header$'
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4914
! !
1234
920a33e66069 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4915