示例#1
0
文件: define.py 项目: chaosim/dao
def macrorules(*rules):
    result = []
    for rule in rules:
        head = tuple(element(x) for x in rule[0])
        body = begin(*(element(x) for x in rule[1:]))
        result.append((head, body))
    return MacroRules(result)
示例#2
0
文件: define.py 项目: hermetique/dao
def macrorules(*rules):
  result = []
  for rule in rules:
    head = tuple(element(x) for x in rule[0])
    body = begin(*(element(x) for x in rule[1:]))
    result.append((head, body))
  return MacroRules(result)
示例#3
0
文件: compile.py 项目: hermetique/dao
def compile_to_python(exp, env, done=None):
    '''assemble steps from dao expression to python code'''
    original_exp = exp
    compiler = Compiler()
    if done is None:
        done = il.Done(compiler.new_var(il.ConstLocalVar('v')))
    compiler.exit_block_cont_map = {}
    compiler.continue_block_cont_map = {}
    compiler.protect_cont = done
    if env is None: env = Environment()
    exp = element(exp)
    exp = exp.alpha(env, compiler)
    exp = exp.cps(compiler, done)
    exp.analyse(compiler)
    env = Environment()
    exp = exp.optimize(env, compiler)
    #exp = exp.tail_recursive_convert()
    function = compiler.new_var(il.ConstLocalVar('compiled_dao_function'))
    exp = il.Function(function, (), exp)
    exp = il.begin(*exp.pythonize(env, compiler)[0])
    if isinstance(exp, il.Begin):
        exp = exp.statements[0]
    exp.body = exp.body.replace_return_with_yield()
    compiler = Compiler()
    result = exp.to_code(compiler)
    return prelude + result
示例#4
0
文件: compile.py 项目: chaosim/dao
def compile_to_python(exp, env, done=None): 
  '''assemble steps from dao expression to python code'''
  original_exp = exp
  compiler = Compiler()
  if done is None:
    done = il.Done(compiler.new_var(il.ConstLocalVar('v')))
  compiler.exit_block_cont_map = {}
  compiler.continue_block_cont_map = {}
  compiler.protect_cont = done
  if env is None: env = Environment()
  exp = element(exp)
  exp = exp.alpha(env, compiler)
  exp = exp.cps(compiler, done)
  exp.analyse(compiler)
  env = Environment()
  exp = exp.optimize(env, compiler)
  #exp = exp.tail_recursive_convert()
  function = compiler.new_var(il.ConstLocalVar('compiled_dao_function'))
  exp = il.Function(function, (), exp)
  exp = il.begin(*exp.pythonize(env, compiler)[0])
  if isinstance(exp, il.Begin):
    exp = exp.statements[0]
  exp.body = exp.body.replace_return_with_yield()
  compiler = Compiler()
  result = exp.to_code(compiler)
  return prelude + result
示例#5
0
文件: special.py 项目: hermetique/dao
def begin(*exps):
    exps = tuple(element(e) for e in exps)
    if len(exps) == 1: return exps[0]
    else:
        result = []
        for exp in exps:
            if isinstance(exp, SpecialCall) and exp.command is Begin:
                result += list(exp.args)
            else:
                result.append(exp)
        return Begin(*result)
示例#6
0
文件: special.py 项目: chaosim/dao
def begin(*exps):
  exps = tuple(element(e) for e in exps)
  if len(exps)==1: return exps[0]
  else:
    result = []
    for exp in exps:
      if isinstance(exp, SpecialCall) and exp.command is Begin:
        result += list(exp.args)
      else:
        result.append(exp)
    return Begin(*result)        
示例#7
0
def unquote_splice(item):
  return UnquoteSplice(element(item))
示例#8
0
文件: define.py 项目: hermetique/dao
def letrec(bindings, *body):
  return Letrec(tuple((element(var), element(value)) for var, value in bindings), 
                begin(*tuple(element(exp) for exp in body)))
示例#9
0
文件: define.py 项目: hermetique/dao
def let(bindings, *body):
  bindings = tuple((var, element(value)) for var, value in bindings)
  return Let(bindings, begin(*body))
示例#10
0
文件: define.py 项目: hermetique/dao
def lamda(params, *body):
  body = tuple(element(x) for x in body)
  return Lamda(params, begin(*body))
示例#11
0
文件: special.py 项目: chaosim/dao
def exit_block(label=NONE, value=NONE):
  return ExitBlock(element(label), element(value))
示例#12
0
文件: special.py 项目: chaosim/dao
def block(label, *exps):
  return Block(label, begin(*tuple(element(x) for x in exps)))
示例#13
0
文件: define.py 项目: chaosim/dao
def let(bindings, *body):
    bindings = tuple((var, element(value)) for var, value in bindings)
    return Let(bindings, begin(*body))
示例#14
0
文件: special.py 项目: chaosim/dao
def continue_block(label=NONE):
  return ContinueBlock(element(label))
示例#15
0
def quasiquote(item):
  return Quasiquote(element(item))
示例#16
0
文件: define.py 项目: chaosim/dao
def lamda(params, *body):
    body = tuple(element(x) for x in body)
    return Lamda(params, begin(*body))
示例#17
0
文件: special.py 项目: hermetique/dao
def continue_block(label=NONE):
    return ContinueBlock(element(label))
示例#18
0
文件: special.py 项目: hermetique/dao
def exit_block(label=NONE, value=NONE):
    return ExitBlock(element(label), element(value))
示例#19
0
文件: define.py 项目: chaosim/dao
 def __call__(self, *args):
     return Apply(self, tuple(element(arg) for arg in args))
示例#20
0
文件: define.py 项目: chaosim/dao
def macro(params, *body):
    body = tuple(element(x) for x in body)
    return Macro(params, begin(*body))
示例#21
0
文件: define.py 项目: hermetique/dao
def macro(params, *body):
  body = tuple(element(x) for x in body)
  return Macro(params, begin(*body))
示例#22
0
文件: define.py 项目: hermetique/dao
 def __call__(self, *args):
   return Apply(self, tuple(element(arg) for arg in args))
示例#23
0
文件: define.py 项目: chaosim/dao
def letrec(bindings, *body):
    return Letrec(
        tuple((element(var), element(value)) for var, value in bindings), begin(*tuple(element(exp) for exp in body))
    )
示例#24
0
文件: special.py 项目: hermetique/dao
def block(label, *exps):
    return Block(label, begin(*tuple(element(x) for x in exps)))
示例#25
0
def unquote(item):
  return Unquote(element(item))