Merge branch 'master' into channel_list_mutex
authorDennis Schafroth <dennis@indexdata.com>
Tue, 27 Apr 2010 09:01:49 +0000 (11:01 +0200)
committerDennis Schafroth <dennis@indexdata.com>
Tue, 27 Apr 2010 09:01:49 +0000 (11:01 +0200)
etc/tmarcxml.xsl [deleted file]
src/eventl.c

diff --git a/etc/tmarcxml.xsl b/etc/tmarcxml.xsl
deleted file mode 100644 (file)
index 42ae103..0000000
+++ /dev/null
@@ -1,838 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<xsl:stylesheet version="1.0"
-       xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:pz="http://www.indexdata.com/pazpar2/1.0"
-       xmlns:tmarc="http://www.indexdata.com/MARC21/turboxml">
-
-       <xsl:output indent="yes" method="xml" version="1.0"
-               encoding="UTF-8" />
-
-       <!-- Extract metadata from MARC21/USMARC from streamlined marcxml format 
-               http://www.loc.gov/marc/bibliographic/ecbdhome.html -->
-       <xsl:template name="record-hook" />
-
-
-       <xsl:template match="/">
-                       <xsl:apply-templates />
-       </xsl:template>
-
-       <xsl:template match="tmarc:r">
-               <xsl:variable name="title_medium" select="tmarc:d245/tmarc:sh" />
-               <xsl:variable name="journal_title" select="tmarc:d773/tmarc:st" />
-               <xsl:variable name="electronic_location_url" select="tmarc:d856/tmarc:su" />
-               <xsl:variable name="fulltext_a" select="tmarc:d900/tmarc:sa" />
-               <xsl:variable name="fulltext_b" select="tmarc:d900/tmarc:sb" />
-               <!-- Does not always hit the right substring. The field is not always fixed-width? -->
-               <xsl:variable name="control_lang" select="substring(tmarc:c008, 36, 3)" />
-               <xsl:variable name="contains110" select="tmarc:d110" />
-               <xsl:variable name="hasAuthorFields" select="tmarc:d100 or tmarc:d111" />
-
-               <xsl:variable name="medium">
-                       <xsl:choose>
-                               <xsl:when test="$title_medium">
-                                       <xsl:value-of select="translate($title_medium, ' []/', '')" />
-                               </xsl:when>
-                               <xsl:when test="$fulltext_a">
-                                       <xsl:text>electronic resource</xsl:text>
-                               </xsl:when>
-                               <xsl:when test="$fulltext_b">
-                                       <xsl:text>electronic resource</xsl:text>
-                               </xsl:when>
-                               <xsl:when test="$journal_title">
-                                       <xsl:text>article</xsl:text>
-                               </xsl:when>
-                               <xsl:otherwise>
-                                       <xsl:text>book</xsl:text>
-                               </xsl:otherwise>
-                       </xsl:choose>
-               </xsl:variable>
-
-               <pz:record>
-<!--
-                       <xsl:attribute name="mergekey">
-        <xsl:text>title </xsl:text>
-       <xsl:value-of select="tmarc:d245/tmarc:sa" />
-       <xsl:text> author </xsl:text>
-       <xsl:value-of select="tmarc:d100/tmarc:sa" />
-       <xsl:text> medium </xsl:text>
-       <xsl:value-of select="$medium" />
-      </xsl:attribute>
-  -->
-
-                       <xsl:for-each select="tmarc:c001">
-                               <pz:metadata type="id">
-                                       <xsl:value-of select="." />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d010">
-                               <pz:metadata type="lccn">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d020">
-                               <pz:metadata type="isbn">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d022">
-                               <pz:metadata type="issn">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d027">
-                               <pz:metadata type="tech-rep-nr">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d035">
-                               <pz:metadata type="system-control-nr">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d100">
-                               <pz:metadata type="author">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="author-title">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                               <pz:metadata type="author-date">
-                                       <xsl:value-of select="tmarc:sd" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d110">
-                               <pz:metadata type="corporate-name">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="corporate-location">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                               <pz:metadata type="corporate-date">
-                                       <xsl:value-of select="tmarc:sd" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d111">
-                               <pz:metadata type="meeting-name">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="meeting-location">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                               <pz:metadata type="meeting-date">
-                                       <xsl:value-of select="tmarc:sd" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d260">
-                               <pz:metadata type="date">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d130">
-                               <pz:metadata type="title-uniform">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="title-uniform-media">
-                                       <xsl:value-of select="tmarc:sm" />
-                               </pz:metadata>
-                               <pz:metadata type="title-uniform-parts">
-                                       <xsl:value-of select="tmarc:sn" />
-                               </pz:metadata>
-                               <pz:metadata type="title-uniform-partname">
-                                       <xsl:value-of select="tmarc:sp" />
-                               </pz:metadata>
-                               <pz:metadata type="title-uniform-key">
-                                       <xsl:value-of select="tmarc:sr" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d245">
-                               <pz:metadata type="title">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="title-remainder">
-                                       <xsl:value-of select="tmarc:sb" />
-                               </pz:metadata>
-                               <pz:metadata type="title-responsibility">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                               <pz:metadata type="title-dates">
-                                       <xsl:value-of select="tmarc:sf" />
-                               </pz:metadata>
-                               <pz:metadata type="title-medium">
-                                       <xsl:value-of select="tmarc:sh" />
-                               </pz:metadata>
-                               <pz:metadata type="title-number-section">
-                                       <xsl:value-of select="tmarc:sn" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d250">
-                               <pz:metadata type="edition">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d260">
-                               <pz:metadata type="publication-place">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="publication-name">
-                                       <xsl:value-of select="tmarc:sb" />
-                               </pz:metadata>
-                               <pz:metadata type="publication-date">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d300">
-                               <pz:metadata type="physical-extent">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="physical-format">
-                                       <xsl:value-of select="tmarc:sb" />
-                               </pz:metadata>
-                               <pz:metadata type="physical-dimensions">
-                                       <xsl:value-of select="tmarc:sc" />
-                               </pz:metadata>
-                               <pz:metadata type="physical-accomp">
-                                       <xsl:value-of select="tmarc:se" />
-                               </pz:metadata>
-                               <pz:metadata type="physical-unittype">
-                                       <xsl:value-of select="tmarc:sf" />
-                               </pz:metadata>
-                               <pz:metadata type="physical-unitsize">
-                                       <xsl:value-of select="tmarc:sg" />
-                               </pz:metadata>
-                               <pz:metadata type="physical-specified">
-                                       <xsl:value-of select="tmarc:s3" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d440">
-                               <pz:metadata type="series-title">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d500">
-                               <pz:metadata type="description">
-                                       <xsl:for-each select="node()">
-                                               <xsl:value-of select="text()" />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d505">
-                               <pz:metadata type="description">
-                                       <xsl:for-each select="node()">
-                                               <xsl:value-of select="text()" />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d518">
-                               <pz:metadata type="description">
-                                       <xsl:for-each select="node()">
-                                               <xsl:value-of select="text()" />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d520">
-                               <pz:metadata type="description">
-                                       <xsl:for-each select="node()">
-                                               <xsl:value-of select="text()" />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d522">
-                               <pz:metadata type="description">
-                                       <xsl:for-each select="node()">
-                                               <xsl:value-of select="text()" />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d600">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d610">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d611">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d630">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d648">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d650">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d651">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d653">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d654">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d655">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d656">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d657">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d658">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d662">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d69X">
-                               <pz:metadata type="subject">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                               <pz:metadata type="subject-long">
-                                       <xsl:for-each select="node()/text()">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text>, </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <!-- or tmarc:d651 or tmarc:d653 or tmarc:d654 or tmarc:d655 or tmarc:d656 
-                               or tmarc:d657 or tmarc:d658 or tmarc:d662 or tmarc:d69X"> -->
-
-                       <!-- <xsl:for-each select="tmarc:d600" > <pz:metadata type="subject"> 
-                               <xsl:value-of select="tmarc:sa"/> </pz:metadata> <pz:metadata type="subject-long"> 
-                               <xsl:for-each select="tmarc:sa tmarc:sb tmarc:sc tmarc:sd "> <xsl:if test="position() 
-                               > 1"> <xsl:text>, </xsl:text> </xsl:if> <xsl:value-of select="."/> </xsl:for-each> 
-                               </pz:metadata> </xsl:for-each> -->
-
-                       <xsl:for-each select="tmarc:d856">
-                               <pz:metadata type="electronic-url">
-                                       <xsl:value-of select="tmarc:su" />
-                               </pz:metadata>
-                               <pz:metadata type="electronic-text">
-                                       <xsl:if test="tmarc:sy">
-                                               <xsl:value-of select="tmarc:sy/text()" />
-                                       </xsl:if>
-                                       <xsl:if test="tmarc:s3">
-                                               <xsl:value-of select="tmarc:s3/text()" />
-                                       </xsl:if>
-                               </pz:metadata>
-                               <pz:metadata type="electronic-note">
-                                       <xsl:value-of select="tmarc:sz" />
-                               </pz:metadata>
-                               <pz:metadata type="electronic-format-instruction">
-                                       <xsl:value-of select="tmarc:si" />
-                               </pz:metadata>
-                               <pz:metadata type="electronic-format-type">
-                                       <xsl:value-of select="tmarc:sq" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d773">
-                               <pz:metadata type="citation">
-                                       <xsl:for-each select="*">
-                                               <xsl:value-of select="normalize-space(.)" />
-                                               <xsl:text> </xsl:text>
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d852">
-                               <xsl:if test="tmarc:sy">
-                                       <pz:metadata type="publicnote">
-                                               <xsl:value-of select="tmarc:sy" />
-                                       </pz:metadata>
-                               </xsl:if>
-                               <xsl:if test="tmarc:sh">
-                                       <pz:metadata type="callnumber">
-                                               <xsl:value-of select="tmarc:sh" />
-                                       </pz:metadata>
-                               </xsl:if>
-                       </xsl:for-each>
-
-                       <pz:metadata type="medium">
-                               <xsl:value-of select="$medium" />
-                       </pz:metadata>
-
-                       <xsl:for-each select="tmarc:d900/tmarc:sa">
-                               <pz:metadata type="fulltext">
-                                       <xsl:value-of select="." />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <!-- <xsl:if test="$fulltext_a"> <pz:metadata type="fulltext"> <xsl:value-of 
-                               select="$fulltext_a"/> </pz:metadata> </xsl:if> -->
-
-                       <xsl:for-each select="tmarc:d900/tmarc:sb">
-                               <pz:metadata type="fulltext">
-                                       <xsl:value-of select="." />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <!-- <xsl:if test="$fulltext_b"> <pz:metadata type="fulltext"> <xsl:value-of 
-                               select="$fulltext_b"/> </pz:metadata> </xsl:if> -->
-
-                       <xsl:for-each select="tmarc:d907">
-                               <!-- or tmarc:d901"> -->
-                               <pz:metadata type="iii-id">
-                                       <xsl:value-of select="tmarc:sa" />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d926">
-                               <pz:metadata type="holding">
-                                       <xsl:for-each select="tmarc:s">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text> </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d948">
-                               <pz:metadata type="holding">
-                                       <xsl:for-each select="tmarc:s">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text> </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <xsl:for-each select="tmarc:d991">
-                               <pz:metadata type="holding">
-                                       <xsl:for-each select="tmarc:s">
-                                               <xsl:if test="position() > 1">
-                                                       <xsl:text> </xsl:text>
-                                               </xsl:if>
-                                               <xsl:value-of select="." />
-                                       </xsl:for-each>
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <pz:metadata tag="tag100">
-                               <xsl:call-template name="shortTitle">
-                                       <xsl:with-param name="tag" select="100" />
-                               </xsl:call-template>
-                       </pz:metadata>
-
-                       <!-- Stuff for FRBR workset key -->
-                       <xsl:variable name="title130">
-                               <xsl:for-each select="tmarc:d130">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:value-of select="tmarc:sm" />
-                                       <xsl:value-of select="tmarc:sn" />
-                                       <xsl:value-of select="tmarc:sp" />
-                                       <xsl:value-of select="tmarc:sr" />
-                               </xsl:for-each>
-                       </xsl:variable>
-
-                       <xsl:variable name="title240">
-                               <xsl:for-each select="tmarc:d240">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:value-of select="tmarc:sm" />
-                                       <xsl:value-of select="tmarc:sn" />
-                                       <xsl:value-of select="tmarc:sp" />
-                                       <xsl:value-of select="tmarc:sr" />
-                               </xsl:for-each>
-                       </xsl:variable>
-                       <xsl:variable name="title242">
-                               <xsl:for-each select="tmarc:d242">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:if test="$contains110 and not($hasAuthorFields)">
-                                               <xsl:value-of select="tmarc:sb" />
-                                               <xsl:value-of select="tmarc:sf" />
-                                               <xsl:value-of select="tmarc:sg" />
-                                               <xsl:value-of select="tmarc:sn" />
-                                               <xsl:value-of select="tmarc:sp" />
-                                       </xsl:if>
-                               </xsl:for-each>
-                       </xsl:variable>
-                       <xsl:variable name="title242-full">
-                               <xsl:for-each select="tmarc:d242">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:value-of select="tmarc:sb" />
-                                       <xsl:value-of select="tmarc:sf" />
-                                       <xsl:value-of select="tmarc:sg" />
-                                       <xsl:value-of select="tmarc:sn" />
-                                       <xsl:value-of select="tmarc:sp" />
-                               </xsl:for-each>
-                       </xsl:variable>
-
-                       <xsl:variable name="title245">
-                               <xsl:for-each select="tmarc:d245">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:if test="$contains110 and not($hasAuthorFields)">
-                                               <xsl:value-of select="tmarc:sb" />
-                                               <xsl:value-of select="tmarc:sf" />
-                                               <xsl:value-of select="tmarc:sg" />
-                                               <xsl:value-of select="tmarc:sn" />
-                                               <xsl:value-of select="tmarc:sp" />
-                                       </xsl:if>
-                               </xsl:for-each>
-                       </xsl:variable>
-                       <xsl:variable name="title245-full">
-                               <xsl:for-each select="tmarc:d245">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:value-of select="tmarc:sb" />
-                                       <xsl:value-of select="tmarc:sf" />
-                                       <xsl:value-of select="tmarc:sg" />
-                                       <xsl:value-of select="tmarc:sn" />
-                                       <xsl:value-of select="tmarc:sp" />
-                               </xsl:for-each>
-                       </xsl:variable>
-
-                       <xsl:variable name="title246">
-                               <xsl:for-each select="tmarc:d246">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:if test="$contains110 and not($hasAuthorFields)">
-                                               <xsl:value-of select="tmarc:sb" />
-                                               <xsl:value-of select="tmarc:sf" />
-                                               <xsl:value-of select="tmarc:sg" />
-                                               <xsl:value-of select="tmarc:sn" />
-                                               <xsl:value-of select="tmarc:sp" />
-                                       </xsl:if>
-                               </xsl:for-each>
-                       </xsl:variable>
-                       <xsl:variable name="title246-full">
-                               <xsl:for-each select="tmarc:d246">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:value-of select="tmarc:sb" />
-                                       <xsl:value-of select="tmarc:sf" />
-                                       <xsl:value-of select="tmarc:sg" />
-                                       <xsl:value-of select="tmarc:sn" />
-                                       <xsl:value-of select="tmarc:sp" />
-                               </xsl:for-each>
-                       </xsl:variable>
-
-                       <xsl:variable name="title247">
-                               <xsl:for-each select="tmarc:d247">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:if test="$contains110 and not($hasAuthorFields)">
-                                               <xsl:value-of select="tmarc:sb" />
-                                               <xsl:value-of select="tmarc:sf" />
-                                               <xsl:value-of select="tmarc:sg" />
-                                               <xsl:value-of select="tmarc:sn" />
-                                               <xsl:value-of select="tmarc:sp" />
-                                       </xsl:if>
-                               </xsl:for-each>
-                       </xsl:variable>
-                       <xsl:variable name="title247-full">
-                               <xsl:for-each select="tmarc:d247">
-                                       <xsl:value-of select="tmarc:sa" />
-                                       <xsl:value-of select="tmarc:sb" />
-                                       <xsl:value-of select="tmarc:sf" />
-                                       <xsl:value-of select="tmarc:sg" />
-                                       <xsl:value-of select="tmarc:sn" />
-                                       <xsl:value-of select="tmarc:sp" />
-                               </xsl:for-each>
-                       </xsl:variable>
-
-                       <xsl:for-each select="tmarc:c008">
-                               <pz:metadata type="meta-marc-cf008">
-                                       <xsl:value-of select="." />
-                               </pz:metadata>
-                       </xsl:for-each>
-
-                       <pz:metadata type="meta-frbr-short-title">
-                               <xsl:choose>
-                                       <xsl:when test="$title130!=''">
-                                               <xsl:value-of select="$title130" />
-                                       </xsl:when>
-                                       <xsl:when test="$title130='' and $title240!=''">
-                                               <xsl:value-of select="$title240" />
-                                       </xsl:when>
-                                       <!-- Missing the prioritization of 246 on non-english records -->
-                                       <xsl:when test="$title130='' and $title240='' and $title242!=''">
-                                               <xsl:value-of select="$title242" />
-                                       </xsl:when>
-                                       <xsl:when
-                                               test="$title130='' and $title240='' and $title242='' and $title245!=''">
-                                               <xsl:value-of select="$title245" />
-                                       </xsl:when>
-                                       <xsl:when
-                                               test="$title130='' and $title240='' and $title242='' and $title246!=''">
-                                               <xsl:value-of select="$title246" />
-                                       </xsl:when>
-                                       <xsl:when
-                                               test="$title130='' and $title240='' and $title242='' and $title246='' and $title247!=''">
-                                               <xsl:value-of select="$title247" />
-                                       </xsl:when>
-                               </xsl:choose>
-                       </pz:metadata>
-
-                       <pz:metadata type="meta-frbr-full-title">
-                               <xsl:choose>
-                                       <xsl:when test="$title130!=''">
-                                               <xsl:value-of select="$title130" />
-                                       </xsl:when>
-                                       <xsl:when test="$title130='' and $title240!=''">
-                                               <xsl:value-of select="$title240" />
-                                       </xsl:when>
-                                       <!-- Missing the prioritization of 246 on non-english records -->
-                                       <xsl:when test="$title130='' and $title240='' and $title242!=''">
-                                               <xsl:value-of select="$title242-full" />
-                                       </xsl:when>
-                                       <xsl:when
-                                               test="$title130='' and $title240='' and $title242='' and $title245!=''">
-                                               <xsl:value-of select="$title245-full" />
-                                       </xsl:when>
-                                       <xsl:when
-                                               test="$title130='' and $title240='' and $title242='' and $title246!=''">
-                                               <xsl:value-of select="$title246-full" />
-                                       </xsl:when>
-                                       <xsl:when
-                                               test="$title130='' and $title240='' and $title242='' and $title246='' and $title247!=''">
-                                               <xsl:value-of select="$title247-full" />
-                                       </xsl:when>
-                               </xsl:choose>
-                       </pz:metadata>
-
-
-                       <pz:metadata type="meta-frbr-lang">
-                               <xsl:value-of select="$control_lang" />
-                       </pz:metadata>
-
-
-                       <!-- passthrough id data -->
-                       <xsl:for-each select="pz:metadata">
-                               <xsl:copy-of select="." />
-                       </xsl:for-each>
-
-                       <!-- other stylesheets importing this might want to define this -->
-                       <xsl:call-template name="record-hook" />
-
-               </pz:record>
-       </xsl:template>
-
-       <xsl:template match="text()" />
-
-       <!-- TODO Does not work anymore -->
-       <xsl:template name="shortTitle">
-               <xsl:param name="tag" />
-               <xsl:for-each select="tmarc:d">
-                       <xsl:value-of select="tmarc:sa" />
-                       <xsl:value-of select="tmarc:sm" />
-                       <xsl:value-of select="tmarc:sn" />
-                       <xsl:value-of select="tmarc:sp" />
-                       <xsl:value-of select="tmarc:sr" />
-               </xsl:for-each>
-       </xsl:template>
-
-       <!-- No working as expected -->
-       <xsl:template name="description">
-               <xsl:param name="element" />
-               <xsl:for-each select="$element">
-                       <pz:metadata type="description">
-                               <xsl:for-each select="node()">
-                                       <xsl:value-of select="text()" />
-                               </xsl:for-each>
-                       </pz:metadata>
-               </xsl:for-each>
-               <xsl:apply-templates />
-       </xsl:template>
-
-       <!-- <xsl:for-each select="tmarc:d500"> <pz:metadata type="description"> 
-               <xsl:for-each select="node()"> <xsl:value-of select="text()"/> </xsl:for-each> 
-               </pz:metadata> </xsl:for-each> -->
-
-
-
-       <xsl:template name="subject">
-               <xsl:param name="element" />
-               <xsl:for-each select="$element">
-                       <pz:metadata type="subject">
-                               <xsl:value-of select="tmarc:sa" />
-                       </pz:metadata>
-                       <pz:metadata type="subject-long">
-                               <xsl:for-each select="node()/text()">
-                                       <xsl:if test="position() > 1">
-                                               <xsl:text>, </xsl:text>
-                                       </xsl:if>
-                                       <xsl:value-of select="." />
-                               </xsl:for-each>
-                       </pz:metadata>
-               </xsl:for-each>
-       </xsl:template>
-
-
-</xsl:stylesheet>
index f9f0dc2..990dbfe 100644 (file)
@@ -53,6 +53,7 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 #include <yaz/log.h>
 #include <yaz/comstack.h>
 #include <yaz/xmalloc.h>
+#include <yaz/mutex.h>
 #include "eventl.h"
 #include "sel_thread.h"
 
@@ -62,6 +63,13 @@ struct iochan_man_s {
     int sel_fd;
     int no_threads;
     int log_level;
+    YAZ_MUTEX iochan_mutex;
+};
+
+struct iochan_man_iter {
+    iochan_man_t man;
+    IOCHAN current; 
+    int first;
 };
 
 iochan_man_t iochan_man_create(int no_threads)
@@ -72,7 +80,8 @@ iochan_man_t iochan_man_create(int no_threads)
     man->sel_fd = -1;
     man->no_threads = no_threads;
     man->log_level = yaz_log_module_level("iochan");
-
+    man->iochan_mutex = 0;
+    yaz_mutex_create(&man->iochan_mutex);
     return man;
 }
 
@@ -100,8 +109,11 @@ void iochan_man_destroy(iochan_man_t *mp)
 void iochan_add(iochan_man_t man, IOCHAN chan)
 {
     chan->man = man;
+    yaz_mutex_enter(man->iochan_mutex);
+    yaz_log(man->log_level, "iochan_add : chan=%p channel list=%p", chan, man->channel_list);
     chan->next = man->channel_list;
     man->channel_list = chan;
+    yaz_mutex_leave(man->iochan_mutex);
 }
 
 IOCHAN iochan_create(int fd, IOC_CALLBACK cb, int flags,
@@ -159,6 +171,33 @@ static void run_fun(iochan_man_t man, IOCHAN p)
     }
 }
 
+static IOCHAN iochan_man_get_first(struct iochan_man_iter *iter, iochan_man_t man) {
+    iter->man = man;
+    iter->first = 1;
+    yaz_mutex_enter(man->iochan_mutex);
+    iter->current = man->channel_list;
+    yaz_log(man->log_level, "iochan_man_get_first : chan=%p ", iter->current);
+    if (!iter->current)
+        yaz_mutex_leave(man->iochan_mutex);
+    return iter->current;
+}
+
+static IOCHAN iochan_man_get_next(struct iochan_man_iter *iter) {
+    IOCHAN current = NULL, next = NULL;
+    current = iter->current;
+    assert(current);
+    if (current) {
+        next = current->next;
+        iter->current = iter->current->next;
+        if (iter->first) {
+            yaz_log(iter->man->log_level, "iochan_man_get_next : chan=%p next=%p", current, next);
+            iter->first = 0;
+            yaz_mutex_leave(iter->man->iochan_mutex);
+        }
+    }
+    return iter->current;
+}
+
 static int event_loop(iochan_man_t man, IOCHAN *iochans)
 {
     do /* loop as long as there are active associations to process */
@@ -166,8 +205,9 @@ static int event_loop(iochan_man_t man, IOCHAN *iochans)
        IOCHAN p, *nextp;
        fd_set in, out, except;
        int res, max;
-       static struct timeval to;
-       struct timeval *timeout;
+        static struct timeval to;
+        struct timeval *timeout;
+        static struct iochan_man_iter iter; 
 
        FD_ZERO(&in);
        FD_ZERO(&out);
@@ -176,7 +216,7 @@ static int event_loop(iochan_man_t man, IOCHAN *iochans)
        to.tv_sec = 300;
        to.tv_usec = 0;
        max = 0;
-       for (p = *iochans; p; p = p->next)
+       for (p = iochan_man_get_first(&iter, man); p; p = iochan_man_get_next(&iter) )
        {
             if (p->thread_users > 0)
                 continue;
@@ -193,6 +233,8 @@ static int event_loop(iochan_man_t man, IOCHAN *iochans)
            if (p->fd > max)
                max = p->fd;
        }
+        yaz_log(man->log_level, "max=%d nofds=%d", max, man->sel_fd);
+        
         if (man->sel_fd != -1)
         {
             if (man->sel_fd > max)
@@ -231,11 +273,12 @@ static int event_loop(iochan_man_t man, IOCHAN *iochans)
         if (man->log_level)
         {
             int no = 0;
-            for (p = *iochans; p; p = p->next)
+            for (p = iochan_man_get_first(&iter, man); p; p = iochan_man_get_next(&iter)) {
                 no++;
+            }
             yaz_log(man->log_level, "%d channels", no);
         }
-        for (p = *iochans; p; p = p->next)
+        for (p = iochan_man_get_first(&iter, man); p; p = iochan_man_get_next(&iter))
         {
             time_t now = time(0);
             
@@ -276,6 +319,7 @@ static int event_loop(iochan_man_t man, IOCHAN *iochans)
             }
             run_fun(man, p);
        }
+        yaz_mutex_enter(man->iochan_mutex);
         for (nextp = iochans; *nextp; )
         {
             IOCHAN p = *nextp;
@@ -288,6 +332,7 @@ static int event_loop(iochan_man_t man, IOCHAN *iochans)
             else
                 nextp = &p->next;
         }
+        yaz_mutex_leave(man->iochan_mutex);
     }
     while (*iochans);
     return 0;