summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile1
-rw-r--r--oscola-no-ibid.csl683
-rwxr-xr-xpandoc-cs132
3 files changed, 716 insertions, 0 deletions
diff --git a/Makefile b/Makefile
index 3912400..b2178d7 100644
--- a/Makefile
+++ b/Makefile
@@ -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="&lt;" suffix="&gt;"/>
+ <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="&#8212;&#8212;">
+ <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>
diff --git a/pandoc-cs1 b/pandoc-cs1
index 0eafbc3..e5620c9 100755
--- a/pandoc-cs1
+++ b/pandoc-cs1
@@ -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') ) {