Cleaning up indentation and whitespace
authorHeikki Levanto <heikki@indexdata.dk>
Thu, 7 May 2015 12:31:51 +0000 (14:31 +0200)
committerHeikki Levanto <heikki@indexdata.dk>
Thu, 7 May 2015 12:31:51 +0000 (14:31 +0200)
bibframe/triplestore.xml

index 40912c5..1c1d739 100644 (file)
 ]>
 
 <filters  xmlns="http://indexdata.com/metaproxy">
-  <filter type="sparql">
-      <!-- Which sparql server to use, our demo, or your local installation -->
-    <!--defaults uri="http://bibframe.indexdata.com/sparql/"/-->
-    <defaults uri="http://localhost:8890/sparql/"/>
-
-    <!-- work database -->
-    <db path="work" schema="sparql-results">
-      <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
-      <prefix>bf: http://bibframe.org/vocab/</prefix>
-      <!-- The search clause just finds ?works, present is done below -->
-      <form>SELECT DISTINCT ?work </form>
-      <criteria>?work a bf:Work</criteria>
-
-      <!-- bf.uri is a simple way to get to a work -->
-      <index type="bf.uri"> ?work a bf:Work FILTER( ?work  = %u ) </index>
-
-      <!-- Title indexes -->
-      <!-- These are messy, there are so many ways to get to a title -->
-
-      <!-- Main title. Looks logical, but in practice we have seen only a very
-      small number of these -->
-      <index type="bf.title">
-            ?work bf:title %v FILTER(contains(%v, %s))
-      </index>
-
-      <!-- worktitle seems to be the most common way to store the title of a work -->
-      <index type="bf.worktitle">
-          ?work bf:workTitle ?wt .
-          ?wt bf:titleValue %v FILTER(contains(%v, %s))
-      </index>
-
-      <!-- Combining the two above, since users are not likely to know how
-      a given title has been indexed -->
-      <index type="bf.maintitle">
-          { 
-            ?work bf:workTitle ?wt .
-            ?wt bf:titleValue %v FILTER(contains(%v, %s))
-          } UNION {
-            ?work bf:title %v FILTER(contains(%v, %s))
-          }
-      </index>
-
-
-      <!-- the worktitle can also contain a subtitle and a parttitle -->
-      <index type="bf.subtitle">?work bf:workTitle ?wt .
-          ?wt bf:subtitle %v FILTER(contains(%v, %s))
-      </index>
-
-      <index type="bf.parttitle">
-          ?work bf:workTitle ?wt .
-          ?wt bf:partTitle %v FILTER(contains(%v, %s))
-      </index>
-
-      <!-- work.titlevariation - this could also have sub- and partTitles -->
-      <index type="bf.titlevariation">
-          ?work bf:titleVariation ?tv .
-          ?tv bf:titleValue %v FILTER(contains(%v, %s))
-      </index>
-
-      <!-- Instance titles -->
-      <index type="bf.instancetitle">
-          ?inst bf:instanceOf ?work .
-          ?inst bf:instanceTitle ?it .
-          ?it bf:titleValue %v FILTER(contains(%v, %s))
-      </index>
-
-      <!-- Combined title index. There are so many ways titles can be expresses
-      in Bibframe, this seems to cover most of what we have seen -->
-      <index type="bf.anytitle">
-          { ?work bf:workTitle ?wt .
-              { ?wt bf:titleValue %v FILTER(contains(%v, %s)) } UNION
-              { ?wt bf:subtitle %v FILTER(contains(%v, %s)) } UNION
-              { ?wt bf:partTitle %v FILTER(contains(%v, %s)) }
-          } UNION {
-              ?work bf:titleVariation ?tv .
-              ?tv bf:titleValue %v FILTER(contains(%v, %s)) 
-          } UNION {
-              ?inst bf:instanceOf ?work .
-              ?inst bf:instanceTitle ?it .
-              ?it bf:titleValue %v FILTER(contains(%v, %s))
-          } UNION {
-              ?work bf:title %v FILTER(contains(%v, %s))
-          }
-      </index>
-
-      <!-- Author indexes. Much simpler than titles. -->
-      <index type="bf.creator">
-          ?work bf:creator ?c .
-          ?c bf:label %v FILTER(contains(%v, %s))
-      </index>
-
-      <index type="bf.contributor">
-          ?work bf:contributor ?c .
-          ?c bf:label %v FILTER(contains(%v, %s))
-      </index>
-
-      <index type="bf.anyauthor">
-          {
-            ?work bf:creator ?c .
-            ?c bf:label %v FILTER(contains(%v, %s))
-          } UNION {
-            ?work bf:contributor ?c .
-            ?c bf:label %v FILTER(contains(%v, %s))
-          }
-      </index>
-
-      <!-- Subjects -->
-      <index type="bf.subject">
-          ?work bf:subject ?subject .
-          ?subject bf:label %v FILTER(contains(%v, %s))
-      </index>
-
-      <!-- Indexes for persons, organizations, etc -->
-      <!-- The person (etc) may be in any relation to the work, subject,
-      creator, etc, as long as there is a direct link -->
-      <index type="bf.person">
-          ?work ?rel ?person .
-          ?person a bf:Person .
-          ?person bf:label %v FILTER(contains(%v, %s))
-      </index>
-      <!-- TODO - make many more like the person above -->
-
-      <!-- Present formats -->
-      <!-- BF-L is just the links -->
-      <present type="BF-L">
-        CONSTRUCT { ?work ?rel ?subj }
-         WHERE {
-         ?work a bf:Work .
-         ?work ?rel ?subj .
-         ?work ?rel ?subj FILTER( str(?work) = %s )
-        }
-      </present>
-
-      <!-- BF-F expands all links, except to instances and other works -->
-      <present type="BF-F"> 
-        CONSTRUCT { ?work ?rel ?obj .
+    <filter type="sparql">
+
+        <!-- Which sparql server to use, our demo, or your local installation -->
+        <!--defaults uri="http://bibframe.indexdata.com/sparql/"/-->
+        <defaults uri="http://localhost:8890/sparql/"/>
+
+        <!-- work database -->
+
+        <db path="work" schema="sparql-results">
+            <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
+            <prefix>bf: http://bibframe.org/vocab/</prefix>
+
+            <!-- The search clause just finds ?works, present is done below -->
+            <form>SELECT DISTINCT ?work </form>
+            <criteria>?work a bf:Work</criteria>
+
+            <!-- bf.uri is a simple way to get to a work -->
+            <index type="bf.uri"> ?work a bf:Work FILTER( ?work  = %u ) </index>
+
+            <!-- Title indexes -->
+            <!-- These are messy, there are so many ways to get to a title -->
+
+            <!-- Main title. Looks logical, but in practice we have not seen -->
+            <!-- many of these -->
+            <index type="bf.title">
+                    ?work bf:title %v FILTER(contains(%v, %s))
+            </index>
+
+            <!-- worktitle.titleValue seems to be the most common way to -->
+            <!-- store the title of a work -->
+            <index type="bf.worktitle">
+                ?work bf:workTitle ?wt .
+                ?wt bf:titleValue %v FILTER(contains(%v, %s))
+            </index>
+
+            <!-- Combining the two above, since users are not likely -->
+            <!-- to know how a given title has been indexed -->
+            <!-- TODO is "maintitle" a good name for this? I made it up myself -->
+            <index type="bf.maintitle">
+                {
+                    ?work bf:workTitle ?wt .
+                    ?wt bf:titleValue %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?work bf:title %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+            <!-- the worktitle can also contain a subtitle and a parttitle -->
+            <index type="bf.subtitle">?work bf:workTitle ?wt .
+                ?wt bf:subtitle %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.parttitle">
+                ?work bf:workTitle ?wt .
+                ?wt bf:partTitle %v FILTER(contains(%v, %s))
+            </index>
+
+            <!-- work.titlevariation - this could also have sub- and partTitles -->
+            <index type="bf.titlevariation">
+                ?work bf:titleVariation ?tv .
+                ?tv bf:titleValue %v FILTER(contains(%v, %s))
+            </index>
+
+            <!-- Instance titles -->
+            <index type="bf.instancetitle">
+                ?inst bf:instanceOf ?work .
+                ?inst bf:instanceTitle ?it .
+                ?it bf:titleValue %v FILTER(contains(%v, %s))
+            </index>
+
+            <!-- Combined title index. There are so many ways titles can be expresses
+            in Bibframe, this seems to cover most of what we have seen -->
+            <!-- TODO - See the anytitle in instance for a more flexible way -->
+            <index type="bf.anytitle">
+                {
+                    ?work bf:workTitle ?wt .
+                    { ?wt bf:titleValue %v FILTER(contains(%v, %s)) } UNION
+                    { ?wt bf:subtitle %v FILTER(contains(%v, %s)) } UNION
+                    { ?wt bf:partTitle %v FILTER(contains(%v, %s)) }
+                } UNION {
+                    ?work bf:titleVariation ?tv .
+                    ?tv bf:titleValue %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?inst bf:instanceOf ?work .
+                    ?inst bf:instanceTitle ?it .
+                    ?it bf:titleValue %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?work bf:title %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+            <!-- Author indexes. Much simpler than titles. -->
+            <index type="bf.creator">
+                ?work bf:creator ?c .
+                ?c bf:label %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.contributor">
+                ?work bf:contributor ?c .
+                ?c bf:label %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.anyauthor"> <!-- TODO - Is this a good name? -->
+                {
+                    ?work bf:creator ?c .
+                    ?c bf:label %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?work bf:contributor ?c .
+                    ?c bf:label %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+            <!-- Subjects -->
+            <!-- Note that these refer to anything with a bf:subject relation -->
+            <!-- The actual item is likely to be something like topic person etc -->
+            <index type="bf.subject">
+                ?work bf:subject ?subject .
+                ?subject bf:label %v FILTER(contains(%v, %s))
+            </index>
+
+            <!-- Indexes for persons, organizations, etc -->
+            <!-- The person (etc) may be in any relation to the work, -->
+            <!-- subject, creator, etc, as long as there is a direct link -->
+            <index type="bf.person">
+                ?work ?rel ?person .
+                ?person a bf:Person .
+                ?person bf:label %v FILTER(contains(%v, %s))
+            </index>
+            <!-- TODO - make many more like the person above -->
+
+            <!-- Present formats -->
+            <!-- BF-L is just the links -->
+            <present type="BF-L">
+                CONSTRUCT {
+                    ?work ?rel ?subj
+                }
+                WHERE {
+                    ?work a bf:Work .
+                    ?work ?rel ?subj .
+                    ?work ?rel ?subj FILTER( str(?work) = %s )
+                }
+            </present>
+
+            <!-- BF-F expands all links, except to instances and other works -->
+            <present type="BF-F">
+                CONSTRUCT {
+                    ?work ?rel ?obj .
                     ?obj ?rel1 ?obj1 .
                     ?obj1 ?rel2 ?obj2 .
-                    ?obj2 ?rel3 ?obj3 }
-         WHERE {
-         ?work a bf:Work .
-         ?work ?rel ?obj .
-        OPTIONAL { 
-          ?obj ?rel1 ?obj1  
-            MINUS { ?obj a bf:Work } 
-            MINUS { ?obj a bf:Instance }
-            }
-        OPTIONAL {
-          ?obj1 ?rel2 ?obj2 
-            MINUS { ?obj1 a bf:Work } 
-            MINUS { ?obj1 a bf:Instance }
-            } 
-        OPTIONAL { 
-          ?obj2 ?rel3 ?obj3 
-            MINUS { ?obj2 a bf:Work } 
-            MINUS { ?obj2 a bf:Instance }
-            }
-         ?work ?rel ?obj FILTER( str(?work) = %s )
-        }
-      </present>
-
-      <!-- full, with instances. Experimental! -->
-      <present type="BF-FI">  
-        CONSTRUCT { %u ?rel ?wobj1 .
+                    ?obj2 ?rel3 ?obj3
+                }
+                WHERE {
+                    &workfull; <!-- This does not seem to get expanded!! TODO -->
+
+                    ?work a bf:Work .
+                    ?work ?rel ?obj .
+                    OPTIONAL {
+                        ?obj ?rel1 ?obj1
+                        MINUS { ?obj a bf:Work }
+                        MINUS { ?obj a bf:Instance }
+                    }
+                    OPTIONAL {
+                        ?obj1 ?rel2 ?obj2
+                        MINUS { ?obj1 a bf:Work }
+                        MINUS { ?obj1 a bf:Instance }
+                    }
+                    OPTIONAL {
+                        ?obj2 ?rel3 ?obj3
+                        MINUS { ?obj2 a bf:Work }
+                        MINUS { ?obj2 a bf:Instance }
+                    }
+                    ?work ?rel ?obj FILTER( str(?work) = %s )
+                    <!-- TODO Use the %u -->
+                    <!-- TODO Use the BF-FI as the BF-F -->
+                }
+            </present>
+
+            <!-- full, with instances. Experimental! -->
+            <present type="BF-FI">
+                CONSTRUCT {
+                    %u ?rel ?wobj1 .
                     ?wobj1 ?wrel1 ?wobj2 .
                     ?wobj2 ?wrel2 ?wobj3 .
                     ?inst ?irel1 ?iobj1 .
                     ?iobj1 ?irel2 ?iobj2 .
-                    ?iobj2 ?irel3 ?iobj3 }
-         WHERE {
-          %u a bf:Work .
-          %u ?rel ?wobj1 .
-          OPTIONAL { <!-- note, this is not in the final construct
-          the linking triplet will get included like any others -->
-            ?inst bf:instanceOf %u
-          } 
-          &workfull; <!-- This does not seem to get expanded!! TODO -->
-          OPTIONAL {
-              ?wobj ?wrel1 ?wobj1
-              MINUS { ?wobj a bf:Work }
-              MINUS { ?wobj a bf:Instance }
-          }
-          OPTIONAL {
-              ?wobj1 ?wrel2 ?wobj2
-              MINUS { ?wobj1 a bf:Work }
-              MINUS { ?wobj1 a bf:Instance }
-          }
-          OPTIONAL {
-              ?wobj2 ?wrel3 ?wobj3
-              MINUS { ?wobj2 a bf:Work }
-              MINUS { ?wobj2 a bf:Instance }
-          }
-          <!--&instfull; -->
-          OPTIONAL {
-            ?inst ?irel1 ?iobj1
-          }
-          OPTIONAL {
-            ?iobj1 ?irel2 ?iobj2
-          }
-          OPTIONAL {
-            ?iobj2 ?irel3 ?iobj3
-          }
+                    ?iobj2 ?irel3 ?iobj3
+                }
+                WHERE {
+                    %u a bf:Work .
+                    %u ?rel ?wobj1 .
 
-        }
-      </present>
-    </db>
-    
-    <!-- Instance database -->
-
-    <db path="instance" schema="sparql-results">
-        <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
-        <prefix>bf: http://bibframe.org/vocab/</prefix>
-        <!-- The search clause just finds ?insts, present is done below -->
-        <form>SELECT DISTINCT ?inst </form>
-        <criteria>?inst a bf:Instance</criteria>
-
-        <!-- bf.uri is a simple way to get to a work -->
-        <index type="bf.uri"> ?inst a bf:Instance FILTER( ?inst  = %u ) </index>
-
-        <!-- Title indexes -->
-        <!-- These are messy, there are so many ways to get to a title -->
-
-        <!-- Main title. Looks logical. Many instances seem to have a title -->
-        <index type="bf.title">
-            ?inst bf:title %v FILTER(contains(%v, %s))
-        </index>
-
-        <!-- instancetitle is also pretty common -->
-        <index type="bf.instancetitle">
-            ?inst bf:instanceTitle ?it .
-            ?it bf:titleValue %v FILTER(contains(%v, %s))
-        </index>
-        
-        <index type="bf.titlestatement">
-            ?inst bf:titleStatement %v FILTER(contains(%v, %s))
-        </index>
-                
-        <!-- Combining the two above, since users are not likely to know how
-        a given title has been indexed -->
-        <index type="bf.maintitle">
-            { 
-                ?inst bf:instanceTitle ?it .
-                ?it bf:titleValue %v FILTER(contains(%v, %s))
-            } UNION {
-                ?inst bf:title %v FILTER(contains(%v, %s))
-            }
-        </index>
+                    OPTIONAL {
+                        ?wobj ?wrel1 ?wobj1
+                        MINUS { ?wobj a bf:Work }
+                        MINUS { ?wobj a bf:Instance }
+                    }
+                    OPTIONAL {
+                        ?wobj1 ?wrel2 ?wobj2
+                        MINUS { ?wobj1 a bf:Work }
+                        MINUS { ?wobj1 a bf:Instance }
+                    }
+                    OPTIONAL {
+                        ?wobj2 ?wrel3 ?wobj3
+                        MINUS { ?wobj2 a bf:Work }
+                        MINUS { ?wobj2 a bf:Instance }
+                    }
+
+                    <!-- Link to the instance(s) -->
+                    OPTIONAL {
+                        ?inst bf:instanceOf %u
+                    }
+                    <!-- and expand the instance -->
+                    OPTIONAL {
+                        ?inst ?irel1 ?iobj1
+                    }
+                    OPTIONAL {
+                        ?iobj1 ?irel2 ?iobj2
+                    }
+                    OPTIONAL {
+                        ?iobj2 ?irel3 ?iobj3
+                    }
+                }
+            </present>
+        </db>
+
+        <!-- Instance database -->
 
+        <db path="instance" schema="sparql-results">
+            <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
+            <prefix>bf: http://bibframe.org/vocab/</prefix>
+            <!-- The search clause just finds ?insts, present is done below -->
+            <form>SELECT DISTINCT ?inst </form>
+            <criteria>?inst a bf:Instance</criteria>
 
-        <!-- the instancetitle can also contain a subtitle and a parttitle -->
-        <index type="bf.subtitle">
-            ?inst bf:instanceTitle ?it .
-            ?it bf:subtitle %v FILTER(contains(%v, %s))
-        </index>
+            <!-- bf.uri is a simple way to get to a work -->
+            <index type="bf.uri">
+                ?inst a bf:Instance FILTER( ?inst  = %u )
+            </index>
 
-        <index type="bf.parttitle">
-            ?inst bf:instanceTitle ?it .
-            ?it bf:partTitle %v FILTER(contains(%v, %s))
-        </index>
-        <!-- We could also go to the works, and get those titles... -->
+            <!-- Title indexes -->
+            <!-- These are messy, there are so many ways to get to a title -->
 
-        <!-- Combining any kind of title into one index -->
-        <index type="bf.anytitle">
-            {
+            <!-- Main title. Looks logical. Many instances seem to have a title -->
+            <index type="bf.title">
                 ?inst bf:title %v FILTER(contains(%v, %s))
-            } UNION {
+            </index>
+
+            <!-- instancetitle is also pretty common -->
+            <index type="bf.instancetitle">
+                ?inst bf:instanceTitle ?it .
+                ?it bf:titleValue %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.titlestatement">
                 ?inst bf:titleStatement %v FILTER(contains(%v, %s))
-            } UNION {
-                ?inst ?titlerel ?it . <!-- any kind of link -->
-                ?it a bf:Title <!-- to something that is a title -->
-                { 
+            </index>
+
+            <!-- Combining the two above, since users are not likely to know how
+            a given title has been indexed -->
+            <index type="bf.maintitle">
+                {
+                    ?inst bf:instanceTitle ?it .
                     ?it bf:titleValue %v FILTER(contains(%v, %s))
                 } UNION {
-                    ?it bf:partTitle %v FILTER(contains(%v, %s))
+                    ?inst bf:title %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+
+            <!-- the instancetitle can also contain a subtitle and a parttitle -->
+            <index type="bf.subtitle">
+                ?inst bf:instanceTitle ?it .
+                ?it bf:subtitle %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.parttitle">
+                ?inst bf:instanceTitle ?it .
+                ?it bf:partTitle %v FILTER(contains(%v, %s))
+            </index>
+            <!-- We could also go to the works, and get those titles... -->
+
+            <!-- Combining any kind of title into one index -->
+            <index type="bf.anytitle">
+                {
+                    ?inst bf:title %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?inst bf:titleStatement %v FILTER(contains(%v, %s))
                 } UNION {
-                    ?it bf:subtitle %v FILTER(contains(%v, %s))
+                    ?inst ?titlerel ?it . <!-- any kind of link -->
+                    ?it a bf:Title <!-- to something that is a title -->
+                    {
+                        ?it bf:titleValue %v FILTER(contains(%v, %s))
+                    } UNION {
+                        ?it bf:partTitle %v FILTER(contains(%v, %s))
+                    } UNION {
+                        ?it bf:subtitle %v FILTER(contains(%v, %s))
+                    }
                 }
-            }
-        </index>
-        
-        <!-- Author indexes. Many instances don't have any, works do -->
-        <index type="bf.creator">
-            ?inst bf:creator ?c .
-            ?c bf:label %v FILTER(contains(%v, %s))
-        </index>
-
-        <index type="bf.workcreator">
-            ?inst bf:instanceOf ?work .
-            ?work bf:creator ?c .
-            ?c bf:label %v FILTER(contains(%v, %s))
-        </index>
-
-        <index type="bf.workcontributor">
-            ?inst bf:instanceOf ?work .
-            ?work bf:contributor ?c .
-            ?c bf:label %v FILTER(contains(%v, %s))
-        </index>
-
-        <index type="bf.contributor">
-            ?inst bf:contributor ?c .
-            ?c bf:label %v FILTER(contains(%v, %s))
-        </index>
-
-        <index type="bf.anyauthor">
-            {
+            </index>
+
+            <!-- Author indexes. Many instances don't have any, works do -->
+            <index type="bf.creator">
                 ?inst bf:creator ?c .
                 ?c bf:label %v FILTER(contains(%v, %s))
-            } UNION {
-                ?inst bf:contributor ?c .
-                ?c bf:label %v FILTER(contains(%v, %s))
-            } UNION {
+            </index>
+
+            <index type="bf.workcreator">
                 ?inst bf:instanceOf ?work .
                 ?work bf:creator ?c .
                 ?c bf:label %v FILTER(contains(%v, %s))
-            } UNION {
+            </index>
+
+            <index type="bf.workcontributor">
                 ?inst bf:instanceOf ?work .
                 ?work bf:contributor ?c .
                 ?c bf:label %v FILTER(contains(%v, %s))
-            } 
-        </index>
-
-        <!-- BF-L is just the links -->
-        <present type="BF-L">
-            CONSTRUCT { ?inst ?rel ?subj }
-            WHERE {
-            ?inst a bf:Instance .
-            ?inst ?rel ?subj .
-            ?inst ?rel ?subj FILTER( str(?inst) = %s )
-            }
-        </present>
-
-        <!-- Full instance, with the related work too -->
-        <present type="BF-F">  
-            CONSTRUCT { 
-                %u ?irel1 ?iobj1 .
-                ?iobj1 ?irel2 ?iobj2 .
-                ?iobj2 ?irel3 ?iobj3 .
-                ?work ?wrel1 ?wobj1 .
-                ?wobj1 ?wrel2 ?wobj2 .
-                ?wobj2 ?wrel3 ?wobj3
-            }
-            WHERE {
-                %u a bf:Instance .
-                %u ?irel1 ?iobj1
-                OPTIONAL {
-                    ?iobj1 ?irel2 ?iobj2
-                    MINUS { ?iobj1 a bf:Work }
-                    MINUS { ?iobj1 a bf:Instance }
+            </index>
+
+            <index type="bf.contributor">
+                ?inst bf:contributor ?c .
+                ?c bf:label %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.anyauthor">
+                {
+                    ?inst bf:creator ?c .
+                    ?c bf:label %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?inst bf:contributor ?c .
+                    ?c bf:label %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?inst bf:instanceOf ?work .
+                    ?work bf:creator ?c .
+                    ?c bf:label %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?inst bf:instanceOf ?work .
+                    ?work bf:contributor ?c .
+                    ?c bf:label %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+            <!-- BF-L is just the links -->
+            <present type="BF-L">
+                CONSTRUCT {
+                    ?inst ?rel ?subj
+                }
+                WHERE {
+                    ?inst a bf:Instance .
+                    ?inst ?rel ?subj .
+                    ?inst ?rel ?subj FILTER( str(?inst) = %s )
+                }
+            </present>
+
+            <!-- Full instance, with the related work too -->
+            <present type="BF-F">
+                CONSTRUCT {
+                    %u ?irel1 ?iobj1 .
+                    ?iobj1 ?irel2 ?iobj2 .
+                    ?iobj2 ?irel3 ?iobj3 .
+                    ?work ?wrel1 ?wobj1 .
+                    ?wobj1 ?wrel2 ?wobj2 .
+                    ?wobj2 ?wrel3 ?wobj3
+                }
+                WHERE {
+                    %u a bf:Instance .
+                    %u ?irel1 ?iobj1
                     OPTIONAL {
-                        ?iobj2 ?irel3 ?iobj3
-                        MINUS { ?iobj2 a bf:Work }
-                        MINUS { ?iobj2 a bf:Instance }
+                        ?iobj1 ?irel2 ?iobj2
+                        MINUS { ?iobj1 a bf:Work }
+                        MINUS { ?iobj1 a bf:Instance }
+                        OPTIONAL {
+                            ?iobj2 ?irel3 ?iobj3
+                            MINUS { ?iobj2 a bf:Work }
+                            MINUS { ?iobj2 a bf:Instance }
+                        }
                     }
-                }
 
-                OPTIONAL {
-                    %u bf:instanceOf ?work
                     OPTIONAL {
-                        ?work ?wrel1 ?wobj1
-                        MINUS { ?wobj1 a bf:Work }
-                        MINUS { ?wobj1 a bf:Instance }
+                        %u bf:instanceOf ?work
                         OPTIONAL {
-                            ?wobj1 ?wrel2 ?wobj2
-                            MINUS { ?wobj2 a bf:Work }
-                            MINUS { ?wobj2 a bf:Instance }
+                            ?work ?wrel1 ?wobj1
+                            MINUS { ?wobj1 a bf:Work }
+                            MINUS { ?wobj1 a bf:Instance }
                             OPTIONAL {
-                                ?wobj2 ?wrel3 ?wobj3
-                                MINUS { ?wobj3 a bf:Work }
-                                MINUS { ?wobj3 a bf:Instance }
+                                ?wobj1 ?wrel2 ?wobj2
+                                MINUS { ?wobj2 a bf:Work }
+                                MINUS { ?wobj2 a bf:Instance }
+                                OPTIONAL {
+                                    ?wobj2 ?wrel3 ?wobj3
+                                    MINUS { ?wobj3 a bf:Work }
+                                    MINUS { ?wobj3 a bf:Instance }
+                                }
                             }
                         }
                     }
                 }
-            }
-        </present>
-
-    </db>
-
-    <!-- Small databases -->
-
-    <!-- "small" contains all the things common to all small databases -->
-    <!-- It is only to be used as an include, it is not searchable, since -->
-    <!-- it has no schema atribute -->
-    <!-- It is divided into "smallindex", "smallbody", and a "small" that includes
-    both, so that title searches can include the body, but have different indexes -->
-    
-    <db path="smallindex">
-      <index type="any">?thing bf:label %v FILTER(contains(%v, %s))</index>
-      <index type="1016">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-
-    <db path="smallbody">
-      <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
-      <prefix>bf: http://bibframe.org/vocab/</prefix>
-      <form>SELECT DISTINCT ?thing </form>
-      <criteria>?thing ?rel ?obj</criteria>
-      <present type="BF-L">
-        CONSTRUCT { %u ?rel ?obj }
-         WHERE {
-           %u ?rel ?obj .
-         }
-      </present>
-      <!-- Experimental, to get just the URIs out, in proper rdf. Probably not useful 
-      <uri type="BF-U">
-        CONSTRUCT { %u bf:uri %u }
-         WHERE {
-           %u bf:label ?lbl .
-         }
-      </uri>
-      -->
-      <present type="BF-F">
-          <!-- I don't think we need more than one level for these simple 
-          databases -->
-        CONSTRUCT { %u ?rel ?obj . 
+            </present>
+
+        </db>
+
+        <!-- Small databases -->
+
+        <!-- "small" contains all the things common to all small databases -->
+        <!-- It is only to be used as an include, it is not searchable, since -->
+        <!-- it has no schema atribute -->
+        <!-- It is divided into "smallindex", "smallbody", and a "small" that includes
+        both, so that title searches can include the body, but have different indexes -->
+
+        <db path="smallindex">
+            <index type="any">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+            <index type="1016">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="smallbody">
+            <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
+            <prefix>bf: http://bibframe.org/vocab/</prefix>
+            <form>SELECT DISTINCT ?thing </form>
+            <criteria>?thing ?rel ?obj</criteria>
+            <present type="BF-L">
+                CONSTRUCT {
+                    %u ?rel ?obj
+                }
+                WHERE {
+                    %u ?rel ?obj .
+                }
+            </present>
+            <present type="BF-F">
+                <!-- I don't think we need more than one level -->
+                <!--for these simple databases -->
+                CONSTRUCT {
+                    %u ?rel ?obj .
                     ?obj ?rel1 ?obj1 .
-                  }
-         WHERE {
-           %u ?rel ?obj .
-           OPTIONAL { ?obj ?rel1 ?obj1 }
-         }
-      </present>
-    </db>
-    <db path="small" include="smallindex smallbody"/>
-    
-    <db path="place" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Place</criteria>
-      <index type="bf.place">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-    <db path="person" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Person</criteria>
-      <index type="bf.person">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-    <db path="meeting" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Meeting</criteria>
-      <index type="bf.meeting">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-    <db path="agent" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Agent</criteria>
-      <index type="bf.agent">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-    <db path="event" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Event</criteria>
-      <index type="bf.event">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-    <db path="organization" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Organization</criteria>
-      <index type="bf.organization">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-    <db path="topic" schema="sparql-results" include="small" >
-      <criteria>?thing a bf:Topic</criteria>
-      <index type="bf.topic">?thing bf:label %v FILTER(contains(%v, %s))</index>
-    </db>
-
-    <!-- Title search, probably not needed. -->
-    <db path="title" schema="sparql-results" include="smallbody" >
-      <criteria>?thing a bf:Title</criteria>
-      <index type="any">
-           { ?thing bf:titleValue %v FILTER(contains(%v, %s)) } UNION
-           { ?thing bf:subtitle %v FILTER(contains(%v, %s)) } UNION
-           { ?thing bf:partTitle %v FILTER(contains(%v, %s)) } 
-      </index>
-      <index type="1016">
-           { ?thing bf:titleValue %v FILTER(contains(%v, %s)) } UNION
-           { ?thing bf:subtitle %v FILTER(contains(%v, %s)) } UNION
-           { ?thing bf:partTitle %v FILTER(contains(%v, %s)) } 
-      </index>
-      <index type="bf.title">?thing bf:titleValue %v FILTER(contains(%v, %s))</index>
-      <index type="bf.subtitle">?thing bf:subtitle %v FILTER(contains(%v, %s))</index>
-      <index type="bf.parttitle">?thing bf:partTitle %v FILTER(contains(%v, %s))</index>
-    </db>
-
-    <!-- A hack to be able to look at any triplet in the base -->
-    <!-- TODO - Switch to the new system, probably using "small" -->
-    <db path="node" schema="sparql-results">
-      <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
-      <prefix>bf: http://bibframe.org/vocab/</prefix>
-      <form>SELECT ?node ?rel ?obj</form>
-      <index type="any">?node ?rel ?obj FILTER( str(?node) = %s )</index>
-    </db>
-    <!-- A way to see which triplets refers to a given uri. -->
-    <!-- TODO - Switch to the new system, probably using "small" -->
-    <db path="ref" schema="sparql-results">
-      <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
-      <prefix>bf: http://bibframe.org/vocab/</prefix>
-      <form>SELECT ?node ?rel ?obj</form>
-      <index type="any">?node ?rel ?obj FILTER( str(?obj) = %s )</index>
-    </db>
-  </filter>
-  <filter type="log">
-    <message>http</message>
-    <category apdu="true"/>
-  </filter>
-  <filter type="http_client">
-    <x-forwarded-for>true</x-forwarded-for>
-  </filter>
+                }
+                WHERE {
+                    %u ?rel ?obj .
+                    OPTIONAL { ?obj ?rel1 ?obj1 }
+                }
+            </present>
+        </db>
+
+        <!-- The combined "small" database defaults -->
+        <db path="small" include="smallindex smallbody"/>
+
+        <!-- Various "small" databases, leaning heavily on the defaults above -->
+        <db path="place" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Place</criteria>
+            <index type="bf.place">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="person" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Person</criteria>
+            <index type="bf.person">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="meeting" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Meeting</criteria>
+            <index type="bf.meeting">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="agent" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Agent</criteria>
+            <index type="bf.agent">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="event" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Event</criteria>
+            <index type="bf.event">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="organization" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Organization</criteria>
+            <index type="bf.organization">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <db path="topic" schema="sparql-results" include="small" >
+            <criteria>?thing a bf:Topic</criteria>
+            <index type="bf.topic">
+                ?thing bf:label %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <!-- Title search, for seatching Title objects. -->
+        <!-- Not sure if this is needed, but it is a nice example -->
+        <db path="title" schema="sparql-results" include="smallbody" >
+            <criteria>?thing a bf:Title</criteria>
+
+            <index type="any">
+                {
+                    ?thing bf:titleValue %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?thing bf:subtitle %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?thing bf:partTitle %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+            <index type="1016">
+                {
+                    ?thing bf:titleValue %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?thing bf:subtitle %v FILTER(contains(%v, %s))
+                } UNION {
+                    ?thing bf:partTitle %v FILTER(contains(%v, %s))
+                }
+            </index>
+
+            <index type="bf.title">
+                ?thing bf:titleValue %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.subtitle">
+                ?thing bf:subtitle %v FILTER(contains(%v, %s))
+            </index>
+
+            <index type="bf.parttitle">
+                ?thing bf:partTitle %v FILTER(contains(%v, %s))
+            </index>
+        </db>
+
+        <!-- A hack to be able to look at any triplet in the base -->
+        <!-- TODO - Switch to the new system, probably using "small" -->
+        <db path="node" schema="sparql-results">
+            <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
+            <prefix>bf: http://bibframe.org/vocab/</prefix>
+            <form>SELECT ?node ?rel ?obj</form>
+            <index type="any">?node ?rel ?obj FILTER( str(?node) = %s )</index>
+        </db>
+        <!-- A way to see which triplets refers to a given uri. -->
+        <!-- TODO - Switch to the new system, probably using "small" -->
+        <db path="ref" schema="sparql-results">
+            <prefix>rdf: http://www.w3.org/1999/02/22-rdf-syntax-ns</prefix>
+            <prefix>bf: http://bibframe.org/vocab/</prefix>
+            <form>SELECT ?node ?rel ?obj</form>
+            <index type="any">?node ?rel ?obj FILTER( str(?obj) = %s )</index>
+        </db>
+    </filter>
+
+    <filter type="log">
+        <message>http</message>
+        <category apdu="true"/>
+    </filter>
+
+    <filter type="http_client">
+        <x-forwarded-for>true</x-forwarded-for>
+    </filter>
 </filters>