--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>\r
+<xsl:stylesheet version="1.0" xmlns:marc="http://www.loc.gov/MARC21/slim" xmlns:srw_dc="info:srw/schema/1/dc-schema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://purl.org/dc/elements/1.1/" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" exclude-result-prefixes="marc">\r
+ <xsl:import href="MARC21slimUtils.xsl"/>\r
+ <xsl:output method="xml" indent="yes" encoding="UTF-8"/>\r
+ <!-- modification log \r
+ NT 01/04: added collection level element\r
+ and removed attributes\r
+\r
+ JR 06/04: Added ISBN identifier\r
+\r
+ JR 09/05: Added additional <subject> subfields and 651 for <coverage>\r
+ RG 10/07/05: Corrected subject subfields; 10/12/05: added if statement for <language>\r
+ JR 05/05/06: Updated the schemaLocation\r
+-->\r
+ <xsl:template match="/">\r
+ <xsl:if test="marc:collection">\r
+ <srw_dc:dcCollection xmlns:srw_dc="info:srw/schema/1/dc-schema" xsi:schemaLocation="info:srw/schema/1/dc-schema http://www.loc.gov/standards/sru/dc-schema.xsd">\r
+ <xsl:for-each select="marc:collection">\r
+ <xsl:for-each select="marc:record">\r
+ <srw_dc:dc>\r
+ <xsl:apply-templates select="."/>\r
+ </srw_dc:dc>\r
+ </xsl:for-each>\r
+ </xsl:for-each>\r
+ </srw_dc:dcCollection>\r
+ </xsl:if>\r
+ <xsl:if test="marc:record">\r
+ <srw_dc:dc xmlns:srw_dc="info:srw/schema/1/dc-schema" xsi:schemaLocation="info:srw/schema/1/dc-schema http://www.loc.gov/standards/sru/dc-schema.xsd">\r
+ <xsl:apply-templates select="marc:record"/>\r
+ </srw_dc:dc>\r
+ </xsl:if>\r
+ </xsl:template>\r
+ <xsl:template match="marc:record">\r
+ <xsl:variable name="leader" select="marc:leader"/>\r
+ <xsl:variable name="leader6" select="substring($leader,7,1)"/>\r
+ <xsl:variable name="leader7" select="substring($leader,8,1)"/>\r
+ <xsl:variable name="controlField008" select="marc:controlfield[@tag=008]"/>\r
+ <xsl:for-each select="marc:datafield[@tag=245]">\r
+ <title>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">abfghk</xsl:with-param>\r
+ </xsl:call-template>\r
+ </title>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=100]|marc:datafield[@tag=110]|marc:datafield[@tag=111]|marc:datafield[@tag=700]|marc:datafield[@tag=710]|marc:datafield[@tag=711]|marc:datafield[@tag=720]">\r
+ <creator>\r
+ <xsl:value-of select="normalize-space(.)"/>\r
+ </creator>\r
+ </xsl:for-each>\r
+ <type>\r
+ <xsl:if test="$leader7='c'">\r
+ <!-- nt fix 1/04 -->\r
+ <!--<xsl:attribute name="collection">yes</xsl:attribute>-->\r
+ <xsl:text>collection</xsl:text>\r
+ </xsl:if>\r
+ <xsl:if test="$leader6='d' or $leader6='f' or $leader6='p' or $leader6='t'">\r
+ <!-- nt fix 1/04 -->\r
+ <!--<xsl:attribute name="manuscript">yes</xsl:attribute> -->\r
+ <xsl:text>manuscript</xsl:text>\r
+ </xsl:if>\r
+ <xsl:choose>\r
+ <xsl:when test="$leader6='a' or $leader6='t'">text</xsl:when>\r
+ <xsl:when test="$leader6='e' or $leader6='f'">cartographic</xsl:when>\r
+ <xsl:when test="$leader6='c' or $leader6='d'">notated music</xsl:when>\r
+ <xsl:when test="$leader6='i' or $leader6='j'">sound recording</xsl:when>\r
+ <xsl:when test="$leader6='k'">still image</xsl:when>\r
+ <xsl:when test="$leader6='g'">moving image</xsl:when>\r
+ <xsl:when test="$leader6='r'">three dimensional object</xsl:when>\r
+ <xsl:when test="$leader6='m'">software, multimedia</xsl:when>\r
+ <xsl:when test="$leader6='p'">mixed material</xsl:when>\r
+ </xsl:choose>\r
+ </type>\r
+ <xsl:for-each select="marc:datafield[@tag=655]">\r
+ <type>\r
+ <xsl:value-of select="normalize-space(.)"/>\r
+ </type>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=260]">\r
+ <publisher>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">ab</xsl:with-param>\r
+ </xsl:call-template>\r
+ </publisher>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=260]/marc:subfield[@code='c']">\r
+ <date>\r
+ <xsl:value-of select="."/>\r
+ </date>\r
+ </xsl:for-each>\r
+ <xsl:if test="substring($controlField008,36,3)">\r
+ <language>\r
+ <xsl:value-of select="substring($controlField008,36,3)"/>\r
+ </language>\r
+ </xsl:if> \r
+ <xsl:for-each select="marc:datafield[@tag=856]/marc:subfield[@code='q']">\r
+ <format>\r
+ <xsl:value-of select="."/>\r
+ </format>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=520]">\r
+ <description>\r
+ <!-- nt fix 01/04 -->\r
+ <xsl:value-of select="normalize-space(marc:subfield[@code='a'])"/>\r
+ </description>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=521]">\r
+ <description>\r
+ <xsl:value-of select="marc:subfield[@code='a']"/>\r
+ </description>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[500<@tag][@tag<=599][not(@tag=506 or @tag=530 or @tag=540 or @tag=546)]">\r
+ <description>\r
+ <xsl:value-of select="marc:subfield[@code='a']"/>\r
+ </description>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=600]">\r
+ <subject>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">abcdefghjklmnopqrstu4</xsl:with-param>\r
+ </xsl:call-template>\r
+ <xsl:if test="marc:subfield[@code='v' or @code='x' or @code='y' or @code='z']">\r
+ <xsl:text>--</xsl:text>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">vxyz</xsl:with-param>\r
+ <xsl:with-param name="delimeter">--</xsl:with-param>\r
+ </xsl:call-template>\r
+ </xsl:if>\r
+ </subject>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=610]">\r
+ <subject>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">abcdefghklmnoprstu4</xsl:with-param>\r
+ </xsl:call-template>\r
+ <xsl:if test="marc:subfield[@code='v' or @code='x' or @code='y' or\r
+ @code='z']">\r
+ <xsl:text>--</xsl:text>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">vxyz</xsl:with-param>\r
+ <xsl:with-param name="delimeter">--</xsl:with-param>\r
+ </xsl:call-template>\r
+ </xsl:if>\r
+ </subject>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=611]">\r
+ <subject>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">acdefghklnpqstu4</xsl:with-param>\r
+ </xsl:call-template>\r
+ <xsl:if test="marc:subfield[@code='v' or @code='x' or @code='y' or\r
+ @code='z']">\r
+ <xsl:text>--</xsl:text>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">vxyz</xsl:with-param>\r
+ <xsl:with-param name="delimeter">--</xsl:with-param>\r
+ </xsl:call-template>\r
+ </xsl:if>\r
+ </subject>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=630]">\r
+ <subject>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">adfghklmnoprst</xsl:with-param>\r
+ </xsl:call-template>\r
+ <xsl:if test="marc:subfield[@code='v' or @code='x' or @code='y' or\r
+ @code='z']">\r
+ <xsl:text>--</xsl:text>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">vxyz</xsl:with-param>\r
+ <xsl:with-param name="delimeter">--</xsl:with-param>\r
+ </xsl:call-template>\r
+ </xsl:if>\r
+ </subject>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=650]">\r
+ <subject>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">ae</xsl:with-param></xsl:call-template>\r
+ <xsl:if test="marc:subfield[@code='v' or @code='x' or @code='y' or\r
+ @code='z']">\r
+ <xsl:text>--</xsl:text>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">vxyz</xsl:with-param>\r
+ <xsl:with-param name="delimeter">--</xsl:with-param>\r
+ </xsl:call-template>\r
+ </xsl:if>\r
+ </subject>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=653]">\r
+ <subject>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">a</xsl:with-param>\r
+ </xsl:call-template>\r
+ </subject>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=651]">\r
+ <coverage>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">a</xsl:with-param>\r
+ </xsl:call-template>\r
+ <xsl:if test="marc:subfield[@code='v' or @code='x' or @code='y' or\r
+ @code='z']">\r
+ <xsl:text>--</xsl:text>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">vxyz</xsl:with-param>\r
+ <xsl:with-param name="delimeter">--</xsl:with-param>\r
+ </xsl:call-template>\r
+ </xsl:if>\r
+ </coverage>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=752]">\r
+ <coverage>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">abcd</xsl:with-param>\r
+ </xsl:call-template>\r
+ </coverage>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=530]">\r
+ <!-- nt 01/04 attribute fix -->\r
+ <relation>\r
+ <!--<xsl:attribute name="type">original</xsl:attribute>-->\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">abcdu</xsl:with-param>\r
+ </xsl:call-template>\r
+ </relation>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=760]|marc:datafield[@tag=762]|marc:datafield[@tag=765]|marc:datafield[@tag=767]|marc:datafield[@tag=770]|marc:datafield[@tag=772]|marc:datafield[@tag=773]|marc:datafield[@tag=774]|marc:datafield[@tag=775]|marc:datafield[@tag=776]|marc:datafield[@tag=777]|marc:datafield[@tag=780]|marc:datafield[@tag=785]|marc:datafield[@tag=786]|marc:datafield[@tag=787]">\r
+ <relation>\r
+ <xsl:call-template name="subfieldSelect">\r
+ <xsl:with-param name="codes">ot</xsl:with-param>\r
+ </xsl:call-template>\r
+ </relation>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=856]">\r
+ <identifier>\r
+ <xsl:value-of select="marc:subfield[@code='u']"/>\r
+ </identifier>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=020]">\r
+ <identifier>\r
+ <xsl:text>URN:ISBN:</xsl:text>\r
+ <xsl:value-of select="marc:subfield[@code='a']"/>\r
+ </identifier>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=506]">\r
+ <rights>\r
+ <xsl:value-of select="marc:subfield[@code='a']"/>\r
+ </rights>\r
+ </xsl:for-each>\r
+ <xsl:for-each select="marc:datafield[@tag=540]">\r
+ <rights>\r
+ <xsl:value-of select="marc:subfield[@code='a']"/>\r
+ </rights>\r
+ </xsl:for-each>\r
+ </xsl:template>\r
+</xsl:stylesheet>\r
+<!-- Stylus Studio meta-information - (c)1998-2003 Copyright Sonic Software Corporation. All rights reserved.\r
+<metaInformation>\r
+<scenarios/><MapperInfo srcSchemaPath="" srcSchemaRoot="" srcSchemaPathIsRelative="yes" srcSchemaInterpretAsXML="no" destSchemaPath="" destSchemaRoot="" destSchemaPathIsRelative="yes" destSchemaInterpretAsXML="no"/>\r
+</metaInformation>\r
+-->
\ No newline at end of file