Check if a symbol consists of five parts separated by dash.
(atc-check-symbol-5part sym) → (mv yes/no part1 part2 part3 part4 part5)
If the symbol has the form
Function:
(defun atc-check-symbol-5part (sym) (declare (xargs :guard (symbolp sym))) (let ((__function__ 'atc-check-symbol-5part)) (declare (ignorable __function__)) (b* ((parts (str::strtok! (symbol-name sym) (list #\-))) ((unless (= (len parts) 5)) (mv nil nil nil nil nil nil)) (part1 (intern-in-package-of-symbol (first parts) sym)) (part2 (intern-in-package-of-symbol (second parts) sym)) (part3 (intern-in-package-of-symbol (third parts) sym)) (part4 (intern-in-package-of-symbol (fourth parts) sym)) (part5 (intern-in-package-of-symbol (fifth parts) sym))) (mv t part1 part2 part3 part4 part5))))
Theorem:
(defthm booleanp-of-atc-check-symbol-5part.yes/no (b* (((mv ?yes/no ?part1 ?part2 ?part3 ?part4 ?part5) (atc-check-symbol-5part sym))) (booleanp yes/no)) :rule-classes :rewrite)
Theorem:
(defthm symbolp-of-atc-check-symbol-5part.part1 (b* (((mv ?yes/no ?part1 ?part2 ?part3 ?part4 ?part5) (atc-check-symbol-5part sym))) (symbolp part1)) :rule-classes :rewrite)
Theorem:
(defthm symbolp-of-atc-check-symbol-5part.part2 (b* (((mv ?yes/no ?part1 ?part2 ?part3 ?part4 ?part5) (atc-check-symbol-5part sym))) (symbolp part2)) :rule-classes :rewrite)
Theorem:
(defthm symbolp-of-atc-check-symbol-5part.part3 (b* (((mv ?yes/no ?part1 ?part2 ?part3 ?part4 ?part5) (atc-check-symbol-5part sym))) (symbolp part3)) :rule-classes :rewrite)
Theorem:
(defthm symbolp-of-atc-check-symbol-5part.part4 (b* (((mv ?yes/no ?part1 ?part2 ?part3 ?part4 ?part5) (atc-check-symbol-5part sym))) (symbolp part4)) :rule-classes :rewrite)
Theorem:
(defthm symbolp-of-atc-check-symbol-5part.part5 (b* (((mv ?yes/no ?part1 ?part2 ?part3 ?part4 ?part5) (atc-check-symbol-5part sym))) (symbolp part5)) :rule-classes :rewrite)