Process the inputs.
(splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld) → (mv erp filepath tunit object-ident new-object1 new-object2 new-type1 new-type2 split-members const-new$)
Function:
(defun splitgso-process-inputs (const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld) (declare (xargs :guard (plist-worldp wrld))) (let ((__function__ 'splitgso-process-inputs)) (declare (ignorable __function__)) (b* (((reterr) (filepath :irrelevant) (c$::irr-transunit) (c$::irr-ident) (c$::irr-ident) (c$::irr-ident) (c$::irr-ident) (c$::irr-ident) nil nil) ((unless (symbolp const-old)) (reterr (msg "~x0 must be a symbol" const-old))) (tunits-old (acl2::constant-value const-old wrld)) ((unless (transunit-ensemblep tunits-old)) (reterr (msg "~x0 must be a translation unit ensemble." const-old))) ((unless (c$::transunit-ensemble-annop tunits-old)) (reterr (msg "~x0 must be an annotated with validation information." const-old))) (tunits-map (transunit-ensemble->unwrap tunits-old)) ((when (or (omap::emptyp tunits-map) (not (omap::emptyp (omap::tail tunits-map))))) (reterr (msg "~x0 must be a translation unit ensemble with at exactly one translation unit" const-old))) (filepath (deftrans-filepath (omap::head-key tunits-map) "SPLITGSO")) (tunit (omap::head-val tunits-map)) ((unless (stringp object-name)) (reterr (msg "~x0 must be a string" object-name))) (object-ident (ident object-name)) ((unless (stringp new-object1)) (reterr (msg "~x0 must be a string" new-object1))) (new-object1 (ident new-object1)) ((unless (stringp new-object2)) (reterr (msg "~x0 must be a string" new-object2))) (new-object2 (ident new-object2)) ((unless (stringp new-type1)) (reterr (msg "~x0 must be a string" new-type1))) (new-type1 (ident new-type1)) ((unless (stringp new-type2)) (reterr (msg "~x0 must be a string" new-type2))) (new-type2 (ident new-type2)) ((unless (string-listp split-members)) (reterr (msg "~x0 must be a string" split-members))) (split-members (ident-map split-members)) ((unless (symbolp const-new)) (reterr (msg "~x0 must be a symbol" const-new)))) (retok filepath tunit object-ident new-object1 new-object2 new-type1 new-type2 split-members const-new))))
Theorem:
(defthm filepathp-of-splitgso-process-inputs.filepath (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (filepathp filepath)) :rule-classes :rewrite)
Theorem:
(defthm transunitp-of-splitgso-process-inputs.tunit (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (transunitp tunit)) :rule-classes :rewrite)
Theorem:
(defthm identp-of-splitgso-process-inputs.object-ident (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (identp object-ident)) :rule-classes :rewrite)
Theorem:
(defthm identp-of-splitgso-process-inputs.new-object1 (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (identp new-object1)) :rule-classes :rewrite)
Theorem:
(defthm identp-of-splitgso-process-inputs.new-object2 (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (identp new-object2)) :rule-classes :rewrite)
Theorem:
(defthm identp-of-splitgso-process-inputs.new-type1 (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (identp new-type1)) :rule-classes :rewrite)
Theorem:
(defthm identp-of-splitgso-process-inputs.new-type2 (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (identp new-type2)) :rule-classes :rewrite)
Theorem:
(defthm ident-listp-of-splitgso-process-inputs.split-members (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (ident-listp split-members)) :rule-classes :rewrite)
Theorem:
(defthm symbolp-of-splitgso-process-inputs.const-new$ (b* (((mv acl2::?erp c$::?filepath ?tunit ?object-ident ?new-object1 ?new-object2 ?new-type1 ?new-type2 ?split-members ?const-new$) (splitgso-process-inputs const-old const-new object-name new-object1 new-object2 new-type1 new-type2 split-members wrld))) (symbolp const-new$)) :rule-classes :rewrite)