rubyx/lib/soml/parfait/integer.soml

89 lines
1.3 KiB
Plaintext
Raw Normal View History

2015-11-08 14:30:42 +02:00
class Integer < Value
2015-11-10 19:09:17 +02:00
int as_char()
if_plus( self - 9)
2015-11-08 17:11:03 +02:00
return 32
else
2015-11-11 20:45:40 +02:00
return 48 + self
2015-11-08 14:30:42 +02:00
end
end
2015-11-08 17:11:03 +02:00
int div10_soml()
int tmp = self >> 1
int q = self >> 2
q = q + tmp
tmp = q >> 4
q = q + tmp
tmp = q >> 8
q = q + tmp
tmp = q >> 16
q = q + tmp
q = q >> 3
int r = q * 10
r = self - r
r = r + 6
r = r >> 4
return q + r
end
2015-11-08 17:11:03 +02:00
Word as_string(Word str)
2015-11-08 23:58:54 +02:00
if_minus( self - 10 )
2015-11-10 19:09:17 +02:00
int num = as_char()
str = str.push_char( num )
2015-11-08 23:58:54 +02:00
else
int rest = self.div10()
2015-11-08 23:58:54 +02:00
str = rest.as_string( str )
2015-11-10 19:09:17 +02:00
rest = rest * 10
rest = self - rest
str = rest.as_string(str)
2015-11-08 14:30:42 +02:00
end
return str
end
2015-11-08 17:11:03 +02:00
Word to_s()
2015-11-08 14:30:42 +02:00
Word start = " "
start.set_length(0)
2015-11-08 17:11:03 +02:00
return as_string( start )
2015-11-08 14:30:42 +02:00
end
2015-11-10 19:09:17 +02:00
int puti()
Word str = self.to_s()
str.putstring()
return self
end
2015-11-11 20:36:40 +02:00
int mod4()
return self & 3
2015-11-11 20:36:40 +02:00
end
2015-11-20 19:12:58 +02:00
int fibr( )
if_plus( self - 2 )
int tmp
tmp = self - 1
int a = tmp.fibr( )
tmp = self - 2
int b = tmp.fibr( )
return a + b
else
return self
end
end
int fibw( )
int result = 1
int a = 0
int b = 1
int i = 2
while_plus( self - i )
result = a + b
a = b
b = result
i = i + 1
end
return result
end
2015-11-08 14:30:42 +02:00
end