コード例 #1
0
ファイル: ala.py プロジェクト: gyezhz/migen
 def get_process_fragment(self):
     return Fragment([
         self.token("result").r.eq(
             _Operator(self.op,
                       [self.token("operands").a,
                        self.token("operands").b]))
     ])
コード例 #2
0
ファイル: misc.py プロジェクト: vic0/migen
def optree(op, operands, lb=None, ub=None, default=None):
	if lb is None:
		lb = 0
	if ub is None:
		ub = len(operands)
	l = ub - lb
	if l == 0:
		if default is None:
			raise AttributeError
		else:
			return default
	elif l == 1:
		return operands[lb]
	else:
		s = lb + l//2
		return _Operator(op,
			[optree(op, operands, lb, s, default),
			optree(op, operands, s, ub, default)])
コード例 #3
0
ファイル: misc.py プロジェクト: ross1909/migen
def optree(op, operands, lb=None, ub=None, default=None):
    if lb is None:
        lb = 0
    if ub is None:
        ub = len(operands)
    l = ub - lb
    if l == 0:
        if default is None:
            raise AttributeError
        else:
            return default
    elif l == 1:
        return operands[lb]
    else:
        s = lb + l // 2
        return _Operator(op, [
            optree(op, operands, lb, s, default),
            optree(op, operands, s, ub, default)
        ])
コード例 #4
0
ファイル: ala.py プロジェクト: ross1909/migen
	def get_process_fragment(self):
		return Fragment([
			self.token("result").r.eq(_Operator(self.op, 
				[self.token("operands").a, self.token("operands").b]))
		])
コード例 #5
0
ファイル: visit.py プロジェクト: peteut/migen
 def visit_Operator(self, node):
     return _Operator(node.op, [self.visit(o) for o in node.operands])
コード例 #6
0
ファイル: visit.py プロジェクト: RP7/migen
	def visit_Operator(self, node):
		return _Operator(node.op, [self.visit(o) for o in node.operands])