コンテンツにスキップ

英文维基 | 中文维基 | 日文维基 | 草榴社区

「モジュール:Road data/strings/doc」の版間の差分

削除された内容 追加された内容
Momijiro (会話 | 投稿記録)
en:Module:Road data/strings/doc oldid=613419074 移植 見出しのみ訳
 
Cewbot (会話 | 投稿記録)
m Bot作業依頼: sourceタグをsyntaxhighlightタグに置換 (Category:非推奨のsourceタグを使用しているページ) - log
 
5行目: 5行目:
At its most basic level, this module is a nested table of strings. At the top is the root table, named for the abbreviation of a country, state, or province. This table stores the type data for a particular place, which is named in the comment in the first line, and is returned at the end of the module. The table is composed of further tables, one per type. The basic syntax for a type table is:
At its most basic level, this module is a nested table of strings. At the top is the root table, named for the abbreviation of a country, state, or province. This table stores the type data for a particular place, which is named in the comment in the first line, and is returned at the end of the module. The table is composed of further tables, one per type. The basic syntax for a type table is:


<source lang="lua">
<syntaxhighlight lang="lua">
place.type = {shield = "",
place.type = {shield = "",
link = "",
link = "",
abbr = ""}
abbr = ""}
</syntaxhighlight>
</source>


The three main fields in a type table are <code>shield</code>, <code>link</code>, and <code>abbr</code>. Generally, <code>shield</code> determines the shield that is displayed, if any; <code>link</code> specifies the target of the link generated by a including module, if any; and <code>abbr</code> determines the displayed abbreviation. Currently, these are the three types used by all countries. By convention, they are always specified, using an empty string if there is no value.
The three main fields in a type table are <code>shield</code>, <code>link</code>, and <code>abbr</code>. Generally, <code>shield</code> determines the shield that is displayed, if any; <code>link</code> specifies the target of the link generated by a including module, if any; and <code>abbr</code> determines the displayed abbreviation. Currently, these are the three types used by all countries. By convention, they are always specified, using an empty string if there is no value.
16行目: 16行目:


Once a type is defined, it can be referred to later in the code. A common idiom used for bannered types is defining the shield to be the shield field of the base type (from [[Module:Road data/strings/USA/MO]]):
Once a type is defined, it can be referred to later in the code. A common idiom used for bannered types is defining the shield to be the shield field of the base type (from [[Module:Road data/strings/USA/MO]]):
<source lang="lua">
<syntaxhighlight lang="lua">
MO.US = {shield = "US %route%.svg",
MO.US = {shield = "US %route%.svg",
link = "U.S. Route %route% in Missouri",
link = "U.S. Route %route% in Missouri",
27行目: 27行目:
banner = "Alternate plate.svg",
banner = "Alternate plate.svg",
width = "expand"}
width = "expand"}
</syntaxhighlight>
</source>


Another common idiom is defining a type alias by setting an entry in the root table equal to a previously defined type (from [[Module:Road data/strings/HKG]]):
Another common idiom is defining a type alias by setting an entry in the root table equal to a previously defined type (from [[Module:Road data/strings/HKG]]):
<source lang="lua">
<syntaxhighlight lang="lua">
HKG.Route = {shield = "HK Route%route%.svg",
HKG.Route = {shield = "HK Route%route%.svg",
link = "Route %route% (Hong Kong)",
link = "Route %route% (Hong Kong)",
36行目: 36行目:
HKG.route = HKG.Route
HKG.route = HKG.Route
</syntaxhighlight>
</source>


===パーサー引数===
===パーサー引数===
65行目: 65行目:


The two statements may be combined. The parser will parse the if-then-else statement first, and then perform the argument inclusion. This combination is commonly used with bannered routes in the United States, where the <code>dab</code> argument is tested and the link disambiguation is adjusted accordingly, as follows (from [[Module:Road data/strings/USA/AL]]):
The two statements may be combined. The parser will parse the if-then-else statement first, and then perform the argument inclusion. This combination is commonly used with bannered routes in the United States, where the <code>dab</code> argument is tested and the link disambiguation is adjusted accordingly, as follows (from [[Module:Road data/strings/USA/AL]]):
<source lang="lua">
<syntaxhighlight lang="lua">
AL["US-Bus"] = {shield = "US %route%.svg",
AL["US-Bus"] = {shield = "US %route%.svg",
link = "U.S. Route %route% Business ([dab||%dab%, |]Alabama)",
link = "U.S. Route %route% Business ([dab||%dab%, |]Alabama)",
71行目: 71行目:
banner = "Business plate.svg",
banner = "Business plate.svg",
width = "expand"}
width = "expand"}
</syntaxhighlight>
</source>


When parsing the <code>link</code> field, the parser first checks to see if the <code>dab</code> argument was provided. If so, it replaces the statement with <code>%dab%, </code>. If not, the statement is replaced with the empty string placed in the <code>else</code> block. Then, the parser replaces <code>%route%</code> with the route number and, if the <code>dab</code> argument was provided, <code>%dab%</code> with the value of that argument.
When parsing the <code>link</code> field, the parser first checks to see if the <code>dab</code> argument was provided. If so, it replaces the statement with <code>%dab%, </code>. If not, the statement is replaced with the empty string placed in the <code>else</code> block. Then, the parser replaces <code>%route%</code> with the route number and, if the <code>dab</code> argument was provided, <code>%dab%</code> with the value of that argument.
79行目: 79行目:


The most straightforward functionality provided by nested tables is switching. In its most basic form, the table consists of a series of key-value pairs, with the keys being route numbers and the values being the format strings used by those routes. Usually, the format string returned does not need parsing, but the option is there. A <code>default</code> entry should be provided to handle any route numbers not explicitly stated. The following is a representative example of route-based switching (from [[Module:Road data/strings/USA/AR]]):
The most straightforward functionality provided by nested tables is switching. In its most basic form, the table consists of a series of key-value pairs, with the keys being route numbers and the values being the format strings used by those routes. Usually, the format string returned does not need parsing, but the option is there. A <code>default</code> entry should be provided to handle any route numbers not explicitly stated. The following is a representative example of route-based switching (from [[Module:Road data/strings/USA/AR]]):
<source lang="lua">
<syntaxhighlight lang="lua">
AR.AR = {shield = {default = "Arkansas %route%.svg",
AR.AR = {shield = {default = "Arkansas %route%.svg",
["917"] = "Arkansas 917-1.svg",
["917"] = "Arkansas 917-1.svg",
86行目: 86行目:
abbr = "Hwy.&nbsp;%route%",
abbr = "Hwy.&nbsp;%route%",
width = "expand"}
width = "expand"}
</syntaxhighlight>
</source>


In this example, Highways 917 and 980 have non-standard shield names, which are explicitly provided. Other route numbers use the default format.
In this example, Highways 917 and 980 have non-standard shield names, which are explicitly provided. Other route numbers use the default format.


Switching on other arguments is also allowed. The name of the argument to be used for switching is stated in the <code>arg</code> field of the table. Nesting switches on different arguments is also allowed. A good example that uses both forms of switching can be found in [[Module:Road data/strings/CAN/ON|Ontario]]:
Switching on other arguments is also allowed. The name of the argument to be used for switching is stated in the <code>arg</code> field of the table. Nesting switches on different arguments is also allowed. A good example that uses both forms of switching can be found in [[Module:Road data/strings/CAN/ON|Ontario]]:
<source lang="lua">
<syntaxhighlight lang="lua">
local regionalShields = {arg = "county",
local regionalShields = {arg = "county",
["Essex"] = "Essex County Road %route%.png",
["Essex"] = "Essex County Road %route%.png",
99行目: 99行目:
["Simcoe"] = {["52"] = "Simcoe county road 52.png",
["Simcoe"] = {["52"] = "Simcoe county road 52.png",
default = "Simcoe County Road %route%.JPG"}}
default = "Simcoe County Road %route%.JPG"}}
</syntaxhighlight>
</source>


In this example, which is a shield table that is reused by several types in Ontario, the <code>county</code> argument is used for the primary switch. If the route is in Simcoe County, a second switch is performed, this time on the route number.
In this example, which is a shield table that is reused by several types in Ontario, the <code>county</code> argument is used for the primary switch. If the route is in Simcoe County, a second switch is performed, this time on the route number.
105行目: 105行目:
===存在確認テスト===
===存在確認テスト===
Another use for tables is existence testing. If a table has the <code>ifexists</code> field set to <code>true</code>, the parser will perform existence testing on the result of parsing the <code>default</code> field. If the test fails, the result of parsing the <code>otherwise</code> field is returned. Existence testing may be chained by using a second ifexists table as the value of the first table's <code>otherwise</code> field, and so on. Here's an example of nested existence testing (from [[Module:Road data/strings/GBR]]):
Another use for tables is existence testing. If a table has the <code>ifexists</code> field set to <code>true</code>, the parser will perform existence testing on the result of parsing the <code>default</code> field. If the test fails, the result of parsing the <code>otherwise</code> field is returned. Existence testing may be chained by using a second ifexists table as the value of the first table's <code>otherwise</code> field, and so on. Here's an example of nested existence testing (from [[Module:Road data/strings/GBR]]):
<source lang="lua">
<syntaxhighlight lang="lua">
GBR.B = {shield = {ifexists = true,
GBR.B = {shield = {ifexists = true,
default = "UK road B%route%.svg",
default = "UK road B%route%.svg",
112行目: 112行目:
link = "",
link = "",
abbr = "B%route%"}
abbr = "B%route%"}
</syntaxhighlight>
</source>


===起動法Hooks===
===起動法Hooks===
118行目: 118行目:


Generally speaking, a hook is called by setting the <code>hook</code> field in a table as equal to the name of a hook. Hooks receive two arguments, both tables: <code>parameters</code>, which is the table in the definition; and <code>args</code>, which is simply the table of arguments normally passed to the parser. The hook returns a string, which is then parsed as usual. A powerful feature of hooks is that they can add arbitrary values to the argument table, which may be referenced in the string returned by the hook. Generally, the format string returned by the hook is specified in some form by the <code>default</code> field of the table, though there are exceptions. Here is an example of a hook (from [[Module:Road data/strings/MEX]]):
Generally speaking, a hook is called by setting the <code>hook</code> field in a table as equal to the name of a hook. Hooks receive two arguments, both tables: <code>parameters</code>, which is the table in the definition; and <code>args</code>, which is simply the table of arguments normally passed to the parser. The hook returns a string, which is then parsed as usual. A powerful feature of hooks is that they can add arbitrary values to the argument table, which may be referenced in the string returned by the hook. Generally, the format string returned by the hook is specified in some form by the <code>default</code> field of the table, though there are exceptions. Here is an example of a hook (from [[Module:Road data/strings/MEX]]):
<source lang="lua">
<syntaxhighlight lang="lua">
MEX.SH = {shield = {ifexists = true,
MEX.SH = {shield = {ifexists = true,
arg = "state",
arg = "state",
130行目: 130行目:
default = "%fullstate% State Highway %route%"},
default = "%fullstate% State Highway %route%"},
abbr = "SH&nbsp;%route%"}
abbr = "SH&nbsp;%route%"}
</syntaxhighlight>
</source>


In this example, the parser will process the link by calling the <code>mask</code> hook. In short, this hook takes the argument referenced in <code>base</code>, passes it through the mask module specified in <code>mask</code>, and stores it in the field in the arguments noted in <code>masked</code>. The hook returns the string given in <code>default</code>, which has access to the <code>fullstate</code> argument added by the hook.
In this example, the parser will process the link by calling the <code>mask</code> hook. In short, this hook takes the argument referenced in <code>base</code>, passes it through the mask module specified in <code>mask</code>, and stores it in the field in the arguments noted in <code>masked</code>. The hook returns the string given in <code>default</code>, which has access to the <code>fullstate</code> argument added by the hook.
136行目: 136行目:
===その他の機能===
===その他の機能===
Functionality exists to display multiple shields for one route, which is used to display tolled and free shields for routes where they differ. This is done by supplying a table with two values, which are listed without indices. The parser is called twice by the calling module, and it returns one shield per call. An example may be found in [[Module:Road data/strings/USA/TX|Texas]]:
Functionality exists to display multiple shields for one route, which is used to display tolled and free shields for routes where they differ. This is done by supplying a table with two values, which are listed without indices. The parser is called twice by the calling module, and it returns one shield per call. An example may be found in [[Module:Road data/strings/USA/TX|Texas]]:
<source lang="lua">
<syntaxhighlight lang="lua">
TX.Both = {shield = {"Texas %route%.svg", "Toll Texas %route% new.svg"},
TX.Both = {shield = {"Texas %route%.svg", "Toll Texas %route% new.svg"},
link = "Texas State Highway %route%",
link = "Texas State Highway %route%",
abbr = "SH&nbsp;%route%",
abbr = "SH&nbsp;%route%",
width = 40}
width = 40}
</syntaxhighlight>
</source>


==構造==
==構造==
Each country has its own module. In the United States and Canada, each state/territory/province also has its own module. Each module begins with a comment stating the name of the country or state, followed by the root table declaration, as follows (from [[Module:Road data/strings/USA/AS]]):
Each country has its own module. In the United States and Canada, each state/territory/province also has its own module. Each module begins with a comment stating the name of the country or state, followed by the root table declaration, as follows (from [[Module:Road data/strings/USA/AS]]):
<source lang="lua">
<syntaxhighlight lang="lua">
-- American Samoa
-- American Samoa
local AS = {}
local AS = {}
</syntaxhighlight>
</source>


The root table is named based on the established abbreviation for the country or state, which is the same as the abbreviation used in the module title. This table stores the various types used in that particular place. Most of the remaining code in the module defines these various types. The module ends by returning the root table:
The root table is named based on the established abbreviation for the country or state, which is the same as the abbreviation used in the module title. This table stores the various types used in that particular place. Most of the remaining code in the module defines these various types. The module ends by returning the root table:
<source lang="lua">
<syntaxhighlight lang="lua">
return AS
return AS
</syntaxhighlight>
</source>


===別名定義===
===別名定義===
There are two ways to define a type as an alias. If the type is defined within the module, simply set the new type as equal to the type being aliased, as shown above (from [[Module:Road data/strings/HKG]]):
There are two ways to define a type as an alias. If the type is defined within the module, simply set the new type as equal to the type being aliased, as shown above (from [[Module:Road data/strings/HKG]]):
<source lang="lua">
<syntaxhighlight lang="lua">
HKG.Route = {shield = "HK Route%route%.svg",
HKG.Route = {shield = "HK Route%route%.svg",
link = "Route %route% (Hong Kong)",
link = "Route %route% (Hong Kong)",
163行目: 163行目:
HKG.route = HKG.Route
HKG.route = HKG.Route
</syntaxhighlight>
</source>


If the type is defined in a separate module, such as a state highway type being used in another state's module, a special syntax may be used to refer to that module (from [[Module:Road data/strings/USA/NJ]]):
If the type is defined in a separate module, such as a state highway type being used in another state's module, a special syntax may be used to refer to that module (from [[Module:Road data/strings/USA/NJ]]):
<source lang="lua">
<syntaxhighlight lang="lua">
NJ.NY = {alias = {module = "USA/NY", type = "NY"}}
NJ.NY = {alias = {module = "USA/NY", type = "NY"}}
</syntaxhighlight>
</source>


This code sets the <code>NY</code> type as a link to the <code>NY</code> type in [[Module:Road data/strings/USA/NY]]. The parser will import that module and process the type as if the original module had declared it itself. The alias declaration may not add or override any data in the type table it points to.
This code sets the <code>NY</code> type as a link to the <code>NY</code> type in [[Module:Road data/strings/USA/NY]]. The parser will import that module and process the type as if the original module had declared it itself. The alias declaration may not add or override any data in the type table it points to.

2020年7月6日 (月) 12:54時点における最新版

This module is used to store type data for use with several road templates, including {{jct}} and {{routelist row}}. Background information and a summary of the syntax are listed below.

構文

[編集]

階層とフィールド

[編集]

At its most basic level, this module is a nested table of strings. At the top is the root table, named for the abbreviation of a country, state, or province. This table stores the type data for a particular place, which is named in the comment in the first line, and is returned at the end of the module. The table is composed of further tables, one per type. The basic syntax for a type table is:

place.type = {shield = "",
              link = "",
              abbr = ""}

The three main fields in a type table are shield, link, and abbr. Generally, shield determines the shield that is displayed, if any; link specifies the target of the link generated by a including module, if any; and abbr determines the displayed abbreviation. Currently, these are the three types used by all countries. By convention, they are always specified, using an empty string if there is no value.

Two additional fields are used in the United States. banner stores the name of the banner file, while width stores a code representing the width of the shield. Unlike the three main fields, these are generally omitted entirely when unused.

Once a type is defined, it can be referred to later in the code. A common idiom used for bannered types is defining the shield to be the shield field of the base type (from Module:Road data/strings/USA/MO):

MO.US = {shield = "US %route%.svg",
         link = "U.S. Route %route% in Missouri",
         abbr = "US&nbsp;%route%",
         width = "expand"}

MO["US-Alt"] = {shield = MO.US.shield,
                link = "U.S. Route %route% Alternate ([dab||%dab%, |]Missouri)",
                abbr = "US&nbsp;%route% Alt.",
                banner = "Alternate plate.svg",
                width = "expand"}

Another common idiom is defining a type alias by setting an entry in the root table equal to a previously defined type (from Module:Road data/strings/HKG):

HKG.Route = {shield = "HK Route%route%.svg",
             link = "Route %route% (Hong Kong)",
             abbr = "Route&nbsp;%route%"}
 
HKG.route = HKG.Route

パーサー引数

[編集]

When the parser function of Module:Road data/parser is called, it is passed up to three parameters. The second one is the field to parse, and the last one is a rarely-used option designed for multiple-shield types. The first and most important parameter is a table of arguments collected by the calling module, which generally includes the state, country, or both; the type and number of the route; and a few miscellaneous arguments. This table of arguments forms the basis of the parser's format string syntax.

The table accessible by the strings includes the following entries by default:

  • state: The state or province the route is located in.
  • country: The country the route is located in. If the country is not passed by the calling module, the parser will attempt to include it.

The above entries are primarily used to find the string module itself, so they should not be a concern for module writers.

  • type: The type of the route. This determines the entry of the root table that is used by the parser.
  • route: The route "number". This is easily the most important argument for module writers.

The following entries are used less often:

  • county: The county the route is located in. This is usually used for county routes in the United States.
  • township: This entry is similar in function and utility to the county entry.
  • dab: A tag used to disambiguate the link target. This is mostly used for bannered routes in the United States.
  • denom: This rare entry is used exclusively for West Virginia county routes.

Parser hooks, which will be described later, can add entries to this table that may be used by strings.

基本文字列の構文

[編集]

The most basic value that can be used for most type table fields is a specially formatted string, which will be referred to in this documentation as a format string. This is the string that will ultimately be parsed and returned by the parser. A format string is an ordinary string object. The power of these strings comes in the form of two special instructions that are recognized by the parser.

The first is anything in %argument% form. The parser will replace such a statement with the value of the argument entry in the arguments table described earlier. This is what allows the route number to be spliced into a shield or link name.

The second special string is in the form of [arg|equals|then|else]. This functions as a rudimentary if-then-else statement. The parser tests the value of arg to see if it is equal to the value specified in equals. equals may be empty, in which case the parser tests the existence of the arg argument. If the result of the test is true, the statement is replaced with the value of the then block. Otherwise, it is replaced with the value of the else block.

The two statements may be combined. The parser will parse the if-then-else statement first, and then perform the argument inclusion. This combination is commonly used with bannered routes in the United States, where the dab argument is tested and the link disambiguation is adjusted accordingly, as follows (from Module:Road data/strings/USA/AL):

AL["US-Bus"] = {shield = "US %route%.svg",
                link = "U.S. Route %route% Business ([dab||%dab%, |]Alabama)",
                abbr = "US-%route% Bus.",
                banner = "Business plate.svg",
                width = "expand"}

When parsing the link field, the parser first checks to see if the dab argument was provided. If so, it replaces the statement with %dab%, . If not, the statement is replaced with the empty string placed in the else block. Then, the parser replaces %route% with the route number and, if the dab argument was provided, %dab% with the value of that argument.

切替

[編集]

Some logic is too complicated to represent with only format strings. This framework provides several methods to express complex data. All of these involve storing a nested table as the value of a field.

The most straightforward functionality provided by nested tables is switching. In its most basic form, the table consists of a series of key-value pairs, with the keys being route numbers and the values being the format strings used by those routes. Usually, the format string returned does not need parsing, but the option is there. A default entry should be provided to handle any route numbers not explicitly stated. The following is a representative example of route-based switching (from Module:Road data/strings/USA/AR):

AR.AR = {shield = {default = "Arkansas %route%.svg",
                   ["917"] = "Arkansas 917-1.svg",
                   ["980"] = "Arkansas 980(Airport).svg"},
         link = "Arkansas Highway %route% [dab||(%dab%)|]",
         abbr = "Hwy.&nbsp;%route%",
         width = "expand"}

In this example, Highways 917 and 980 have non-standard shield names, which are explicitly provided. Other route numbers use the default format.

Switching on other arguments is also allowed. The name of the argument to be used for switching is stated in the arg field of the table. Nesting switches on different arguments is also allowed. A good example that uses both forms of switching can be found in Ontario:

local regionalShields = {arg = "county",
                         ["Essex"] = "Essex County Road %route%.png",
                         ["York"] = "York Regional Road %route%.svg",
                         ["Durham"] = "Durham Regional Road %route%.svg",
                         ["Niagara"] = "Niagara Regional Road %route%.svg",
                         ["Simcoe"] = {["52"] = "Simcoe county road 52.png",
                                       default = "Simcoe County Road %route%.JPG"}}

In this example, which is a shield table that is reused by several types in Ontario, the county argument is used for the primary switch. If the route is in Simcoe County, a second switch is performed, this time on the route number.

存在確認テスト

[編集]

Another use for tables is existence testing. If a table has the ifexists field set to true, the parser will perform existence testing on the result of parsing the default field. If the test fails, the result of parsing the otherwise field is returned. Existence testing may be chained by using a second ifexists table as the value of the first table's otherwise field, and so on. Here's an example of nested existence testing (from Module:Road data/strings/GBR):

GBR.B = {shield = {ifexists = true,
                   default = "UK road B%route%.svg",
                   otherwise = {ifexists = true,
                                default = "UK road B%route%.png"}},
         link = "",
         abbr = "B%route%"}

起動法Hooks

[編集]

Due to technical limitations, these string modules cannot contain functions. Rather than force functionality into the string framework, the parser can call functions in a separate hooks module. The functions in this module, Module:Road data/parser/hooks, are more-or-less fully functional functions. The exact functionalities of these hooks are beyond the scope of this documentation. Descriptions of these hooks may be found on their documentation page.

Generally speaking, a hook is called by setting the hook field in a table as equal to the name of a hook. Hooks receive two arguments, both tables: parameters, which is the table in the definition; and args, which is simply the table of arguments normally passed to the parser. The hook returns a string, which is then parsed as usual. A powerful feature of hooks is that they can add arbitrary values to the argument table, which may be referenced in the string returned by the hook. Generally, the format string returned by the hook is specified in some form by the default field of the table, though there are exceptions. Here is an example of a hook (from Module:Road data/strings/MEX):

MEX.SH = {shield = {ifexists = true,
                    arg = "state",
                    SON = "HIGHWAYSON %route%.jpg",
                    NLE = "Nuevo Leon State Highway %route%.PNG",
                    default = ""},
          link = {hook = "mask",
                  mask = "Road data/masks/MEX",
                  base = "state",
                  masked = "fullstate",
                  default = "%fullstate% State Highway %route%"},
          abbr = "SH&nbsp;%route%"}

In this example, the parser will process the link by calling the mask hook. In short, this hook takes the argument referenced in base, passes it through the mask module specified in mask, and stores it in the field in the arguments noted in masked. The hook returns the string given in default, which has access to the fullstate argument added by the hook.

その他の機能

[編集]

Functionality exists to display multiple shields for one route, which is used to display tolled and free shields for routes where they differ. This is done by supplying a table with two values, which are listed without indices. The parser is called twice by the calling module, and it returns one shield per call. An example may be found in Texas:

TX.Both = {shield = {"Texas %route%.svg", "Toll Texas %route% new.svg"},
           link = "Texas State Highway %route%",
           abbr = "SH&nbsp;%route%",
           width = 40}

構造

[編集]

Each country has its own module. In the United States and Canada, each state/territory/province also has its own module. Each module begins with a comment stating the name of the country or state, followed by the root table declaration, as follows (from Module:Road data/strings/USA/AS):

-- American Samoa
local AS = {}

The root table is named based on the established abbreviation for the country or state, which is the same as the abbreviation used in the module title. This table stores the various types used in that particular place. Most of the remaining code in the module defines these various types. The module ends by returning the root table:

return AS

別名定義

[編集]

There are two ways to define a type as an alias. If the type is defined within the module, simply set the new type as equal to the type being aliased, as shown above (from Module:Road data/strings/HKG):

HKG.Route = {shield = "HK Route%route%.svg",
             link = "Route %route% (Hong Kong)",
             abbr = "Route&nbsp;%route%"}
 
HKG.route = HKG.Route

If the type is defined in a separate module, such as a state highway type being used in another state's module, a special syntax may be used to refer to that module (from Module:Road data/strings/USA/NJ):

NJ.NY = {alias = {module = "USA/NY", type = "NY"}}

This code sets the NY type as a link to the NY type in Module:Road data/strings/USA/NY. The parser will import that module and process the type as if the original module had declared it itself. The alias declaration may not add or override any data in the type table it points to.

スタイル

[編集]

There are a few style guidelines that should be followed:

  1. Align table fields using spaces. All tables should be aligned so that fields line up with each other, as shown in the above examples.
  2. Do not place a table's closing brace on a separate line.
  3. Each table field should be on its own line.
  4. Add spaces to either side of an assignment operator (equals sign).
  5. Leave a blank line between types. Type aliases should be set off from their base type by a blank line, but no blank lines should be placed between the aliases themselves.