Misplaced Pages

User:רנדום/CiteNG

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
< User:רנדום

The CiteNG extension provides advanced citation capabilities, extending those provided by the Cite extension, and is fully compatible with it.

Getting Started

Basic Usage Example

As said above, CiteNG is fully compatible with Cite.




Beyond The Basics

Terminology

Pointer

A pointer is a tag that points to a named definition. Editors place pointers in the article to cite or reference a source. A pointer is created by placing the <ref> tag anywhere in the text. A pointer tag must specify the name attribute, and must not have a tag body (i.e. <ref .../>). A pointer tag with no name or empty name attribute generates an error; a pointer tag with a tag body becomes an Inline Definition.

A pointer tag is rendered for display with a Pointer Rendering Template. The default rendering template replaces the original tag with a super-script numeric label (i.e. ) that links to the named definition. If a rendering template isn't specified, it is inherited from the definition to which this pointer points to.

Syntax
<ref name="NAME" "}} ]/>

Example:

<ref name="NASA89-1" pointer-renderer="{{PointerLabelRenderer|label=note}}"/>


<reference group="Notes" pointer-renderer="{{PointerLabelRenderer|label=note}}"> <ref name="Sun vs. MS dispute"> </reference>

Definition

  • Named Definition
  • Anonymous Definition
  • Typed Definition
  • Inline Definition
  • Group
  • Pointer Rendering Template
  • Definition Rendering Template
  • Group Rendering Template
  • Style


Group

  • reference
    • group
    • pointer-renderer
    • definition-renderer
    • group-renderer
    • style

The Citation-Reference Style

Syntax 1

The Moon is Earth's only natural satellite and is the fifth largest satellite in the Solar System.<ref name="R1"/> It is the largest moon in the Solar System relative to the size of its planet, a quarter the diameter of Earth and 1/81 its mass, and is the second densest satellite after Io. It is in synchronous rotation with Earth, always showing the same face; the near side is marked with dark volcanic maria among the bright ancient crustal highlands and prominent impact craters. <reference style="citation"> <ref name="R1"><ref name="NASA89"/>, pp.105-106</ref> </reference> <reference style="reference"> <ref:book name="NASA89" .../> </reference>

Syntax 2

The Moon is Earth's only natural satellite and is the fifth largest satellite in the Solar System.<ref g="citation"><ref name="NASA89"/>, pp. 105-106</ref> It is the largest moon in the Solar System relative to the size of its planet, a quarter the diameter of Earth and 1/81 its mass, and is the second densest satellite after Io. It is in synchronous rotation with Earth, always showing the same face; the near side is marked with dark volcanic maria among the bright ancient crustal highlands and prominent impact craters. <reference style="citation"/> <reference style="reference"> <ref:book name="NASA89" .../> </reference>

Syntax 3

The Moon is Earth's only natural satellite and is the fifth largest satellite in the Solar System.<ref name="NASA89-1"/> It is the largest moon in the Solar System relative to the size of its planet, a quarter the diameter of Earth and 1/81 its mass, and is the second densest satellite after Io. It is in synchronous rotation with Earth, always showing the same face; the near side is marked with dark volcanic maria among the bright ancient crustal highlands and prominent impact craters. <reference style="citation"> <ref><ref name="NASA89" pp="105-106"/></ref> <reference style="reference"> <ref:book name="NASA89" .../> </reference>

Zbale

In CiteNG, a Reference has two parts: the Reference Definition and zero or more Reference Pointers. A reference definition describes a previously published work, and is usually placed within a Definition Group, at the foot of the article. A reference pointer is placed within the article body, and is used to point to a reference definition.

Reference Definition

Technically speaking, a reference definition has three main properties:

Property Description
Location The place within the article where the reference definition is located. A definition within the article body is called an inline definition; a definition that is located inside a definition group is called a grouped definition. Inline definitions are scattered in the article, and are hard to find and maintain. In contrast, grouped definitions are easily found and maintained: they are grouped together at the foot of the article.
  • Inline: ...and the design of Smalltalk.<ref name="alank">http://smalltalk.org/history.html</ref>
  • Grouped: ...and the design of Java.<ref name="jg"/>
    ==References==
    <references>
      <ref name="jg">http://java.org/history</ref>
    </references>
Type A definition is either typed or typeless. A typed definition specifies the type of the published work it describes (i.e., book, journal, web site etc.); a typeless definition does not. A typed definition can be automatically formatted; a typeless definition is formatted manually, either in a free style, or using a citation template.
  • Typed: <ref:book title="Green" first="John" .../>
  • Naive typeless: <ref>Allan, John (1998), "Green" ...</ref>
  • Advanced typeless: <ref>{{cite book | title="Green" | first="John" ... }}</ref>
Identification

In-place and Out-of-place Definition

An in-place definition is a reference definition that is placed somewhere within the article text

In this style, the reference is declared within the article body. This style is easy to use, but makes it hard to maintain the declarations, as they are scattered in the text in no particular order. When the article is rendered, the declaration is considered as if it was declared within a named Reference Declaration Block, matched by the group attribute. If a group attribute is not specified, it defaults to "_anonymous_". Likewise, an unnamed reference declaration block defaults to "_anonymous_".

For example, the following two styles are equivalent:

Definition within the article Definition in a reference declaration block

Blah ... <ref name="foo" label="bar">text</ref> ... blah blah
==References==
<references/>

Blah ... <ref name="foo"/> ... blah blah
==References==
<references>
  <ref name="foo" label="bar">text</ref>
</references>



blah blah <ref >TEXT</ref> blah blah

If group is not specified, the reference is treated as if group = references.


Definitions

Reference Pointer

A Reference Pointer ("pointer" for short) is a tag that points to a named Reference Declaration. Editors place this tag in the article to cite a source. A pointer tag is rendered for display using a Rendering Template. The rendering template will usually replace the original tag with a link to the appropriate reference declaration, thus allowing the reader to view the source with a mouse click.

Syntax:

<ref name="NAME"/>

Short Syntax

For ease of use, the following additional short syntax is supported. Note that this syntax is only supported for reference pointers. In XML terms, <tag foo/> is actually <tag foo="foo"/>.

Syntax:

<ref NAME/>

Reference Declaration

A Reference Declaration ("declaration" for short") is a tag that defines the content of a reference. Declarations can be placed anywhere in the text (in-place), but it's best if they are placed within a Reference Declaration Block. A declaration must be named for a pointer (or pointers) to point on it. Unnamed declarations cannot be pointed at by pointers. When a declaration is placed within the article, it can be grouped to a named reference declaration block, thus providing control on the location of the declaration within the rendered article. A declaration can optionally have a label, which is the human-readable name of the declaration. Usually, the Harvard Referencing format is used for labels (i.e., "Darwin 1846"), but any text will do. Reference declarations are rendered using a rendering template.

In-place Declarations

In this style, the reference is declared within the article body. This style is easy to use, but makes it hard to maintain the declarations, as they are scattered in the text in no particular order. When the article is rendered, the declaration is considered as if it was declared within a named Reference Declaration Block, matched by the group attribute. If a group attribute is not specified, it defaults to "_anonymous_". Likewise, an unnamed reference declaration block defaults to "_anonymous_".

For example, the following two styles are equivalent:

Definition within the article Definition in a reference declaration block

Blah ... <ref name="foo" label="bar">text</ref> ... blah blah
==References==
<references/>

Blah ... <ref name="foo"/> ... blah blah
==References==
<references>
  <ref name="foo" label="bar">text</ref>
</references>

Named Declaration

Syntax:

Blah ... <ref name="NAME"  >TEXT</ref> ... blah blah
Unnamed Declaration

Syntax:

Blah ... <ref  >TEXT</ref> ... blah blah

Built-in Styles

Built-in Classes

Class:Notes

Attribute Default Value Result
pointer-renderer Template:Ref:Pointer:SupIndexedLabelRenderer Hello World.
declaration-renderer Template:Ref:Declaration:DefaultRenderer 1. This is a note.
2. And so is this.

Class:Citations

Attribute Default Value Result
pointer-renderer Template:Ref:Pointer:SupIndexedRenderer Hello World.
declaration-renderer Template:Ref:Declaration:DefaultRenderer 1. This is a citation.
2. And so is this.

Class:References

Attribute Default Value Result
pointer-renderer Template:Ref:Pointer:LabelRenderer During the mid nineties research undertaken in Luton (Slater & Jones,

1996) showed that...

declaration-renderer None 1. This is a reference.
2. And so is this.

Built-in Renderers

Pointer Renderer

A Pointer Renderer is a template that transforms a Reference Pointer tag (i.e., <ref name="foo"/>) to wiki markup text. Several such templates are provided, each generates a different wiki text. The following table lists the parameters that are set when this template is invoked:

Attribute Description Sample
name The name of the declaration to which this pointer links Blo95
label The label (if exists) of the declaration Darwin 1846
index The index of the reference 1 2 ... N
anchor The anchor of this pointer; a declaration may link back here ref_pointer_1
target The anchor of the declaration; the pointer should link to this anchor ref_declaration_1
Template:Ref:Pointer:LabelRenderer
<span id="{{{anchor}}}" class="reference">
  ]
</span>
Template:Ref:Pointer:SupIndexRenderer
<sup id="{{{anchor}}}" class="reference">
  </nowiki>]]
</sup>
Template:Ref:Pointer:SupIndexedLabelRenderer
<sup id="{{{anchor}}}" class="reference">
  </nowiki>]]
</sup>

Declaration Renderer

A Declaration Renderer is a template that transforms a Reference Declaration tag (i.e., <ref name="foo"/>blah blah</ref>) to wiki markup text. This template is called at least once for every declaration. If more than one reference pointers point to a declaration, this template is called once for each pointer, usually linking the declaration to each of its pointers. The following table lists the parameters that are set when this template is invoked:

Attribute Description Sample
name The name of the declaration Blo95
label The label (if exists) of the declaration Darwin 1846
index The index of the reference declaration; usually serves as the numeric identifier of the declaration 1 2 ... N
pointer The current pointer that needs to be linked 1 2 ... count
count The number of pointers that point to this declaration N
anchor The anchor of this pointer; a declaration may link back here ref_pointer_1
target The anchor of the declaration; the pointer should link to this anchor ref_declaration_1
Template:Ref:Declaration:DefaultRenderer
{{{index}}}.&nbsp; 
{{#ifexpr:{{{pointer}}} <= 1 | <span id="{{{anchor}}}" class="reference"> }}
{{#switch:{{{count}}}
    | 0 = <b>^</b>
    | 1 = <b>]</b>
    #default = ] 
}}
{{#ifeq:{{{pointer}}} | {{{count}}} | &nbsp;{{{text}}}</span> }}

Block Renderers

Template:Ref:Block:HeaderRenderer
Template:Ref:Block:FooterRenderer

Demo

Notes, Citations and References

'''Java''' is a ] originally developed by ] 
and released in 1995 as a core component of Sun Microsystems' ]. 
The language derives much of its ] from [[C 
(programming language)|C]]<ref name="syntax"/> and ]<ref name="syntax1"/> but has
 a simpler ]<ref name="object model"/> and fewer low-level facilities. 
Java applications are typically ] to ] 
that can run on any ] (JVM) regardless of ]. 
Sun's trademark license for usage of the Java brand insists that all implementations be
"compatible"<ref name="lawsuit"/>. 
==Notes==
<references:notes>
  <ref name="lawsuite">
    This resulted from a legal dispute with ] after Sun claimed that the Microsoft
    implementation did not support ] or [[Java Native
    Interface|JNI]] and had added platform-specific features of their own. Sun sued in 1997, 
    and in 2001 won a settlement of $20 million as well as a court order enforcing the terms of
    the license from Sun.<ref name="lawsuite javaworld"/>
  </ref> 
</reference:notes>
==Citations==
<references:citations>
  <ref name="JvW"><ref name="van Wyhe 2008"/>, p. 121</ref>
</references:citations>
==References==
<references:references>
  <references>
    <ref:book name="spec"
      author
], ], ], and ], ''The Java language specification'', third edition. Addison-Wesley, 2005. ISBN 0-321-24678-0 (see also 
    <ref:news name="lawsuit javaworld"
      author="James Niccolai"
      title="Sun, Microsoft settle Java lawsuit"
      url="http://www.javaworld.com/javaworld/jw-01-2001/jw-0124-iw-mssuncourt.html"
      work="JavaWorld"
      publisher="]"
      date="January 23, 2001"
      accessdate="2008-07-09"
    </ref:news>
  </references>
</references:references>