// This Vancouver style was modeled after these resources: // // // citing: // // // based on 'cite_AMA.php' // NOTES: - In the Vancouver style, the reference list is arranged numerically in the order in which references are cited in the text. // This isn't currently handled by this style // - For conference proceedings, you'll currently need to add the place & date of the conference in the proceedings title field // (e.g. "Proceedings of the 5th Germ Cell Tumour Conference; 2001 Sep 13-15; Leeds, UK"). // TODO: - abstracts, newspaper/magazine articles, patents & reports? // - arrange references numerically // - for newspaper articles, only the beginning page number of an article should be included (see: ) // - where to put (and how to format) editors of whole books that also have an author? // - see also inline comments labeled with TODO (and NOTE) // Modified for use in biblio by Ron Jerome // // $Id: biblio_style_vancouver.inc,v 1.1.4.6 2011-02-08 02:38:18 rjerome Exp $ /** * Get the style information * * @return * The name of the style */ function biblio_style_vancouver_info() { return array( 'vancouver' => 'Vancouver' ); } function biblio_style_vancouver_author_options() { $author_options = array( 'BetweenAuthorsDelimStandard' => ', ', 'BetweenAuthorsDelimLastAuthor' => ', ', 'AuthorsInitialsDelimFirstAuthor' => ' ', 'AuthorsInitialsDelimStandard' => ' ', 'betweenInitialsDelim' => '', 'initialsBeforeAuthorFirstAuthor' => FALSE, 'initialsBeforeAuthorStandard' => FALSE, 'numberOfInitialsToKeep' => 2, 'shortenGivenNames' => TRUE, 'numberOfAuthorsTriggeringEtAl' => 6, 'includeNumberOfAuthors' => 6, 'customStringAfterFirstAuthors' => ', et al.', 'encodeHTML' => TRUE ); return $author_options; } function biblio_style_vancouver($node, $base = 'biblio', $inline = FALSE) { $output = ''; $markupPatternsArray = array("italic-prefix" => '', "italic-suffix" => '<\/i>', "endash" => '-'); $author_options = biblio_style_vancouver_author_options(); if (isset($node->biblio_contributors[1])) { $authors = theme('biblio_format_authors', array('contributors' => $node->biblio_contributors[1], 'options' => $author_options, 'inline' => $inline)); } //$editors = theme('biblio_format_authors', array('contributors' => $node->biblio_contributors[2], 'options' => $author_options, 'inline' => $inline)); //if (empty($authors)) $authors = theme('biblio_authors', $node->biblio_contributors[5], 'mla', 5, $inline); // if no authors substitute corp author if available //if (empty($authors)) $authors = '[' . t('Anonymous') . ']'; // use anonymous if we still have nothing. //$output .= '' . $authors . ".  \n"; if (!empty ($node->biblio_citekey)&&(variable_get('biblio_display_citation_key',0))) { $output .= '[' . check_plain($node->biblio_citekey) . '] '; } switch ($node->biblio_type) { case 102: //Journal Article case 105: //Newspaper Article case 106: //Magazine Article if (!empty($authors)) { $output .= ''; $output .= $authors; if (!preg_match("/\. *$/", $authors)) $output .= "."; $output .= ""; } if (!empty($node->title)) // title { if (!empty($authors)) $output .= " "; $output .= ''; $url = biblio_get_title_url_info($node); $output .= l($node->title, $url['link'], $url['options']); $output .= ""; if (!preg_match("/[?!.]$/", $node->title)) $output .= "."; } // From here on we'll assume that at least either the 'author' or the 'title' field did contain some contents // if this is not the case, the output string will begin with a space. However, any preceding/trailing whitespace will be removed at the cleanup stage (see below) if (!empty($node->biblio_alternate_title)) // abbreviated journal name $output .= " " . preg_replace("/\./", "", $node->biblio_alternate_title); // no punctuation marks are used in the abbreviated journal name, just spaces (TODO: smarten regex pattern) // if there's no abbreviated journal name, we'll use the full journal name instead: elseif (!empty($node->biblio_secondary_title)) // publication (= journal) name $output .= " " . $node->biblio_secondary_title; if (isset($node->online_publication)) // this record refers to an online publication $output .= " [Internet]"; // NOTE: some of the above mentioned resources use "[serial online]", "[serial on the Internet]" or just "[online]" instead // NOTE: the formatting of year/volume/issue is meant for journal articles (TODO: newspaper/magazine articles) if (!empty($node->biblio_year)) // year $output .= ". " . $node->biblio_year; if (isset($node->online_publication)) // append the current date if this record refers to an online publication $output .= " [cited " . date("Y M j") . "]"; if (!empty($node->biblio_volume) || !empty($node->biblio_issue)) $output .= ";"; if (!empty($node->biblio_volume)) // volume (=month) $output .= $node->biblio_volume; if (!empty($node->biblio_issue)) // issue (=day) $output .= "(" . $node->biblio_issue . ")"; if (!empty($node->biblio_pages)) // pages { if (!empty($node->biblio_year) || !empty($node->biblio_volume) || !empty($node->biblio_issue) || !empty($node->biblio_alternate_title) || !empty($node->biblio_secondary_title)) // only add ": " if either year, volume, issue, abbrev_journal or publication isn't empty $output .= ":"; $output .= theme('biblio_page_number', array('orig_page_info' => $node->biblio_pages, 'page_range_delim' => $markupPatternsArray["endash"], 'shorten_page_range_end' => TRUE)); // function 'formatPageInfo()' is defined in 'cite.inc.php' } if (isset($node->online_publication)) // this record refers to an online publication { // append an optional string (given in 'online_citation') plus the DOI (or URL): if (!empty($node->online_citation)) // online_citation { if (!empty($node->biblio_year) || !empty($node->biblio_volume) || !empty($node->biblio_issue) || !empty($node->biblio_alternate_title) || !empty($node->biblio_secondary_title)) // only add ":" or "," if either year, volume, issue, abbrev_journal or publication isn't empty { if (empty($node->biblio_pages)) $output .= ":"; // print instead of pages else $output .= ";"; // append to pages (TODO: not sure whether this is correct) } $output .= $node->online_citation; } if (!empty($node->doi) || !empty($node->url)) // doi OR url { if (!empty($node->online_citation) OR (empty($node->online_citation) AND (!empty($node->biblio_year) || !empty($node->biblio_volume) || !empty($node->biblio_issue) || !empty($node->biblio_alternate_title) || !empty($node->biblio_secondary_title)))) // only add "." if online_citation isn't empty, or else if either year, volume, issue, abbrev_journal or publication isn't empty $output .= "."; $output .= " Available from: " . $markupPatternsArray["underline-prefix"]; // NOTE: some of the above mentioned resources use "Available from: URL:http://..." instead if (!empty($node->doi)) // doi $uri = "http://dx.doi.org/" . $node->doi; else // url $uri = $node->url; if ($encodeHTML) $output .= encodeHTML($uri); else $output .= $uri; $output .= $markupPatternsArray["underline-suffix"]; } } if (!preg_match("/\. *$/", $output) AND (!isset($node->online_publication))) $output .= "."; // NOTE: the examples in the above mentioned resources differ wildly w.r.t. whether the closing period should be omitted for online publications break; case 101: //Book Chapter case 103: //Conference Paper if (!empty($authors)) { $output .= ''; $output .= $authors; if (!preg_match("/\. *$/", $authors)) $output .= "."; $output .= ''; } if (!empty($node->title)) // title { if (!empty($authors)) $output .= " "; $output .= ''; $url = biblio_get_title_url_info($node); $output .= l($node->title, $url['link'], $url['options']); $output .= ""; if (!preg_match("/[?!.]$/", $node->title)) $output .= "."; } if (!empty($node->biblio_contributors[2])) // editor { $editor_options = array( 'BetweenAuthorsDelimStandard' => ', ', 'BetweenAuthorsDelimLastAuthor' => ', ', 'AuthorsInitialsDelimFirstAuthor' => ' ', 'AuthorsInitialsDelimStandard' => ' ', 'betweenInitialsDelim' => '', 'initialsBeforeAuthorFirstAuthor' => FALSE, 'initialsBeforeAuthorStandard' => FALSE, 'shortenGivenNames' => TRUE, 'numberOfAuthorsTriggeringEtAl' => 6, 'includeNumberOfAuthors' => 6, 'customStringAfterFirstAuthors' => ' et al.', 'encodeHTML' => TRUE ); $editor = theme('biblio_format_authors', array('contributors' => $node->biblio_contributors[2], 'options' => $editor_options, 'inline' => $inline)); $output .= " In: " . $editor . ", "; if (count ($node->biblio_contributors[2]) > 1) // there are at least two editors (separated by ';') $output .= "editors"; else // there's only one editor (or the editor field is malformed with multiple editors but missing ';' separator[s]) $output .= "editor"; } $publication = preg_replace("/[ \r\n]*\(Eds?:[^\)\r\n]*\)/", "", $node->biblio_secondary_title); if (!empty($publication)) // publication { if (!preg_match("/[?!.] *$/", $output)) $output .= "."; if (empty($editor)) $output .= " In:"; $output .= " " . $publication; } if (!empty($node->biblio_volume)) // volume { if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; $output .= " Vol " . $node->biblio_volume; // TODO: not sure whether this is correct } if (!empty($node->biblio_edition) && !preg_match("/^(1|1st|first|one)( ed\.?| edition)?$/i", $node->biblio_edition)) // edition { if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; if (preg_match("/^\d{1,3}$/", $node->biblio_edition)) // if the edition field contains a number of up to three digits, we assume it's an edition number (such as "2nd ed.") { if ($node->biblio_edition == "2") $editionSuffix = "nd"; elseif ($node->biblio_edition == "3") $editionSuffix = "rd"; else $editionSuffix = "th"; } else $editionSuffix = ""; if (!preg_match("/( ed\.?| edition)$/i", $node->biblio_edition)) $editionSuffix .= " ed."; $output .= " " . $node->biblio_edition . $editionSuffix; } if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; if (!empty($node->biblio_place_published)) // place { // // for places in the USA, format any two-letter postal code for the state (i.e. ensure upper case & wrap in parens, eg. "Boca Raton (FL)"): // if (preg_match("/(.+?)[$punct$space]+($uspsStateAbbreviations)[$punct$space]*$/i$patternModifiers", $node->biblio_place_published)) // $output .= " " . preg_replace("/(.+?)[$punct$space]+($uspsStateAbbreviations)[$punct$space]*$/ie$patternModifiers", "'\\1 ('.strtoupper('\\2').')'", $node->biblio_place_published); // else $output .= " " . $node->biblio_place_published; } if (!empty($node->biblio_publisher)) // publisher { if (!empty($node->biblio_place_published)) $output .= ":"; $output .= " " . $node->biblio_publisher; } if (!empty($node->biblio_year)) // year $output .= "; " . $node->biblio_year; if (!empty($node->biblio_pages)) // pages $output .= ". " . theme_biblio_page_number($node->biblio_pages, $markupPatternsArray["endash"], "p. ", "p. ", "", "", "", "", TRUE); // function 'formatPageInfo()' is defined in 'cite.inc.php' $output .= ". " . theme('biblio_page_number', array('orig_page_info' => $node->biblio_pages, 'page_range_delim' => $markupPatternsArray["endash"], 'single_page_prefix' => "p. ", 'page_range_prefix' => "p. ", 'shorten_page_range_end' => TRUE)); // function 'formatPageInfo()' is defined in 'cite.inc.php' if (!empty($node->biblio_alternate_title) OR !empty($node->biblio_tertiary_title)) // if there's either a full or an abbreviated series title { if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; $output .= " ("; if (!empty($node->biblio_alternate_title)) // abbreviated series title $output .= preg_replace("/\./", "", $node->biblio_alternate_title); // no punctuation marks are used in the abbreviated series title, just spaces (TODO: smarten regex pattern) // if there's no abbreviated series title, we'll use the full series title instead: elseif (!empty($node->biblio_tertiary_title)) // full series title $output .= $node->biblio_tertiary_title; if (!empty($node->biblio_volume)||!empty($node->biblio_issue)) $output .= "; "; if (!empty($node->biblio_volume)) // series volume $output .= "vol " . $node->biblio_volume; if (!empty($node->biblio_volume) && !empty($node->biblio_issue)) $output .= "; "; // TODO: not sure whether this is correct if (!empty($node->biblio_issue)) // series issue (I'm not really sure if -- for this cite style -- the series issue should be rather omitted here) $output .= "no " . $node->biblio_issue; // since a series volume should be prefixed with "vol", is it correct to prefix series issues with "no"? $output .= ")"; } if (!preg_match("/\. *$/", $output)) $output .= "."; break; default : // all other types //TODO // if (preg_match("[ \r\n]*\(ed\)", $node->author)) // single editor // $author = $author . ", ed"; // elseif (preg_match("[ \r\n]*\(eds\)", $node->author)) // multiple editors // $author = $author . ", eds"; if (!empty($authors)) // author { $output .= ''; $output .= $authors; if (!preg_match("/\. *$/", $authors)) $output .= "."; $output .= ''; } if (!empty($node->title)) // title { if (!empty($authors)) $output .= " "; // TODO: book/volume/report/etc titles should be formatted in heading caps, however, this doesn't yet work correctly if the publication title contains HTML entities $output .= ''; $url = biblio_get_title_url_info($node); $output .= l($node->title, $url['link'], $url['options']); $output .= ""; } if ($node->type == "Software") // for software, add software label $output .= " [computer program]"; if (isset($node->online_publication) AND empty($node->thesis)) // this record refers to an online publication (online theses will be handled further down below) $output .= " [Internet]"; // NOTE: some of the above mentioned resources use "[monograph online]", "[monograph on the Internet]" or just "[online]" instead if (!empty($node->biblio_volume) AND ($node->type != "Software")) // volume { if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; $output .= " Vol " . $node->biblio_volume; // TODO: not sure whether this is correct } if (!empty($node->biblio_edition)) // edition { if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; if ($node->type == "Software") // software edition (=version) { $output .= " Version " . $node->biblio_edition; } elseif (!preg_match("/^(1|1st|first|one)( ed\.?| edition)?$/i", $node->biblio_edition)) // edition { if (preg_match("/^\d{1,3}$/", $node->biblio_edition)) // if the edition field contains a number of up to three digits, we assume it's an edition number (such as "2nd ed.") { if ($node->biblio_edition == "2") $editionSuffix = "nd"; elseif ($node->biblio_edition == "3") $editionSuffix = "rd"; else $editionSuffix = "th"; } else $editionSuffix = ""; if (!preg_match("/( ed\.?| edition)$/i", $node->biblio_edition)) $editionSuffix .= " ed."; $output .= " " . $node->biblio_edition . $editionSuffix; } } if (isset($node->biblio_contributors[2])) // editor (if different from author, see note above regarding the check for ' (ed)' or ' (eds)') { $editor_options = array( 'BetweenAuthorsDelimStandard' => ', ', 'BetweenAuthorsDelimLastAuthor' => ', ', 'AuthorsInitialsDelimFirstAuthor' => ' ', 'AuthorsInitialsDelimStandard' => ' ', 'betweenInitialsDelim' => '', 'initialsBeforeAuthorFirstAuthor' => FALSE, 'initialsBeforeAuthorStandard' => FALSE, 'shortenGivenNames' => TRUE, 'numberOfAuthorsTriggeringEtAl' => 6, 'includeNumberOfAuthors' => 3, 'customStringAfterFirstAuthors' => ' et al.', 'encodeHTML' => TRUE ); $editor = theme('biblio_format_authors', array('contributors' => $node->biblio_contributors[2], 'options' => $editor_options, 'inline' => $inline)); if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; $output .= " " . $editor; if (count($node->biblio_contributors[2]) > 1) // there are at least two editors (separated by ';') $output .= ", editors"; else // there's only one editor (or the editor field is malformed with multiple editors but missing ';' separator[s]) $output .= ", editor"; } if (!empty($node->thesis)) // thesis { // TODO: do we need to use the term "[dissertation]" instead of "[Ph.D. thesis]", etc? What about other thesis types then? $output .= " [" . $node->thesis; if (isset($node->online_publication)) // this record refers to an online thesis $output .= " on the Internet]"; else $output .= "]"; } if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; if (!empty($node->biblio_place_published)) // place { // // for places in the USA, format any two-letter postal code for the state (i.e. ensure upper case & wrap in parentheses, eg. "Boca Raton (FL)"): // if (preg_match("/(.+?)[$punct$space]+($uspsStateAbbreviations)[$punct$space]*$/i$patternModifiers", $node->biblio_place_published)) // $output .= " " . preg_replace("/(.+?)[$punct$space]+($uspsStateAbbreviations)[$punct$space]*$/ie$patternModifiers", "'\\1 ('.strtoupper('\\2').')'", $node->biblio_place_published); // else $output .= " " . $node->biblio_place_published; } if (!empty($node->biblio_publisher)) // publisher { if (!empty($node->biblio_place_published)) $output .= ":"; $output .= " " . $node->biblio_publisher; } $output .= ";"; if (!empty($node->biblio_year)) // year $output .= " " . $node->biblio_year; if ($node->type == "Software") // for software, volume (=month) and issue (=day) information is printed after the year (TODO: not sure whether this is correct) { if (!empty($node->biblio_volume)) // volume (=month) $output .= " " . $node->biblio_volume; if (!empty($node->biblio_issue)) // issue (=day) $output .= " " . $node->biblio_issue; } if (isset($node->online_publication)) // append the current date if this record refers to an online publication $output .= " [cited " . date("Y M j") . "]"; if (!empty($node->biblio_alternate_title) OR !empty($node->biblio_tertiary_title)) // if there's either a full or an abbreviated series title { if (!preg_match("/[?!.][ \"" . $markupPatternsArray["italic-suffix"] . "]*$/", $output)) $output .= "."; $output .= " ("; if (!empty($node->biblio_alternate_title)) // abbreviated series title $output .= preg_replace("/\./", "", $node->biblio_alternate_title); // no punctuation marks are used in the abbreviated series title, just spaces (TODO: smarten regex pattern) // if there's no abbreviated series title, we'll use the full series title instead: elseif (!empty($node->biblio_tertiary_title)) // full series title $output .= $node->biblio_tertiary_title; if (!empty($node->biblio_volume)||!empty($node->biblio_issue)) $output .= "; "; if (!empty($node->biblio_volume)) // series volume $output .= "vol " . $node->biblio_volume; if (!empty($node->biblio_volume) && !empty($node->biblio_issue)) $output .= "; "; // TODO: not sure whether this is correct if (!empty($node->biblio_issue)) // series issue (I'm not really sure if -- for this cite style -- the series issue should be rather omitted here) $output .= "no " . $node->biblio_issue; // since a series volume should be prefixed with "vol", is it correct to prefix series issues with "no"? $output .= ")"; } if (isset($node->online_publication) || $node->type == "Software") // this record refers to an online publication, or a computer program/software { // append an optional string (given in 'online_citation') plus the DOI (or URL): if (!empty($node->online_citation)) // online_citation { if (!preg_match("/\. *$/", $output)) $output .= "."; $output .= $node->online_citation; } if (!empty($node->doi) || !empty($node->url)) // doi OR url { if (!preg_match("/\. *$/", $output)) $output .= "."; $output .= " Available from: " . $markupPatternsArray["underline-prefix"]; // NOTE: some of the above mentioned resources use "Available from: URL:http://..." instead if (!empty($node->doi)) // doi $uri = "http://dx.doi.org/" . $node->doi; else // url $uri = $node->url; if ($encodeHTML) $output .= encodeHTML($uri); else $output .= $uri; $output .= $markupPatternsArray["underline-suffix"]; } } if (!preg_match("/\. *$/", $output) AND (!isset($node->online_publication)) AND ($node->type != "Software")) $output .= "."; // NOTE: the examples in the above mentioned resources differ wildly w.r.t. whether the closing period should be omitted for online publications break; } return filter_xss($output, biblio_get_allowed_tags()); }