CheckArguments
data:image/s3,"s3://crabby-images/d9b6f/d9b6f01a9f0c9a7b070f99e0098060ead16ed3f4" alt=""
CheckArguments[f[args],n]
gives True if args consists of exactly n positional arguments followed by valid options for f, and False otherwise.
CheckArguments[f[args],{min,max}]
requires the number of positional arguments to be between min and max.
CheckArguments[f[args],spec,assoc]
modifies the behavior based on the information in the association assoc.
Details
data:image/s3,"s3://crabby-images/7d7d3/7d7d36408be2dd4bbfa247450f4941cfc0407fed" alt=""
- CheckArguments issues appropriate messages for f and returns False if f[…] has the wrong number of positional arguments, unknown options or invalid option specifications.
- The following keys can be used for the association assoc:
-
"ExtraOptions" {} additional options to treat as known options for f "OptionsMode" "Longest" how to interpret the optional positional arguments of args - Additional options given to "ExtraOptions" can be specified as rules nameval or as symbols func, which is equivalent to Options[func].
- CheckArguments checks whether all options specified for f have valid names.
- The following values of "OptionsMode" can be used: »
-
"Longest" treat all trailing elements of args matching OptionsPattern[] as options for f "Shortest" treat anything other than one or more known options as positional arguments None treat all elements as positional arguments - Even with "OptionsMode""Shortest", an unknown option past position max still generates a message. »
- CheckArguments has the attribute HoldFirst.
Examples
open allclose allBasic Examples (1)
Scope (6)
Check the arguments for a function that takes between 1 and 3 positional arguments:
Require at least 2 positional arguments:
Calling f with 1 argument is invalid:
data:image/s3,"s3://crabby-images/99a22/99a22ce35c72bdd3b80b9d17c660b450d4c12214" alt=""
Require exactly 3 positional arguments:
Allow "hidden" options that do not appear in Options[f]:
The option a0 is not a known option for f:
Allow the option named hidden as well as any option of Graphics to be set:
Treat unknown trailing options in positions min+1 though max as positional arguments rather than options for f:
The rule b2 is treated as a positional argument:
With the default "OptionsMode""Longest", a message is issued for unknown options:
data:image/s3,"s3://crabby-images/ba2b6/ba2b6151c73c5d70d23295b9f56f60dc21b91e15" alt=""
A known option is still treated as an option for f with "OptionsMode""Shortest":
Treat all elements as positional arguments rather than options for f:
data:image/s3,"s3://crabby-images/788bf/788bf01b8212ebf5ea29880534014de2b064e41c" alt=""
Applications (2)
Define a function that takes two arguments:
Issue a message for any other number of arguments and return unevaluated:
The following evaluates normally:
With an incorrect argument count, a message is issued:
data:image/s3,"s3://crabby-images/05f46/05f4633d96084063a2be839ce22ecda36c75b12d" alt=""
Define a function that calls a helper function if called with at most one argument:
When called with at most one argument, the helper function is called:
When called with more than one argument, f returns unevaluated and issues a message:
data:image/s3,"s3://crabby-images/a605e/a605ee28856ac00e69f8e9c483464c40c62d2c5c" alt=""
Properties & Relations (8)
CheckArguments[f[…],…] issues a message for f and returns False for invalid input to f:
data:image/s3,"s3://crabby-images/9333c/9333c58ef8e7d61f5fc14723f8456326c1e4c96e" alt=""
data:image/s3,"s3://crabby-images/53ad3/53ad36876b23ed7785dce6abf729f09afd1292c3" alt=""
If f does not accept options, all arguments are assumed to be positional:
data:image/s3,"s3://crabby-images/2d569/2d569248c415c1b22b433a73dbb00cc76abf64ba" alt=""
CheckArguments[…,{min,max}] will always treat the first min arguments as positional:
Here, even though b0 matches OptionsPattern[], it is treated as a positional argument:
If the rule b0 is given after the positional arguments, it is treated as an unknown option:
data:image/s3,"s3://crabby-images/90013/90013934954357e39b1187f26db1d50fa393b5bf" alt=""
Trailing rules matching OptionsPattern[] are treated as options if they are known options to f:
This is true even if "OptionsMode""Shortest" is given:
An option specification that contains both known and unknown options generates a message:
data:image/s3,"s3://crabby-images/c706b/c706b37beb373020a7307b1b27743e43d6de4d20" alt=""
In "OptionsMode""Shortest", a list with known and unknown options is treated as a positional argument if possible:
An unknown option past the maximum number of positional arguments still generates a message:
data:image/s3,"s3://crabby-images/2705d/2705d46b5ba7207a96f27f7b3ee8fb4eb2dc20ee" alt=""
Only rules matching OptionsPattern[] can be valid option specifications:
The rule 12 does not match OptionsPattern[]:
Thus it is treated as a positional argument:
If 12 is given after the positional arguments, it is treated as an invalid option specification:
data:image/s3,"s3://crabby-images/67a0a/67a0a353aec73b1238054bed3a23576121de7960" alt=""
CheckArguments returns False when ArgumentsOptions returns Failure[…]:
data:image/s3,"s3://crabby-images/82d85/82d8501cb1cdc0b64bb4fe3ced748389a7761014" alt=""
data:image/s3,"s3://crabby-images/0a23f/0a23f47c2065def02a18730ef5a9e920d88f4427" alt=""
Possible Issues (2)
All arguments at or before the minimum argument count are considered positional arguments:
IgnoreCaseTrue is treated as an argument despite being an option to StringCases:
CheckArguments does not check whether the option values are correct:
Infinity is not a valid value for Heads:
data:image/s3,"s3://crabby-images/7a71b/7a71bdd9d5ccbd63e5b95cf729ac37c879dc9079" alt=""
Text
Wolfram Research (2020), CheckArguments, Wolfram Language function, https://reference.wolfram.com/language/ref/CheckArguments.html (updated 2024).
CMS
Wolfram Language. 2020. "CheckArguments." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2024. https://reference.wolfram.com/language/ref/CheckArguments.html.
APA
Wolfram Language. (2020). CheckArguments. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/CheckArguments.html