예제 #1
0
    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
예제 #2
0
 def compile(self, display=0):
     tree = self._get_tree()
     gen = ModuleCodeGenerator(tree)
     if display:
         import pprint
         print pprint.pprint(tree)
     self.code = gen.getCode()
예제 #3
0
        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
예제 #4
0
                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.
예제 #5
0
                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.
예제 #6
0
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)