def on_new(self, event): body = [ "def __init__(self):", " Choice.__init__(self)", " self.__glumolinit__()", "def __glumolinit__(self):", " self.text = 'Say something'" ] name = "Choice" + str(len(self.shapes) + 1) c = self.woolsey.classe.add_class(name, ["Choice"], body) newname = guess_free_name("Choice") from compiler.misc import set_filename from compiler.pycodegen import ModuleCodeGenerator set_filename("__foo__.py", self.woolsey.active_resource.ast) gen = ModuleCodeGenerator(self.woolsey.active_resource.ast) self.classe = classe = self.woolsey.active_resource.get_class() wx.GetApp().gns.run(gen.getCode()) obj = self.woolsey.create_dialog_item(name) item = self.woolsey.create_child("Say something") item.classe = c item.obj = obj self.Refresh() del self.current_position return item
def compile(self, display=0): tree = self._get_tree() gen = ModuleCodeGenerator(tree) if display: import pprint print pprint.pprint(tree) self.code = gen.getCode()
arg_names, defaults=[], # more args to come... lineno=0): assert filename, "filename is required" try: tree = parse_function(_fix_src(src), func_name, arg_names, defaults) except SyntaxError, err: err.lineno += lineno err.filename = filename raise SyntaxError, err set_filename_and_offset(filename, lineno, tree) gen = ModuleCodeGenerator(tree) return gen.getCode() # And a 'standard' compile, but with the filename offset feature. def compile(src, filename, mode='exec', flags=None, dont_inherit=None, lineno=0): if flags is not None or dont_inherit is not None or mode != 'exec': raise RuntimeError, "not implemented yet" try: tree = parse(_fix_src(src), mode) except SyntaxError, err: err.lineno += lineno
msg += ":\n " + orig_source raise Exception(msg) else: raise recursively_replace(tree, wrap_node) if mode == 'exec': set_filename(filename, lineno - line_offset, tree) cg = ModuleCodeGenerator(tree) else: set_filename(filename, lineno - line_offset, tree) cg = ExpressionCodeGenerator(tree) return cg.getCode() def py_compile_exec_bytecode(source, **kwargs): code = py_compile(source, 'exec', **kwargs) return marshal.dumps(code) def py_compile_eval_bytecode(source, **kwargs): source = source.strip() code = py_compile(source, 'eval', **kwargs) return marshal.dumps(code) ##### Classes that are exported in place of the normal list, dict, and ##### object.
def compile_function(src, filename, func_name, arg_names, defaults=[], # more args to come... lineno=0): assert filename, "filename is required" try: tree = parse_function(_fix_src(src), func_name, arg_names, defaults) except SyntaxError, err: err.lineno += lineno err.filename = filename raise SyntaxError, err set_filename_and_offset(filename, lineno, tree) gen = ModuleCodeGenerator(tree) return gen.getCode() # And a 'standard' compile, but with the filename offset feature. def compile(src, filename, mode='exec', flags=None, dont_inherit=None, lineno=0): if flags is not None or dont_inherit is not None or mode != 'exec': raise RuntimeError, "not implemented yet" try: tree = parse(_fix_src(src), mode) except SyntaxError, err: err.lineno += lineno err.filename = filename raise SyntaxError, err set_filename_and_offset(filename, lineno, tree) gen = ModuleCodeGenerator(tree)