RegressionTests__IntegerTest.st
author Claus Gittinger <cg@exept.de>
Mon, 02 Dec 2013 15:05:29 +0100
changeset 1024 17f4613fc1d4
parent 941 0192003475ec
child 1025 1d694c9fd79d
permissions -rw-r--r--
class: RegressionTests::IntegerTest changed: #testLargeMultiplication
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
69
ffbf7492f5e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 59
diff changeset
     1
"{ Package: 'exept: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
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
     6
	instanceVariableNames:''
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
     7
	classVariableNames:''
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
     8
	poolDictionaries:''
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
     9
	category:'tests-Regression'
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    19
     (self doMul0_a:0) ==   0   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    20
     (self doMul0_a:1) ==   0   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    21
     (self doMul0_a:SmallInteger maxVal) == 0  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    32
     (self doMul1_a:0) ==   0  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    33
     (self doMul1_a:1) ==   1  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    34
     (self doMul1_a:SmallInteger maxVal) == SmallInteger maxVal  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    45
     (self doMul2_a:0) ==   0            
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    46
     (self doMul2_a:1) ==   2   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    47
     (self doMul2_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal)  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    58
     (self doMul3_a:0) ==   0            
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    59
     (self doMul3_a:1) ==   3   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    60
     (self doMul3_a:-1) ==  -3   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    61
     (self doMul3_a:10000) ==   30000   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    62
     (self doMul3_a:SmallInteger maxVal) = (SmallInteger maxVal + SmallInteger maxVal + SmallInteger maxVal)  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    74
     (self doMul4_a:0) ==   0            
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    75
     (self doMul4_a:1) ==   4   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    76
     (self doMul4_a:-1) ==  -4   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    77
     (self doMul4_a:10000) ==   40000    
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    78
     (self doMul4_a:SmallInteger maxVal//4) == 4611686018427387900    
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    90
     (self doMul5_a:0) ==   0            
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    91
     (self doMul5_a:1) ==   5   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    92
     (self doMul5_a:-1) ==  -5   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    93
     (self doMul5_a:10000) ==   50000    
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
    94
     (self doMul5_a:SmallInteger maxVal//5) == 4611686018427387900    
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   105
     (self doMulM1_a:0) ==   0            
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   106
     (self doMulM1_a:1) ==   -1   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   107
     (self doMulM1_a:SmallInteger maxVal) == (SmallInteger minVal + 1)  
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
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
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   118
     (self doPlus1_a:SmallInteger maxVal) =   1073741824  
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
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   126
     (self doPlus1_b:SmallInteger maxVal) ==   1073741824  
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
    "
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
   223
     self basicNew testMulM1   
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:[
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   232
        self assert: ( (self doPlus1_a:SmallInteger maxVal) = 4611686018427387904).
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   233
        self assert: ( (self doPlus1_a:SmallInteger minVal) = -4611686018427387903 ).
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   234
    ] ifFalse:[
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   235
        self assert: ( (self doPlus1_a:SmallInteger maxVal) = 1073741824).
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   236
        self assert: ( (self doPlus1_a:SmallInteger minVal) = -1073741823 ).
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:[
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   249
        self assert: ( (self doPlus1_b:SmallInteger maxVal) = 4611686018427387904).
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   250
        self assert: ( (self doPlus1_b:SmallInteger minVal) = -4611686018427387903 ).
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   251
    ] ifFalse:[
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   252
        self assert: ( (self doPlus1_b:SmallInteger maxVal) = 1073741824).
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
   253
        self assert: ( (self doPlus1_b:SmallInteger minVal) = -1073741823 ).
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
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   264
                        |local1|
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   265
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   266
                        local1 := arg.
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   267
                        ^ local1 abs + 1
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
"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   271
 self absPlusOneOf:-1      
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
   272
 self absPlusOneOf:-1.0      
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
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   707
testComparing
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   708
    |a b|
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   709
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   710
    a := 12.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   711
    b := 16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   712
    self doCompare:a againstGreater:b.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   713
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   714
    a := 12.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   715
    b := 16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   716
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   717
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   718
    a := 0.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   719
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   720
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   721
    a := -1.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   722
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   723
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   724
    a := 16r-80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   725
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   726
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   727
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   728
    self doCompare:a againstGreater:16r80000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   729
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   730
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   731
    self doCompare:a againstGreater:16r40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   732
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   733
    a := 16r-3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   734
    self doCompare:a againstGreater:16r3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   735
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   736
    a := 16r-40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   737
    self doCompare:a againstGreater:16r3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   738
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   739
    a := 16r-3FFFFFFF.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   740
    self doCompare:a againstGreater:16r40000000.
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   741
362
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   742
    "/ smallint-largeInt boundaries
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   743
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   744
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   745
    self doCompare:a againstEqual:16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   746
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   747
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   748
    self doCompare:a againstGreater:16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   749
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   750
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   751
    self doCompare:a againstGreater:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   752
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   753
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   754
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   755
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   756
    a := 16r3FFFFFFE.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   757
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   758
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   759
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   760
    self doCompare:a againstEqual:16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   761
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   762
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   763
    self doCompare:a againstGreater:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   764
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   765
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   766
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   767
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   768
    a := 16r3FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   769
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   770
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   771
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   772
    self doCompare:a againstEqual:16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   773
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   774
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   775
    self doCompare:a againstGreater:16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   776
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   777
    a := 16r40000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   778
    self doCompare:a againstGreater:16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   779
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   780
    a := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   781
    self doCompare:a againstEqual:16r7FFFFFFF.
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 := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   784
    self doCompare:a againstGreater:16r80000000.
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 := 16r7FFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   787
    self doCompare:a againstGreater:16rFFFFFFFF.
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 := 16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   790
    self doCompare:a againstEqual:16r80000000.
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 := 16r80000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   793
    self doCompare:a againstGreater:16rFFFFFFFF.
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 := 16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   796
    self doCompare:a againstEqual: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 := 16rFFFFFFFF.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   799
    self doCompare:a againstGreater:16r100000000.
c2504e878ebd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
   800
172
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   801
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   802
     self basicNew testComparing
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   803
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   804
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   805
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   806
testConstants
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   807
    |t|
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   808
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   809
    self assert:((t := self num_16r80000000) > 0).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   810
    self assert:((t := self num_16r80000000) = 16r80000000).
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   811
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   812
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   813
     self basicNew testConstants
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   814
    "
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   815
!
4007fa906cab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 151
diff changeset
   816
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   817
testDivision
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   818
    |a b op rslt|
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   819
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   820
    op := #//.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   821
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   822
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   823
    self assert:(-1 // 8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   824
    self assert:(a // 8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   825
    self assert:(-1 // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   826
    self assert:(a // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   827
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   828
    self assert:((rslt := -1 perform:op with: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   829
    self assert:((rslt := a perform:op with: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   830
    self assert:((rslt := -1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   831
    self assert:((rslt := a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   832
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   833
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   834
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   835
    self assert:(1 // -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   836
    self assert:(a // -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   837
    self assert:(1 // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   838
    self assert:(a // b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   839
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   840
    self assert:((rslt := 1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   841
    self assert:((rslt := a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   842
    self assert:((rslt := 1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   843
    self assert:((rslt := a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   844
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   845
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   846
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   847
    self assert:(-1 // -8 == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   848
    self assert:(a // -8 == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   849
    self assert:(-1 // b == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   850
    self assert:(a // b == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   851
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   852
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   853
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   854
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   855
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   856
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   857
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   858
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   859
    self assert:(1 // 8 == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   860
    self assert:(a // 8 == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   861
    self assert:(1 // b == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   862
    self assert:(a // b == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   863
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   864
    self assert:((rslt := 1 perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   865
    self assert:((rslt := a perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   866
    self assert:((rslt := 1 perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   867
    self assert:((rslt := a perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   868
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   869
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   870
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   871
    self assert:(-16 // 8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   872
    self assert:(a // 8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   873
    self assert:(-16 // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   874
    self assert:(a // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   875
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   876
    self assert:((rslt := -16 perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   877
    self assert:((rslt := a perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   878
    self assert:((rslt := -16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   879
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   880
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   881
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   882
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   883
    self assert:(16 // -8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   884
    self assert:(a // -8 == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   885
    self assert:(16 // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   886
    self assert:(a // b == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   887
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   888
    self assert:((rslt := 16 perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   889
    self assert:((rslt := a perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   890
    self assert:((rslt := 16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   891
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   892
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   893
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   894
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   895
    self assert:(-16 // -8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   896
    self assert:(a // -8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   897
    self assert:(-16 // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   898
    self assert:(a // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   899
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   900
    self assert:((rslt := -16 perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   901
    self assert:((rslt := a perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   902
    self assert:((rslt := -16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   903
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   904
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   905
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   906
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   907
    self assert:(16 // 8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   908
    self assert:(a // 8 == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   909
    self assert:(16 // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   910
    self assert:(a // b == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   911
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   912
    self assert:((rslt := 16 perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   913
    self assert:((rslt := a perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   914
    self assert:((rslt := 16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   915
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   916
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   917
    op := #quo:.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   918
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   919
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   920
    self assert:((rslt := -1 quo: 8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   921
    self assert:((rslt := a quo: 8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   922
    self assert:((rslt := -1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   923
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   924
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   925
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   926
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   927
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   928
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   929
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   930
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   931
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   932
    self assert:((rslt := 1 quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   933
    self assert:((rslt := a quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   934
    self assert:((rslt := 1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   935
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   936
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   937
    self assert:((rslt := 1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   938
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   939
    self assert:((rslt := 1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   940
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   941
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   942
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   943
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   944
    self assert:((rslt := -1 quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   945
    self assert:((rslt := a quo: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   946
    self assert:((rslt := -1 quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   947
    self assert:((rslt := a quo: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   948
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   949
    self assert:((rslt := -1 perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   950
    self assert:((rslt := a perform:op with: -8) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   951
    self assert:((rslt := -1 perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   952
    self assert:((rslt := a perform:op with: b) == 0).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
   953
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   954
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   955
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   956
    self assert:((rslt := 1 quo: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   957
    self assert:((rslt := a quo: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   958
    self assert:((rslt := 1 quo: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   959
    self assert:((rslt := a quo: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   960
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   961
    self assert:((rslt := 1 perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   962
    self assert:((rslt := a perform:op with: 8) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   963
    self assert:((rslt := 1 perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   964
    self assert:((rslt := a perform:op with: b) == 0).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   965
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   966
    a := -16.
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:((rslt := -16 quo: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   969
    self assert:((rslt := a quo: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   970
    self assert:((rslt := -16 quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   971
    self assert:((rslt := a quo: b) == -2).
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 := -16 perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   974
    self assert:((rslt := a perform:op with: 8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   975
    self assert:((rslt := -16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   976
    self assert:((rslt := a perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   977
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   978
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   979
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   980
    self assert:((rslt := 16 quo: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   981
    self assert:((rslt := a quo: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   982
    self assert:((rslt := 16 quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   983
    self assert:((rslt := a quo: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   984
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   985
    self assert:((rslt := 16 perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   986
    self assert:((rslt := a perform:op with: -8) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   987
    self assert:((rslt := 16 perform:op with: b) == -2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   988
    self assert:((rslt := a perform:op with: 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
    a := -16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   991
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   992
    self assert:((rslt := -16 quo: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   993
    self assert:((rslt := a quo: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   994
    self assert:((rslt := -16 quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   995
    self assert:((rslt := a quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   996
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   997
    self assert:((rslt := -16 perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   998
    self assert:((rslt := a perform:op with: -8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
   999
    self assert:((rslt := -16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1000
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1001
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1002
    a := 16.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1003
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1004
    self assert:((rslt := 16 quo: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1005
    self assert:((rslt := a quo: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1006
    self assert:((rslt := 16 quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1007
    self assert:((rslt := a quo: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1008
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1009
    self assert:((rslt := 16 perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1010
    self assert:((rslt := a perform:op with: 8) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1011
    self assert:((rslt := 16 perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1012
    self assert:((rslt := a perform:op with: b) == 2).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  1013
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1014
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1015
     self basicNew testDivision
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1016
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1017
!
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  1018
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1019
testEncodeDecode
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1020
    self assert:(1 encodeAsBCD hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1021
    self assert:(12 encodeAsBCD hexPrintString = '12').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1022
    self assert:(123 encodeAsBCD hexPrintString = '123').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1023
    self assert:(1234 encodeAsBCD hexPrintString = '1234').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1024
    self assert:(12345 encodeAsBCD hexPrintString = '12345').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1025
    self assert:(123456 encodeAsBCD hexPrintString = '123456').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1026
    self assert:(1234567 encodeAsBCD hexPrintString = '1234567').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1027
    self assert:(12345678 encodeAsBCD hexPrintString = '12345678').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1028
    self assert:(123456789 encodeAsBCD hexPrintString = '123456789').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1029
    self assert:(1234567890 encodeAsBCD hexPrintString = '1234567890').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1030
    self assert:(12345678901 encodeAsBCD hexPrintString = '12345678901').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1031
    self assert:(123456789012 encodeAsBCD hexPrintString = '123456789012').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1032
    self assert:(1234567890123 encodeAsBCD hexPrintString = '1234567890123').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1033
    self assert:(12345678901234 encodeAsBCD hexPrintString = '12345678901234').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1034
    self assert:(123456789012345 encodeAsBCD hexPrintString = '123456789012345').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1035
    self assert:(1234567890123456 encodeAsBCD hexPrintString = '1234567890123456').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1036
    self assert:(12345678901234567 encodeAsBCD hexPrintString = '12345678901234567').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1037
    self assert:(123456789012345678 encodeAsBCD hexPrintString = '123456789012345678').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1038
    self assert:(1234567890123456789 encodeAsBCD hexPrintString = '1234567890123456789').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1039
    self assert:(12345678901234567890 encodeAsBCD hexPrintString = '12345678901234567890').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1040
    self assert:(4611686018427387902 encodeAsBCD hexPrintString = '4611686018427387902').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1041
    self assert:(4611686018427387903 encodeAsBCD hexPrintString = '4611686018427387903').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1042
    self assert:(4611686018427387904 encodeAsBCD hexPrintString = '4611686018427387904').
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1043
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1044
    self assert:(16r1 decodeFromBCD = 1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1045
    self assert:(16r12 decodeFromBCD = 12).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1046
    self assert:(16r123 decodeFromBCD = 123).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1047
    self assert:(16r1234 decodeFromBCD = 1234).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1048
    self assert:(16r12345 decodeFromBCD = 12345).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1049
    self assert:(16r123456 decodeFromBCD = 123456).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1050
    self assert:(16r1234567 decodeFromBCD = 1234567).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1051
    self assert:(16r12345678 decodeFromBCD = 12345678).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1052
    self assert:(16r123456789 decodeFromBCD = 123456789).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1053
    self assert:(16r1234567890 decodeFromBCD = 1234567890).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1054
    self assert:(16r12345678901 decodeFromBCD = 12345678901).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1055
    self assert:(16r123456789012 decodeFromBCD = 123456789012).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1056
    self assert:(16r1000000000000 decodeFromBCD = 1000000000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1057
    self assert:(16r0000500000000 decodeFromBCD = 500000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1058
    self assert:(16r1234500000000 decodeFromBCD = 1234500000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1059
    self assert:(16r1234567890000 decodeFromBCD = 1234567890000).
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1060
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1061
    self assert:(16r1234567890123 decodeFromBCD = 1234567890123).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1062
    self assert:(16r12345678901234 decodeFromBCD = 12345678901234).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1063
    self assert:(16r123456789012345 decodeFromBCD = 123456789012345).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1064
    self assert:(16r1234567890123456 decodeFromBCD = 1234567890123456).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1065
    self assert:(16r12345678901234567 decodeFromBCD = 12345678901234567).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1066
    self assert:(16r123456789012345678 decodeFromBCD = 123456789012345678).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1067
    self assert:(16r1234567890123456789 decodeFromBCD = 1234567890123456789).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1068
    self assert:(16r12345678901234567890 decodeFromBCD = 12345678901234567890).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1069
    self assert:(16r4611686018427387902 decodeFromBCD = 4611686018427387902).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1070
    self assert:(16r4611686018427387903 decodeFromBCD = 4611686018427387903).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1071
    self assert:(16r4611686018427387904 decodeFromBCD = 4611686018427387904).
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1072
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1073
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1074
     self basicNew testEncodeDecode
42
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1075
    "
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1076
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1077
    "Modified: / 26.10.1999 / 22:01:35 / stefan"
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1078
!
b7e57becd932 more tests
Claus Gittinger <cg@exept.de>
parents: 41
diff changeset
  1079
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1080
testFactorial
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1081
    "/ <testedMethods: #( (Integer >> #factorial) (Integer >> #*) ) >
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1082
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1083
    self assert:(1 factorial = 1).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1084
    self assert:(2 factorial = 2).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1085
    self assert:(10 factorial = 3628800).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1086
    self assert:(11 factorial = 39916800).
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1087
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1088
    "
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1089
     self basicNew testFactorial
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1090
    "
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1091
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1092
    "Created: / 24-04-2010 / 13:52:23 / cg"
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1093
    "Modified: / 27-04-2010 / 10:34:22 / cg"
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1094
!
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1095
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1096
testGCD
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1097
    "/ <testedMethods: #( (Integer >> #gcd:) ) >
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1098
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1099
    self assert:(9 gcd:6) = 3.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1100
    self assert:(6 gcd:9) = 3.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1101
    self assert:(2 gcd:0) = 2.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1102
    self assert:(0 gcd:2) = 2.
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1103
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1104
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1105
     self basicNew testGCD
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1106
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1107
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1108
    "Created: / 27-04-2010 / 09:49:31 / cg"
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1109
!
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  1110
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1111
testILC
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1112
    "inline-cache"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1113
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1114
    self assert:((self checkIsInteger:1) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1115
    self assert:((self checkIsInteger:nil) == false).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1116
    self assert:((self checkIsInteger:1) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1117
    self assert:((self checkIsInteger:nil) == false).
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1118
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1119
    self assert:((self checkIsInteger:0) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1120
    self assert:((self checkIsInteger:nil) == false).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1121
    self assert:((self checkIsInteger:0) == true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1122
    self assert:((self checkIsInteger:nil) == false).
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1123
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1124
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1125
     self basicNew testILC
54
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1126
    "
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1127
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1128
    "Created: / 6.6.1999 / 14:47:51 / cg"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1129
    "Modified: / 9.6.1999 / 17:49:57 / cg"
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1130
!
77b06a241d57 ilc check
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
  1131
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1132
testInline1
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1133
    "inlined tests.
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1134
     Notice, the arithmetic tests are both performed via regular sends
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1135
     and via constructed performs. The reason is to test both inlined
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1136
     JIT-compiler code AND the regular methods code."
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1137
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1138
    self assert:( (self absPlusOneOf:1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1139
    self assert:( (self absPlusOneOf:-1) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1140
    self assert:( (self absPlusOneOf:1.0) = 2 ).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1141
    self assert:( (self absPlusOneOf:-1.0) = 2 ).
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1142
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1143
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1144
     self basicNew testInline1
91
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1145
    "
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1146
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1147
    "Created: / 31.10.2000 / 20:22:48 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1148
    "Modified: / 31.10.2000 / 20:23:06 / cg"
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1149
!
a781d70791b7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 89
diff changeset
  1150
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1151
testInteger1
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1152
    "general conversion & arithmetic tests.
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1153
     Notice, the arithmetic tests are both performed via regular sends
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1154
     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
  1155
     JIT-compiler code AND the regular method's code."
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1156
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1157
    |minVal maxVal maxValPlus1 minValMinus1 halfMin halfMax t|
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1158
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1159
    minVal := SmallInteger perform:('minVal' asSymbol).
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1160
    maxVal := SmallInteger perform:('maxVal' asSymbol).
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1161
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1162
    self assert:(minVal == self num_smallInt_minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1163
    self assert:(maxVal == self num_smallInt_maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1164
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1165
    self assert:(minVal == SmallInteger minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1166
    self assert:(maxVal == SmallInteger maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1167
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1168
    t := SmallInteger perform:('maxBytes' asSymbol).
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1169
    self assert:(t == SmallInteger maxBytes).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1170
    t := SmallInteger perform:('maxBits' asSymbol).
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1171
    self assert:(t == SmallInteger maxBits).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1172
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1173
    self testPrinting1.
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1174
935
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1175
    self assert:(SmallInteger maxBytes == ExternalAddress pointerSize).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1176
    "/ again, preventing inlining by compiler
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1177
    self assert:(SmallInteger perform:#maxBytes) == (ExternalAddress perform:#pointerSize).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1178
    self assert:(SmallInteger perform:'maxBytes' asSymbol) == (ExternalAddress perform:'pointerSize' asSymbol).
9fb8ac67472d class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 934
diff changeset
  1179
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1180
    SmallInteger maxBytes == 4 ifTrue:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1181
        self assert:(minVal hexPrintString = '-40000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1182
        self assert:(maxVal hexPrintString = '3FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1183
        self assert:(minVal == -1073741824).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1184
        self assert:(maxVal == 1073741823).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1185
        maxValPlus1 := 1073741824.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1186
        minValMinus1 := -1073741825.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1187
        self assert:(minValMinus1 hexPrintString = '-40000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1188
        self assert:(maxValPlus1 hexPrintString = '40000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1189
        halfMin := -16r20000000.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1190
        halfMax := 16r20000000.
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1191
    ].
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1192
    SmallInteger maxBytes == 8 ifTrue:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1193
        self assert:(minVal hexPrintString = '-4000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1194
        self assert:(maxVal hexPrintString = '3FFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1195
        self assert:(minVal == -4611686018427387904).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1196
        self assert:(maxVal == 4611686018427387903).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1197
        maxValPlus1 := 4611686018427387904.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1198
        minValMinus1 := -4611686018427387905.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1199
        self assert:(minValMinus1 hexPrintString = '-4000000000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1200
        self assert:(maxValPlus1 hexPrintString = '4000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1201
        halfMin := -16r2000000000000000.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1202
        halfMax := 16r2000000000000000.
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1203
    ].
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1204
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1205
    "arithmetic overFlow checks"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1206
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1207
"/    self assert:((maxVal + 1) inspect.maxValPlus1 inspect. true).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1208
    self assert:((maxVal perform:'+' asSymbol with:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1209
    self assert:((maxVal + 1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1210
    self assert:((minVal perform:'-' asSymbol with:1) = minValMinus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1211
    self assert:((minVal - 1) = minValMinus1).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1212
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1213
    self assert:((halfMax perform:'+' asSymbol with:halfMax) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1214
    self assert:((halfMax + halfMax) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1215
    self assert:((halfMin perform:'+' asSymbol with:halfMin) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1216
    self assert:((halfMin + halfMin) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1217
    self assert:((halfMax perform:'*' asSymbol with:2) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1218
    self assert:((halfMax * 2) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1219
    self assert:((halfMin perform:'*' asSymbol with:2) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1220
    self assert:((halfMin * 2) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1221
    self assert:((maxValPlus1 perform:'//' asSymbol with:2) == halfMax).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1222
    self assert:((maxValPlus1 // 2) == halfMax).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1223
    self assert:((halfMax perform:'bitShift:' asSymbol with:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1224
    self assert:((halfMin perform:'bitShift:' asSymbol with:1) == minVal).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1225
    self assert:((halfMax bitShift:1) = maxValPlus1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1226
    self assert:((halfMin bitShift:1) == minVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1227
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1228
    "LargeInt op -> SmallInt result"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1229
    t := maxVal + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1230
    self assert:(t - 1 == maxVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1231
    t := minVal - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1232
    self assert:(t + 1 == minVal).
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1233
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1234
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1235
     self basicNew testInteger1
57
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1236
    "
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1237
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1238
    "Modified: / 6.6.1999 / 14:46:11 / cg"
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1239
!
14aec105070d category
Claus Gittinger <cg@exept.de>
parents: 56
diff changeset
  1240
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1241
testIntegerMisc
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1242
    "misc tests.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1243
     Notice, the arithmetic tests are both performed via regular sends
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1244
     and via constructed performs. The reason is to test both inlined
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1245
     JIT-compiler code AND the regular methods code."
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1246
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1247
    |n1 n2 s|
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1248
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1249
    n1 := 100000.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1250
    n2 := n1 negated.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1251
    s := 1.
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1252
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1253
    self assert:(n1 printString = '100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1254
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1255
    self assert:(n1 negated printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1256
    self assert:((n1 perform:'negated' asSymbol) printString = '-100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1257
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1258
    self assert:(n1 negated abs printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1259
    self assert:((n1 perform:'negated' asSymbol) abs printString = '100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1260
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1261
    self assert:(n1 abs negated printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1262
    self assert:((n1 perform:'abs' asSymbol) negated printString = '-100000').
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1263
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1264
    n1 := SmallInteger maxVal.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1265
    self assert:(n1 negated class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1266
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1267
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1268
    n1 := SmallInteger minVal.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1269
    self assert:(n1 negated class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1270
    self assert:((n1 perform:'negated' asSymbol) class == LargeInteger).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1271
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1272
    n1 := SmallInteger minVal negated - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1273
    self assert:(n1 negated class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1274
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1275
    self assert:(n1 == SmallInteger maxVal).
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1276
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1277
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1278
     self basicNew testIntegerMisc
53
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1279
    "
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1280
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1281
    "Created: / 6.6.1999 / 14:47:51 / cg"
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1282
    "Modified: / 9.6.1999 / 17:49:57 / cg"
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1283
!
94b4cfba8e21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 52
diff changeset
  1284
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1285
testIntegerMisc2
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1286
    "misc tests.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1287
     Notice, the arithmetic tests are both performed via regular sends
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1288
     and via constructed performs. The reason is to test both inlined
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1289
     JIT-compiler code AND the regular methods code."
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1290
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1291
    |n sel|
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1292
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1293
    "/ fib is optional
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1294
    (0 respondsTo:#fib) ifFalse:[^ self].
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  1295
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1296
    self assert:(0 fib == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1297
    self assert:(1 fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1298
    self assert:(2 fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1299
    self assert:(3 fib == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1300
    self assert:(4 fib == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1301
    self assert:(5 fib == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1302
    self assert:(6 fib == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1303
    self assert:(7 fib == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1304
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1305
    n := 0.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1306
    self assert:(n fib == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1307
    n := 1.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1308
    self assert:(n fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1309
    n := 2.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1310
    self assert:(n fib == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1311
    n := 3.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1312
    self assert:(n fib == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1313
    n := 4.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1314
    self assert:(n fib == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1315
    n := 5.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1316
    self assert:(n fib == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1317
    n := 6.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1318
    self assert:(n fib == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1319
    n := 7.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1320
    self assert:(n fib == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1321
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1322
    #(0 1 2 3 4 5 6 7) 
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1323
    with:#(0 1 1 2 3 5 8 13)
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1324
    do:[:n :rslt |
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1325
        self assert:(n fib == rslt).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1326
    ].
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1327
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1328
"/    #(0 1 2 3 4 5 6 7) 
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1329
"/    with:#(0 1 1 2 3 5 8 13)
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1330
"/    do:[:n :rslt |
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1331
"/        self assert:(n fib_recursive == rslt).
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1332
"/    ].
151
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1333
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1334
    sel := #fib.
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1335
    self assert:((0 perform:sel) == 0).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1336
    self assert:((1 perform:sel) == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1337
    self assert:((2 perform:sel) == 1).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1338
    self assert:((3 perform:sel) == 2).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1339
    self assert:((4 perform:sel) == 3).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1340
    self assert:((5 perform:sel) == 5).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1341
    self assert:((6 perform:sel) == 8).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1342
    self assert:((7 perform:sel) == 13).
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1343
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1344
    "
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1345
     self basicNew testIntegerMisc2
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1346
    "
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1347
!
56cceb5c0318 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 150
diff changeset
  1348
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1349
testIntegerShifts
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1350
    "arithmetic tests.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1351
     Notice, the arithmetic tests are both performed via regular sends
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1352
     and via constructed performs. The reason is to test both inlined
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1353
     JIT-compiler code AND the regular methods code."
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1354
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1355
    self testIntegerShifts1.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1356
    self testIntegerShifts2.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1357
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1358
    self assert:(
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1359
     (((0 to:64) collect:[:s | 1 bitShift:s])
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1360
        collect:[:n | n highBit]) = (1 to:65)
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1361
    ).
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1362
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1363
    1 to:10000 do:[:s |
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1364
        self assert:( (1 bitShift:s) highBit == (s+1) )
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1365
    ].
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1366
    1 to:10000 do:[:s |
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1367
        self assert:( ((1 bitShift:s) - 1) highBit == s )
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1368
    ].
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1369
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1370
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1371
     self basicNew testIntegerShifts
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1372
    "
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1373
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1374
    "Created: / 6.6.1999 / 14:47:51 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1375
    "Modified: / 9.6.1999 / 17:49:57 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1376
!
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1377
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1378
testIntegerShifts1
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1379
    "arithmetic tests.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1380
     Notice, the arithmetic tests are both performed via regular sends
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1381
     and via constructed performs. The reason is to test both inlined
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1382
     JIT-compiler code AND the regular methods code."
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1383
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1384
    |n1 n2 s|
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1385
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1386
    n1 := 100000.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1387
    n2 := n1 negated.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1388
    s := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1389
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1390
    self assert:(n1 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1391
    self assert:(n2 printString = '-100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1392
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1393
    self assert:((n1 bitShift:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1394
    self assert:((n1 bitShift:1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1395
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1396
    self assert:((n1 perform:'bitShift:' asSymbol with:1) printString = '200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1397
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1398
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1399
    self assert:((n1 bitShift:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1400
    self assert:((n1 bitShift:2) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1401
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1402
    self assert:((n1 perform:'bitShift:' asSymbol with:2) printString = '400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1403
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1404
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1405
    self assert:((n1 bitShift:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1406
    self assert:((n1 bitShift:3) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1407
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1408
    self assert:((n1 perform:'bitShift:' asSymbol with:3) printString = '800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1409
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1410
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1411
    self assert:((n1 bitShift:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1412
    self assert:((n1 bitShift:4) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1413
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1414
    self assert:((n1 perform:'bitShift:' asSymbol with:4) printString = '1600000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1415
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1416
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1417
    self assert:((n1 bitShift:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1418
    self assert:((n1 bitShift:5) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1419
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1420
    self assert:((n1 perform:'bitShift:' asSymbol with:5) printString = '3200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1421
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1422
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1423
    self assert:((n1 bitShift:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1424
    self assert:((n1 bitShift:6) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1425
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1426
    self assert:((n1 perform:'bitShift:' asSymbol with:6) printString = '6400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1427
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1428
    s := s + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1429
    self assert:((n1 bitShift:s) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1430
    self assert:((n1 bitShift:7) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1431
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '12800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1432
    self assert:((n1 perform:'bitShift:' asSymbol with:7) printString = '12800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1433
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1434
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1435
     self basicNew testIntegerShifts1
45
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1436
    "
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1437
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1438
    "Created: / 6.6.1999 / 14:47:51 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1439
    "Modified: / 9.6.1999 / 17:49:57 / cg"
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1440
!
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1441
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1442
testIntegerShifts2
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1443
    "arithmetic tests.
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1444
     Notice, the arithmetic tests are both performed via regular sends
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1445
     and via constructed performs. The reason is to test both inlined
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1446
     JIT-compiler code AND the regular methods code."
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1447
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1448
    |n1 s|
5d24d22a546b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 44
diff changeset
  1449
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1450
    n1 := 12800000.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1451
    s := -1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1452
    self assert:((n1 bitShift:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1453
    self assert:((n1 bitShift:-1) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1454
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1455
    self assert:((n1 perform:'bitShift:' asSymbol with:-1) printString = '6400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1456
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1457
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1458
    self assert:((n1 bitShift:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1459
    self assert:((n1 bitShift:-2) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1460
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '3200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1461
    self assert:((n1 perform:'bitShift:' asSymbol with:-2) printString = '3200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1462
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1463
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1464
    self assert:((n1 bitShift:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1465
    self assert:((n1 bitShift:-3) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1466
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1467
    self assert:((n1 perform:'bitShift:' asSymbol with:-3) printString = '1600000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1468
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1469
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1470
    self assert:((n1 bitShift:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1471
    self assert:((n1 bitShift:-4) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1472
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1473
    self assert:((n1 perform:'bitShift:' asSymbol with:-4) printString = '800000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1474
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1475
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1476
    self assert:((n1 bitShift:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1477
    self assert:((n1 bitShift:-5) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1478
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1479
    self assert:((n1 perform:'bitShift:' asSymbol with:-5) printString = '400000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1480
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1481
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1482
    self assert:((n1 bitShift:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1483
    self assert:((n1 bitShift:-6) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1484
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1485
    self assert:((n1 perform:'bitShift:' asSymbol with:-6) printString = '200000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1486
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1487
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1488
    self assert:((n1 bitShift:s) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1489
    self assert:((n1 bitShift:-7) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1490
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1491
    self assert:((n1 perform:'bitShift:' asSymbol with:-7) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1492
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1493
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1494
    self assert:((n1 bitShift:s) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1495
    self assert:((n1 bitShift:-8) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1496
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '50000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1497
    self assert:((n1 perform:'bitShift:' asSymbol with:-8) printString = '50000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1498
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1499
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1500
    self assert:((n1 bitShift:s) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1501
    self assert:((n1 bitShift:-9) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1502
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '25000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1503
    self assert:((n1 perform:'bitShift:' asSymbol with:-9) printString = '25000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1504
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1505
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1506
    self assert:((n1 bitShift:s) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1507
    self assert:((n1 bitShift:-10) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1508
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '12500').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1509
    self assert:((n1 perform:'bitShift:' asSymbol with:-10) printString = '12500').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1510
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1511
    s := s - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1512
    self assert:((n1 bitShift:s) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1513
    self assert:((n1 bitShift:-11) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1514
    self assert:((n1 perform:'bitShift:' asSymbol with:s) printString = '6250').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1515
    self assert:((n1 perform:'bitShift:' asSymbol with:-11) printString = '6250').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1516
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1517
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1518
     self basicNew testIntegerShifts2
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1519
    "
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1520
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1521
    "Created: / 6.6.1999 / 14:47:51 / cg"
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1522
    "Modified: / 9.6.1999 / 17:49:57 / cg"
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1523
!
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  1524
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1525
testIntegerShifts3
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1526
    "arithmetic tests.
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1527
     Notice, the arithmetic tests are both performed via regular sends
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1528
     and via constructed performs. The reason is to test both inlined
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1529
     JIT-compiler code AND the regular methods code."
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1530
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1531
    self assert:( self doConstantIntegerShift == 1).
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1532
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1533
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1534
     self basicNew testIntegerShifts3
95
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
  1535
    "
362e58ff28ba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 91
diff changeset
  1536
!
89
228f2b80bc17 bitShift-test
Claus Gittinger <cg@exept.de>
parents: 70
diff changeset
  1537
107
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1538
testIntegerShifts4
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1539
    "arithmetic tests.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1540
     Notice, the arithmetic tests are both performed via regular sends
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1541
     and via constructed performs. The reason is to test both inlined
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1542
     JIT-compiler code AND the regular methods code."
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1543
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1544
    |a|
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1545
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1546
    a := 16r1234.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1547
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1548
    self assert:( ((a bitShift:-4) bitAnd:16rFF) == 16r23 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1549
    self assert:( ((a bitShift:-8) bitAnd:16rFF) == 16r12 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1550
    self assert:( ((a bitShift:-12) bitAnd:16rFF) == 16r1 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1551
    self assert:( ((a bitShift:-16) bitAnd:16rFF) == 0 ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1552
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1553
    "/ should not shift in any sign bits ...
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1554
    a := 16r1FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1555
    self assert:( (a bitShift:-4) == 16r1FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1556
    a := 16r3FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1557
    self assert:( (a bitShift:-4) == 16r3FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1558
    a := 16r7FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1559
    self assert:( (a bitShift:-4) == 16r7FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1560
    a := 16rFFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1561
    self assert:( (a bitShift:-4) == 16rFFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1562
    a := 16r1FFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1563
    self assert:( (a bitShift:-4) == 16r1FFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1564
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1565
    a := 16r1FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1566
    self assert:( (a bitShift:-8) == 16r1FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1567
    a := 16r3FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1568
    self assert:( (a bitShift:-8) == 16r3FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1569
    a := 16r7FFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1570
    self assert:( (a bitShift:-8) == 16r7FFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1571
    a := 16rFFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1572
    self assert:( (a bitShift:-8) == 16rFFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1573
    a := 16r1FFFFFFFF.
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1574
    self assert:( (a bitShift:-8) == 16r1FFFFFF ).
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1575
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1576
    "
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1577
     self basicNew testIntegerShifts4
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1578
    "
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1579
!
cb302e2b079c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 104
diff changeset
  1580
565
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1581
testIsPowerOfTwo
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1582
    self assert:(1 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1583
    self assert:(2 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1584
    self assert:(4 isPowerOfTwo).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1585
    self assert:(3 isPowerOfTwo not).
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1586
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1587
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1588
     self basicNew testIsPowerOfTwo
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1589
    "
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1590
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1591
    "Created: / 27-04-2010 / 10:35:36 / cg"
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1592
!
4fcc34472bd1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 564
diff changeset
  1593
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1594
testLargeAddition
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1595
    "general conversion & arithmetic tests.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1596
     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
  1597
     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
  1598
     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
  1599
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  1600
    |s n1 n2 x|
13
45a348a410e8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
  1601
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1602
    "Large + Large addition"
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1603
    self testReading1.
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1604
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1605
    self assert:((20 factorial + 20 factorial) printString = '4865804016353280000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1606
    self assert:((20 factorial + 1) printString = '2432902008176640001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1607
    self assert:((20 factorial + 1000) printString = '2432902008176641000').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1608
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1609
    "Large + Small addition"
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1610
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1611
    self testLargeAddition1.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1612
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1613
    "Large + Large addition"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1614
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1615
    self testLargeAddition2.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1616
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1617
    "Large - small subtraction"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1618
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1619
    self testLargeAddition3.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1620
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1621
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1622
     self basicNew testLargeAddition
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1623
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1624
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1625
    "Modified: / 4.6.1999 / 15:26:55 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1626
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1627
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1628
testLargeAddition1
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1629
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1630
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1631
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1632
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1633
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1634
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1635
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1636
    "Large + Small addition"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1637
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1638
    n1 := 16r3FFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1639
    self assert:((n1 + n2 ) hexPrintString = '40000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1640
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1641
    n1 := 16r3FFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1642
    self assert:((n1 + n2 ) hexPrintString = '400000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1643
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1644
    n1 := 16r3FFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1645
    self assert:((n1 + n2 ) hexPrintString = '4000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1646
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1647
    n1 := 16r3FFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1648
    self assert:((n1 + n2 ) hexPrintString = '40000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1649
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1650
    n1 := 16r3FFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1651
    self assert:((n1 + n2 ) hexPrintString = '400000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1652
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1653
    n1 := 16r3FFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1654
    self assert:((n1 + n2 ) hexPrintString = '4000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1655
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1656
    n1 := 16r3FFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1657
    self assert:((n1 + n2 ) hexPrintString = '40000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1658
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '40000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1659
    n1 := 16r3FFFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1660
    self assert:((n1 + n2 ) hexPrintString = '400000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1661
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '400000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1662
    n1 := 16r3FFFFFFFFFFFFFFF. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1663
    self assert:((n1 + n2 ) hexPrintString = '4000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1664
    self assert:((n1 perform:'+' asSymbol with:n2 ) hexPrintString = '4000000000000000').
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1665
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1666
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1667
     self basicNew testLargeAddition1
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1668
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1669
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1670
    "Modified: / 4.6.1999 / 15:26:55 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1671
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1672
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1673
testLargeAddition2
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1674
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1675
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1676
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1677
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1678
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1679
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1680
29
cedaa7d102d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 28
diff changeset
  1681
    "Large + Large addition"
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1682
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1683
    n1 := 16r100000000. n2 := 16r7FFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1684
    self assert:((n1 - n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1685
    self assert:((16r100000000 - n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1686
    self assert:((n1 - 16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1687
    self assert:((16r100000000 - 16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1688
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1689
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1690
    self assert:((n1 perform:'-' asSymbol with:16r7FFFFFFF ) hexPrintString = '80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1691
    self assert:((16r100000000 perform:'-' asSymbol with:16r7FFFFFFF ) hexPrintString = '80000001').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1692
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1693
    n1 := 16r100000000. n2 := 16r80000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1694
    self assert:((n1 - n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1695
    self assert:((16r100000000 - n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1696
    self assert:((n1 - 16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1697
    self assert:((16r100000000 - 16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1698
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1699
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1700
    self assert:((n1 perform:'-' asSymbol with:16r80000000 ) hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1701
    self assert:((16r100000000 perform:'-' asSymbol with:16r80000000 ) hexPrintString = '80000000').
17
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  1702
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  1703
    n1 := 16r100000000. n2 := 16rFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1704
    self assert:((n1 - n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1705
    self assert:((16r100000000 - n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1706
    self assert:((x := n1 - 16rFFFFFFFF) == 1).
17
2573c1ad19a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
  1707
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1708
    self assert:((n1 - 16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1709
    self assert:((16r100000000 - 16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1710
    self assert:((n1 perform:'-' asSymbol with:n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1711
    self assert:((16r100000000 perform:'-' asSymbol with:n2 ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1712
    self assert:((n1 perform:'-' asSymbol with:16rFFFFFFFF ) hexPrintString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1713
    self assert:((16r100000000 perform:'-' asSymbol with:16rFFFFFFFF ) hexPrintString = '1').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1714
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1715
    n1 := 16r100000000. n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1716
    self assert:((n1 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1717
    self assert:((n1 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1718
    self assert:((16r100000000 - n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1719
    self assert:((n1 - 1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1720
    self assert:((16r100000000 - 1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1721
    self assert:((n1 perform:'-' asSymbol with:n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1722
    self assert:((16r100000000 perform:'-' asSymbol with:n2) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1723
    self assert:((n1 perform:'-' asSymbol with:1) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1724
    self assert:((16r100000000 perform:'-' asSymbol with:1) hexPrintString = 'FFFFFFFF').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1725
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1726
    n1 := 16r100000000. n2 := 16r10000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1727
    self assert:((n1 - n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1728
    self assert:((16r100000000 - n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1729
    self assert:((n1 - 16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1730
    self assert:((16r100000000 - 16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1731
    self assert:((n1 perform:'-' asSymbol with:n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1732
    self assert:((16r100000000 perform:'-' asSymbol with:n2) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1733
    self assert:((n1 perform:'-' asSymbol with:16r10000000) hexPrintString = 'F0000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1734
    self assert:((16r100000000 perform:'-' asSymbol with:16r10000000) hexPrintString = 'F0000000').
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1735
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1736
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1737
     self basicNew testLargeAddition2
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1738
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1739
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1740
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1741
testLargeAddition3
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1742
    "general conversion & arithmetic tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1743
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1744
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1745
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1746
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1747
    |s n1 n2 x|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  1748
23
5db5444c09d5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 22
diff changeset
  1749
    "Large - small subtraction"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1750
    self assert:((20 factorial + 20 factorial - 1) printString = '4865804016353279999').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1751
    self assert:((20 factorial - 10 factorial + 3628800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1752
    self assert:((20 factorial - 11 factorial + 39916800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1753
    self assert:((20 factorial - 12 factorial + 479001600) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1754
    self assert:((20 factorial - 13 factorial + 6227020800) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1755
    self assert:((20 factorial - 14 factorial + 87178291200) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1756
    self assert:((20 factorial - 15 factorial + 1307674368000) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1757
    self assert:((20 factorial - 16 factorial + 20922789888000) printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1758
    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
  1759
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1760
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1761
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1762
    n1 := n2 := 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1763
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1764
    n1 := n2 := 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1765
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1766
    n1 := n2 := 16rFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1767
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1768
    n1 := n2 := 16rFFFFFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1769
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1770
    n1 := n2 := 16rFFFFFFFFFFFFFFFF.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1771
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1772
    n1 := n2 := 1000 factorial.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1773
    self assert:((1000 factorial + n1 - n2) = 1000 factorial).
51
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1774
0e665a7d77ea checkin from browser
Claus Gittinger <cg@exept.de>
parents: 46
diff changeset
  1775
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1776
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1777
     self basicNew testLargeAddition3
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1778
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1779
52
544196f29bee *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 51
diff changeset
  1780
    "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
  1781
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1782
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1783
testLargeBitOperations
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1784
    "large bit operations test."
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1785
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1786
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFF) hexPrintString = '2211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1787
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFF) hexPrintString  = '332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1788
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFF) hexPrintString = '44332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1789
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFF) hexPrintString = '5544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1790
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFF) hexPrintString = '665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1791
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFF) hexPrintString = '77665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1792
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFF) hexPrintString = '8877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1793
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFF) hexPrintString = '998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1794
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'AA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1795
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'BBAA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1796
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'CCBBAA998877665544332211'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1797
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1798
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFF) hexPrintString = 'FFEEDDCCBBAA99887766554433FFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1799
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFF) hexPrintString  = 'FFEEDDCCBBAA998877665544FFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1800
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA9988776655FFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1801
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA99887766FFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1802
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA998877FFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1803
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA9988FFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1804
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAA99FFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1805
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBAAFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1806
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCBBFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1807
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDCCFFFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1808
     self assert:(16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFFFF) hexPrintString = 'FFEEDDFFFFFFFFFFFFFFFFFFFFFFFF'.
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1809
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  1810
    Time millisecondsToRun:[
547
80bb15555bdf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 546
diff changeset
  1811
        1000000 timesRepeat:[
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  1812
            (16rFFEEDDCCBBAA998877665544332211 bitAnd:16rFFFFFFFFFFFFFFFFFFFFFFFF)
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  1813
        ]
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1814
    ]. 
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1815
    "/ bitAnd inherited via Integer:  1638 1575 1576
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1816
    "/ bitAnd tuned in largeInteger:  172 171 172 
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1817
549
255a421653d4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 548
diff changeset
  1818
    Time millisecondsToRun:[
255a421653d4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 548
diff changeset
  1819
        1000000 timesRepeat:[
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1820
            (16rFFEEDDCCBBAA998877665544332211 bitOr:16rFFFFFFFFFFFFFFFFFFFFFFFF)
549
255a421653d4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 548
diff changeset
  1821
        ]
550
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1822
    ].     
909a51620f53 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 549
diff changeset
  1823
    "/ bitOr inherited via Integer:  1903 1856 1856
546
b441955005b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 545
diff changeset
  1824
545
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1825
    "
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1826
     self basicNew testLargeBitOperations
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1827
    "
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1828
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1829
    "Modified: / 4.6.1999 / 15:26:55 / cg"
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1830
!
99ccb895860f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  1831
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1832
testLargeCompression1
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1833
    |l nullBytes|
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1834
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1835
    #(
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1836
        #[ 1 ]          16r01
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1837
        #[ 1 2 ]        16r0201
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1838
        #[ 1 2 3]       16r030201
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1839
        #[ 1 2 3 4]     16r04030201
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1840
    ) pairWiseDo:[:bytes :expected |
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1841
        0 to:16 do:[:nNullBytes |
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1842
            nullBytes := ByteArray new:nNullBytes withAll:0.
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1843
            l := LargeInteger digitBytes:(bytes , nullBytes).
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1844
            self assert:( l compressed == expected ).
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1845
        ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1846
    ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1847
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1848
    #(
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1849
        #[ 1 2 3 4 5]       16r0504030201
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1850
        #[ 1 2 3 4 5 6]     16r060504030201
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1851
        #[ 1 2 3 4 5 6 7]   16r07060504030201
932
6a02da56499a class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  1852
        #[ 1 2 3 4 5 6 7 8] 16r0807060504030201
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1853
    ) pairWiseDo:[:bytes :expected |
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1854
        0 to:16 do:[:nNullBytes |
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1855
            nullBytes := ByteArray new:nNullBytes withAll:0.
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1856
            l := LargeInteger digitBytes:(bytes , nullBytes).
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1857
            ExternalAddress pointerSize == 8 ifTrue:[
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1858
                self assert:( l compressed == expected ).
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1859
            ] ifFalse:[
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1860
                self assert:( l compressed = expected ).
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1861
            ]
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1862
        ]
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1863
    ].
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1864
933
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1865
    #(
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1866
        #[ 1 2 3 4 5 6 7 8 9]       16r090807060504030201
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1867
        #[ 1 2 3 4 5 6 7 8 9 10]    16r0a090807060504030201
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1868
        #[ 1 2 3 4 5 6 7 8 9 10 11] 16r0b0a090807060504030201
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1869
    ) pairWiseDo:[:bytes :expected |
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1870
        0 to:16 do:[:nNullBytes |
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1871
            nullBytes := ByteArray new:nNullBytes withAll:0.
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1872
            l := LargeInteger digitBytes:(bytes , nullBytes).
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1873
            self assert:( l compressed = expected ).
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1874
        ]
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1875
    ].
241ecf77b594 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 932
diff changeset
  1876
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1877
    "
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1878
     self basicNew testLargeCompression1
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1879
    "
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1880
!
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  1881
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1882
testLargeDivision
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1883
    |t v a b|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1884
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1885
    "/ 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
  1886
    t := 20 factorial.
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1887
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1888
    self assert:(t printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1889
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1890
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1891
    self assert:(t printString = '243290200817664000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1892
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1893
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1894
    self assert:(t printString = '24329020081766400').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1895
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1896
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1897
    self assert:(t printString = '2432902008176640').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1898
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1899
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1900
    self assert:(t printString = '243290200817664').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1901
    self assert:(t \\ 10 == 4).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1902
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1903
    self assert:(t printString = '24329020081766').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1904
    self assert:(t \\ 10 == 6).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1905
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1906
    self assert:(t printString = '2432902008176').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1907
    self assert:(t \\ 10 == 6).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1908
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1909
    self assert:(t printString = '243290200817').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1910
    self assert:(t \\ 10 == 7).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1911
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1912
    self assert:(t printString = '24329020081').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1913
    self assert:(t \\ 10 == 1).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1914
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1915
    self assert:(t printString = '2432902008').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1916
    self assert:(t \\ 10 == 8).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1917
    t := t // 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1918
    self assert:(t printString = '243290200').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1919
    self assert:(t \\ 10 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1920
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1921
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1922
    t := 20 factorial.
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1923
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1924
    self assert:(t printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1925
    self assert:(t \\ 1000 == 0).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1926
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1927
    self assert:(t printString = '2432902008176640').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1928
    self assert:(t \\ 1000 == 640).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1929
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1930
    self assert:(t printString = '2432902008176').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1931
    self assert:(t \\ 1000 == 176).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1932
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1933
    self assert:(t printString = '2432902008').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1934
    self assert:(t \\ 1000 == 8).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1935
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1936
    self assert:(t printString = '2432902').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1937
    self assert:(t \\ 1000 == 902).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1938
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1939
    self assert:(t printString = '2432').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1940
    self assert:(t \\ 1000 == 432).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1941
    t := t // 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1942
    self assert:(t == 2).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1943
    self assert:(t \\ 1000 == 2).
16
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1944
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1945
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1946
    t := 20 factorial.
b10bb029410d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 15
diff changeset
  1947
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1948
    "Large // SmallInt division"
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1949
    t := t // 20.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1950
    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
  1951
    t := t // 19.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1952
    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
  1953
    t := t // 18.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1954
    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
  1955
    t := t // 17.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1956
    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
  1957
    t := t // 16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1958
    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
  1959
    t := t // 15.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1960
    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
  1961
    t := t // 14.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1962
    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
  1963
    t := t // 13.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1964
    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
  1965
    t := t // 12.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1966
    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
  1967
    t := t // 11.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1968
    self assert:(t printString = 10 factorial printString).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1969
    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
  1970
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  1971
    t := 20 factorial.
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  1972
    t := t + 21 factorial.
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  1973
    t absSubtract:21 factorial.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1974
    self assert:(t compressed = 20 factorial).
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  1975
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1976
    self assert:(
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1977
             [   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1978
               |v| 
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1979
               v := 100 factorial copy.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1980
               v absSubtract:99 factorial.   
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1981
               v compressed = (100 factorial - 99 factorial).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1982
             ] value).
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  1983
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  1984
    "Large // Large division"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1985
    self assert:((20 factorial // 19 factorial) == 20).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1986
    self assert:((20 factorial * 21 // 20 // 21) = (19 factorial)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1987
    self assert:((10000 factorial // 9999 factorial) == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  1988
    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
  1989
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1990
    a := 40 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1991
    b := 39 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1992
    self assert:(a // 40 = b).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1993
    self assert:(a / 40 = b).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1994
    self assert:(a // b = 40).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1995
    self assert:(a // b = 40).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1996
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1997
    "
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1998
     self basicNew testLargeDivision
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  1999
    "
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2000
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2001
    "Modified: / 4.6.1999 / 23:54:57 / cg"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2002
!
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2003
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2004
testLargeDivision2
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2005
    |t|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2006
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2007
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2008
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2009
    self assert:(t printString = '265252859812191058636308480000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2010
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2011
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2012
    self assert:(t printString = '26525285981219105863630848000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2013
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2014
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2015
    self assert:(t printString = '2652528598121910586363084800000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2016
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2017
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2018
    self assert:(t printString = '265252859812191058636308480000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2019
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2020
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2021
    self assert:(t printString = '26525285981219105863630848000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2022
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2023
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2024
    self assert:(t printString = '2652528598121910586363084800').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2025
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2026
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2027
    self assert:(t printString = '265252859812191058636308480').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2028
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2029
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2030
    self assert:(t printString = '26525285981219105863630848').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2031
    self assert:(t \\ 10 == 8).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2032
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2033
    self assert:(t printString = '2652528598121910586363084').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2034
    self assert:(t \\ 10 == 4).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2035
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2036
    self assert:(t printString = '265252859812191058636308').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2037
    self assert:(t \\ 10 == 8).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2038
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2039
    self assert:(t printString = '26525285981219105863630').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2040
    self assert:(t \\ 10 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2041
    t := t // 10.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2042
    self assert:(t printString = '2652528598121910586363').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2043
    self assert:(t \\ 10 == 3).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2044
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2045
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2046
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2047
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2048
    self assert:(t printString = '265252859812191058636308480000000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2049
    self assert:(t \\ 1000 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2050
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2051
    self assert:(t printString = '265252859812191058636308480000').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2052
    self assert:(t \\ 1000 == 0).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2053
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2054
    self assert:(t printString = '265252859812191058636308480').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2055
    self assert:(t \\ 1000 == 480).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2056
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2057
    self assert:(t printString = '265252859812191058636308').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2058
    self assert:(t \\ 1000 == 308).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2059
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2060
    self assert:(t printString = '265252859812191058636').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2061
    self assert:(t \\ 1000 == 636).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2062
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2063
    self assert:(t printString = '265252859812191058').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2064
    self assert:(t \\ 1000 == 058).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2065
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2066
    self assert:(t printString = '265252859812191').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2067
    self assert:(t \\ 1000 == 191).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2068
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2069
    self assert:(t printString = '265252859812').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2070
    self assert:(t \\ 1000 == 812).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2071
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2072
    self assert:(t printString = '265252859').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2073
    self assert:(t \\ 1000 == 859).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2074
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2075
    self assert:(t printString = '265252').
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2076
    self assert:(t \\ 1000 == 252).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2077
    t := t // 1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2078
    self assert:(t == 265).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2079
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2080
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2081
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2082
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2083
    "Large // SmallInt division"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2084
    t := t // 30.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2085
    self assert:(t printString = 29 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2086
    t := t // 29.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2087
    self assert:(t printString = 28 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2088
    t := t // 28.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2089
    self assert:(t printString = 27 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2090
    t := t // 27.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2091
    self assert:(t printString = 26 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2092
    t := t // 26.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2093
    self assert:(t printString = 25 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2094
    t := t // 25.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2095
    self assert:(t printString = 24 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2096
    t := t // 24.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2097
    self assert:(t printString = 23 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2098
    t := t // 23.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2099
    self assert:(t printString = 22 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2100
    t := t // 22.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2101
    self assert:(t printString = 21 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2102
    t := t // 21.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2103
    self assert:(t printString = 20 factorial printString).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2104
    self assert:(t = 20 factorial).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2105
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2106
    t := 30 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2107
    t := t + 31 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2108
    t absSubtract:31 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2109
    self assert:(t compressed = 30 factorial).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2110
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2111
    "Large // Large division"
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2112
    self assert:((30 factorial // 29 factorial) == 30).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2113
    self assert:((30 factorial * 31 // 30 // 31) = (29 factorial)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2114
    self assert:((10000 factorial // 9999 factorial) == 10000).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2115
    self assert:((10000 factorial // 9999 factorial) == (10000 factorial / 9999 factorial)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2116
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2117
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2118
     self basicNew testLargeDivision
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2119
    "
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2120
26
eb5fdf34fb28 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 25
diff changeset
  2121
    "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
  2122
!
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2123
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2124
testLargeIntegerHelpers
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2125
    |t1 t2|
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2126
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2127
    "/ mul2
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2128
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2129
    t1 := 16r12345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2130
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2131
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2132
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2133
    t1 := 16r1234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2134
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2135
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2136
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2137
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2138
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2139
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2140
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2141
    t1 := 16r12345678901234567890123456789012345678901234567890123456789012345678901234567890.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2142
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2143
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2144
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2145
    t1 := 10000 factorial.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2146
    t2 := t1 deepCopy.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2147
    self assert:(t2 mul2 = (t1 * 2)).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2148
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2149
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2150
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2151
    self assert:(t2 mul2 = (t1 * 2)).
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2152
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2153
"/    t1 := 1000 factorial.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2154
"/    t := Time millisecondsToRun:[ 100000 timesRepeat:[ t1 mul2. ] ].
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2155
"/    Transcript showCR:t.
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2156
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2157
    "/ div2
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2158
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2159
    t1 := 16r12345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2160
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2161
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2162
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2163
    "/ do not compare t2 = t1 // x, because t2 may be unnormalized
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2164
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2165
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2166
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2167
    self assert:(t2 printStringRadix:16) = ((t1 // 4) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2168
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2169
    self assert:(t2 printStringRadix:16) = ((t1 // 8) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2170
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2171
    self assert:(t2 printStringRadix:16) = ((t1 // 16) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2172
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2173
    self assert:(t2 printStringRadix:16) = ((t1 // 32) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2174
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2175
    self assert:(t2 printStringRadix:16) = ((t1 // 64) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2176
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2177
    self assert:(t2 printStringRadix:16) = ((t1 // 128) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2178
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2179
    self assert:(t2 printStringRadix:16) = ((t1 // 256) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2180
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2181
    self assert:(t2 printStringRadix:16) = ((t1 // 512) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2182
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2183
    self assert:(t2 printStringRadix:16) = ((t1 // 1024) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2184
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2185
    t1 := 16r1234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2186
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2187
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2188
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2189
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2190
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2191
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2192
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2193
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2194
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2195
    t1 := 16r12345678901234567890123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2196
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2197
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2198
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2199
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2200
    self assert:(t2 printStringRadix:16) = ((t1 // 4) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2201
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2202
    self assert:(t2 printStringRadix:16) = ((t1 // 8) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2203
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2204
    self assert:(t2 printStringRadix:16) = ((t1 // 16) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2205
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2206
    t1 := 10000 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2207
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2208
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2209
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2210
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2211
    t1 := 16r123456789012345678901234567890123456789012345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2212
    t2 := t1 deepCopy.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2213
    t2 div2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2214
    self assert:(t2 printStringRadix:16) = ((t1 // 2) printStringRadix:16).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2215
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2216
    t1 := 12345678901234567890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2217
    t2 := t1 divMod:1000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2218
    self assert:(t2 at:1) = 12345678901234567.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2219
    self assert:(t2 at:2) = 890.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2220
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2221
    
282
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2222
    "
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2223
     self basicNew testLargeIntegerHelpers
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2224
    "
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2225
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2226
    "Modified: / 20.5.1999 / 09:41:19 / cg"
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2227
!
c894633f5110 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 238
diff changeset
  2228
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2229
testLargeMultiplication
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2230
    |t1 t2|
12
29d0f2e59dcb splitted into smaller methods to avoid JIT-bail-out
Claus Gittinger <cg@exept.de>
parents: 11
diff changeset
  2231
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2232
    "multiplication"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2233
    t1 := 100.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2234
    self assert:(t1 * t1 == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2235
    self assert:((t1 perform:'*' asSymbol with:t1) == 10000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2236
    self assert:((t1 * t1) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2237
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2238
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2239
    t1 := 1000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2240
    self assert:(t1 * t1 == 1000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2241
    self assert:((t1 perform:'*' asSymbol with:t1) == 1000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2242
    self assert:((t1 * t1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2243
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2244
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2245
    t1 := 10000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2246
    self assert:(t1 * t1 == 100000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2247
    self assert:((t1 perform:'*' asSymbol with:t1) == 100000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2248
    self assert:((t1 * t1) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2249
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '100000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2250
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2251
    t1 := 100000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2252
    SmallInteger maxBytes == 4 ifTrue:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2253
        self assert:(t1 * t1 = 10000000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2254
        self assert:((t1 perform:'*' asSymbol with:t1) = 10000000000).
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2255
    ].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2256
    SmallInteger maxBytes == 8 ifTrue:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2257
        self assert:(t1 * t1 == 10000000000).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2258
        self assert:((t1 perform:'*' asSymbol with:t1) == 10000000000).
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2259
    ].
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
  2260
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2261
    self assert:((t1 * t1) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2262
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2263
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2264
    t1 := 1000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2265
    self assert:((t1 * t1) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2266
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2267
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2268
    t1 := 10000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2269
    self assert:((t1 * t1) printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2270
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '100000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2271
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2272
    t1 := 100000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2273
    self assert:((t1 * t1) printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2274
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '10000000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2275
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2276
    t1 := 1000000000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2277
    self assert:((t1 * t1) printString = '1000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2278
    self assert:((t1 perform:'*' asSymbol with:t1) printString = '1000000000000000000').
11
30bdd5912a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10
diff changeset
  2279
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2280
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2281
    "Large * SmallInt multiplication"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2282
    self assert:(10 factorial printString = '3628800').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2283
    self assert:(20 factorial printString = '2432902008176640000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2284
    self assert:(100 factorial printString = '93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2285
    self assert:(1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000').
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2286
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2287
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2288
    t2 := 100000000000000000.                   "/ large on 32bit; small on 64bt machines
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2289
    self assert:(t1 * t2) = 10000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2290
    self assert:(t2 * t1) = 10000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2291
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2292
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2293
    t2 := 1000000000000000000.                  "/ large on 32bit; small on 64bt machines
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2294
    self assert:(t1 * t2) = 100000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2295
    self assert:(t2 * t1) = 100000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2296
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2297
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2298
    t2 := 10000000000000000000.                 "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2299
    self assert:(t1 * t2) = 1000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2300
    self assert:(t2 * t1) = 1000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2301
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2302
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2303
    t2 := 100000000000000000000.                "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2304
    self assert:(t1 * t2) = 10000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2305
    self assert:(t2 * t1) = 10000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2306
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2307
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2308
    t2 := 1000000000000000000000.               "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2309
    self assert:(t1 * t2) = 100000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2310
    self assert:(t2 * t1) = 100000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2311
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2312
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2313
    t2 := 10000000000000000000000.              "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2314
    self assert:(t1 * t2) = 1000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2315
    self assert:(t2 * t1) = 1000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2316
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2317
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2318
    t2 := 100000000000000000000000.             "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2319
    self assert:(t1 * t2) = 10000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2320
    self assert:(t2 * t1) = 10000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2321
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2322
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2323
    t2 := 1000000000000000000000000.            "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2324
    self assert:(t1 * t2) = 100000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2325
    self assert:(t2 * t1) = 100000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2326
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2327
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2328
    t2 := 10000000000000000000000000.           "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2329
    self assert:(t1 * t2) = 1000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2330
    self assert:(t2 * t1) = 1000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2331
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2332
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2333
    t2 := 100000000000000000000000000.          "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2334
    self assert:(t1 * t2) = 10000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2335
    self assert:(t2 * t1) = 10000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2336
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2337
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2338
    t2 := 1000000000000000000000000000.         "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2339
    self assert:(t1 * t2) = 100000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2340
    self assert:(t2 * t1) = 100000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2341
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2342
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2343
    t2 := 10000000000000000000000000000.        "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2344
    self assert:(t1 * t2) = 1000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2345
    self assert:(t2 * t1) = 1000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2346
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2347
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2348
    t2 := 100000000000000000000000000000.       "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2349
    self assert:(t1 * t2) = 10000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2350
    self assert:(t2 * t1) = 10000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2351
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2352
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2353
    t2 := 1000000000000000000000000000000.      "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2354
    self assert:(t1 * t2) = 100000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2355
    self assert:(t2 * t1) = 100000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2356
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2357
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2358
    t2 := 10000000000000000000000000000000.     "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2359
    self assert:(t1 * t2) = 1000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2360
    self assert:(t2 * t1) = 1000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2361
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2362
    t1 := 100000000.                            "/ small
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2363
    t2 := 100000000000000000000000000000000.    "/ large
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2364
    self assert:(t1 * t2) = 10000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2365
    self assert:(t2 * t1) = 10000000000000000000000000000000000000000.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2366
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
  2367
    "Large * Large multiplication"
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2368
    self assert:((16r3FFF * 16r3FFF) hexPrintString = 'FFF8001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2369
    self assert:((16r7FFF * 16r7FFF) hexPrintString = '3FFF0001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2370
    self assert:((16rFFFF * 16rFFFF) hexPrintString = 'FFFE0001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2371
    self assert:((16r3FFFFF * 16r3FFFFF) hexPrintString = 'FFFFF800001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2372
    self assert:((16r7FFFFF * 16r7FFFFF) hexPrintString = '3FFFFF000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2373
    self assert:((16rFFFFFF * 16rFFFFFF) hexPrintString = 'FFFFFE000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2374
    self assert:((16r3FFFFFFF * 16r3FFFFFFF) hexPrintString = 'FFFFFFF80000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2375
    self assert:((16r7FFFFFFF * 16r7FFFFFFF) hexPrintString = '3FFFFFFF00000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2376
    self assert:((16rFFFFFFFF * 16rFFFFFFFF) hexPrintString = 'FFFFFFFE00000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2377
    self assert:((16r3FFFFFFFFF * 16r3FFFFFFFFF) hexPrintString = 'FFFFFFFFF8000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2378
    self assert:((16r7FFFFFFFFF * 16r7FFFFFFFFF) hexPrintString = '3FFFFFFFFF0000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2379
    self assert:((16rFFFFFFFFFF * 16rFFFFFFFFFF) hexPrintString = 'FFFFFFFFFE0000000001').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2380
    self assert:((20 factorial * 20 factorial) printString = '5919012181389927685417441689600000000').
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2381
1024
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  2382
    t1 := 699697179634740272935560322271216335182775596927422865716399200802062765682314102885264570100200211251370690926108604161579425545019863369232209949922751354278329212124724267803033599595114924195721823679025053720850308776953208134469115885358619139670731195605237506312288263327925364912720266772715929600.
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  2383
    self assert:(t1 printString = '699697179634740272935560322271216335182775596927422865716399200802062765682314102885264570100200211251370690926108604161579425545019863369232209949922751354278329212124724267803033599595114924195721823679025053720850308776953208134469115885358619139670731195605237506312288263327925364912720266772715929600').
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  2384
    self assert:((t1 * t1) = 489576143188809998144298426641311496989165214458056165805143410866108690058261346129614030084813851082564698610174813898740525406243367146120734370570458429364167811695064904353093506532695086211301649001517008746471464304183710723162864634442619484210170532881759249266026059786349673031239277666195699357198366128286910123306594912484590029738722281929300359929462301099981920256369394887701755497894820998573896950238852994224811101315810851671448056042419257789317787959570728520197146733902575090480065597582292177085754523686580725860228636039424698638422538988050350726807943014483010988455057592156160000).
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  2385
    self assert:((t1 * t1) printString = '489576143188809998144298426641311496989165214458056165805143410866108690058261346129614030084813851082564698610174813898740525406243367146120734370570458429364167811695064904353093506532695086211301649001517008746471464304183710723162864634442619484210170532881759249266026059786349673031239277666195699357198366128286910123306594912484590029738722281929300359929462301099981920256369394887701755497894820998573896950238852994224811101315810851671448056042419257789317787959570728520197146733902575090480065597582292177085754523686580725860228636039424698638422538988050350726807943014483010988455057592156160000').
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  2386
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2387
    #( 
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2388
        16rFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2389
        16rFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2390
        16rFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2391
        16rFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2392
        16rFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2393
        16rFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2394
        16rFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2395
        16rFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2396
        16rFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2397
        16rFFFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2398
        16rFFFFFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2399
        16rFFFFFFFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2400
    ) do:[:eachFactor1 |
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2401
        #( 
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2402
            16rFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2403
            16rFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2404
            16rFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2405
            16rFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2406
            16rFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2407
            16rFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2408
            16rFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2409
            16rFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2410
            16rFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2411
            16rFFFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2412
            16rFFFFFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2413
            16rFFFFFFFFFFFFFFFFFFFFFFFF
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2414
        ) do:[:eachFactor2 |
941
0192003475ec class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 940
diff changeset
  2415
            |t3|
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2416
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2417
            t1 := (eachFactor1 * eachFactor2).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2418
            t2 := (eachFactor2 * eachFactor1).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2419
        
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2420
            self assert:(t1 = t2).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2421
t1 = 20203181441155852828228393631745 ifTrue:[
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2422
 eachFactor1 = 1099511627775 ifTrue:[
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2423
self halt
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2424
]].
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2425
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2426
            self assert:(t1 / eachFactor1) = eachFactor2.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2427
            self assert:(t1 / eachFactor2) = eachFactor1.
941
0192003475ec class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 940
diff changeset
  2428
            t3 := (eachFactor1 asLargeInteger * eachFactor2 asLargeInteger).
0192003475ec class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 940
diff changeset
  2429
            self assert: t1 = t3.
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2430
        ].
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2431
    ].
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2432
    
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2433
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2434
     self basicNew testLargeMultiplication
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2435
    "
10
3cbe91972e2b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 9
diff changeset
  2436
1024
17f4613fc1d4 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 941
diff changeset
  2437
    "Modified: / 02-12-2013 / 15:05:14 / cg"
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2438
!
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2439
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2440
testLargeSubtraction1
336
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2441
    |a1 a2 a b1 b2 b c1 c2 c|
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2442
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2443
    "/ on 32bit machines - these lead to smallint overflow
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2444
    self assert:((2770568 + 2770568) printString = '5541136').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2445
    self assert:((2770568 - 2770568) printString = '0').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2446
    self assert:((2770568 negated + 2770568 negated) printString = '-5541136').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2447
    self assert:((5541136 negated - 2770568 negated) printString = '-2770568').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2448
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2449
    "Large - small subtraction"
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2450
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2451
    self assert:((2770568900 + 2770568900) printString = '5541137800').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2452
    self assert:((2770568900 - 2770568900) printString = '0').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2453
    self assert:((2770568900 negated + 2770568900 negated) printString = '-5541137800').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2454
    self assert:((5541137800 negated - 2770568900 negated) printString = '-2770568900').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2455
    self assert:((2770568900 negated - 5541137800 negated) printString = '2770568900').
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2456
336
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2457
    a1 := -2770568900. a2 := 59049.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2458
    a := (a1 / a2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2459
    b1 := -5872025600. b2 := 59049.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2460
    b := (b1 / b2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2461
    c1 := 344606300. c2 := 6561.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2462
    c := (c1 / c2) negated.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2463
    self assert:(a - b closeTo: c).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2464
    self assert:((a - b) asFloat closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2465
    self assert:((a asFloat - b) closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2466
    self assert:((a - b asFloat) closeTo: c asFloat).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2467
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2468
    a := -10.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2469
    b := -12.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2470
    self assert:(a - b = 2).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2471
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2472
    a := -10000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2473
    b := -12000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2474
    self assert:(a - b = 2000000).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2475
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2476
    a := -100000000000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2477
    b := -120000000000000.
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2478
    self assert:(a - b = 20000000000000).
031ea06f1959 more checks
sr
parents: 335
diff changeset
  2479
337
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  2480
    "smallInteger - largeInteger"
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  2481
    self assert:(-1000000000 - -2000000000 = 1000000000).
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  2482
    "largeInteger - smallInteger"
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  2483
    self assert:(-2000000000 - -1000000000 = -1000000000).
c0fbd5e3dd76 more checks
sr
parents: 336
diff changeset
  2484
940
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2485
    a := 40 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2486
    b := 39 factorial.
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2487
    self assert:(a - b + b = a).
f0b195f99e55 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 937
diff changeset
  2488
335
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2489
    "
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2490
     self basicNew testLargeSubtraction1
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2491
    "
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2492
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2493
    "Modified: / 27.11.1999 / 16:41:54 / cg"
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2494
!
bdafaceb889a oops - largeInteger subtraction
sr
parents: 316
diff changeset
  2495
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2496
testLargeSubtraction2
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2497
    "/ on 64bit machines - these lead to smallint overflow
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2498
    self assert:((16r3FFFFFFFFFFFFFFF negated - 1 - 1) printString = '-4611686018427387905').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2499
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2500
    "
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2501
     self basicNew testLargeSubtraction2
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2502
    "
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2503
!
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2504
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2505
testLiteralNumbers
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2506
    self assert:(self num_00000000000010000 hexPrintString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2507
    self assert:(self num_00000000000100000 hexPrintString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2508
    self assert:(self num_00000000001000000 hexPrintString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2509
    self assert:(self num_00000000010000000 hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2510
    self assert:(self num_00000000100000000 hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2511
    self assert:(self num_00000001000000000 hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2512
    self assert:(self num_00000010000000000 hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2513
    self assert:(self num_00000100000000000 hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2514
    self assert:(self num_00001000000000000 hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2515
    self assert:(self num_00010000000000000 hexPrintString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2516
    self assert:(self num_00100000000000000 hexPrintString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2517
    self assert:(self num_01000000000000000 hexPrintString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2518
    self assert:(self num_10000000000000000 hexPrintString = '10000000000000000').
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2519
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2520
    self assert:(self num_00000000000007FFF hexPrintString = '7FFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2521
    self assert:(self num_00000000000008000 hexPrintString = '8000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2522
    self assert:(self num_0000000000000FFFF hexPrintString = 'FFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2523
    self assert:(self num_000000000007FFFFF hexPrintString = '7FFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2524
    self assert:(self num_00000000000800000 hexPrintString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2525
    self assert:(self num_00000000000FFFFFF hexPrintString = 'FFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2526
    self assert:(self num_0000000007FFFFFFF hexPrintString = '7FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2527
    self assert:(self num_00000000080000000 hexPrintString = '80000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2528
    self assert:(self num_000000000FFFFFFFF hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2529
    self assert:(self num_0000000FFFFFFFFFF hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2530
    self assert:(self num_00000FFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2531
    self assert:(self num_000FFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2532
    self assert:(self num_0FFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2533
    self assert:(self num_1FFFFFFFFFFFFFFFF hexPrintString = '1FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2534
    self assert:(self num_20000000000000000 hexPrintString = '20000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2535
    self assert:(self num_3FFFFFFFFFFFFFFFF hexPrintString = '3FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2536
    self assert:(self num_40000000000000000 hexPrintString = '40000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2537
    self assert:(self num_7FFFFFFFFFFFFFFFF hexPrintString = '7FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2538
    self assert:(self num_80000000000000000 hexPrintString = '80000000000000000').
21
7acbbe514e11 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 20
diff changeset
  2539
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2540
    self assert:(self num_00000FFFFFFFFFFFE hexPrintString = 'FFFFFFFFFFFE').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2541
    self assert:(self num_00000FFFFFFFFFFFC hexPrintString = 'FFFFFFFFFFFC').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2542
    self assert:(self num_00000FFFFFFFFFFF8 hexPrintString = 'FFFFFFFFFFF8').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2543
    self assert:(self num_00000FFFFFFFFFFF0 hexPrintString = 'FFFFFFFFFFF0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2544
    self assert:(self num_00000FFFFFFFFFFE0 hexPrintString = 'FFFFFFFFFFE0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2545
    self assert:(self num_00000FFFFFFFFFFC0 hexPrintString = 'FFFFFFFFFFC0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2546
    self assert:(self num_00000FFFFFFFFFF80 hexPrintString = 'FFFFFFFFFF80').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2547
    self assert:(self num_00000FFFFFFFFFF00 hexPrintString = 'FFFFFFFFFF00').
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2548
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2549
    self assert:(self num_0000000000FFF0000 hexPrintString = 'FFF0000').
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
  2550
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2551
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2552
     self basicNew testLiteralNumbers
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2553
    "
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2554
22
7f01716fbbe2 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 21
diff changeset
  2555
    "Modified: / 4.6.1999 / 18:41:09 / cg"
19
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2556
!
c21f3bbedd21 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 18
diff changeset
  2557
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2558
testModulu
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2559
    |a b op|
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2560
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2561
    op := #\\.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2562
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2563
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2564
    self assert:(-1 \\ 8 == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2565
    self assert:(a \\ 8 == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2566
    self assert:(-1 \\ b == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2567
    self assert:(a \\ b == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2568
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2569
    self assert:((-1 perform:op with: 8) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2570
    self assert:((a perform:op with: 8) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2571
    self assert:((-1 perform:op with: b) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2572
    self assert:((a perform:op with: b) == 7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2573
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2574
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2575
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2576
    self assert:(1 \\ -8 == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2577
    self assert:(a \\ -8 == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2578
    self assert:(1 \\ b == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2579
    self assert:(a \\ b == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2580
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2581
    self assert:((1 perform:op with: -8) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2582
    self assert:((a perform:op with: -8) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2583
    self assert:((1 perform:op with: b) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2584
    self assert:((a perform:op with: b) == -7).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2585
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2586
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2587
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2588
    self assert:(-1 \\ -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2589
    self assert:(a \\ -8 == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2590
    self assert:(-1 \\ b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2591
    self assert:(a \\ b == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2592
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2593
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2594
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2595
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2596
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2597
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2598
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2599
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2600
    self assert:(1 \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2601
    self assert:(a \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2602
    self assert:(1 \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2603
    self assert:(a \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2604
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2605
    self assert:((1 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2606
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2607
    self assert:((1 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2608
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2609
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2610
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2611
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2612
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2613
    self assert:(-17 \\ 8 == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2614
    self assert:(a \\ 8 == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2615
    self assert:(-17 \\ b == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2616
    self assert:(a \\ b == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2617
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2618
    self assert:((-17 perform:op with: 8) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2619
    self assert:((a perform:op with: 8) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2620
    self assert:((-17 perform:op with: b) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2621
    self assert:((a perform:op with: b) == 7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2622
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2623
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2624
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2625
    self assert:(17 \\ -8 == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2626
    self assert:(a \\ -8 == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2627
    self assert:(17 \\ b == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2628
    self assert:(a \\ b == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2629
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2630
    self assert:((17 perform:op with: -8) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2631
    self assert:((a perform:op with: -8) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2632
    self assert:((17 perform:op with: b) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2633
    self assert:((a perform:op with: b) == -7).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2634
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2635
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2636
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2637
    self assert:(-17 \\ -8 == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2638
    self assert:(a \\ -8 == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2639
    self assert:(-17 \\ b == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2640
    self assert:(a \\ b == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2641
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2642
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2643
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2644
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2645
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2646
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2647
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2648
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2649
    self assert:(17 \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2650
    self assert:(a \\ 8 == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2651
    self assert:(17 \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2652
    self assert:(a \\ b == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2653
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2654
    self assert:((17 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2655
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2656
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2657
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2658
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2659
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2660
    op := #rem:.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2661
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2662
    b := 8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2663
    self assert:((-1 rem: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2664
    self assert:((a rem: 8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2665
    self assert:((-1 rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2666
    self assert:((a rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2667
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2668
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2669
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2670
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2671
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2672
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2673
    a := 1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2674
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2675
    self assert:((1 rem: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2676
    self assert:((a rem: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2677
    self assert:((1 rem: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2678
    self assert:((a rem: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2679
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2680
    self assert:((1 perform:op with: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2681
    self assert:((a perform:op with: -8) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2682
    self assert:((1 perform:op with: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2683
    self assert:((a perform:op with: b) == 1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2684
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2685
    a := -1.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2686
    b := -8.
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2687
    self assert:((-1 rem: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2688
    self assert:((a rem: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2689
    self assert:((-1 rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2690
    self assert:((a rem: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2691
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2692
    self assert:((-1 perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2693
    self assert:((a perform:op with: -8) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2694
    self assert:((-1 perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2695
    self assert:((a perform:op with: b) == -1).
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2696
150
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2697
    a := 1.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2698
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2699
    self assert:((1 rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2700
    self assert:((a rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2701
    self assert:((1 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2702
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2703
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2704
    self assert:((1 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2705
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2706
    self assert:((1 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2707
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2708
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2709
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2710
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2711
    self assert:((-17 rem: 8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2712
    self assert:((a rem: 8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2713
    self assert:((-17 rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2714
    self assert:((a rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2715
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2716
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2717
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2718
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2719
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2720
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2721
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2722
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2723
    self assert:((17 rem: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2724
    self assert:((a rem: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2725
    self assert:((17 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2726
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2727
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2728
    self assert:((17 perform:op with: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2729
    self assert:((a perform:op with: -8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2730
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2731
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2732
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2733
    a := -17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2734
    b := -8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2735
    self assert:((-17 rem: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2736
    self assert:((a rem: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2737
    self assert:((-17 rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2738
    self assert:((a rem: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2739
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2740
    self assert:((-17 perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2741
    self assert:((a perform:op with: -8) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2742
    self assert:((-17 perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2743
    self assert:((a perform:op with: b) == -1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2744
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2745
    a := 17.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2746
    b := 8.
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2747
    self assert:((17 rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2748
    self assert:((a rem: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2749
    self assert:((17 rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2750
    self assert:((a rem: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2751
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2752
    self assert:((17 perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2753
    self assert:((a perform:op with: 8) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2754
    self assert:((17 perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2755
    self assert:((a perform:op with: b) == 1).
a57daf60d4f2 more modulu & division tests
Claus Gittinger <cg@exept.de>
parents: 112
diff changeset
  2756
112
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2757
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2758
     self basicNew testModulu
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2759
    "
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2760
!
e3bd6adcc7cf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
  2761
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2762
testPrinting1
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2763
    self assert:(10 printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2764
    self assert:(100 printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2765
    self assert:(1000 printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2766
    self assert:(10000 printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2767
    self assert:(100000 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2768
    self assert:(1000000 printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2769
    self assert:(10000000 printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2770
    self assert:(100000000 printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2771
    self assert:(1000000000 printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2772
    self assert:(10000000000 printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2773
    self assert:(100000000000 printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2774
    self assert:(1000000000000 printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2775
    self assert:(10000000000000 printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2776
    self assert:(100000000000000 printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2777
    self assert:(1000000000000000 printString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2778
    self assert:(10000000000000000 printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2779
    self assert:(100000000000000000 printString = '100000000000000000').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2780
    self assert:(1000000000000000000 printString = '1000000000000000000').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2781
    self assert:(10000000000000000000 printString = '10000000000000000000').
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2782
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2783
    self assert:(16rF hexPrintString = 'F').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2784
    self assert:(16rFF hexPrintString = 'FF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2785
    self assert:(16rFFF hexPrintString = 'FFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2786
    self assert:(16rFFFF hexPrintString = 'FFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2787
    self assert:(16rFFFFF hexPrintString = 'FFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2788
    self assert:(16rFFFFFF hexPrintString = 'FFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2789
    self assert:(16rFFFFFFF hexPrintString = 'FFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2790
    self assert:(16rFFFFFFFF hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2791
    self assert:(16rFFFFFFFFF hexPrintString = 'FFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2792
    self assert:(16rFFFFFFFFFF hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2793
    self assert:(16rFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2794
    self assert:(16rFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2795
    self assert:(16rFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2796
    self assert:(16rFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2797
    self assert:(16rFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2798
    self assert:(16rFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2799
    self assert:(16rFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2800
    self assert:(16rFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2801
    self assert:(16rFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2802
    self assert:(16rFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFF').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2803
    self assert:(16rFFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFFF').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2804
    self assert:(16rFFFFFFFFFFFFFFFFFFFFFF hexPrintString = 'FFFFFFFFFFFFFFFFFFFFFF').
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  2805
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2806
    self assert:(16r10 hexPrintString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2807
    self assert:(16r100 hexPrintString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2808
    self assert:(16r1000 hexPrintString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2809
    self assert:(16r10000 hexPrintString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2810
    self assert:(16r100000 hexPrintString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2811
    self assert:(16r1000000 hexPrintString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2812
    self assert:(16r10000000 hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2813
    self assert:(16r100000000 hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2814
    self assert:(16r1000000000 hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2815
    self assert:(16r10000000000 hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2816
    self assert:(16r100000000000 hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2817
    self assert:(16r1000000000000 hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2818
    self assert:(16r10000000000000 hexPrintString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2819
    self assert:(16r100000000000000 hexPrintString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2820
    self assert:(16r1000000000000000 hexPrintString = '1000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2821
    self assert:(16r10000000000000000 hexPrintString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2822
    self assert:(16r100000000000000000 hexPrintString = '100000000000000000').
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  2823
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2824
    self assert:(126 printString) = '126'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2825
    self assert:(127 printString) = '127'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2826
    self assert:(128 printString) = '128'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2827
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2828
    self assert:(255 printString) = '255'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2829
    self assert:(256 printString) = '256'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2830
    self assert:(257 printString) = '257'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2831
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2832
    self assert:(32767 printString) = '32767'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2833
    self assert:(32768 printString) = '32768'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2834
    self assert:(32769 printString) = '32769'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2835
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2836
    self assert:(65535 printString) = '65535'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2837
    self assert:(65536 printString) = '65536'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2838
    self assert:(65537 printString) = '65537'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2839
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2840
    self assert:(2147483647 printString) = '2147483647'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2841
    self assert:(2147483648 printString) = '2147483648'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2842
    self assert:(2147483649 printString) = '2147483649'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2843
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2844
    self assert:(4294967295 printString) = '4294967295'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2845
    self assert:(4294967296 printString) = '4294967296'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2846
    self assert:(4294967297 printString) = '4294967297'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2847
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2848
    self assert:(127 printStringRadix:16) = '7F'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2849
    self assert:(123 printStringRadix:12) = 'A3'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2850
    self assert:(123 printStringRadix:10) = '123'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2851
    self assert:(123 printStringRadix:8 ) = '173'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2852
    self assert:(123 printStringRadix:3 ) = '11120'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2853
    self assert:(123 printStringRadix:2 ) = '1111011'.   
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2854
    self should:[ 123 printStringRadix:1 ] raise:Error.
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2855
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2856
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2857
     self basicNew testPrinting1
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2858
    "
40
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  2859
17d7ab809846 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 39
diff changeset
  2860
    "Modified: / 26.10.1999 / 22:01:35 / stefan"
7
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2861
!
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2862
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2863
testReading1
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2864
    |t|
7341cc740119 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6
diff changeset
  2865
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2866
    self assert:((Integer readFrom:'4865804016353280000') printString = '4865804016353280000').
937
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2867
    self assert:((Integer readFrom:'4294967295') printString = '4294967295').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2868
    self assert:((Integer readFrom:'4294967295') = 4294967295).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2869
    self assert:((Integer readFrom:'4294967296') printString = '4294967296').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2870
    self assert:((Integer readFrom:'4294967296') = 4294967296).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2871
    self assert:((Integer readFrom:'4294967297') printString = '4294967297').
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2872
    self assert:((Integer readFrom:'4294967297') = 4294967297).
93ad4e077877 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 935
diff changeset
  2873
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2874
    self assert:((Integer readFrom:'FFFFFFFF' radix:16) hexPrintString = 'FFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2875
    self assert:((Integer readFrom:'FFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2876
    self assert:((Integer readFrom:'FFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2877
    self assert:((Integer readFrom:'FFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2878
    self assert:((Integer readFrom:'FFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2879
    self assert:((Integer readFrom:'FFFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFFF').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2880
    self assert:((Integer readFrom:'FFFFFFFFFFFFFF' radix:16) hexPrintString = 'FFFFFFFFFFFFFF').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2881
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2882
    self assert:((Integer readFrom:'10000000' radix:16) hexPrintString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2883
    self assert:((Integer readFrom:'100000000' radix:16) hexPrintString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2884
    self assert:((Integer readFrom:'1000000000' radix:16) hexPrintString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2885
    self assert:((Integer readFrom:'10000000000' radix:16) hexPrintString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2886
    self assert:((Integer readFrom:'100000000000' radix:16) hexPrintString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2887
    self assert:((Integer readFrom:'1000000000000' radix:16) hexPrintString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2888
    self assert:((Integer readFrom:'10000000000000' radix:16) hexPrintString = '10000000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2889
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2890
    t := Integer readFrom:'FFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2891
    self assert:((t + 1) hexPrintString = '100000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2892
    t := Integer readFrom:'FFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2893
    self assert:((t + 1) hexPrintString = '1000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2894
    t := Integer readFrom:'FFFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2895
    self assert:((t + 1) hexPrintString = '10000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2896
    t := Integer readFrom:'FFFFFFFFFFF' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2897
    self assert:((t + 1) hexPrintString = '100000000000').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2898
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2899
    t := Integer readFrom:'10000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2900
    self assert:((t + 1) hexPrintString = '10000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2901
    t := Integer readFrom:'100000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2902
    self assert:((t + 1) hexPrintString = '100000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2903
    t := Integer readFrom:'1000000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2904
    self assert:((t + 1) hexPrintString = '1000000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2905
    t := Integer readFrom:'10000000000' radix:16.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2906
    self assert:((t + 1) hexPrintString = '10000000001').
5
f100f290c769 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4
diff changeset
  2907
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2908
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2909
     self basicNew testReading1
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2910
    "
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2911
!
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2912
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2913
testSmallIntegerArithmetic
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2914
    "arithmetic tests.
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2915
     Notice, the arithmetic tests are both performed via regular sends
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2916
     and via constructed performs. The reason is to test both inlined
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2917
     JIT-compiler code AND the regular methods code."
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2918
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2919
    |s n1 n2 t|
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2920
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2921
    "/ test division and modulu ...
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2922
    self assert:(1 printString = '1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2923
    self assert:(10 printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2924
    self assert:(100 printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2925
    self assert:(1000 printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2926
    self assert:(10000 printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2927
    self assert:(100000 printString = '100000').
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2928
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2929
    "addition with overflow"
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2930
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2931
    SmallInteger maxBytes == 4 ifTrue:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2932
        n1 := 16r3FFFFFFF.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2933
        n2 := -16r40000000.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2934
    ] ifFalse:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2935
        n1 := 16r3FFFFFFFFFFFFFFF.
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2936
        n2 := -16r4000000000000000.
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2937
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2938
    self assert:(n1 class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2939
    self assert:(n2 class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2940
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2941
    self assert:((n1 + 1) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2942
    t := n1 + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2943
    self assert:((t - 1) class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2944
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2945
    self assert:((n2 - 1) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2946
    t := n2 - 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2947
    self assert:((t + 1) class == SmallInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2948
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2949
    self assert:((n1 negated) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2950
    self assert:((n2 negated) class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2951
    self assert:((n1 perform:'negated' asSymbol) class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2952
    self assert:((n2 perform:'negated' asSymbol) class == LargeInteger).
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2953
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2954
    self assert:((n1 abs == n1)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2955
    self assert:((n2 abs = n2 negated)).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2956
    self assert:((n1 perform:'abs' asSymbol) == n1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2957
    self assert:((n2 perform:'abs' asSymbol) = n2 negated).
28
fca649220051 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 27
diff changeset
  2958
38
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  2959
    self testSmallIntegerMultiplication1.
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  2960
    self testSmallIntegerMultiplication1b.
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  2961
    self testSmallIntegerMultiplication2.
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2962
    self testSmallIntegerDivision1.
38
d9e56dee842c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 37
diff changeset
  2963
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2964
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2965
     self basicNew testSmallIntegerArithmetic
27
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2966
    "
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2967
8386e8469cdf checkin from browser
Claus Gittinger <cg@exept.de>
parents: 26
diff changeset
  2968
    "Created: / 6.6.1999 / 14:47:51 / cg"
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  2969
    "Modified: / 9.6.1999 / 17:49:57 / cg"
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  2970
!
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  2971
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2972
testSmallIntegerDivision1
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2973
    "division tests.
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2974
     Notice, the arithmetic tests are both performed via regular sends
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2975
     and via constructed performs. The reason is to test both inlined
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2976
     JIT-compiler code AND the regular methods code."
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2977
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2978
    |s n1 n2 t|
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2979
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2980
    n1 := 1000.
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2981
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2982
    "/ truncation towards...
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2983
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2984
    "/ ... negative infinity
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2985
    n2 := 3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2986
    self assert:((n1 // n2) == 333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2987
    self assert:((n1 // n2) printString = '333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2988
    self assert:((n1 perform:'//' asSymbol with:n2) == 333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2989
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2990
    n2 := -3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2991
    self assert:((n1 // n2) == -334).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2992
    self assert:((n1 // n2) printString = '-334').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2993
    self assert:((n1 perform:'//' asSymbol with:n2) == -334).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2994
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2995
    n2 := 3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2996
    self assert:((n1 // n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2997
    self assert:((n1 // n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  2998
    self assert:((n1 perform:'//' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  2999
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3000
    n2 := -3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3001
    self assert:((n1 // n2) == -1).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3002
    self assert:((n1 // n2) printString = '-1').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3003
    self assert:((n1 perform:'//' asSymbol with:n2) == -1).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3004
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3005
    "/ ... zero
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3006
    n2 := 3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3007
    self assert:((n1 quo: n2) == 333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3008
    self assert:((n1 quo: n2) printString = '333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3009
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3010
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3011
    n2 := -3.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3012
    self assert:((n1 quo: n2) == -333).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3013
    self assert:((n1 quo: n2) printString = '-333').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3014
    self assert:((n1 perform:'quo:' asSymbol with:n2) == -333).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3015
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3016
    n2 := 3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3017
    self assert:((n1 quo: n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3018
    self assert:((n1 quo: n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3019
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3020
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3021
    n2 := -3600000.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3022
    self assert:((n1 quo: n2) == 0).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3023
    self assert:((n1 quo: n2) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3024
    self assert:((n1 perform:'quo:' asSymbol with:n2) == 0).
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3025
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3026
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3027
     self basicNew testSmallIntegerDivision1
46
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3028
    "
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3029
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3030
    "Modified: / 9.6.1999 / 17:47:56 / cg"
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3031
    "Created: / 9.6.1999 / 17:49:45 / cg"
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3032
!
cfc40ffac21a added division checks
Claus Gittinger <cg@exept.de>
parents: 45
diff changeset
  3033
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3034
testSmallIntegerMultiplication1
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3035
    "multiply tests (var * const).
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3036
     Notice, the arithmetic tests are both performed via regular sends
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3037
     and via constructed performs. The reason is to test both inlined
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3038
     JIT-compiler code AND the regular methods code."
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3039
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3040
    |s n1 n2 t|
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3041
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3042
    n1 := 100000.
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3043
    n2 := n1 negated.
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3044
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3045
    self assert:(n1 printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3046
    self assert:(n2 printString = '-100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3047
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3048
    self assert:((n1 * 0) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3049
    self assert:((n1 perform:'*' asSymbol with:0) printString = '0').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3050
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3051
    self assert:((n1 * 1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3052
    self assert:((n1 perform:'*' asSymbol with:1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3053
    self assert:((n2 * 1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3054
    self assert:((n2 perform:'*' asSymbol with:1) printString = '-100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3055
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3056
    self assert:((n1 * -1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3057
    self assert:((n1 perform:'*' asSymbol with:-1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3058
    self assert:((n2 * -1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3059
    self assert:((n2 perform:'*' asSymbol with:-1) printString = '100000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3060
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3061
    self assert:((n1 * 2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3062
    self assert:((n1 perform:'*' asSymbol with:2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3063
    self assert:((n1 * 3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3064
    self assert:((n1 perform:'*' asSymbol with:3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3065
    self assert:((n1 * 4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3066
    self assert:((n1 perform:'*' asSymbol with:4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3067
    self assert:((n1 * 5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3068
    self assert:((n1 perform:'*' asSymbol with:5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3069
    self assert:((n1 * 6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3070
    self assert:((n1 perform:'*' asSymbol with:6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3071
    self assert:((n1 * 7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3072
    self assert:((n1 perform:'*' asSymbol with:7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3073
    self assert:((n1 * 8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3074
    self assert:((n1 perform:'*' asSymbol with:8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3075
    self assert:((n1 * 9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3076
    self assert:((n1 perform:'*' asSymbol with:9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3077
    self assert:((n1 * 10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3078
    self assert:((n1 perform:'*' asSymbol with:10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3079
    self assert:((n1 * 11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3080
    self assert:((n1 perform:'*' asSymbol with:11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3081
    self assert:((n1 * 12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3082
    self assert:((n1 perform:'*' asSymbol with:12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3083
    self assert:((n1 * 13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3084
    self assert:((n1 perform:'*' asSymbol with:13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3085
    self assert:((n1 * 14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3086
    self assert:((n1 perform:'*' asSymbol with:14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3087
    self assert:((n1 * 15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3088
    self assert:((n1 perform:'*' asSymbol with:15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3089
    self assert:((n1 * 16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3090
    self assert:((n1 perform:'*' asSymbol with:16) printString = '1600000').
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3091
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3092
    n1 := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3093
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3094
    self assert:((n1 * n2) printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3095
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3096
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3097
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3098
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3099
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3100
    self assert:((n1 * n2) printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3101
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3102
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3103
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3104
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3105
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3106
    self assert:((n1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3107
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3108
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3109
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3110
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3111
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3112
    self assert:((n1 * n2) printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3113
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3114
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3115
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3116
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3117
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3118
    self assert:((n1 * n2) printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3119
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3120
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3121
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3122
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3123
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3124
    self assert:((n1 * n2) printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3125
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3126
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3127
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3128
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3129
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3130
    self assert:((n1 * n2) printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3131
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3132
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3133
    n1 := 1.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3134
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3135
    self assert:((n1 * n2) printString = '10').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3136
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3137
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3138
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3139
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3140
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3141
    self assert:((n1 * n2) printString = '1000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3142
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3143
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3144
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3145
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3146
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3147
    self assert:((n1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3148
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3149
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3150
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3151
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3152
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3153
    self assert:((n1 * n2) printString = '10000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3154
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3155
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3156
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3157
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3158
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3159
    self assert:((n1 * n2) printString = '1000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3160
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3161
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3162
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3163
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3164
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3165
    self assert:((n1 * n2) printString = '100000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3166
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3167
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3168
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3169
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3170
    n1 := n1 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3171
    self assert:((n1 * n2) printString = '10000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3172
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3173
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3174
    n1 := 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3175
    n2 := 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3176
    self assert:((n1 * n2) printString = '100').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3177
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3178
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3179
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3180
    self assert:((n1 * n2) printString = '10000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3181
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3182
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3183
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3184
    self assert:((n1 * n2) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3185
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3186
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3187
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3188
    self assert:((n1 * n2) printString = '100000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3189
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3190
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3191
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3192
    self assert:((n1 * n2) printString = '10000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3193
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3194
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3195
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3196
    self assert:((n1 * n2) printString = '1000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3197
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3198
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3199
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3200
    self assert:((n1 * n2) printString = '100000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3201
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3202
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3203
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3204
    self assert:((n1 * n2) printString = '10000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3205
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3206
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3207
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3208
    self assert:((n1 * n2) printString = '1000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3209
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3210
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3211
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3212
    self assert:((n1 * n2) printString = '100000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3213
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3214
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3215
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3216
    self assert:((n1 * n2) printString = '10000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3217
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '10000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3218
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3219
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3220
    self assert:((n1 * n2) printString = '1000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3221
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '1000000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3222
    n1 := n1 * 10.
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3223
    n2 := n2 * 10.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3224
    self assert:((n1 * n2) printString = '100000000000000000000000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3225
    self assert:((n1 perform:'*' asSymbol with:n2) printString = '100000000000000000000000000').
41
7b7d7890a939 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 40
diff changeset
  3226
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3227
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3228
     self basicNew testSmallIntegerMultiplication1
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3229
    "
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3230
32
03d8794d981d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 31
diff changeset
  3231
    "Modified: / 9.6.1999 / 17:47:56 / cg"
33
f7b691b71cad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 32
diff changeset
  3232
    "Created: / 9.6.1999 / 17:49:45 / cg"
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3233
!
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3234
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3235
testSmallIntegerMultiplication1b
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3236
    "multiply tests (const * var).
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3237
     Notice, the arithmetic tests are both performed via regular sends
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3238
     and via constructed performs. The reason is to test both inlined
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3239
     JIT-compiler code AND the regular methods code."
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3240
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3241
    |s n1 n2 t|
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3242
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3243
    n1 := 100000.
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3244
    n2 := n1 negated.
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3245
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3246
    self assert:((0 * n1) printString = '0').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3247
    self assert:((0 perform:'*' asSymbol with:n1) printString = '0').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3248
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3249
    self assert:((1 * n1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3250
    self assert:((1 perform:'*' asSymbol with:n1) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3251
    self assert:((1 * n2) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3252
    self assert:((1 perform:'*' asSymbol with:n2) printString = '-100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3253
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3254
    self assert:((-1 * n1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3255
    self assert:((-1 perform:'*' asSymbol with:n1) printString = '-100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3256
    self assert:((-1 * n2) printString = '100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3257
    self assert:((-1 perform:'*' asSymbol with:n2) printString = '100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3258
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3259
    self assert:((2 * n1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3260
    self assert:((2 perform:'*' asSymbol with:n1) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3261
    self assert:((3 * n1) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3262
    self assert:((3 perform:'*' asSymbol with:n1) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3263
    self assert:((4 * n1) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3264
    self assert:((4 perform:'*' asSymbol with:n1) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3265
    self assert:((5 * n1) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3266
    self assert:((5 perform:'*' asSymbol with:n1) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3267
    self assert:((6 * n1) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3268
    self assert:((6 perform:'*' asSymbol with:n1) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3269
    self assert:((7 * n1) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3270
    self assert:((7 perform:'*' asSymbol with:n1) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3271
    self assert:((8 * n1) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3272
    self assert:((8 perform:'*' asSymbol with:n1) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3273
    self assert:((9 * n1) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3274
    self assert:((9 perform:'*' asSymbol with:n1) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3275
    self assert:((10 * n1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3276
    self assert:((10 perform:'*' asSymbol with:n1) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3277
    self assert:((11 * n1) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3278
    self assert:((11 perform:'*' asSymbol with:n1) printString = '1100000').
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3279
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3280
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3281
     self basicNew testSmallIntegerMultiplication1b
35
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3282
    "
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3283
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3284
    "Modified: / 9.6.1999 / 17:47:56 / cg"
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3285
    "Created: / 9.6.1999 / 17:49:45 / cg"
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3286
!
91703aab73bd checkin from browser
Claus Gittinger <cg@exept.de>
parents: 34
diff changeset
  3287
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3288
testSmallIntegerMultiplication2
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3289
    "multiply tests.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3290
     Notice, the arithmetic tests are both performed via regular sends
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3291
     and via constructed performs. The reason is to test both inlined
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3292
     JIT-compiler code AND the regular methods code."
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3293
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3294
    |s n1 n2 t|
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3295
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3296
    n1 := 100000.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3297
    n2 := n1 negated.
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3298
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3299
    self assert:((n1 * 2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3300
    self assert:((n1 perform:'*' asSymbol with:2) printString = '200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3301
    self assert:((n1 * 3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3302
    self assert:((n1 perform:'*' asSymbol with:3) printString = '300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3303
    self assert:((n1 * 4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3304
    self assert:((n1 perform:'*' asSymbol with:4) printString = '400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3305
    self assert:((n1 * 5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3306
    self assert:((n1 perform:'*' asSymbol with:5) printString = '500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3307
    self assert:((n1 * 6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3308
    self assert:((n1 perform:'*' asSymbol with:6) printString = '600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3309
    self assert:((n1 * 7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3310
    self assert:((n1 perform:'*' asSymbol with:7) printString = '700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3311
    self assert:((n1 * 8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3312
    self assert:((n1 perform:'*' asSymbol with:8) printString = '800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3313
    self assert:((n1 * 9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3314
    self assert:((n1 perform:'*' asSymbol with:9) printString = '900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3315
    self assert:((n1 * 10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3316
    self assert:((n1 perform:'*' asSymbol with:10) printString = '1000000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3317
    self assert:((n1 * 11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3318
    self assert:((n1 perform:'*' asSymbol with:11) printString = '1100000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3319
    self assert:((n1 * 12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3320
    self assert:((n1 perform:'*' asSymbol with:12) printString = '1200000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3321
    self assert:((n1 * 13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3322
    self assert:((n1 perform:'*' asSymbol with:13) printString = '1300000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3323
    self assert:((n1 * 14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3324
    self assert:((n1 perform:'*' asSymbol with:14) printString = '1400000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3325
    self assert:((n1 * 15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3326
    self assert:((n1 perform:'*' asSymbol with:15) printString = '1500000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3327
    self assert:((n1 * 16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3328
    self assert:((n1 perform:'*' asSymbol with:16) printString = '1600000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3329
    self assert:((n1 * 17) printString = '1700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3330
    self assert:((n1 perform:'*' asSymbol with:17) printString = '1700000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3331
    self assert:((n1 * 18) printString = '1800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3332
    self assert:((n1 perform:'*' asSymbol with:18) printString = '1800000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3333
    self assert:((n1 * 19) printString = '1900000').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3334
    self assert:((n1 perform:'*' asSymbol with:19) printString = '1900000').
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3335
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3336
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3337
     self basicNew testSmallIntegerMultiplication2
34
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3338
    "
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3339
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3340
    "Modified: / 9.6.1999 / 17:47:56 / cg"
f52571b86f62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 33
diff changeset
  3341
    "Created: / 9.6.1999 / 17:49:45 / cg"
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3342
!
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3343
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3344
testSmallIntegerMultiplication3
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3345
    "multiply tests.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3346
     Notice, the arithmetic tests are both performed via regular sends
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3347
     and via constructed performs. The reason is to test both inlined
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3348
     JIT-compiler code AND the regular methods code."
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3349
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3350
    |s n1 n2 t|
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3351
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3352
    n1 := 16rFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3353
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3354
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3355
    self assert:((n1 * 2) printString = '131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3356
    self assert:((n1 perform:'*' asSymbol with:2) printString = '131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3357
    self assert:((n2 * 2) printString = '-131070').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3358
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-131070').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3359
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3360
    n1 := 16rFFFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3361
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3362
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3363
    self assert:((n1 * 2) printString = '33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3364
    self assert:((n1 perform:'*' asSymbol with:2) printString = '33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3365
    self assert:((n2 * 2) printString = '-33554430').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3366
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-33554430').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3367
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3368
    n1 := 16r3FFFFFFF.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3369
    n2 := n1 negated.
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3370
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3371
    self assert:((n1 * 2) printString = '2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3372
    self assert:((n1 perform:'*' asSymbol with:2) printString = '2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3373
    self assert:((n2 * 2) printString = '-2147483646').
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3374
    self assert:((n2 perform:'*' asSymbol with:2) printString = '-2147483646').
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3375
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3376
    SmallInteger maxBytes == 4 ifTrue:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3377
        n1 := 16r3FFFFFFF.
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3378
    ] ifFalse:[
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3379
        n1 := 16r3FFFFFFFFFFFFFFF.
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3380
    ].
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3381
    self assert:(n1 class == SmallInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3382
    self assert:((n1 * 2) class == LargeInteger).
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3383
    self assert:((n1 perform:'*' asSymbol with:2) class == LargeInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3384
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3385
    n1 := SmallInteger maxVal // 11.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3386
    self assert:((n1 * 11) class == SmallInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3387
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3388
    n1 := n1 + 1.
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3389
    self assert:((n1 * 11) class == LargeInteger).
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3390
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3391
    "
103
99b92f745f74 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 95
diff changeset
  3392
     self basicNew testSmallIntegerMultiplication3
39
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3393
    "
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3394
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3395
    "Modified: / 9.6.1999 / 17:47:56 / cg"
bed97f34d7e8 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 38
diff changeset
  3396
    "Created: / 9.6.1999 / 17:49:45 / cg"
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3397
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3398
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3399
!IntegerTest methodsFor:'tests-class protocol'!
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3400
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3401
testCreationFromBytes1
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3402
  "self run: #testCreationFromBytes1"
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3403
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3404
  " 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
  3405
  " 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
  3406
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3407
   | maxSmallInt hexString 
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3408
     byte1 byte2 byte3 byte4   
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3409
     byte5 byte6 byte7 byte8   
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3410
     builtInteger builtIntegerH builtIntegerL|
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3411
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3412
    maxSmallInt := SmallInteger maxVal.
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3413
    hexString := maxSmallInt printStringHex.
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3414
    ExternalAddress pointerSize == 8 ifTrue:[
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3415
        self assert: hexString size = 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3416
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3417
        byte8 := Integer readFrom: (hexString copyFrom: 1 to: 2) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3418
        byte7 := Integer readFrom: (hexString copyFrom: 3 to: 4) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3419
        byte6 := Integer readFrom: (hexString copyFrom: 5 to: 6) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3420
        byte5 := Integer readFrom: (hexString copyFrom: 7 to: 8) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3421
        byte4 := Integer readFrom: (hexString copyFrom: 9 to: 10) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3422
        byte3 := Integer readFrom: (hexString copyFrom: 11 to: 12) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3423
        byte2 := Integer readFrom: (hexString copyFrom: 13 to: 14) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3424
        byte1 := Integer readFrom: (hexString copyFrom: 15 to: 16) base: 16.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3425
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3426
        builtIntegerH := Integer byte1: byte5 byte2: byte6 byte3: byte7 byte4: byte8.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3427
        builtIntegerL := Integer byte1: byte1 byte2: byte2 byte3: byte3 byte4: byte4.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3428
        builtInteger := (builtIntegerH bitShift:32) bitOr:builtIntegerL.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3429
        self assert: builtInteger = maxSmallInt.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3430
    ] ifFalse:[
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3431
        self assert: hexString size = 8.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3432
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3433
        byte4 := Integer readFrom: (hexString copyFrom: 1 to: 2) base: 16.
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3434
        byte3 := Integer readFrom: (hexString copyFrom: 3 to: 4) base: 16.
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3435
        byte2 := Integer readFrom: (hexString copyFrom: 5 to: 6) base: 16.
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3436
        byte1 := Integer readFrom: (hexString copyFrom: 7 to: 8) base: 16.
934
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3437
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3438
        builtInteger := Integer byte1: byte1 byte2: byte2 byte3: byte3 byte4: byte4.
bf29a53f0eba class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 933
diff changeset
  3439
        self assert: builtInteger = maxSmallInt.
316
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3440
    ].
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3441
    self assert: builtInteger class = SmallInteger
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3442
! !
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3443
d2d718967147 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 282
diff changeset
  3444
!IntegerTest methodsFor:'tests-concrete bugs'!
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3445
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3446
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
  3447
    "create an Idn from the given arguments
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3448
    "
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3449
    |hgEnc typ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3450
     eqEnc "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3451
     oid   "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3452
     IDN|
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3453
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3454
    IDN := self class.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3455
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3456
    eqEnc := rack.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3457
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3458
    eqEnc > 0 ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3459
                 eqEnc < 0    ifTrue:[idn := #Dontcare]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3460
        ifFalse:[port == 256  ifTrue:[idn := #NWNode]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3461
        ifFalse:[ idn := #Unspecified ]].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3462
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3463
      ^ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3464
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3465
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3466
    eqEnc >= 255 ifTrue:[       "/ is a logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3467
        eqEnc > 255 ifTrue:[ ^ #Unspecified ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3468
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3469
        slot == 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3470
            subr == 1 ifTrue:[ ^ #ConnectManager ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3471
            subr == 2 ifTrue:[ ^ #ClockManager   ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3472
        ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3473
        oid := 4.                               "/ logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3474
    ] ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3475
        oid := 2.                               "/ equipment
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3476
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3477
    hgEnc := 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3478
    typ   := aTypeOrSymbol.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3479
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3480
    subr ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3481
        subr > 16r0f  ifTrue:[ ^ #Unspecified ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3482
        eqEnc := eqEnc bitOr:(subr bitShift: 8).
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3483
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3484
        slot ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3485
            slot > 16rff  ifTrue:[ ^ #Unspecified ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3486
            eqEnc := eqEnc bitOr:(slot bitShift:12).
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3487
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3488
            port ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3489
                port > 16rff  ifTrue:[ ^ #Unspecified ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3490
                eqEnc := eqEnc bitOr:(port bitShift:20).
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3491
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3492
                chn ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3493
                    chn > 16rfff  ifTrue:[ ^ #Unspecified ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3494
                    oid   := 3.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3495
                    typ   := aTypeOrSymbol ? 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3496
                    hgEnc := chn.    
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3497
                ]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3498
            ]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3499
        ]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3500
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3501
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3502
    typ notNil ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3503
        typ isSymbol ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3504
            typ := 0
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3505
        ]. 
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3506
        hgEnc := hgEnc bitOr:(typ bitShift:12).    
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3507
        hgEnc := hgEnc bitOr:(oid bitShift:20).    
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3508
    ].            
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3509
    ^ #ok.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3510
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3511
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3512
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
  3513
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3514
!
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3515
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3516
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
  3517
    "create an Idn from the given arguments
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3518
    "
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3519
    |hgEnc typ idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3520
     eqEnc "{ Class:SmallInteger }"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3521
     oid   "{ Class:SmallInteger }"|
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3522
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3523
    eqEnc := rack.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3524
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3525
"/    eqEnc > 0 ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3526
"/                 eqEnc < 0    ifTrue:[idn := IDN Dontcare]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3527
"/        ifFalse:[port == 256  ifTrue:[idn := IDN NWNode]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3528
"/        ifFalse:[ idn := IDN Unspecified ]].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3529
"/
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3530
"/      ^ self fromIdn:idn
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3531
"/    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3532
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3533
"/    eqEnc >= 255 ifTrue:[       "/ is a logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3534
"/        eqEnc > 255 ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3535
"/
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3536
"/        slot == 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3537
"/            subr == 1 ifTrue:[ ^ self fromIdn:(IDN ConnectManager) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3538
"/            subr == 2 ifTrue:[ ^ self fromIdn:(IDN ClockManager)   ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3539
"/        ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3540
"/        oid := 4.                               "/ logical resource
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3541
"/    ] ifFalse:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3542
"/        oid := 2.                               "/ equipment
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3543
"/    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3544
"/    hgEnc := 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3545
"/    typ   := aTypeOrSymbol.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3546
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3547
    subr ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3548
        subr > 16r0f  ifTrue:[ ^ nil "self fromIdn:(IDN Unspecified)" ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3549
        eqEnc := eqEnc bitOr:(subr bitShift: 8).
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3550
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3551
        slot ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3552
            slot > 16rff  ifTrue:[ ^ nil "self fromIdn:(IDN Unspecified)" ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3553
            eqEnc := eqEnc bitOr:(slot bitShift:12).
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3554
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3555
            port ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3556
                port > 16rff  ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3557
                eqEnc := eqEnc bitOr:(port bitShift:20).
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3558
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3559
                chn ~~ 0 ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3560
                    chn > 16rfff  ifTrue:[ ^ self fromIdn:(IDN Unspecified) ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3561
                    oid   := 3.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3562
                    typ   := aTypeOrSymbol ? 0.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3563
                    hgEnc := chn.    
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3564
                ]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3565
            ]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3566
        ]
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3567
    ].
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3568
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3569
    typ notNil ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3570
        typ isSymbol ifTrue:[
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3571
            typ := (MDT::MDTCType asNumberType:typ) ? 0
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3572
        ]. 
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3573
        hgEnc := hgEnc bitOr:(typ bitShift:12).    
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3574
        hgEnc := hgEnc bitOr:(oid bitShift:20).    
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3575
    ].            
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3576
    ^ self basicNew eqEncode:eqEnc hgEncode:hgEnc.
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3577
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3578
"
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3579
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
  3580
"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3581
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3582
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3583
test_gcdBug1
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3584
| theBase theMersenne theRest theGcd theOldRest theOldGcd |
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3585
theBase := 2.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3586
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3587
132 to: 135 do: 
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3588
[: theOrder |
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3589
 false    "<<<< here i replaced some piece of code by false just to
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3590
reproduce the error without having to ship all my code >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3591
   ifFalse: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3592
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3593
     theRest := ((theBase raisedTo: theOrder) - 1) / (theBase - 1).
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3594
     30 to: 67 "theOrder - 1" do:
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3595
 [:theFactorOrder |
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3596
"/Transcript show:theOrder; space.
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3597
"/Transcript showCR:theFactorOrder.
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3598
     (theOrder \\ theFactorOrder) = 0
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3599
        ifTrue: [       "<<<< is a divisor of the order >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3600
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3601
          theFactorOrder = 131 ifTrue: ['131 ist kein Teiler von 132'
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3602
halt].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3603
          (theOrder / theFactorOrder) isFraction 
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3604
             ifTrue: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3605
               self halt "Fehler!!"      "<<<<<<<<< dieser Code wird
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3606
                                        nicht ausgeführt!!!!!! >>>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3607
             ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3608
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3609
          theMersenne := ((theBase raisedTo: theFactorOrder) - 1) /
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3610
(theBase - 1).
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3611
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3612
          theGcd := theRest gcd: theMersenne.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3613
          [theGcd > 1]
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3614
             whileTrue: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3615
               theFactorOrder > 129 ifTrue: [self halt]."< no halt!! >"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3616
               theOldRest := theRest asString.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3617
               theOldGcd := theGcd asString.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3618
               theRest := theRest / theGcd.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3619
               theGcd := theGcd gcd: theRest. "<<<<<<<<< ERROR
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3620
>>>>>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3621
               ((theRest \\ theGcd) ~= 0) ifTrue: [self halt].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3622
               (theRest / theGcd) isFraction ifTrue: [self halt.].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3623
             ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3624
          ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3625
      ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3626
    theRest = 1 ifTrue: [   "<<<< there is no prime factor of order
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3627
theOrder >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3628
      theOrder halt
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3629
   ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3630
 ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3631
].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3632
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3633
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3634
     self new test_gcdBug1
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3635
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3636
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3637
    "Modified: / 27-04-2010 / 00:02:02 / cg"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3638
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3639
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3640
test_gcdBug2
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3641
| theBase theMersenne theRest theGcd theOldRest theOldGcd |
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3642
theBase := 2.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3643
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3644
132 to: 135 do: 
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3645
[: theOrder |
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3646
 false    "<<<< here i replaced some piece of code by false just to
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3647
reproduce the error without having to ship all my code >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3648
   ifFalse: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3649
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3650
     theRest := ((theBase raisedTo: theOrder) - 1) / (theBase - 1).
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3651
     60 to: 67 "theOrder - 1" do:
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3652
 [:theFactorOrder |
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3653
"/Transcript show:theOrder; space.
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3654
"/Transcript showCR:theFactorOrder.
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3655
     (theOrder \\ theFactorOrder) = 0
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3656
        ifTrue: [       "<<<< is a divisor of the order >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3657
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3658
          theFactorOrder = 131 ifTrue: ['131 ist kein Teiler von 132'
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3659
halt].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3660
          (theOrder / theFactorOrder) isFraction 
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3661
             ifTrue: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3662
               self halt "Fehler!!"      "<<<<<<<<< dieser Code wird
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3663
                                        nicht ausgeführt!!!!!! >>>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3664
             ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3665
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3666
          theMersenne := ((theBase raisedTo: theFactorOrder) - 1) /
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3667
(theBase - 1).
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3668
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3669
          theGcd := theRest gcd: theMersenne.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3670
          [theGcd > 1]
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3671
             whileTrue: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3672
               theFactorOrder > 129 ifTrue: [self halt]."< no halt!! >"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3673
               theOldRest := theRest asString.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3674
               theOldGcd := theGcd asString.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3675
               theRest := theRest / theGcd.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3676
               theGcd := theGcd gcd: theRest. "<<<<<<<<< ERROR
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3677
>>>>>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3678
               ((theRest \\ theGcd) ~= 0) ifTrue: [self halt].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3679
               (theRest / theGcd) isFraction ifTrue: [self halt.].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3680
             ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3681
          ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3682
      ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3683
    theRest = 1 ifTrue: [   "<<<< there is no prime factor of order
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3684
theOrder >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3685
      theOrder halt
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3686
   ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3687
 ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3688
].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3689
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3690
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3691
     self new test_gcdBug2
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3692
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3693
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3694
    "Modified: / 27-04-2010 / 00:02:09 / cg"
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3695
!
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3696
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3697
test_gcdBug3
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3698
| theBase theMersenne theRest theGcd theOldRest theOldGcd |
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3699
theBase := 2.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3700
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3701
132 to: 135 do: 
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3702
[: theOrder |
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3703
 false    "<<<< here i replaced some piece of code by false just to
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3704
reproduce the error without having to ship all my code >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3705
   ifFalse: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3706
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3707
     theRest := ((theBase raisedTo: theOrder) - 1) / (theBase - 1).
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3708
     2 to:theOrder - 1 do:
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3709
 [:theFactorOrder |
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3710
"/Transcript show:theOrder; space.
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3711
"/Transcript showCR:theFactorOrder.
238
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3712
     (theOrder \\ theFactorOrder) = 0
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3713
        ifTrue: [       "<<<< is a divisor of the order >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3714
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3715
          theFactorOrder = 131 ifTrue: ['131 ist kein Teiler von 132'
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3716
halt].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3717
          (theOrder / theFactorOrder) isFraction 
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3718
             ifTrue: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3719
               self halt "Fehler!!"      "<<<<<<<<< dieser Code wird
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3720
                                        nicht ausgeführt!!!!!! >>>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3721
             ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3722
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3723
          theMersenne := ((theBase raisedTo: theFactorOrder) - 1) /
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3724
(theBase - 1).
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3725
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3726
          theGcd := theRest gcd: theMersenne.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3727
          [theGcd > 1]
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3728
             whileTrue: [
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3729
               theFactorOrder > 129 ifTrue: [self halt]."< no halt!! >"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3730
               theOldRest := theRest asString.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3731
               theOldGcd := theGcd asString.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3732
               theRest := theRest / theGcd.
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3733
               theGcd := theGcd gcd: theRest. "<<<<<<<<< ERROR
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3734
>>>>>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3735
               ((theRest \\ theGcd) ~= 0) ifTrue: [self halt].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3736
               (theRest / theGcd) isFraction ifTrue: [self halt.].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3737
             ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3738
          ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3739
      ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3740
    theRest = 1 ifTrue: [   "<<<< there is no prime factor of order
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3741
theOrder >>>>"
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3742
      theOrder halt
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3743
   ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3744
 ].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3745
].
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3746
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3747
    "
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3748
     self new test_gcdBug2
41116eb0ebba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 206
diff changeset
  3749
    "
564
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3750
4606c52eb488 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
  3751
    "Modified: / 27-04-2010 / 00:02:15 / cg"
104
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3752
! !
baa58c703a71 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 103
diff changeset
  3753
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3754
!IntegerTest class methodsFor:'documentation'!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3755
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3756
version
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3757
    ^ '$Header$'
563
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  3758
!
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  3759
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  3760
version_CVS
d666bfa81a9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 550
diff changeset
  3761
    ^ '$Header$'
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3762
! !
931
029ddee933b3 class: RegressionTests::IntegerTest
Claus Gittinger <cg@exept.de>
parents: 565
diff changeset
  3763