(vl-paramdecl-set-default x val) → (mv ok new-x)
Function:
(defun vl-paramdecl-set-default (x val) (declare (xargs :guard (and (vl-paramdecl-p x) (vl-maybe-paramvalue-p val)))) (let ((__function__ 'vl-paramdecl-set-default)) (declare (ignorable __function__)) (b* (((vl-paramdecl x)) (val (vl-maybe-paramvalue-fix val)) ((mv ok type) (vl-paramtype-case x.type :vl-typeparam (if (or (not val) (vl-paramvalue-datatype-p val)) (mv t (change-vl-typeparam x.type :default val)) (mv nil (change-vl-typeparam x.type :default nil))) :vl-implicitvalueparam (if (or (not val) (vl-paramvalue-expr-p val)) (mv t (change-vl-implicitvalueparam x.type :default val)) (mv nil (change-vl-implicitvalueparam x.type :default nil))) :vl-explicitvalueparam (if (or (not val) (vl-paramvalue-expr-p val)) (mv t (change-vl-explicitvalueparam x.type :default val)) (mv nil (change-vl-explicitvalueparam x.type :default nil)))))) (mv ok (change-vl-paramdecl x :type type)))))
Theorem:
(defthm vl-paramdecl-p-of-vl-paramdecl-set-default.new-x (b* (((mv ?ok ?new-x) (vl-paramdecl-set-default x val))) (vl-paramdecl-p new-x)) :rule-classes :rewrite)
Theorem:
(defthm vl-paramdecl-set-default-of-vl-paramdecl-fix-x (equal (vl-paramdecl-set-default (vl-paramdecl-fix x) val) (vl-paramdecl-set-default x val)))
Theorem:
(defthm vl-paramdecl-set-default-vl-paramdecl-equiv-congruence-on-x (implies (vl-paramdecl-equiv x x-equiv) (equal (vl-paramdecl-set-default x val) (vl-paramdecl-set-default x-equiv val))) :rule-classes :congruence)
Theorem:
(defthm vl-paramdecl-set-default-of-vl-maybe-paramvalue-fix-val (equal (vl-paramdecl-set-default x (vl-maybe-paramvalue-fix val)) (vl-paramdecl-set-default x val)))
Theorem:
(defthm vl-paramdecl-set-default-vl-maybe-paramvalue-equiv-congruence-on-val (implies (vl-maybe-paramvalue-equiv val val-equiv) (equal (vl-paramdecl-set-default x val) (vl-paramdecl-set-default x val-equiv))) :rule-classes :congruence)