• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
      • Std/lists
      • Std/alists
      • Obags
      • Std/util
      • Std/strings
      • Std/osets
      • Std/io
      • Std/basic
      • Std/system
        • Fresh-logical-name-with-$s-suffix
        • Irrelevant-formals-info
        • Std/system/function-queries
        • Std/system/term-queries
        • Std/system/term-transformations
        • Std/system/enhanced-utilities
        • Install-not-normalized-event
        • Install-not-normalized-event-lst
        • Std/system/term-function-recognizers
        • Genvar$
        • Std/system/event-name-queries
        • Pseudo-tests-and-call-listp
        • Maybe-pseudo-event-formp
        • Add-suffix-to-fn-or-const
        • Chk-irrelevant-formals-ok
        • Table-alist+
        • Pseudo-tests-and-callp
        • Add-suffix-to-fn-or-const-lst
        • Known-packages+
        • Add-suffix-to-fn-lst
        • Unquote-term
        • Event-landmark-names
        • Add-suffix-lst
        • Std/system/theorem-queries
        • Unquote-term-list
        • Std/system/macro-queries
          • Macro-keyword-args
          • Macro-keyword-args+
          • Macro-required-args+
          • Macro-required-args
            • Macro-args+
          • Pseudo-command-landmark-listp
          • Install-not-normalized$
          • Pseudo-event-landmark-listp
          • Known-packages
          • Std/system/partition-rest-and-keyword-args
          • Rune-enabledp
          • Rune-disabledp
          • Included-books
          • Std/system/pseudo-event-formp
          • Std/system/plist-worldp-with-formals
          • Std/system/w
          • Std/system/geprops
          • Std/system/arglistp
          • Std/system/constant-queries
        • Std/typed-lists
        • Std/bitsets
        • Std/testing
        • Std/typed-alists
        • Std/stobjs
      • Community
      • Proof-automation
      • Macro-libraries
      • ACL2
      • Interfacing-tools
      • Hardware-verification
      • Software-verification
      • Math
      • Testing-utilities
    • Std/system/macro-queries

    Macro-required-args

    Required arguments of a macro, in order.

    Signature
    (macro-required-args mac wrld) → required-args
    Arguments
    mac — Guard (symbolp mac).
    wrld — Guard (plist-worldp wrld).
    Returns
    required-args — A symbol-listp.

    The arguments of a macro form a list that optionally starts with &whole followed by another symbol, continues with zero or more symbols that do not start with & (which are the required arguments) and possibly ends with a symbol starting with & followed by more things.

    After removing &whole and the symbol following it (if the list of arguments starts with &whole), we collect all the arguments until either the end of the list is reached or a symbol starting with & is encountered.

    See macro-required-args+ for an enhanced variant of this utility.

    Definitions and Theorems

    Function: macro-required-args-aux

    (defun macro-required-args-aux (args)
      (declare (xargs :guard (true-listp args)))
      (let ((__function__ 'macro-required-args-aux))
        (declare (ignorable __function__))
        (if (endp args)
            nil
          (b* ((arg (car args)))
            (if (lambda-keywordp arg)
                nil
              (cons arg
                    (macro-required-args-aux (cdr args))))))))

    Function: macro-required-args

    (defun macro-required-args (mac wrld)
      (declare (xargs :guard (and (symbolp mac)
                                  (plist-worldp wrld))))
      (let ((__function__ 'macro-required-args))
        (declare (ignorable __function__))
        (b* ((all-args (macro-args mac wrld)))
          (if (endp all-args)
              nil
            (if (eq (car all-args) '&whole)
                (macro-required-args-aux (cddr all-args))
              (macro-required-args-aux all-args))))))