Module:WPSHIPS utilities/doc
This is the documentation page for Module:WPSHIPS utilities
ship_name_format
This function attempts to apply appropriate formatting to unformatted ship names. The formats supported are:
- <prefix> <name> <(disambiguator)> where:
- <prefix> – one from a list of defined prefixes commonly used for ships (ARA, HMS, USS, etc.); rendered in upright font
- <name> – the ship's proper name; rendered in italic font
- <(disambiguator)> (optional) – typically the ship's hull or pennant number, or other disambiguator; always contained in parentheses; rendered in upright font
 
- <name> <(disambiguator)> where:
- <name> – the ship's proper name; rendered in italic font
- <(disambiguator)> (required) – the ship's hull or pennant number or a recognized ship-type descriptor; always contained in parentheses; rendered in upright font
- hull and pennant numbers take two basic forms
- uppercase letters, possibly followed by a space or hyphen, followed by digits (SSBN-659, R07, ON 688)
- digits, possibly followed by a space or hyphen, followed by uppercase letters (401B)
 
 
- hull and pennant numbers take two basic forms
 
- <nationality> <ship type> <name> <(disambiguator)> where:
- <nationality> – one- or two- word nation name in adjectival form (Dutch, East Timorese, French, Ottoman, etc.); rendered in upright font
- <ship type> – one from a list of one- to four-word phrases that describes a ship's type (aviso, brig sloop, landing ship medium, ship of the line); rendered in upright font
- <name> – the ship's proper name; rendered in italic font
- <(disambiguator)> (optional) – typically the ship's hull or pennant number, or other disambiguator; always contained in parentheses; rendered in upright font
 
The function will also attempt to render ship-class names when the name is in the form:
- <name>-class <ship type> where:
- <name> – the class' proper name; rendered in italic font according to the setting of Template:Para
- <ship type> – a phrase that describes a ship's type; rendered in upright font
 
Lists
The function relies on three lists to accomplish its task. These lists are:
- ship_prefix_list– a list of commonly used ship prefixes initially taken from Template:Tlx; these are usually, but not always wholly uppercase
- nationality_list– a list of nation names in their adjectival form; these are always capitalized; always one or two words
- ship_type_list– a list ship-type descriptor phrases; these are usually, but not always wholly lowercase; always one to two words
To add to any of these lists, the form is:
- ['addition'] = true,
the trailing comma is important. See the instructions that accompany each list for limitations and implementation details.
Usage
The minimal form is:
- {{#invoke:WPSHIPS_utilities|ship_name_format|name=}}
Parameters
The function requires one parameter and supports several optional parameters.
- |name= – (required) the name to format
- |dab=none – for use with Template:Para in Template:Tlx, excludes a disambiguator from the formatted name
- |sclass=2 – for use with {{DISPLAYTITLE}}and with Template:Para or Template:Para in Template:Tld, when the class is not named for a member of the class; causes the class name to be rendered in upright font
- |adj=off – for use in ship-class articles with Template:Para or Template:Para in Template:Tld, formats the class name in its noun form and excludes the ship type phrase and disambiguator
- |showerrs=yes – debug tool; not currently supported in any templates;
Wrapper template
- {{Ship name format}} is a wrapper template to make it easier for editors to label ships in the main body of articles or as input to templates or modules. It supports the same parameters as the module.
- In most cases, {{ship}} is preferred over using this wrapper template or this module.
- It is useful to set the DISPLAYTITLE of redirects, disambiguation pages, or other pages named after ships which do not use one of the other "ships" templates such as {{Infobox ship begin}} to do this.  Example: {{DISPLAYTITLE:{{ship_name_format|name={{FULLPAGENAME}}}}}}
- Other templates and modules should not transclude this template, instead they should call the module directly.
- Wikipedia pages should not transclude this template many times, as it may cause the page to exceed Wikipedia's template limits. Those pages should invoke the module directly.
This function is the driver for Template:Tlx.  The function assembles an external wikilink from known fragments and positional parameter {{{1}}}.  A ship name provided in positional parameter {{{2}}} is formatted using ship_name_format().  New with this implementation of Template:Tld is the addition of Template:Para.  The {{#invoke:}} in the template defaults to Template:Para which can be overridden by setting Template:Para in the template.
wpsu.hnsa()
Similar to Template:Tlx, this code supports Template:Tlx by attempting to construct a link to a ship article at the Historic Naval Ships Association website.
The template has the form:
- {{hnsa|<page>|<name>}}
where:
- <page> is the name of the page from the url http://hnsa.org/hnsa-ships/<page>
- <name> (optional) is the name of the ship; if left blank, the template uses the current page title; if a ship name, it is formatted using do_ship_name_format()
from which this code produces:
- [http://hnsa.org/hnsa-ships/<page> <name>] at Historic Naval Ships Association