Module:Check for unknown parameters/doc: Difference between revisions

From the Croc Wiki, the Croc encyclopedia
Jump to navigationJump to search
Content added Content deleted
No edit summary
 
(30 intermediate revisions by 21 users not shown)
Line 1: Line 1:
{{used in system|in [[MediaWiki:Abusefilter-warning-DS]]}}
{{High-risk|8200000+}}
{{module rating|p}}
{{module rating|p}}
{{Lua|Module:If preview}}
<!-- Categories go at the bottom of this page and interwikis go in Wikidata. -->interviews


This module may be appended to a template to check for users
This module may be appended to a template to check for uses of unknown parameters.


== Usage ==
== Usage ==
Line 10: Line 10:
{{#invoke:check for unknown parameters|check
{{#invoke:check for unknown parameters|check
|unknown=[[Category:Some tracking category]]
|unknown=[[Category:Some tracking category]]
|arg1|arg2|...|argN}}
|arg1|arg2|arg3|argN}}
</pre>
</pre>
or to sort the entries in the tracking category by parameter with a preview error message
or to sort the entries in the tracking category by parameter with a preview error message
Line 69: Line 69:


==See also==
==See also==
* {{clc|Unknown parameters}} (category page can have {{tl|Unknown parameters category}})
* {{clc|Unknown parameters}} (category page can have header {{tl|Unknown parameters category}})
* [[Module:Check for deprecated parameters]] - similar module that checks for deprecated parameters
* [[Module:Check for deprecated parameters]] similar module that checks for deprecated parameters
* [[Module:Check for clobbered parameters]] – module that checks for conflicting parameters
* [[:module:TemplatePar]] - similar function (originally from dewiki)
* [[Module:TemplatePar]] similar function (originally from dewiki)
* [[Template:Parameters]] and [[Module:Parameters]] – generates a list of parameter names for a given template
* [[Template:Parameters]] and [[Module:Parameters]] – generates a list of parameter names for a given template
* [[Project:TemplateData]] based template parameter validation
* [[:he:Module:ParamValidator]] - parameter validation system on hewiki, relies on TemplateData. module doc in English. checks the following:
* [[Module:Parameter validation]] checks a lot more
**use of undeclared parameters
* [[User:Bamyers99/TemplateParametersTool]] - A tool for checking usage of template parameters
** use of parameters marked in templatedata "deprecated"
** mistyped (mainly, parameters declared in templatedata as "number" receiving non-numerical value)
**missing parameters marked in TemplateData as "required"
**understands aliases, and warns when more than one alias of a parameter is used


<includeonly>{{sandbox other||
<includeonly>{{sandbox other||
<!-- Categories go here and interwikis go in Wikidata. -->
<!-- Categories go here and interwikis go in Wikidata. -->
[[Category:Modules that add a tracking category]]


}}</includeonly>
}}</includeonly>

Latest revision as of 15:26, January 29, 2022

This module may be appended to a template to check for uses of unknown parameters.

Usage

Basic usage

{{#invoke:check for unknown parameters|check
|unknown=[[Category:Some tracking category]]
|arg1|arg2|arg3|argN}}

or to sort the entries in the tracking category by parameter with a preview error message

{{#invoke:check for unknown parameters|check
|unknown=[[Category:Some tracking category|_VALUE_]]
|preview=unknown parameter "_VALUE_"
|arg1|arg2|...|argN}}

or for an explicit red error message

{{#invoke:check for unknown parameters|check
|unknown=<span class="error">Sorry, I don't recognize _VALUE_</span>
|arg1|arg2|...|argN}}

Here, arg1, arg2, ..., argN, are the known parameters. Unnamed (positional) parameters can be added too: |1|2|argname1|argname2|.... Any parameter which is used, but not on this list, will cause the module to return whatever is passed with the unknown parameter. The _VALUE_ keyword, if used, will be changed to the name of the parameter. This is useful for either sorting the entries in a tracking category, or for provide more explicit information.

By default, the module makes no distinction between a defined-but-blank parameter and a non-blank parameter. That is, both unlisted |foo=x and |foo= are reported. To only track non-blank parameters use |ignoreblank=1.

By default, the module ignores blank positional parameters. That is, an unlisted |2= is ignored. To include blank positional parameters in the tracking use |showblankpositional=1.

Lua patterns

This module supports Lua patterns (similar to regular expressions), which are useful when there are many known parameters which use a systematic pattern. For example, template:infobox3cols uses

| regexp1 = header[%d][%d]*
| regexp2 = label[%d][%d]*
| regexp3 = data[%d][%d]*[abc]?
| regexp4 = class[%d][%d]*[abc]?
| regexp5 = rowclass[%d][%d]*
| regexp6 = rowstyle[%d][%d]*
| regexp7 = rowcellstyle[%d][%d]*

to match all parameters of the form headerNUM, labelNUM, dataNUM, dataNUMa, dataNUMb, dataNUMc, ..., rowcellstyleNUM, where NUM is a string of digits.

Example

{{Infobox
| above = {{{name|}}}

| label1 = Height
| data1 = {{{height|}}}

| label2 = Weight
| data2 = {{{weight|}}}

| label3 = Website
| data3 = {{{website|}}}
}}<!-- 
  end infobox, start tracking
-->{{#invoke:Check for unknown parameters|check
| unknown = {{main other|[[Category:Some tracking category|_VALUE_]]}}
| preview = unknown parameter "_VALUE_"
| name
| height | weight
| website
}}

See also