Skip to content
Permalink
Newer
Older
100644 695 lines (590 sloc) 21.1 KB
Sep 5, 2014
1
;(function($B){
2
3
eval($B.InjectBuiltins())
4
5
var object = _b_.object, $N = _b_.None
Sep 5, 2014
6
7
function $err(op,other){
8
var msg = "unsupported operand type(s) for "+op
9
msg += ": 'int' and '"+$B.get_class(other).__name__+"'"
10
throw _b_.TypeError.$factory(msg)
Sep 5, 2014
11
}
12
13
// dictionary for built-in class 'int'
14
var int = {__class__: $B.$type,
15
__name__: 'int',
16
__dir__: object.__dir__,
17
$is_class: true,
18
$native: true,
19
$descriptors: {
20
'numerator': true,
21
'denominator': true,
22
'imag': true,
23
'real': true
24
}
Sep 5, 2014
25
}
26
27
int.from_bytes = function() {
28
var $=$B.args("from_bytes", 3,
29
{bytes:null, byteorder:null, signed:null}, ['bytes', 'byteorder', 'signed'],
30
arguments, {signed:False}, null, null)
Sep 5, 2014
31
32
var x = $.bytes,
33
byteorder = $.byteorder,
34
signed = $.signed
35
var _bytes, _len
36
if (isinstance(x, [_b_.list, _b_.tuple])) {
37
_bytes=x
38
_len=len(x)
Jan 14, 2015
39
} else if (isinstance(x, [_b_.bytes, _b_.bytearray])) {
40
_bytes=x.source
41
_len=x.source.length
Jan 14, 2015
42
} else {
43
_b_.TypeError.$factory("Error! " + _b_.type(x) + " is not supported in int.from_bytes. fix me!")
Sep 5, 2014
44
}
45
46
switch(byteorder) {
47
case 'big':
48
var num = _bytes[_len - 1];
49
var _mult=256
50
for (var i = (_len - 2); i >= 0; i--) {
51
// For operations, use the functions that can take or return
52
// big integers
53
num = $B.add($B.mul(_mult, _bytes[i]), num)
54
_mult = $B.mul(_mult,256)
Jan 14, 2015
56
if (!signed) return num
57
if (_bytes[0] < 128) return num
58
return $B.sub(num, _mult)
59
case 'little':
60
var num = _bytes[0]
61
if (num >= 128) num = num - 256
62
var _mult=256
63
for (var i = 1; i < _len; i++) {
64
num = $B.add($B.mul(_mult, _bytes[i]), num)
65
_mult = $B.mul(_mult,256)
Jan 14, 2015
67
if (!signed) return num
68
if (_bytes[_len - 1] < 128) return num
69
return $B.sub(num, _mult)
Sep 5, 2014
70
}
71
72
throw _b_.ValueError.$factory("byteorder must be either 'little' or 'big'");
Sep 5, 2014
73
}
74
75
int.to_bytes = function(length, byteorder, star) {
Sep 5, 2014
76
//var len = x.length
77
throw _b_.NotImplementedError.$factory("int.to_bytes is not implemented yet")
Sep 5, 2014
78
}
79
80
81
//int.__and__ = function(self,other){return self & other} // bitwise AND
Sep 5, 2014
82
83
int.__abs__ = function(self){return abs(self)}
85
int.__bool__ = function(self){return new Boolean(self.valueOf())}
Sep 5, 2014
86
87
int.__ceil__ = function(self){return Math.ceil(self)}
Sep 5, 2014
89
//is this a duplicate?
90
int.__class__ = $B.$type
Sep 5, 2014
91
92
int.__divmod__ = function(self, other){return divmod(self, other)}
94
int.__eq__ = function(self,other){
Sep 5, 2014
95
// compare object "self" to class "int"
96
if(other===undefined) return self===int
97
if(isinstance(other,int)) return self.valueOf()==other.valueOf()
98
if(isinstance(other,_b_.float)) return self.valueOf()==other.valueOf()
Sep 5, 2014
99
if(isinstance(other,_b_.complex)){
100
if (other.$imag != 0) return False
101
return self.valueOf() == other.$real
Sep 5, 2014
102
}
103
104
if (hasattr(other, '__eq__')) return getattr(other, '__eq__')(self)
105
Sep 5, 2014
106
return self.valueOf()===other
107
}
108
109
int.__float__ = function(self){
110
return new Number(self)
111
}
112
113
function preformat(self, fmt){
114
if(fmt.empty){return _b_.str(self)}
115
if(fmt.type && 'bcdoxXn'.indexOf(fmt.type)==-1){
116
throw _b_.ValueError.$factory("Unknown format code '"+fmt.type+
117
"' for object of type 'int'")
118
}
120
switch(fmt.type){
121
case undefined:
122
case 'd':
123
return self.toString()
124
case 'b':
125
return (fmt.alternate ? '0b' : '') + self.toString(2)
126
case 'c':
127
return _b_.chr(self)
128
case 'o':
129
return (fmt.alternate ? '0o' : '') + self.toString(8)
131
return (fmt.alternate ? '0x' : '') + self.toString(16)
133
return (fmt.alternate ? '0X' : '') + self.toString(16).toUpperCase()
134
case 'n':
135
return self // fix me
136
}
138
return res
139
}
140
141
142
int.__format__ = function(self,format_spec){
143
var fmt = new $B.parse_format_spec(format_spec)
144
if(fmt.type && 'eEfFgG%'.indexOf(fmt.type)!=-1){
145
// Call __format__ on float(self)
146
return _b_.float.$dict.__format__(self, format_spec)
148
fmt.align = fmt.align || '>'
149
var res = preformat(self, fmt)
150
if(fmt.comma){
151
var sign = res[0]=='-' ? '-' : '',
152
rest = res.substr(sign.length),
153
len = rest.length,
154
nb = Math.ceil(rest.length/3),
155
chunks = []
156
for(var i=0;i<nb;i++){
157
chunks.push(rest.substring(len-3*i-3, len-3*i))
158
}
159
chunks.reverse()
160
res = sign+chunks.join(',')
161
}
162
return $B.format_width(res, fmt)
Sep 5, 2014
163
}
164
165
//int.__float__ = function(self){return float(self)}
167
int.__floordiv__ = function(self,other){
Sep 5, 2014
168
if(isinstance(other,int)){
169
if(other==0) throw ZeroDivisionError.$factory('division by zero')
Sep 5, 2014
170
return Math.floor(self/other)
171
}
172
if(isinstance(other,_b_.float)){
173
if(!other.valueOf()) throw ZeroDivisionError.$factory('division by zero')
174
return Math.floor(self/other)
Sep 5, 2014
175
}
176
if(hasattr(other,'__rfloordiv__')){
177
return getattr(other,'__rfloordiv__')(self)
178
}
179
$err("//",other)
180
}
181
182
int.__hash__ = function(self){
184
return int.__hashvalue__ || $B.$py_next_hash-- // for hash of int type (not instance of int)
185
}
186
187
return self.valueOf()
188
}
Sep 5, 2014
189
190
//int.__ior__ = function(self,other){return self | other} // bitwise OR
Sep 5, 2014
191
192
int.__index__ = function(self){return self}
Sep 5, 2014
193
194
int.__init__ = function(self,value){
Sep 5, 2014
195
if(value===undefined){value=0}
196
self.toString = function(){return value}
197
//self.valueOf = function(){return value}
Sep 5, 2014
199
}
200
201
int.__int__ = function(self){return self}
Sep 5, 2014
202
203
int.__invert__ = function(self){return ~self}
Sep 5, 2014
204
206
int.__lshift__ = function(self,other){
207
if(isinstance(other, int)){
208
return int.$factory($B.LongInt.$dict.__lshift__($B.LongInt(self), $B.LongInt(other)))
209
}
210
var rlshift = getattr(other, '__rlshift__', null)
211
if(rlshift!==null){return rlshift(self)}
212
$err('<<', other)
213
}
214
215
int.__mod__ = function(self,other) {
Sep 5, 2014
216
// can't use Javascript % because it works differently for negative numbers
217
if(isinstance(other,_b_.tuple) && other.length==1) other=other[0]
218
if(isinstance(other,[int, _b_.float, bool])){
219
if(other===false){other=0}else if(other===true){other=1}
220
if(other==0){throw _b_.ZeroDivisionError.$factory(
221
"integer division or modulo by zero")}
222
return (self%other+other)%other
Sep 5, 2014
223
}
224
if(hasattr(other,'__rmod__')) return getattr(other,'__rmod__')(self)
225
$err('%',other)
226
}
227
228
int.__mro__ = [object]
Sep 5, 2014
229
230
int.__mul__ = function(self,other){
231
Sep 5, 2014
232
var val = self.valueOf()
Jan 22, 2015
233
234
// this will be quick check, so lets do it early.
235
if(typeof other==="string") {
236
return other.repeat(val)
237
}
238
239
if(isinstance(other,int)){
240
var res = self*other
241
if(res>$B.min_int && res<$B.max_int){return res}
242
else{return int.$factory($B.LongInt.$dict.__mul__($B.LongInt(self),
243
$B.LongInt(other)))}
245
if(isinstance(other,_b_.float)){
246
return new Number(self*other)
Sep 5, 2014
248
if(isinstance(other,_b_.bool)){
249
if (other.valueOf()) return self
250
return int.$factory(0)
Sep 5, 2014
251
}
252
if(isinstance(other,_b_.complex)){
253
return $B.make_complex(int.__mul__(self, other.$real),
254
int.__mul__(self, other.$imag))
Sep 5, 2014
255
}
256
if(isinstance(other,[_b_.list,_b_.tuple])){
257
var res = []
258
// make temporary copy of list
259
var $temp = other.slice(0,other.length)
260
for(var i=0;i<val;i++) res=res.concat($temp)
261
if(isinstance(other,_b_.tuple)) res=_b_.tuple(res)
262
return res
263
}
264
if(hasattr(other,'__rmul__')) return getattr(other,'__rmul__')(self)
265
$err("*",other)
266
}
267
268
int.__name__ = 'int'
Sep 5, 2014
269
270
int.__neg__ = function(self){return -self}
Sep 5, 2014
271
272
int.__new__ = function(cls){
273
if(cls===undefined){throw _b_.TypeError.$factory('int.__new__(): not enough arguments')}
274
return {__class__:cls.$factory ? cls : cls.$dict}
Sep 5, 2014
275
}
276
277
int.__pos__ = function(self){return self}
Sep 5, 2014
278
279
int.__pow__ = function(self,other,z){
Sep 5, 2014
280
if(isinstance(other, int)) {
Feb 9, 2015
281
switch(other.valueOf()) {
282
case 0:
283
return int.$factory(1)
Feb 9, 2015
284
case 1:
285
return int.$factory(self.valueOf())
Feb 9, 2015
286
}
May 19, 2017
287
if(z !== undefined && z !== null){
288
// If z is provided, the algorithm is faster than computing
289
// self ** other then applying the modulo z
290
var res = (self % z + z) % z
291
for(var i=1; i<other; i++){
292
res *= self
293
res = (res % z + z) % z
294
}
295
return res
296
}
297
var res = Math.pow(self.valueOf(),other.valueOf())
298
if(res>$B.min_int && res<$B.max_int){return res}
May 19, 2017
299
else if(res !== Infinity && !isFinite(res)){return res}
301
return int.$factory($B.LongInt.$dict.__pow__($B.LongInt(self),
May 19, 2017
302
$B.LongInt(other)))
303
}
Sep 5, 2014
304
}
305
if(isinstance(other, _b_.float)) {
306
if(self>=0){return new Number(Math.pow(self, other.valueOf()))}
307
else{
308
// use complex power
309
return _b_.complex.__pow__($B.make_complex(self, 0), other)
311
}else if(isinstance(other, _b_.complex)){
312
var preal = Math.pow(self, other.$real),
313
ln = Math.log(self)
314
return $B.make_complex(preal*Math.cos(ln), preal*Math.sin(ln))
Sep 5, 2014
315
}
316
if(hasattr(other,'__rpow__')) return getattr(other,'__rpow__')(self)
317
$err("**",other)
318
}
319
320
int.__repr__ = function(self){
Sep 5, 2014
321
if(self===int) return "<class 'int'>"
322
return self.toString()
323
}
324
325
// bitwise right shift
326
int.__rshift__ = function(self,other){
327
if(isinstance(other, int)){
328
return int.$factory($B.LongInt.$dict.__rshift__($B.LongInt(self),
329
$B.LongInt(other)))
330
}
331
var rrshift = getattr(other, '__rrshift__', null)
332
if(rrshift!==null){return rrshift(self)}
333
$err('>>', other)
334
}
Sep 5, 2014
335
336
int.__setattr__ = function(self,attr,value){
338
if(int.$factory[attr]===undefined){
339
throw _b_.AttributeError.$factory("'int' object has no attribute '"+attr+"'")
341
throw _b_.AttributeError.$factory("'int' object attribute '"+attr+"' is read-only")
Sep 5, 2014
343
}
344
// subclasses of int can have attributes set
345
self[attr] = value
Sep 5, 2014
347
}
348
349
int.__str__ = int.__repr__
Sep 5, 2014
350
351
int.__truediv__ = function(self,other){
Sep 5, 2014
352
if(isinstance(other,int)){
353
if(other==0) throw ZeroDivisionError.$factory('division by zero')
354
if(other.__class__==$B.LongInt.$dict){return new Number(self/parseInt(other.value))}
355
return new Number(self/other)
Sep 5, 2014
356
}
357
if(isinstance(other,_b_.float)){
358
if(!other.valueOf()) throw ZeroDivisionError.$factory('division by zero')
359
return new Number(self/other)
Sep 5, 2014
360
}
361
if(isinstance(other,_b_.complex)){
362
var cmod = other.$real*other.$real+other.$imag*other.$imag
363
if(cmod==0) throw ZeroDivisionError.$factory('division by zero')
364
return $B.make_complex(self*other.$real/cmod,-self*other.$imag/cmod)
Sep 5, 2014
365
}
366
if(hasattr(other,'__rtruediv__')) return getattr(other,'__rtruediv__')(self)
367
$err("/",other)
368
}
369
370
//int.__xor__ = function(self,other){return self ^ other} // bitwise XOR
Sep 5, 2014
371
372
int.bit_length = function(self){
Sep 5, 2014
373
s = bin(self)
374
s = getattr(s,'lstrip')('-0b') // remove leading zeros and minus sign
375
return s.length // len('100101') --> 6
376
}
377
378
// descriptors
379
int.numerator = function(self){return self}
380
int.denominator = function(self){return int.$factory(1)}
381
int.imag = function(self){return int.$factory(0)}
382
int.real = function(self){return self}
383
385
$B.max_int32= (1<<30) * 2 - 1
386
$B.min_int32= - $B.max_int32
387
388
// code for operands & | ^
Sep 5, 2014
389
var $op_func = function(self,other){
Jun 7, 2015
390
if(isinstance(other,int)) {
391
if(other.__class__===$B.LongInt.$dict){
392
return $B.LongInt.$dict.__sub__($B.LongInt(self), $B.LongInt(other))
393
}
394
if (self > $B.max_int32 || self < $B.min_int32 ||
395
other > $B.max_int32 || other < $B.min_int32) {
396
return $B.LongInt.$dict.__sub__($B.LongInt(self), $B.LongInt(other))
397
}
398
return self-other
Jun 7, 2015
399
}
Sep 5, 2014
400
if(isinstance(other,_b_.bool)) return self-other
401
if(hasattr(other,'__rsub__')) return getattr(other,'__rsub__')(self)
402
$err("-",other)
403
}
404
405
$op_func += '' // source code
406
var $ops = {'&':'and','|':'or','^':'xor'}
Sep 5, 2014
407
for(var $op in $ops){
408
var opf = $op_func.replace(/-/gm,$op)
409
opf = opf.replace(new RegExp('sub','gm'),$ops[$op])
410
eval('int.__'+$ops[$op]+'__ = '+opf)
Sep 5, 2014
411
}
412
413
// code for + and -
414
var $op_func = function(self,other){
415
if(isinstance(other,int)){
416
if(typeof other=='number'){
417
var res = self.valueOf()-other.valueOf()
418
if(res>=$B.min_int && res<=$B.max_int){return res}
419
else{return $B.LongInt.$dict.__sub__($B.LongInt(self),
420
$B.LongInt(other))}
421
}else if(typeof other=="boolean"){
422
return other ? self-1 : self
423
}else{
424
return $B.LongInt.$dict.__sub__($B.LongInt(self),
425
$B.LongInt(other))
Sep 5, 2014
427
}
428
if(isinstance(other,_b_.float)){
429
return new Number(self-other)
Sep 5, 2014
430
}
431
if(isinstance(other,_b_.complex)){
432
return $B.make_complex(self-other.$real,-other.$imag)
Sep 5, 2014
433
}
434
if(isinstance(other,_b_.bool)){
435
var bool_value=0;
436
if(other.valueOf()) bool_value=1;
Sep 5, 2014
438
}
439
if(isinstance(other,_b_.complex)){
440
return $B.make_complex(self.valueOf() - other.$real, other.$imag)
Sep 5, 2014
441
}
442
if(hasattr(other,'__rsub__')) return getattr(other,'__rsub__')(self)
443
throw $err('-',other)
444
}
445
$op_func += '' // source code
446
var $ops = {'+':'add','-':'sub'}
447
for(var $op in $ops){
448
var opf = $op_func.replace(/-/gm,$op)
449
opf = opf.replace(new RegExp('sub','gm'),$ops[$op])
450
eval('int.__'+$ops[$op]+'__ = '+opf)
Sep 5, 2014
451
}
452
453
// comparison methods
454
var $comp_func = function(self,other){
455
if (other.__class__ === $B.LongInt.$dict) {
456
return $B.LongInt.$dict.__lt__(other, $B.LongInt(self))
457
}
Sep 5, 2014
458
if(isinstance(other,int)) return self.valueOf() > other.valueOf()
459
if(isinstance(other,_b_.float)) return self.valueOf() > other.valueOf()
Sep 5, 2014
460
if(isinstance(other,_b_.bool)) {
461
return self.valueOf() > _b_.bool.$dict.__hash__(other)
462
}
463
if (hasattr(other, '__int__') || hasattr(other, '__index__')) {
464
return int.__gt__(self, $B.$GetInt(other))
467
// See if other has the opposite operator, eg < for >
468
var inv_op = getattr(other, '__lt__', null)
469
if(inv_op !== null){return inv_op(self)}
470
471
throw _b_.TypeError.$factory(
472
"unorderable types: int() > "+$B.get_class(other).__name__+"()")
Sep 5, 2014
473
}
474
$comp_func += '' // source code
Sep 5, 2014
476
for(var $op in $B.$comps){
477
eval("int.__"+$B.$comps[$op]+'__ = '+
478
$comp_func.replace(/>/gm,$op).
479
replace(/__gt__/gm,'__'+$B.$comps[$op]+'__').
480
replace(/__lt__/, '__'+$B.$inv_comps[$op]+'__'))
Sep 5, 2014
481
}
482
483
// add "reflected" methods
484
$B.make_rmethods(int)
Sep 5, 2014
485
486
var $valid_digits=function(base) {
487
var digits=''
488
if (base === 0) return '0'
489
if (base < 10) {
490
for (var i=0; i < base; i++) digits+=String.fromCharCode(i+48)
491
return digits
492
}
493
494
var digits='0123456789'
495
// A = 65 (10 + 55)
496
for (var i=10; i < base; i++) digits+=String.fromCharCode(i+55)
497
return digits
498
}
499
500
int.$factory = function(value, base){
501
// int() with no argument returns 0
502
if(value===undefined){return 0}
504
// int() of an integer returns the integer if base is undefined
505
if(typeof value=='number' &&
506
(base===undefined || base==10)){return parseInt(value)}
Dec 28, 2014
508
if(base!==undefined){
509
if(!isinstance(value,[_b_.str,_b_.bytes,_b_.bytearray])){
510
throw TypeError.$factory("int() can't convert non-string with explicit base")
Dec 28, 2014
511
}
512
}
513
514
if(isinstance(value,_b_.complex)){
515
throw TypeError.$factory("can't convert complex to int")
Dec 28, 2014
516
}
517
518
var $ns=$B.args('int',2,{x:null,base:null},['x','base'],arguments,
519
{'base':10},'null','null')
520
var value = $ns['x']
521
var base = $ns['base']
523
if(isinstance(value, _b_.float) && base===10){
524
if(value<$B.min_int || value>$B.max_int){
525
return $B.LongInt.$dict.$from_float(value)
526
}
527
else{return value>0 ? Math.floor(value) : Math.ceil(value)}
Sep 5, 2014
529
Dec 26, 2014
530
if (!(base >=2 && base <= 36)) {
531
// throw error (base must be 0, or 2-36)
532
if (base != 0) throw _b_.ValueError.$factory("invalid base")
Dec 26, 2014
533
}
534
535
if (typeof value == 'number'){
536
537
if(base==10){
538
if(value < $B.min_int || value > $B.max_int) return $B.LongInt(value)
539
return value
540
}else if(value.toString().search('e')>-1){
Dec 26, 2014
541
// can't convert to another base if value is too big
542
throw _b_.OverflowError.$factory("can't convert to base "+base)
Dec 26, 2014
543
}else{
544
var res=parseInt(value, base)
545
if(res < $B.min_int || res > $B.max_int) return $B.LongInt(value,base)
546
return res
Dec 26, 2014
547
}
548
}
Sep 5, 2014
549
550
if(value===true) return Number(1)
551
if(value===false) return Number(0)
552
if(value.__class__===$B.LongInt.$dict){
553
var z = parseInt(value.value)
554
if(z>$B.min_int && z<$B.max_int){return z}
555
else{return value}
556
}
Sep 5, 2014
557
Jan 22, 2015
558
base=$B.$GetInt(base)
Sep 5, 2014
559
560
if(isinstance(value, _b_.str)) value=value.valueOf()
561
if(typeof value=="string") {
562
var _value=value.trim() // remove leading/trailing whitespace
563
if (_value.length == 2 && base==0 && (_value=='0b' || _value=='0o' || _value=='0x')) {
564
throw _b_.ValueError.$factory('invalid value')
Sep 5, 2014
565
}
566
if (_value.length >2) {
567
var _pre=_value.substr(0,2).toUpperCase()
Sep 5, 2014
568
if (base == 0) {
569
if (_pre == '0B') base=2
570
if (_pre == '0O') base=8
571
if (_pre == '0X') base=16
572
}
573
if (_pre=='0B' || _pre=='0O' || _pre=='0X') {
Sep 5, 2014
575
}
576
}
577
var _digits=$valid_digits(base)
578
var _re=new RegExp('^[+-]?['+_digits+']+$', 'i')
580
throw _b_.ValueError.$factory(
581
"invalid literal for int() with base "+base +": '"+_b_.str(value)+"'")
Sep 5, 2014
582
}
583
if(base <= 10 && !isFinite(value)) {
584
throw _b_.ValueError.$factory(
585
"invalid literal for int() with base "+base +": '"+_b_.str(value)+"'")
587
var res=parseInt(_value, base)
588
if(res < $B.min_int || res > $B.max_int) return $B.LongInt(_value, base)
589
return res
Sep 5, 2014
590
}
592
if(isinstance(value,[_b_.bytes,_b_.bytearray])){
593
var _digits = $valid_digits(base)
594
for(var i=0;i<value.source.length;i++){
595
if(_digits.indexOf(String.fromCharCode(value.source[i]))==-1){
596
throw _b_.ValueError.$factory("invalid literal for int() with base "+
597
base +": "+_b_.repr(value))
598
}
599
}
600
return Number(parseInt(getattr(value,'decode')('latin-1'), base))
601
}
Sep 5, 2014
602
603
if(hasattr(value, '__int__')) return getattr(value,'__int__')()
604
if(hasattr(value, '__index__')) return getattr(value,'__index__')()
605
if(hasattr(value, '__trunc__')) {
606
var res = getattr(value,'__trunc__')(),
607
int_func = _b_.getattr(res, '__int__', null)
608
if(int_func===null){
609
throw TypeError.$factory('__trunc__ returned non-Integral (type '+
610
$B.get_class(res).__name__+')')
611
}
612
var res=int_func()
613
if(isinstance(res, int)){return res}
614
throw TypeError.$factory('__trunc__ returned non-Integral (type '+
615
$B.get_class(res).__name__+')')
616
}
Sep 5, 2014
617
618
throw _b_.TypeError.$factory("int() argument must be a string, a bytes-like "+
619
"object or a number, not '"+$B.get_class(value).__name__+"'")
Sep 5, 2014
620
}
621
622
$B.set_func_names(int, "builtins")
Sep 5, 2014
624
_b_.int = int
625
626
// Boolean type
627
var $BoolDict = _b_.bool.$dict
628
629
$BoolDict.__add__ = function(self,other){
630
return (other ? 1 : 0)+(self ? 1 : 0)
631
}
632
633
$BoolDict.__and__ = function(self, other){
634
return bool(int.__and__(self, other))
635
}
636
637
$BoolDict.__eq__ = function(self,other){
638
return self ? bool(other) : !bool(other)
639
}
640
641
$BoolDict.__ne__ = function(self,other){
642
return self ? !bool(other) : bool(other)
643
}
644
645
$BoolDict.__ge__ = function(self,other){
646
return _b_.int.__ge__($BoolDict.__hash__(self),other)
647
}
648
649
$BoolDict.__gt__ = function(self,other){
650
return _b_.int.__gt__($BoolDict.__hash__(self),other)
651
}
652
653
$BoolDict.__hash__ = $BoolDict.__index__= $BoolDict.__int__=function(self) {
654
if(self.valueOf()) return 1
655
return 0
656
}
657
658
$BoolDict.__le__ = function(self,other){return !$BoolDict.__gt__(self,other)}
659
660
$BoolDict.__lshift__ = function(self,other){return self.valueOf() << other}
661
662
$BoolDict.__lt__ = function(self,other){return !$BoolDict.__ge__(self,other)}
663
664
$BoolDict.__mul__ = function(self,other){
666
}
667
668
$BoolDict.__neg__ = function(self){return -$B.int_or_bool(self)}
669
670
$BoolDict.__or__ = function(self, other){
671
return bool(int.__or__(self, other))
672
}
673
674
$BoolDict.__pos__ = $B.int_or_bool
675
676
$BoolDict.__repr__ = $BoolDict.__str__ = function(self){
677
return self ? "True" : "False"
678
}
679
680
$BoolDict.__setattr__ = function(self, attr){
681
return no_set_attr($BoolDict, attr)
682
}
683
684
$BoolDict.__sub__ = function(self,other){
685
return (self ? 1 : 0) - (other ? 1 : 0)
686
}
687
688
$BoolDict.__xor__ = function(self, other) {
689
return self.valueOf() != other.valueOf()
690
}
691
692
693
$BoolDict.__mro__ = [int, _b_.object]
Sep 5, 2014
695
})(__BRYTHON__)