diff options
-rw-r--r-- | Makefile | 1 | ||||
-rw-r--r-- | oscola-no-ibid.csl | 683 | ||||
-rwxr-xr-x | pandoc-cs1 | 32 |
3 files changed, 716 insertions, 0 deletions
@@ -32,6 +32,7 @@ args_meta += -V subtitle="$(subtitle)" args_meta += -M author="Carlo Piana, Ulf Öberg" args_meta += -V author="Carlo Piana" -V author="Ulf Öberg" args_meta += -V date="" +args_meta += -M csl=oscola-no-ibid.csl args_latex += --template=template.tex --latex-engine=xelatex args_latex += -H header.tex -B before.tex -A after.tex args_latex += -V mainfont="Lora" -V sansfont="Quattrocento Sans" -V monofont="Inconsolata" diff --git a/oscola-no-ibid.csl b/oscola-no-ibid.csl new file mode 100644 index 0000000..1fe428a --- /dev/null +++ b/oscola-no-ibid.csl @@ -0,0 +1,683 @@ +<?xml version="1.0" encoding="utf-8"?> +<style xmlns="http://purl.org/net/xbiblio/csl" class="note" version="1.0" demote-non-dropping-particle="never" default-locale="en-GB"> + <info> + <title>OSCOLA (Oxford University Standard for Citation of Legal Authorities) (no Ibid.)</title> + <title-short>OSCOLA</title-short> + <id>http://www.zotero.org/styles/oscola-no-ibid</id> + <link href="http://www.zotero.org/styles/oscola-no-ibid" rel="self"/> + <link href="http://www.zotero.org/styles/australian-guide-to-legal-citation" rel="template"/> + <link href="http://www.law.ox.ac.uk/publications/oscola.php" rel="documentation"/> + <author> + <name>Sebastian Karcher</name> + </author> + <category citation-format="note"/> + <category field="law"/> + <summary>The OSCOLA Standards with no ibid. For a Zotero Group showing data-entry in Zotero see: https://www.zotero.org/groups/oscola_samples/items/order/itemType</summary> + <updated>2013-11-15T01:14:57+00:00</updated> + <rights license="http://creativecommons.org/licenses/by-sa/3.0/">This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 License</rights> + </info> + <locale> + <terms> + <term name="chapter" form="short"> + <single>ch.</single> + <multiple>chs.</multiple> + </term> + <term name="section" form="short"> + <single>s</single> + <multiple>ss</multiple> + </term> + <term name="paragraph" form="short"> + <single>para</single> + <multiple>paras</multiple> + </term> + <term name="translator" form="short"> + <single>tr.</single> + <multiple>trs.</multiple> + </term> + <term name="edition" form="short">edn.</term> + <term name="et-al">and others</term> + </terms> + </locale> + <!--Authors and Persons--> + <macro name="author-note"> + <!--for bills & hearing this should start with jurisdiction once available--> + <choose> + <if type="interview"> + <group delimiter=", "> + <names variable="interviewer"> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + <names variable="author" prefix="Interview with "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + </group> + </if> + <else-if type="personal_communication"> + <group delimiter=" "> + <group delimiter=" from "> + <text variable="genre"/> + <names variable="author"> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + </group> + <names variable="recipient" prefix="to "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + </group> + </else-if> + <else-if type="broadcast"> + <text variable="publisher"/> + </else-if> + <else-if type="legal_case legislation" match="any"/> + <else> + <names variable="author"> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + <label form="short" prefix=" (" suffix=")" strip-periods="true"/> + <substitute> + <names variable="editor"/> + <names variable="translator"/> + <text macro="title"/> + </substitute> + </names> + </else> + </choose> + </macro> + <macro name="author-short"> + <choose> + <if type="interview"> + <group delimiter=", "> + <names variable="interviewer"> + <name delimiter-precedes-last="never" and="text" form="short" delimiter=", " initialize="false" initialize-with=""/> + </names> + <names variable="author" prefix="Interview with "> + <name delimiter-precedes-last="never" and="text" form="short" delimiter=", " initialize="false" initialize-with=""/> + </names> + </group> + </if> + <else-if type="personal_communication"> + <group delimiter=" "> + <group delimiter=" from "> + <text variable="genre"/> + <names variable="author"> + <name delimiter-precedes-last="never" and="text" delimiter=", " form="short" initialize="false" initialize-with=""/> + </names> + </group> + <names variable="recipient" prefix="to "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" form="short" initialize-with=""/> + </names> + </group> + </else-if> + <else-if type="broadcast"> + <text variable="publisher"/> + </else-if> + <else> + <names variable="author"> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with="" form="short"/> + <substitute> + <names variable="editor"/> + <names variable="translator"/> + <text macro="title"/> + </substitute> + </names> + </else> + </choose> + </macro> + <macro name="author"> + <!--for bills & hearing this should start with jurisdiction once available--> + <choose> + <if type="interview"> + <group delimiter=", "> + <names variable="interviewer"> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize-with="" name-as-sort-order="all" sort-separator=" "/> + </names> + <names variable="author" prefix="Interview with "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + </group> + </if> + <else-if type="personal_communication"> + <group delimiter=" "> + <group delimiter=", "> + <names variable="author"> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize-with="" name-as-sort-order="all" sort-separator=" "/> + </names> + <text variable="genre"/> + </group> + <names variable="recipient" prefix="to "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + </group> + </else-if> + <else-if type="broadcast"> + <text variable="publisher"/> + </else-if> + <else-if type="legal_case legislation" match="any"/> + <else> + <names variable="author"> + <name delimiter-precedes-last="never" and="text" delimiter=", " name-as-sort-order="all" initialize-with="" sort-separator=" "/> + <label form="short" prefix=" (" suffix=")" strip-periods="true"/> + <substitute> + <names variable="editor"/> + <names variable="translator"/> + <text macro="title"/> + </substitute> + </names> + </else> + </choose> + </macro> + <macro name="editor"> + <choose> + <if type="chapter paper-conference entry-encyclopedia" match="none"> + <names variable="editor translator container-author" delimiter=", "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + <label form="short" prefix=" " strip-periods="true"/> + </names> + </if> + </choose> + </macro> + <macro name="editor-chapter"> + <group> + <text term="in" suffix=" "/> + <names variable="editor translator container-author" delimiter=", "> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + <label form="short" prefix=" (" suffix=")" strip-periods="true"/> + </names> + </group> + </macro> + <!-- Titles --> + <macro name="title"> + <choose> + <if type="book motion_picture manuscript" match="any"> + <text variable="title" font-style="italic" text-case="title"/> + </if> + <else-if type="bill legislation" match="any"> + <text variable="title"/> + </else-if> + <else-if type="legal_case"> + <text variable="title" font-style="italic" strip-periods="true"/> + </else-if> + <else> + <text variable="title" quotes="true" text-case="title"/> + </else> + </choose> + </macro> + <macro name="title-short"> + <choose> + <if type="book motion_picture manuscript" match="any"> + <text variable="title" font-style="italic" text-case="title" form="short"/> + </if> + <else-if type="bill legislation" match="any"> + <text variable="title" form="short"/> + </else-if> + <else-if type="legal_case"> + <choose> + <if variable="title-short"> + <text variable="title-short" font-style="italic"/> + </if> + <else> + <text variable="title" font-style="italic"/> + </else> + </choose> + </else-if> + <else> + <text variable="title" quotes="true" text-case="title" form="short"/> + </else> + </choose> + </macro> + <!--Dates--> + <macro name="issued-year"> + <date variable="issued" form="text" date-parts="year"/> + </macro> + <macro name="issued-full"> + <date variable="issued" form="text"/> + </macro> + <macro name="date-parenthesis"> + <choose> + <if type="legal_case article-journal article-magazine" match="any"> + <choose> + <if variable="number authority" match="all"> + <text macro="issued-year" prefix="[" suffix="]"/> + </if> + <else-if variable="volume"> + <text macro="issued-year" prefix="(" suffix=")"/> + </else-if> + <else-if variable="container-title volume number" match="any"> + <!--no year in square brackets for unreported case w/o medium neutral citation--> + <text macro="issued-year" prefix="[" suffix="]"/> + </else-if> + </choose> + </if> + <else-if type="legislation bill" match="any"> + <text macro="issued-year"/> + </else-if> + </choose> + </macro> + <!--publication info --> + <macro name="publisher"> + <choose> + <if type="book chapter broadcast personal_communication manuscript paper-conference article-newspaper report legislation motion_picture speech interview thesis entry-encyclopedia webpage" match="any"> + <group delimiter=" "> + <group prefix="(" suffix=")" delimiter=", "> + <choose> + <if type="article-newspaper"> + <text variable="publisher-place" strip-periods="true"/> + <date variable="issued" form="text"/> + </if> + <else-if type="broadcast personal_communication manuscript" match="any"> + <date variable="issued" form="text"/> + </else-if> + <else-if type="legislation bill" match="any"> + <!--this should be jurisdiction we use code instead--> + <text variable="container-title" strip-periods="true"/> + </else-if> + <else> + <!--this won't work in Zotero yet, but does no harm --> + <names variable="director"> + <label form="verb" text-case="capitalize-first" suffix=" "/> + <name delimiter-precedes-last="never" and="text" delimiter=", " initialize="false" initialize-with=""/> + </names> + <text macro="editor"/> + <choose> + <!--if none of these, this we don't want edition either. Might be Loose-Leaf--> + <if variable="publisher issued genre container-title" match="any"> + <text macro="edition"/> + </if> + </choose> + <choose> + <if type="speech"> + <text variable="event"/> + <text variable="event-place"/> + <text macro="issued-full"/> + </if> + <else-if type="thesis" match="any"> + <text variable="genre" strip-periods="true"/> + <group delimiter=" "> + <text variable="publisher" strip-periods="true"/> + <text macro="issued-year"/> + </group> + </else-if> + <else-if type="webpage"> + <text variable="container-title" font-style="italic"/> + <text macro="issued-full"/> + </else-if> + <else-if type="interview" match="any"> + <text macro="issued-full"/> + </else-if> + <else> + <group delimiter=" "> + <text variable="publisher" strip-periods="true"/> + <text macro="issued-year"/> + </group> + </else> + </choose> + </else> + </choose> + </group> + <choose> + <if type="report interview" match="any"> + <group delimiter=" "> + <text variable="genre" strip-periods="true"/> + <text variable="number"/> + </group> + </if> + </choose> + </group> + </if> + </choose> + </macro> + <macro name="looseleaf-note"> + <choose> + <if type="book"> + <choose> + <if variable="publisher issued" match="none"> + <choose> + <if variable="locator"> + <group delimiter=" "> + <label variable="locator" form="short" strip-periods="true"/> + <text variable="locator"/> + <text variable="edition" prefix="(" suffix=")"/> + </group> + </if> + </choose> + </if> + </choose> + </if> + </choose> + </macro> + <macro name="volume-book"> + <choose> + <if type="book chapter report" match="any"> + <group delimiter=" "> + <label variable="volume" form="short" strip-periods="true"/> + <text variable="volume"/> + </group> + </if> + </choose> + </macro> + <macro name="edition"> + <choose> + <if is-numeric="edition"> + <group delimiter=" "> + <number variable="edition" form="ordinal"/> + <label variable="edition" form="short" strip-periods="true"/> + </group> + </if> + <else> + <text variable="edition" strip-periods="true"/> + </else> + </choose> + </macro> + <macro name="book-container"> + <choose> + <if type="chapter paper-conference entry-encyclopedia" match="any"> + <group> + <text macro="editor-chapter" prefix=" "/> + <text variable="container-title" font-style="italic" prefix=", "/> + </group> + </if> + </choose> + </macro> + <macro name="broadcast-container"> + <choose> + <if type="broadcast" match="any"> + <text variable="container-title" font-style="italic"/> + </if> + </choose> + </macro> + <macro name="bill-number"> + <choose> + <if type="bill"> + <text variable="number" prefix="[" suffix="]"/> + </if> + </choose> + </macro> + <macro name="article-case-info"> + <choose> + <if type="article-journal article-magazine article-newspaper legal_case" match="any"> + <group delimiter=", "> + <!--Assume that only cases with a Medium Neutral Citation have a docket number --> + <choose> + <if variable="authority number" match="all"> + <group delimiter=" "> + <text variable="authority" form="short" strip-periods="true"/> + <text variable="number"/> + </group> + </if> + </choose> + <group delimiter=" "> + <text variable="volume"/> + <choose> + <if type="legal_case"> + <choose> + <if variable="container-title"> + <text variable="container-title" form="short" strip-periods="true"/> + </if> + </choose> + </if> + <else-if type="article-magazine article-newspaper" match="any"> + <text variable="container-title" font-style="italic"/> + </else-if> + <else> + <text variable="container-title"/> + </else> + </choose> + </group> + </group> + </if> + </choose> + </macro> + <macro name="page-first"> + <choose> + <if type="chapter report paper-conference" match="none"> + <text variable="page-first"/> + </if> + </choose> + </macro> + <macro name="court"> + <choose> + <if type="legal_case"> + <choose> + <if variable="number" match="none"> + <text variable="authority" prefix="(" suffix=")" strip-periods="true"/> + </if> + </choose> + </if> + </choose> + </macro> + <macro name="locator-space"> + <choose> + <if type="legal_case"> + <choose> + <if locator="paragraph"> + <text variable="locator" prefix="[" suffix="]"/> + </if> + <else-if variable="number container-title volume page" match="all"/> + <else-if variable="authority"> + <text variable="locator"/> + </else-if> + </choose> + </if> + <else-if type="legislation book article-journal article-magazine" match="none"> + <group delimiter=" "> + <choose> + <if locator="page" match="none"> + <label variable="locator" form="short" strip-periods="true"/> + </if> + </choose> + <text variable="locator"/> + </group> + </else-if> + <else-if type="book"> + <choose> + <if variable="issued publisher" match="any"> + <group delimiter=" "> + <choose> + <if locator="page" match="none"> + <label variable="locator" form="short" strip-periods="true"/> + </if> + </choose> + <text variable="locator"/> + </group> + </if> + </choose> + </else-if> + </choose> + </macro> + <macro name="locator-comma"> + <choose> + <if type="legal_case"> + <choose> + <if locator="paragraph" match="none"> + <choose> + <if variable="authority" match="none"> + <text variable="locator"/> + </if> + <else-if variable="number container-title volume page" match="all"> + <text variable="locator"/> + </else-if> + </choose> + </if> + </choose> + </if> + <else-if type="legislation article-journal article-magazine" match="any"> + <group delimiter=" "> + <choose> + <if locator="page" match="none"> + <label variable="locator" form="short"/> + </if> + </choose> + <text variable="locator"/> + </group> + </else-if> + </choose> + </macro> + <!--Others --> + <macro name="manuscript-catchall"> + <choose> + <if type="manuscript"> + <text variable="genre"/> + </if> + </choose> + </macro> + <macro name="URL"> + <choose> + <if type="legal_case legislation bill" match="none"> + <choose> + <if variable="URL"> + <group delimiter=" "> + <text variable="URL" prefix="<" suffix=">"/> + <group delimiter=" "> + <text term="accessed"/> + <date variable="accessed" form="text"/> + </group> + </group> + </if> + </choose> + </if> + </choose> + </macro> + <macro name="author-count"> + <names variable="author"> + <name form="count"/> + <substitute> + <names variable="editor"/> + </substitute> + </names> + </macro> + <macro name="sort-type"> + <!--This should just sort secondary sources first. I'm leaving the rest from AGLC for simplicity--> + <choose> + <if type="book chapter paper-conference article-magazine article-newspaper article-journal report speech entry-encyclopedia" match="any"> + <text value="1"/> + </if> + <else-if type="legal_case"> + <text value="2"/> + <text variable="title"/> + </else-if> + <else-if type="bill legislation" match="any"> + <text value="3"/> + <choose> + <if type="legislation"> + <text variable="title"/> + </if> + </choose> + </else-if> + <else-if type="manuscript"> + <!--Manuscript here as a stand-in for Treaty. Not perfect --> + <text value="4"/> + </else-if> + <else> + <text value="1"/> + </else> + </choose> + </macro> + <citation et-al-min="4" et-al-use-first="1"> + <layout suffix="." delimiter="; "> + <choose> + <if position="subsequent"> + <choose> + <if type="legal_case bill legislation manuscript" match="any"> + <!--don't use short form and above note for legal citations --> + <group delimiter=" "> + <text macro="author-note"/> + <text macro="title-short"/> + <text macro="looseleaf-note"/> + <text variable="first-reference-note-number" prefix="(n " suffix=")"/> + <text macro="locator-space"/> + </group> + </if> + <else> + <group delimiter=" "> + <group delimiter=", "> + <text macro="author-short"/> + <choose> + <if disambiguate="true"> + <text macro="title-short"/> + </if> + </choose> + </group> + <text variable="first-reference-note-number" prefix="(n " suffix=")"/> + <text variable="locator"/> + </group> + </else> + </choose> + </if> + <else> + <!--general whole citation --> + <group delimiter=" "> + <group delimiter=", "> + <group delimiter=" "> + <group delimiter=", "> + <text macro="author-note"/> + <group> + <text macro="title"/> + <text macro="book-container"/> + </group> + <text macro="broadcast-container"/> + <text macro="volume-book"/> + <text macro="looseleaf-note"/> + </group> + <group delimiter=" "> + <text macro="date-parenthesis"/> + <text macro="bill-number"/> + <text macro="article-case-info"/> + <text macro="publisher"/> + </group> + </group> + <text macro="manuscript-catchall"/> + </group> + <group delimiter=", "> + <group delimiter=" "> + <text macro="page-first"/> + <text macro="court"/> + <text macro="locator-space"/> + </group> + <text macro="locator-comma"/> + </group> + <text macro="URL"/> + </group> + </else> + </choose> + </layout> + </citation> + <bibliography et-al-min="4" et-al-use-first="1" subsequent-author-substitute="——"> + <sort> + <key macro="sort-type"/> + <key macro="author" names-min="1" names-use-first="1"/> + <key macro="author-count" names-min="2" names-use-first="2"/> + <key macro="author"/> + <key variable="issued"/> + <key variable="title"/> + </sort> + <layout> + <group delimiter=" "> + <group delimiter=", "> + <group delimiter=" "> + <group delimiter=", "> + <text macro="author"/> + <group> + <text macro="title"/> + <text macro="book-container"/> + </group> + <text macro="broadcast-container"/> + <text macro="volume-book"/> + <text macro="looseleaf-note"/> + </group> + <group delimiter=" "> + <text macro="date-parenthesis"/> + <text macro="bill-number"/> + <text macro="article-case-info"/> + <text macro="publisher"/> + </group> + </group> + <text macro="manuscript-catchall"/> + </group> + <group delimiter=" "> + <text macro="page-first"/> + <text macro="court"/> + </group> + <text macro="URL"/> + </group> + </layout> + </bibliography> +</style> @@ -35,6 +35,38 @@ pandoc_filter sub { '@'.$1.'{'.$id, @data, '}'); + if ( ! $bibdata->get('author') ) { + my @authors; + for ( my $i = 1;; $i++ ) { + my ( $first, $last ); + if ( $i == 1 and $bibdata->get('first') ) { + $first = $bibdata->get("first$i"); + $bibdata->delete("first$i"); + } elsif ( $bibdata->get("first$i") ) { + $first = $bibdata->get('first'); + $bibdata->delete('first'); + } + if ( $i == 1 and $bibdata->get('last') ) { + $last = $bibdata->get('last'); + $bibdata->delete('last'); + } elsif ( $bibdata->get("last$i") ) { + $last = $bibdata->get("last$i"); + $bibdata->delete("last$i"); + } + if ( $first and $last ) { + push @authors, "$first {$last}"; + } elsif ($first) { + push @authors, $first; + } elsif ($last) { + push @authors, $last; + } else { + last; + } + } + if ( @authors > 0 ) { + $bibdata->set( 'author', join ( ' and ', @authors ) ); + }; + }; if ( $bibdata->type =~ /web/i ) { $bibdata->set_type('online'); if ( my $urldate = $bibdata->get('accessdate') ) { |