def _makefunc_str_int(cls, f): def main(argv): arg0 = argv[1] arg1 = int(argv[2]) try: res = f(arg0, arg1) except MemoryError: print "MEMORY-ERROR" else: print res return 0 t = Translation(main, gc=cls.gcpolicy, taggedpointers=cls.taggedpointers, gcremovetypeptr=cls.removetypeptr) t.disable(['backendopt']) t.set_backend_extra_options(c_debug_defines=True) t.rtype() if option.view: t.viewcg() exename = t.compile() def run(s, i): data = py.process.cmdexec("%s %s %d" % (exename, s, i)) data = data.strip() if data == 'MEMORY-ERROR': raise MemoryError return data return run
def test_disable_logic(): def f(x, y): return x + y t = Translation(f, [int, int]) t.disable(['backendopt']) t.source_c() assert 'backendopt' not in t.driver.done
def test_disable_logic(): def f(x,y): return x+y t = Translation(f, [int, int]) t.disable(['backendopt']) t.source_c() assert 'backendopt' not in t.driver.done
def test_nonmoving_raw_ptr_for_resizable_list(): def f(n): lst = ['a', 'b', 'c'] lst = rgc.resizable_list_supporting_raw_ptr(lst) lst.append(chr(n)) assert lst[3] == chr(n) assert lst[-1] == chr(n) # ptr = rgc.nonmoving_raw_ptr_for_resizable_list(lst) assert lst[:] == ['a', 'b', 'c', chr(n)] assert lltype.typeOf(ptr) == rffi.CCHARP assert [ptr[i] for i in range(4)] == ['a', 'b', 'c', chr(n)] # lst[-3] = 'X' assert ptr[1] == 'X' ptr[2] = 'Y' assert lst[-2] == 'Y' # addr = rffi.cast(lltype.Signed, ptr) ptr = rffi.cast(rffi.CCHARP, addr) rgc.collect() # should not move lst.items lst[-4] = 'g' assert ptr[0] == 'g' ptr[3] = 'H' assert lst[-1] == 'H' return lst # # direct untranslated run lst = f(35) assert isinstance(lst, rgc._ResizableListSupportingRawPtr) # # llinterp run interpret(f, [35]) # # compilation with the GC transformer import subprocess from rpython.translator.interactive import Translation # def main(argv): f(len(argv)) print "OK!" return 0 # t = Translation(main, gc="incminimark") t.disable(['backendopt']) t.set_backend_extra_options(c_debug_defines=True) exename = t.compile() data = subprocess.check_output([str(exename), '.', '.', '.']) assert data.strip().endswith('OK!')
def test_ll_for_resizable_list(): def f(n): lst = ['a', 'b', 'c'] lst = rgc.resizable_list_supporting_raw_ptr(lst) lst.append(chr(n)) assert lst[3] == chr(n) assert lst[-1] == chr(n) # ll_list = rgc.ll_for_resizable_list(lst) assert lst[:] == ['a', 'b', 'c', chr(n)] assert ll_list.length == 4 assert [ll_list.items[i] for i in range(4)] == ['a', 'b', 'c', chr(n)] # lst[-3] = 'X' assert ll_list.items[1] == 'X' ll_list.items[2] = 'Y' assert lst[-2] == 'Y' # return lst # # direct untranslated run lst = f(35) assert isinstance(lst, rgc._ResizableListSupportingRawPtr) # # llinterp run interpret(f, [35]) # # compilation with the GC transformer import subprocess from rpython.translator.interactive import Translation # def main(argv): f(len(argv)) print "OK!" return 0 # t = Translation(main, gc="incminimark") t.disable(['backendopt']) t.set_backend_extra_options(c_debug_defines=True) exename = t.compile() data = subprocess.check_output([str(exename), '.', '.', '.']) assert data.strip().endswith('OK!')
def compile(self, entry_point, backendopt=True, withsmallfuncsets=None, shared=False, thread=False): t = Translation(entry_point, None, gc="boehm") self.t = t t.set_backend_extra_options(c_debug_defines=True) t.config.translation.reverse_debugger = True t.config.translation.lldebug0 = True t.config.translation.shared = shared t.config.translation.thread = thread if withsmallfuncsets is not None: t.config.translation.withsmallfuncsets = withsmallfuncsets if not backendopt: t.disable(["backendopt_lltype"]) t.annotate() t.rtype() if t.backendopt: t.backendopt() self.exename = t.compile_c() self.rdbname = os.path.join(os.path.dirname(str(self.exename)), 'log.rdb')
def _test_translated(self, use_gc, llcase): import subprocess from rpython.rlib import objectmodel from rpython.translator.interactive import Translation # class Seen: count = 0 class MySimpleFQ(rgc.FinalizerQueue): if not llcase: Class = T_Root else: Class = None def finalizer_trigger(self): seen.count += 1 seen = Seen() fq = MySimpleFQ() if not llcase: EMPTY = None llbuilder = T_Int else: from rpython.rtyper.annlowlevel import llstr EMPTY = lltype.nullptr(llmemory.GCREF.TO) def llbuilder(n): return lltype.cast_opaque_ptr(llmemory.GCREF, llstr(str(n))) def subfunc(): w0 = llbuilder(40) fq.register_finalizer(w0) w1 = llbuilder(41) fq.register_finalizer(w1) w2 = llbuilder(42) fq.register_finalizer(w2) w3 = llbuilder(43) fq.register_finalizer(w3) w4 = llbuilder(44) fq.register_finalizer(w4) w5 = llbuilder(45) fq.register_finalizer(w5) w6 = llbuilder(46) fq.register_finalizer(w6) w7 = llbuilder(47) fq.register_finalizer(w7) w8 = llbuilder(48) fq.register_finalizer(w8) w9 = llbuilder(49) fq.register_finalizer(w9) gc.collect() assert seen.count == 0 assert fq.next_dead() is EMPTY objectmodel.keepalive_until_here(w0) objectmodel.keepalive_until_here(w1) objectmodel.keepalive_until_here(w2) objectmodel.keepalive_until_here(w3) objectmodel.keepalive_until_here(w4) objectmodel.keepalive_until_here(w5) objectmodel.keepalive_until_here(w6) objectmodel.keepalive_until_here(w7) objectmodel.keepalive_until_here(w8) objectmodel.keepalive_until_here(w9) def main(argv): assert fq.next_dead() is EMPTY subfunc() gc.collect() gc.collect() gc.collect() assert seen.count > 0 n = fq.next_dead() while True: if not llcase: assert type(n) is T_Int and 40 <= n.x <= 49 else: from rpython.rtyper.lltypesystem.rstr import STR assert lltype.typeOf(n) is llmemory.GCREF p = lltype.cast_opaque_ptr(lltype.Ptr(STR), n) assert len(p.chars) == 2 assert p.chars[0] == "4" assert "0" <= p.chars[1] <= "9" n = fq.next_dead() if n is EMPTY: break print "OK!" return 0 # t = Translation(main, gc=use_gc) t.disable(['backendopt']) t.set_backend_extra_options(c_debug_defines=True) exename = t.compile() data = subprocess.check_output([str(exename), '.', '.', '.']) assert data.strip().endswith('OK!')
def compile(fn, argtypes, view=False, gcpolicy="none", backendopt=True, annotatorpolicy=None, thread=False, **kwds): argtypes_unroll = unrolling_iterable(enumerate(argtypes)) for argtype in argtypes: if argtype not in [ int, float, str, bool, r_ulonglong, r_longlong, r_uint ]: raise Exception("Unsupported argtype, %r" % (argtype, )) def entry_point(argv): args = () for i, argtype in argtypes_unroll: a = argv[i + 1] if argtype is int: args += (int(a), ) elif argtype is r_uint: args += (r_uint(int(a)), ) elif argtype is r_longlong: args += (parse_longlong(a), ) elif argtype is r_ulonglong: args += (parse_ulonglong(a), ) elif argtype is bool: if a == 'True': args += (True, ) else: assert a == 'False' args += (False, ) elif argtype is float: if a == 'inf': args += (INFINITY, ) elif a == '-inf': args += (-INFINITY, ) elif a == 'nan': args += (NAN, ) else: args += (float(a), ) else: if a.startswith('/'): # escaped string if len(a) == 1: a = '' else: l = a[1:].split(',') a = ''.join([chr(int(x)) for x in l]) args += (a, ) res = fn(*args) print "THE RESULT IS:", llrepr_out(res), ";" return 0 t = Translation(entry_point, None, gc=gcpolicy, backend="c", policy=annotatorpolicy, thread=thread, **kwds) if not backendopt: t.disable(["backendopt_lltype"]) t.driver.config.translation.countmallocs = True t.annotate() try: if py.test.config.option.view: t.view() except AttributeError: pass t.rtype() if backendopt: t.backendopt() try: if py.test.config.option.view: t.view() except AttributeError: pass t.compile_c() ll_res = graphof(t.context, fn).getreturnvar().concretetype def output(stdout): for line in stdout.splitlines(False): if len(repr(line)) == len(line) + 2: # no escaped char print line else: print 'REPR:', repr(line) def f(*args, **kwds): expected_extra_mallocs = kwds.pop('expected_extra_mallocs', 0) expected_exception_name = kwds.pop('expected_exception_name', None) assert not kwds assert len(args) == len(argtypes) for arg, argtype in zip(args, argtypes): assert isinstance(arg, argtype) stdout = t.driver.cbuilder.cmdexec( " ".join([llrepr_in(arg) for arg in args]), expect_crash=(expected_exception_name is not None)) # if expected_exception_name is not None: stdout, stderr = stdout print '--- stdout ---' output(stdout) print '--- stderr ---' output(stderr) print '--------------' stderr, prevline, lastline, empty = stderr.rsplit('\n', 3) assert empty == '' expected = 'Fatal RPython error: ' + expected_exception_name assert lastline == expected or prevline == expected return None output(stdout) stdout, lastline, empty = stdout.rsplit('\n', 2) assert empty == '' assert lastline.startswith('MALLOC COUNTERS: ') mallocs, frees = map(int, lastline.split()[2:]) assert stdout.endswith(' ;') pos = stdout.rindex('THE RESULT IS: ') res = stdout[pos + len('THE RESULT IS: '):-2] # if isinstance(expected_extra_mallocs, int): assert mallocs - frees == expected_extra_mallocs else: assert mallocs - frees in expected_extra_mallocs # if ll_res in [ lltype.Signed, lltype.Unsigned, lltype.SignedLongLong, lltype.UnsignedLongLong ]: return int(res) elif ll_res == lltype.Bool: return bool(int(res)) elif ll_res == lltype.Char: assert len(res) == 1 return res elif ll_res == lltype.Float: return float(res) elif ll_res == lltype.Ptr(STR): return res elif ll_res == lltype.Void: return None raise NotImplementedError("parsing %s" % (ll_res, )) class CompilationResult(object): def __repr__(self): return 'CompilationResult(%s)' % (fn.__name__, ) def __call__(self, *args, **kwds): return f(*args, **kwds) cr = CompilationResult() cr.t = t cr.builder = t.driver.cbuilder return cr
def compile(fn, argtypes, view=False, gcpolicy="none", backendopt=True, annotatorpolicy=None, thread=False, **kwds): argtypes_unroll = unrolling_iterable(enumerate(argtypes)) for argtype in argtypes: if argtype not in [int, float, str, bool, r_ulonglong, r_longlong, r_uint]: raise Exception("Unsupported argtype, %r" % (argtype,)) def entry_point(argv): args = () for i, argtype in argtypes_unroll: a = argv[i + 1] if argtype is int: args += (int(a),) elif argtype is r_uint: args += (r_uint(int(a)),) elif argtype is r_longlong: args += (parse_longlong(a),) elif argtype is r_ulonglong: args += (parse_ulonglong(a),) elif argtype is bool: if a == 'True': args += (True,) else: assert a == 'False' args += (False,) elif argtype is float: if a == 'inf': args += (INFINITY,) elif a == '-inf': args += (-INFINITY,) elif a == 'nan': args += (NAN,) else: args += (float(a),) else: if a.startswith('/'): # escaped string if len(a) == 1: a = '' else: l = a[1:].split(',') a = ''.join([chr(int(x)) for x in l]) args += (a,) res = fn(*args) print "THE RESULT IS:", llrepr_out(res), ";" return 0 t = Translation(entry_point, None, gc=gcpolicy, backend="c", policy=annotatorpolicy, thread=thread, **kwds) if not backendopt: t.disable(["backendopt_lltype"]) t.driver.config.translation.countmallocs = True t.annotate() try: if py.test.config.option.view: t.view() except AttributeError: pass t.rtype() if backendopt: t.backendopt() try: if py.test.config.option.view: t.view() except AttributeError: pass t.compile_c() ll_res = graphof(t.context, fn).getreturnvar().concretetype def output(stdout): for line in stdout.splitlines(False): if len(repr(line)) == len(line) + 2: # no escaped char print line else: print 'REPR:', repr(line) def f(*args, **kwds): expected_extra_mallocs = kwds.pop('expected_extra_mallocs', 0) expected_exception_name = kwds.pop('expected_exception_name', None) assert not kwds assert len(args) == len(argtypes) for arg, argtype in zip(args, argtypes): assert isinstance(arg, argtype) stdout = t.driver.cbuilder.cmdexec( " ".join([llrepr_in(arg) for arg in args]), expect_crash=(expected_exception_name is not None)) # if expected_exception_name is not None: stdout, stderr = stdout print '--- stdout ---' output(stdout) print '--- stderr ---' output(stderr) print '--------------' stderr, prevline, lastline, empty = stderr.rsplit('\n', 3) assert empty == '' expected = 'Fatal RPython error: ' + expected_exception_name assert lastline == expected or prevline == expected return None output(stdout) stdout, lastline, empty = stdout.rsplit('\n', 2) assert empty == '' assert lastline.startswith('MALLOC COUNTERS: ') mallocs, frees = map(int, lastline.split()[2:]) assert stdout.endswith(' ;') pos = stdout.rindex('THE RESULT IS: ') res = stdout[pos + len('THE RESULT IS: '):-2] # if isinstance(expected_extra_mallocs, int): assert mallocs - frees == expected_extra_mallocs else: assert mallocs - frees in expected_extra_mallocs # if ll_res in [lltype.Signed, lltype.Unsigned, lltype.SignedLongLong, lltype.UnsignedLongLong]: return int(res) elif ll_res == lltype.Bool: return bool(int(res)) elif ll_res == lltype.Char: assert len(res) == 1 return res elif ll_res == lltype.Float: return float(res) elif ll_res == lltype.Ptr(STR): return res elif ll_res == lltype.Void: return None raise NotImplementedError("parsing %s" % (ll_res,)) class CompilationResult(object): def __repr__(self): return 'CompilationResult(%s)' % (fn.__name__,) def __call__(self, *args, **kwds): return f(*args, **kwds) cr = CompilationResult() cr.t = t cr.builder = t.driver.cbuilder return cr