Help:DPL

From Meta, a Wikimedia project coordination wiki
Jump to: navigation, search
MediaWiki Handbook: Contents, Readers, Editors, Moderators, System admins, Researchers +/-

DynamicPageList or DPL for short is a MediaWiki extension supporting intersections and other set operations of pages belonging to several categories.

Flavours[edit]

Two versions of dynamic page lists (DPL) exist, a variant using the tags <dynamicpagelist> plus </dynamicpagelist>, and another variant using tags <dpl> plus </dpl>. A project can support none, one, or both of these two extensions, see "parser extension tags" in Special:Version. <dynamicpagelist> is the only variant supported on Wikimedia projects, and only on smaller projects.

The advanced version covers all functions of the older variant, here only the latter is explained. For further details see the descriptions in DynamicPageList and DynamicPageList2.

Operation[edit]

In essence categories are sets of related pages, created by adding [[Category:common property]] to the individual pages. In addition category pages are also ordinary pages in their first part with all features of normal pages, but their main purpose is to list all pages belonging to the category. This changes as soon as [[Category:common property]] is added or removed from one or more of the individual pages, the members of this set.

Watching the category page only tracks modifications to its first part (as for any ordinary page), but it doesn't show any additions or removals of member pages. DPLs address this missing feature, they also allow to sort member pages by various criteria where categories only offer a crude sort key or alphabetical order.

Simple DPLs start with <dynamicpagelist> followed by one or more category=name and optionally other parameter=value pairs, and they are terminated by </dynamicpagelist>. For a similar construct see inputbox.

One (first) category=name is required, and it's the base for some other attributes. Adding more category=name restricts the DPL to pages in the intersection of all specified categories.

With notcategory=name pages in that category are removed from the DPL. So for categories A, B, and C use category=A and category=B with notcategory=C for all pages in both A and B, but not C. And also not only in A, and not only in B.

Two DPLs could be used to get a kind of union, the first DPL for category A, and the second DPL for category B without A, but real unions require the advanced DPL features.

Restrictions[edit]

The attribute namespace= allows to restrict listed pages to a namespace given by its number or name. Use 0 for the main namespace.

The attribute redirects= can be exclude (default) not listing any redirects belonging to the selected categories. With include redirects are listed, and redirects=only limits the DPL to only redirects.

With count=n the DPL is limited to the first n member pages as determined by the sort order (see below). The default is a system-wide maximum, with two DPLs looking at the same set from both ends it's indirectly possible to determine if really all selected pages are shown (see below).

Output[edit]

Use suppresserrors=true to suppress error messages for an empty DPL, e.g. if the selected category doesn't exist.

The default output mode=unordered presents the DPL as unordered list, XHTML <ul>, like Wiki list markup *.

Similarly ordered results in numbered <ol> output like Wiki list markup #. Finally mode=none presents the DPL with one entry per line, terminated with <br />, roughly similar to Wiki list markup ; (semicolon).

Especially in conjunction with namespace= the attribute shownamespace=false allows to suppress the output of the namespace.

Sorting[edit]

DPLs are either sorted by the date of the addition to the first category (this is often not the date of the creation of the individual page), the default ordermethod=categoryadd, or by ordermethod=lastedit, the date of the last modification of the member pages.

Sorting can be order=descending (default, most recent first) or order=ascending, allowing to look at the same set from both ends in two DPLs (see above).

Dates[edit]

With addfirstcategorydate=true the date of the addition to the first category is shown.

Example[edit]

If the following example doesn't work where you read this page look at it on Meta.

<dynamicpagelist>
category=Reader handbook
order=ascending
ordermethod=lastedit
mode=ordered
shownamespace=false
</dynamicpagelist>

This results in a numbered list of help pages, oldest first:

  1. Project
  2. Redirect/expr
  3. Contents/ar
  4. Recent changes/zh
  5. Self link
  6. Preferences
  7. Recent changes/pt-br
  8. Printable
  9. Go button
  10. Searching
  11. Recent changes/en
  12. Tracking changes
  13. Related changes
  14. Recent changes/pt
  15. Date formatting and linking
  16. Recent changes
  17. Redirect
  18. Recent changes/es
  19. Linksearch
  20. Recent changes/de
  21. User contributions
  22. Recent changes/tr
  23. Enhanced recent changes
  24. Recent changes/it
  25. Diff
  26. Recent changes/ru
  27. Downloading pages
  28. Watching pages
  29. Recent changes/fr
  30. What links here
  31. Logging in
  32. Recent changes/ja
  33. Special page
  34. Image page
  35. Recent changes/sq
  36. Page name
  37. Page history
  38. Category


Another example:

<dynamicpagelist>
category=Handbook templates
notcategory=Templates using ParserFunctions
mode=none
addfirstcategorydate=true
</dynamicpagelist>

This creates a plain list with the dates of the addition to the first (here only) category:


1 June 2014: Template:Unclear
26 November 2013: Template:Reader toc/sq
26 November 2013: Template:Reader toc/ar
26 November 2013: Template:Moderator toc/ru
26 November 2013: Template:Editor toc/ru
26 November 2013: Template:System admin toc/ru
26 November 2013: Template:Reader toc/ru
2 October 2013: Template:H:f Help
23 August 2013: Template:Moderator toc/zh-hant
23 August 2013: Template:Reader toc/zh-hant
12 March 2013: Template:Reader toc/de
12 March 2013: Template:Editor toc/de
6 October 2012: Template:H:h Help
29 August 2012: Template:Ph:CheckUser
20 May 2012: Template:System admin toc/zh-hant
20 May 2012: Template:Redaktuesi toc
20 May 2012: Template:Reader toc el
20 May 2012: Template:Ph:Page for demos in the Help namespace
20 May 2012: Template:MediaWiki връзки
20 May 2012: Template:MediaWiki nyje
20 May 2012: Template:MediaWiki linky
20 May 2012: Template:MediaWiki links/zh-hant
20 May 2012: Template:Editor toc/zh-hant
20 May 2012: User:AaronPeterson/css play
21 April 2012: Template:Modifier
21 April 2012: Template:Modif
21 April 2012: Template:Edde
21 April 2012: Template:EdML
21 April 2012: Template:H:h Help/no
21 April 2012: Template:H:h Help/nl
21 April 2012: Template:H:h Help/fr
21 April 2012: Template:H:f Help/zh-hant
21 April 2012: Template:H:f Help/vi
21 April 2012: Template:H:f Help/sq
21 April 2012: Template:H:f Help/no
21 April 2012: Template:H:f Help/nl
21 April 2012: Template:H:f Help/ja
21 April 2012: Template:H:f Help/it
21 April 2012: Template:H:f Help/fr
21 April 2012: Template:H:f Help/ar
21 April 2012: Template:H:f Help/de
20 April 2012: Template:System admin toc/zh
20 April 2012: Template:Reader toc ja
20 April 2012: Template:Reader toc/zh
20 April 2012: Template:Povezave za MediaWiki
20 April 2012: Template:Moderator toc/zh
20 April 2012: Template:MediaWiki links/Ru
20 April 2012: Template:Lezer inhoud
20 April 2012: Template:Kazalo za skrbnike
20 April 2012: Template:Editor toc pt
20 April 2012: Template:Amministratori toc
9 March 2012: Template:Moderator toc
9 March 2012: Template:Reader toc
5 February 2012: Template:-
16 June 2011: Template:MediaWiki links
25 April 2011: Template:H:mwg
25 April 2011: Template:Ed
9 April 2011: Template:Ill
27 March 2011: Template:Editor toc
15 February 2011: Template:Ph:MediaWiki help policy
2 February 2011: Template:Fdnw
2 February 2011: Template:Fd
1 March 2009: Template:Ph:Contents/pt-br
19 December 2007: Template:Wikilink syntax tbl
17 December 2007: Template:MediaWiki links ms
8 November 2007: Template:Xpdn
26 October 2007: Template:मिडियाविकि दूवे
12 July 2007: Template:MediaWiki links/ar
9 June 2007: Help talk:Template/onlyinclude demo
9 June 2007: Help:Template/onlyinclude demo
9 June 2007: Template:H:htest
9 June 2007: Template:H:h Template
18 March 2007: Template:Ediu
15 February 2007: Template:Timd
8 February 2007: Template:H:Language-dependent variables
8 February 2007: Template:H:Miscellaneous variables
8 February 2007: Template:H:Position variables
8 February 2007: Template:H:Size variables
8 February 2007: Template:H:Modifier variables
8 February 2007: Template:H:Formatting variables
8 February 2007: Template:H:Namespace variables
8 February 2007: Template:H:Statistics variables
8 February 2007: Template:H:Section variables
8 February 2007: Template:H:Page name variables
3 January 2007: Template:Edi
9 November 2006: Template:MediaWiki links/tr
31 August 2006: Template:Ph:Vsebina
17 June 2006: Template:H:f Template
25 May 2006: Template:Edhf
29 April 2006: Template:H-langs:
22 April 2006: Template:H:l
22 April 2006: Template:H:
22 April 2006: Template:System admin toc


Meta currently supports only the simple DPL.


+/-

Links to other help pages[edit]

Help contents
Meta · Wikinews · Wikipedia · Wikiquote · Wiktionary · Commons: · Wikidata · MediaWiki · Wikibooks · Wikisource · MediaWiki: Manual · Google
Versions of this help page (for other languages see further)
What links here on Meta or from Meta · Wikipedia · MediaWiki
Reading
Go · Search · Stop words · Namespace · Page name · Section · Backlinks · Redirect · Category · Image page · Special pages · Printable version
Tracking changes
Recent changes (enhanced) | Related changes · Watching pages · Diff · Page history · Edit summary · User contributions · Minor edit · Patrolled edit
Logging in and preferences
Logging in · Preferences · User style
Editing
Starting a new page · Advanced editing · Editing FAQ · Edit toolbar · Export · Import · Shortcuts · Edit conflict · Page size
Referencing
Links · URL · Piped links · Interwiki linking · Footnotes
Style and formatting
Wikitext examples · CSS · Reference card · HTML in wikitext · Formula · List · Table · Sorting · Colors · Images and file uploads
Fixing mistakes
Show preview · Testing · Reverting edits
Advanced functioning
Expansion · Template · Advanced templates · Parser function · Parameter default · Variable · System message · Substitution · Array · Calculation · Embed page
Others
Special characters · Renaming (moving) a page · Preparing a page for translation · Talk page · Signatures · Sandbox · Legal issues for editors
Languages: English