(vl-udptable-assignrhs inexprs lines warnings) → (mv okp warnings expr)
Function:
(defun vl-udptable-assignrhs (inexprs lines warnings) (declare (xargs :guard (and (vl-exprlist-p inexprs) (vl-udptable-p lines) (vl-warninglist-p warnings)))) (declare (xargs :guard (consp inexprs))) (let ((__function__ 'vl-udptable-assignrhs)) (declare (ignorable __function__)) (b* (((when (atom lines)) (mv t (ok) |*sized-1'bx*|)) ((vl-udpline line1) (car lines)) ((when line1.current) (mv nil (fatal :type :vl-bad-udp-line :msg "Combinational UDP, but line has a current state? ~x0." :args (list line1)) |*sized-1'bx*|)) ((unless (same-lengthp inexprs line1.inputs)) (mv nil (fatal :type :vl-bad-udp-line :msg "UDP has ~x0 inputs, but line has ~x1: ~x2." :args (list (len inexprs) (len line1.inputs) line1.inputs)) |*sized-1'bx*|)) ((mv okp warnings match-expr) (vl-udpline-match-expr inexprs line1.inputs warnings)) ((unless okp) (mv nil warnings |*sized-1'bx*|)) (then-expr (case line1.output (:vl-udp-0 |*sized-1'b0*|) (:vl-udp-1 |*sized-1'b1*|) (:vl-udp-x |*sized-1'bx*|) (otherwise nil))) ((unless then-expr) (mv nil (fatal :type :vl-bad-udp-output :msg "UDP line output must be 0/1/x, but is ~x0." :args (list line1.output)) |*sized-1'bx*|)) ((mv okp warnings else-expr) (vl-udptable-assignrhs inexprs (cdr lines) warnings)) ((unless okp) (mv nil warnings |*sized-1'bx*|)) (rhs (make-vl-nonatom :op :vl-qmark :args (list match-expr then-expr else-expr)))) (mv t (ok) rhs))))
Theorem:
(defthm booleanp-of-vl-udptable-assignrhs.okp (b* (((mv ?okp ?warnings ?expr) (vl-udptable-assignrhs inexprs lines warnings))) (booleanp okp)) :rule-classes :type-prescription)
Theorem:
(defthm vl-warninglist-p-of-vl-udptable-assignrhs.warnings (b* (((mv ?okp ?warnings ?expr) (vl-udptable-assignrhs inexprs lines warnings))) (vl-warninglist-p warnings)) :rule-classes :rewrite)
Theorem:
(defthm vl-expr-p-of-vl-udptable-assignrhs.expr (b* (((mv ?okp ?warnings ?expr) (vl-udptable-assignrhs inexprs lines warnings))) (vl-expr-p expr)) :rule-classes :rewrite)