From: Lebbeous Fogle-Weekley <lebbeous@esilibrary.com> Date: Mon, 30 Jan 2012 22:16:08 +0000 (-0500) Subject: Merge remote branch 'working/user/dbs/fix-nonfiling-titles' X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=244e0c8d95beee304caa5f0f17a1137b31569646;p=evergreen%2Fmasslnc.git Merge remote branch 'working/user/dbs/fix-nonfiling-titles' Conflicts: Open-ILS/src/sql/Pg/950.data.seed-values.sql Signed-off-by: Lebbeous Fogle-Weekley <lebbeous@esilibrary.com> --- 244e0c8d95beee304caa5f0f17a1137b31569646 diff --cc Open-ILS/src/sql/Pg/002.schema.config.sql index 06ef826c4d,6cac923bda..f5b2362f0f --- a/Open-ILS/src/sql/Pg/002.schema.config.sql +++ b/Open-ILS/src/sql/Pg/002.schema.config.sql @@@ -86,7 -86,7 +86,7 @@@ CREATE TRIGGER no_overlapping_dep BEFORE INSERT OR UPDATE ON config.db_patch_dependencies FOR EACH ROW EXECUTE PROCEDURE evergreen.array_overlap_check ('deprecates'); - INSERT INTO config.upgrade_log (version, applied_to) VALUES ('0671', :eg_version); -- tsbere/berick -INSERT INTO config.upgrade_log (version, applied_to) VALUES ('0646', :eg_version); -- jamesrf/senator ++INSERT INTO config.upgrade_log (version, applied_to) VALUES ('0672', :eg_version); -- dbs/senator CREATE TABLE config.bib_source ( id SERIAL PRIMARY KEY, diff --cc Open-ILS/src/sql/Pg/950.data.seed-values.sql index ddb6b39fe3,7f0942428b..9f19140926 --- a/Open-ILS/src/sql/Pg/950.data.seed-values.sql +++ b/Open-ILS/src/sql/Pg/950.data.seed-values.sql @@@ -7312,12 -7171,11 +7312,18 @@@ INSERT INTO config.index_normalizer (na ); INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES ( + 'Coded Value Map Normalizer', + 'Applies coded_value_map mapping of values', + 'coded_value_map_normalizer', + 1 +); + ++INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES ( + 'Search Normalize', + 'Apply search normalization rules to the extracted text. A less extreme version of NACO normalization.', + 'search_normalize', + 0 + ); -- make use of the index normalizers diff --cc Open-ILS/src/sql/Pg/upgrade/0672.fix-nonfiling-titles.sql index 0000000000,0000000000..dcfde3eab3 new file mode 100644 --- /dev/null +++ b/Open-ILS/src/sql/Pg/upgrade/0672.fix-nonfiling-titles.sql @@@ -1,0 -1,0 +1,3245 @@@ ++-- Evergreen DB patch 0672.fix-nonfiling-titles.sql ++-- ++-- Titles that begin with non-filing articles using apostrophes ++-- (for example, "L'armée") get spaces injected between the article ++-- and the subsequent text, which then breaks searching for titles ++-- beginning with those articles. ++-- ++-- This patch adds a nonfiling title element to MODS32 that can then ++-- be used to retrieve the title proper without affecting the spaces ++-- in the title. It's what we want, what we really really want, for ++-- title searches. ++-- ++BEGIN; ++ ++ ++-- check whether patch can be applied ++SELECT evergreen.upgrade_deps_block_check('0672', :eg_version); ++ ++-- Update the XPath definition before the titleNonfiling element exists; ++-- but are you really going to read through the whole XSL below before ++-- seeing this important bit? ++UPDATE config.metabib_field ++ SET xpath = $$//mods32:mods/mods32:titleNonfiling[mods32:title and not (@type)]$$, ++ format = 'mods32' ++ WHERE field_class = 'title' AND name = 'proper'; ++ ++UPDATE config.xml_transform SET xslt=$$<?xml version="1.0" encoding="UTF-8"?> ++<xsl:stylesheet xmlns="http://www.loc.gov/mods/v3" xmlns:marc="http://www.loc.gov/MARC21/slim" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" exclude-result-prefixes="xlink marc" version="1.0"> ++ <xsl:output encoding="UTF-8" indent="yes" method="xml"/> ++<!-- ++Revision 1.14 - Fixed template isValid and fields 010, 020, 022, 024, 028, and 037 to output additional identifier elements ++ with corresponding @type and @invalid eq 'yes' when subfields z or y (in the case of 022) exist in the MARCXML ::: 2007/01/04 17:35:20 cred ++ ++Revision 1.13 - Changed order of output under cartographics to reflect schema 2006/11/28 tmee ++ ++Revision 1.12 - Updated to reflect MODS 3.2 Mapping 2006/10/11 tmee ++ ++Revision 1.11 - The attribute objectPart moved from <languageTerm> to <language> ++ 2006/04/08 jrad ++ ++Revision 1.10 MODS 3.1 revisions to language and classification elements ++ (plus ability to find marc:collection embedded in wrapper elements such as SRU zs: wrappers) ++ 2006/02/06 ggar ++ ++Revision 1.9 subfield $y was added to field 242 2004/09/02 10:57 jrad ++ ++Revision 1.8 Subject chopPunctuation expanded and attribute fixes 2004/08/12 jrad ++ ++Revision 1.7 2004/03/25 08:29 jrad ++ ++Revision 1.6 various validation fixes 2004/02/20 ntra ++ ++Revision 1.5 2003/10/02 16:18:58 ntra ++MODS2 to MODS3 updates, language unstacking and ++de-duping, chopPunctuation expanded ++ ++Revision 1.3 2003/04/03 00:07:19 ntra ++Revision 1.3 Additional Changes not related to MODS Version 2.0 by ntra ++ ++Revision 1.2 2003/03/24 19:37:42 ckeith ++Added Log Comment ++ ++--> ++ <xsl:template match="/"> ++ <xsl:choose> ++ <xsl:when test="//marc:collection"> ++ <modsCollection xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.loc.gov/mods/v3 http://www.loc.gov/standards/mods/v3/mods-3-2.xsd"> ++ <xsl:for-each select="//marc:collection/marc:record"> ++ <mods version="3.2"> ++ <xsl:call-template name="marcRecord"/> ++ </mods> ++ </xsl:for-each> ++ </modsCollection> ++ </xsl:when> ++ <xsl:otherwise> ++ <mods xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="3.2" xsi:schemaLocation="http://www.loc.gov/mods/v3 http://www.loc.gov/standards/mods/v3/mods-3-2.xsd"> ++ <xsl:for-each select="//marc:record"> ++ <xsl:call-template name="marcRecord"/> ++ </xsl:for-each> ++ </mods> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:template> ++ <xsl:template name="marcRecord"> ++ <xsl:variable name="leader" select="marc:leader"/> ++ <xsl:variable name="leader6" select="substring($leader,7,1)"/> ++ <xsl:variable name="leader7" select="substring($leader,8,1)"/> ++ <xsl:variable name="controlField008" select="marc:controlfield[@tag='008']"/> ++ <xsl:variable name="typeOf008"> ++ <xsl:choose> ++ <xsl:when test="$leader6='a'"> ++ <xsl:choose> ++ <xsl:when test="$leader7='a' or $leader7='c' or $leader7='d' or $leader7='m'">BK</xsl:when> ++ <xsl:when test="$leader7='b' or $leader7='i' or $leader7='s'">SE</xsl:when> ++ </xsl:choose> ++ </xsl:when> ++ <xsl:when test="$leader6='t'">BK</xsl:when> ++ <xsl:when test="$leader6='p'">MM</xsl:when> ++ <xsl:when test="$leader6='m'">CF</xsl:when> ++ <xsl:when test="$leader6='e' or $leader6='f'">MP</xsl:when> ++ <xsl:when test="$leader6='g' or $leader6='k' or $leader6='o' or $leader6='r'">VM</xsl:when> ++ <xsl:when test="$leader6='c' or $leader6='d' or $leader6='i' or $leader6='j'">MU</xsl:when> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:for-each select="marc:datafield[@tag='245']"> ++ <titleInfo> ++ <xsl:variable name="title"> ++ <xsl:choose> ++ <xsl:when test="marc:subfield[@code='b']"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">b</xsl:with-param> ++ <xsl:with-param name="beforeCodes">afgk</xsl:with-param> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abfgk</xsl:with-param> ++ </xsl:call-template> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:variable name="titleChop"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="$title"/> ++ </xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:choose> ++ <xsl:when test="@ind2>0"> ++ <nonSort> ++ <xsl:value-of select="substring($titleChop,1,@ind2)"/> ++ </nonSort> ++ <title> ++ <xsl:value-of select="substring($titleChop,@ind2+1)"/> ++ </title> ++ </xsl:when> ++ <xsl:otherwise> ++ <title> ++ <xsl:value-of select="$titleChop"/> ++ </title> ++ </xsl:otherwise> ++ </xsl:choose> ++ <xsl:if test="marc:subfield[@code='b']"> ++ <subTitle> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">b</xsl:with-param> ++ <xsl:with-param name="anyCodes">b</xsl:with-param> ++ <xsl:with-param name="afterCodes">afgk</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </subTitle> ++ </xsl:if> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ <!-- A form of title that ignores non-filing characters; useful ++ for not converting "L'Oreal" into "L' Oreal" at index time --> ++ <titleNonfiling> ++ <xsl:variable name="title"> ++ <xsl:choose> ++ <xsl:when test="marc:subfield[@code='b']"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">b</xsl:with-param> ++ <xsl:with-param name="beforeCodes">afgk</xsl:with-param> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abfgk</xsl:with-param> ++ </xsl:call-template> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:variable> ++ <title> ++ <xsl:value-of select="$title"/> ++ </title> ++ <xsl:if test="marc:subfield[@code='b']"> ++ <subTitle> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">b</xsl:with-param> ++ <xsl:with-param name="anyCodes">b</xsl:with-param> ++ <xsl:with-param name="afterCodes">afgk</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </subTitle> ++ </xsl:if> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleNonfiling> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='210']"> ++ <titleInfo type="abbreviated"> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">a</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="subtitle"/> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='242']"> ++ <titleInfo type="translated"> ++ <!--09/01/04 Added subfield $y--> ++ <xsl:for-each select="marc:subfield[@code='y']"> ++ <xsl:attribute name="lang"> ++ <xsl:value-of select="text()"/> ++ </xsl:attribute> ++ </xsl:for-each> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <!-- 1/04 removed $h, b --> ++ <xsl:with-param name="codes">a</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <!-- 1/04 fix --> ++ <xsl:call-template name="subtitle"/> ++ <xsl:call-template name="part"/> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='246']"> ++ <titleInfo type="alternative"> ++ <xsl:for-each select="marc:subfield[@code='i']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:value-of select="text()"/> ++ </xsl:attribute> ++ </xsl:for-each> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <!-- 1/04 removed $h, $b --> ++ <xsl:with-param name="codes">af</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="subtitle"/> ++ <xsl:call-template name="part"/> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='130']|marc:datafield[@tag='240']|marc:datafield[@tag='730'][@ind2!='2']"> ++ <titleInfo type="uniform"> ++ <title> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield"> ++ <xsl:if test="(contains('adfklmor',@code) and (not(../marc:subfield[@code='n' or @code='p']) or (following-sibling::marc:subfield[@code='n' or @code='p'])))"> ++ <xsl:value-of select="text()"/> ++ <xsl:text> </xsl:text> ++ </xsl:if> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"/> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"/> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='740'][@ind2!='2']"> ++ <titleInfo type="alternative"> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ah</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"/> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='100']"> ++ <name type="personal"> ++ <xsl:call-template name="nameABCDQ"/> ++ <xsl:call-template name="affiliation"/> ++ <role> ++ <roleTerm authority="marcrelator" type="text">creator</roleTerm> ++ </role> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='110']"> ++ <name type="corporate"> ++ <xsl:call-template name="nameABCDN"/> ++ <role> ++ <roleTerm authority="marcrelator" type="text">creator</roleTerm> ++ </role> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='111']"> ++ <name type="conference"> ++ <xsl:call-template name="nameACDEQ"/> ++ <role> ++ <roleTerm authority="marcrelator" type="text">creator</roleTerm> ++ </role> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='700'][not(marc:subfield[@code='t'])]"> ++ <name type="personal"> ++ <xsl:call-template name="nameABCDQ"/> ++ <xsl:call-template name="affiliation"/> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='710'][not(marc:subfield[@code='t'])]"> ++ <name type="corporate"> ++ <xsl:call-template name="nameABCDN"/> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='711'][not(marc:subfield[@code='t'])]"> ++ <name type="conference"> ++ <xsl:call-template name="nameACDEQ"/> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='720'][not(marc:subfield[@code='t'])]"> ++ <name> ++ <xsl:if test="@ind1=1"> ++ <xsl:attribute name="type"> ++ <xsl:text>personal</xsl:text> ++ </xsl:attribute> ++ </xsl:if> ++ <namePart> ++ <xsl:value-of select="marc:subfield[@code='a']"/> ++ </namePart> ++ <xsl:call-template name="role"/> ++ </name> ++ </xsl:for-each> ++ <typeOfResource> ++ <xsl:if test="$leader7='c'"> ++ <xsl:attribute name="collection">yes</xsl:attribute> ++ </xsl:if> ++ <xsl:if test="$leader6='d' or $leader6='f' or $leader6='p' or $leader6='t'"> ++ <xsl:attribute name="manuscript">yes</xsl:attribute> ++ </xsl:if> ++ <xsl:choose> ++ <xsl:when test="$leader6='a' or $leader6='t'">text</xsl:when> ++ <xsl:when test="$leader6='e' or $leader6='f'">cartographic</xsl:when> ++ <xsl:when test="$leader6='c' or $leader6='d'">notated music</xsl:when> ++ <xsl:when test="$leader6='i'">sound recording-nonmusical</xsl:when> ++ <xsl:when test="$leader6='j'">sound recording-musical</xsl:when> ++ <xsl:when test="$leader6='k'">still image</xsl:when> ++ <xsl:when test="$leader6='g'">moving image</xsl:when> ++ <xsl:when test="$leader6='r'">three dimensional object</xsl:when> ++ <xsl:when test="$leader6='m'">software, multimedia</xsl:when> ++ <xsl:when test="$leader6='p'">mixed material</xsl:when> ++ </xsl:choose> ++ </typeOfResource> ++ <xsl:if test="substring($controlField008,26,1)='d'"> ++ <genre authority="marc">globe</genre> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag='007'][substring(text(),1,1)='a'][substring(text(),2,1)='r']"> ++ <genre authority="marc">remote sensing image</genre> ++ </xsl:if> ++ <xsl:if test="$typeOf008='MP'"> ++ <xsl:variable name="controlField008-25" select="substring($controlField008,26,1)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$controlField008-25='a' or $controlField008-25='b' or $controlField008-25='c' or marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='j']"> ++ <genre authority="marc">map</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-25='e' or marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='d']"> ++ <genre authority="marc">atlas</genre> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:if test="$typeOf008='SE'"> ++ <xsl:variable name="controlField008-21" select="substring($controlField008,22,1)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$controlField008-21='d'"> ++ <genre authority="marc">database</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-21='l'"> ++ <genre authority="marc">loose-leaf</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-21='m'"> ++ <genre authority="marc">series</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-21='n'"> ++ <genre authority="marc">newspaper</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-21='p'"> ++ <genre authority="marc">periodical</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-21='w'"> ++ <genre authority="marc">web site</genre> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:if test="$typeOf008='BK' or $typeOf008='SE'"> ++ <xsl:variable name="controlField008-24" select="substring($controlField008,25,4)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="contains($controlField008-24,'a')"> ++ <genre authority="marc">abstract or summary</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'b')"> ++ <genre authority="marc">bibliography</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'c')"> ++ <genre authority="marc">catalog</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'d')"> ++ <genre authority="marc">dictionary</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'e')"> ++ <genre authority="marc">encyclopedia</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'f')"> ++ <genre authority="marc">handbook</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'g')"> ++ <genre authority="marc">legal article</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'i')"> ++ <genre authority="marc">index</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'k')"> ++ <genre authority="marc">discography</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'l')"> ++ <genre authority="marc">legislation</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'m')"> ++ <genre authority="marc">theses</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'n')"> ++ <genre authority="marc">survey of literature</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'o')"> ++ <genre authority="marc">review</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'p')"> ++ <genre authority="marc">programmed text</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'q')"> ++ <genre authority="marc">filmography</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'r')"> ++ <genre authority="marc">directory</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'s')"> ++ <genre authority="marc">statistics</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'t')"> ++ <genre authority="marc">technical report</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'v')"> ++ <genre authority="marc">legal case and case notes</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'w')"> ++ <genre authority="marc">law report or digest</genre> ++ </xsl:when> ++ <xsl:when test="contains($controlField008-24,'z')"> ++ <genre authority="marc">treaty</genre> ++ </xsl:when> ++ </xsl:choose> ++ <xsl:variable name="controlField008-29" select="substring($controlField008,30,1)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$controlField008-29='1'"> ++ <genre authority="marc">conference publication</genre> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:if test="$typeOf008='CF'"> ++ <xsl:variable name="controlField008-26" select="substring($controlField008,27,1)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$controlField008-26='a'"> ++ <genre authority="marc">numeric data</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-26='e'"> ++ <genre authority="marc">database</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-26='f'"> ++ <genre authority="marc">font</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-26='g'"> ++ <genre authority="marc">game</genre> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:if test="$typeOf008='BK'"> ++ <xsl:if test="substring($controlField008,25,1)='j'"> ++ <genre authority="marc">patent</genre> ++ </xsl:if> ++ <xsl:if test="substring($controlField008,31,1)='1'"> ++ <genre authority="marc">festschrift</genre> ++ </xsl:if> ++ <xsl:variable name="controlField008-34" select="substring($controlField008,35,1)"></xsl:variable> ++ <xsl:if test="$controlField008-34='a' or $controlField008-34='b' or $controlField008-34='c' or $controlField008-34='d'"> ++ <genre authority="marc">biography</genre> ++ </xsl:if> ++ <xsl:variable name="controlField008-33" select="substring($controlField008,34,1)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$controlField008-33='e'"> ++ <genre authority="marc">essay</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='d'"> ++ <genre authority="marc">drama</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='c'"> ++ <genre authority="marc">comic strip</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='l'"> ++ <genre authority="marc">fiction</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='h'"> ++ <genre authority="marc">humor, satire</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='i'"> ++ <genre authority="marc">letter</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='f'"> ++ <genre authority="marc">novel</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='j'"> ++ <genre authority="marc">short story</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='s'"> ++ <genre authority="marc">speech</genre> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:if test="$typeOf008='MU'"> ++ <xsl:variable name="controlField008-30-31" select="substring($controlField008,31,2)"></xsl:variable> ++ <xsl:if test="contains($controlField008-30-31,'b')"> ++ <genre authority="marc">biography</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'c')"> ++ <genre authority="marc">conference publication</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'d')"> ++ <genre authority="marc">drama</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'e')"> ++ <genre authority="marc">essay</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'f')"> ++ <genre authority="marc">fiction</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'o')"> ++ <genre authority="marc">folktale</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'h')"> ++ <genre authority="marc">history</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'k')"> ++ <genre authority="marc">humor, satire</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'m')"> ++ <genre authority="marc">memoir</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'p')"> ++ <genre authority="marc">poetry</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'r')"> ++ <genre authority="marc">rehearsal</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'g')"> ++ <genre authority="marc">reporting</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'s')"> ++ <genre authority="marc">sound</genre> ++ </xsl:if> ++ <xsl:if test="contains($controlField008-30-31,'l')"> ++ <genre authority="marc">speech</genre> ++ </xsl:if> ++ </xsl:if> ++ <xsl:if test="$typeOf008='VM'"> ++ <xsl:variable name="controlField008-33" select="substring($controlField008,34,1)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$controlField008-33='a'"> ++ <genre authority="marc">art original</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='b'"> ++ <genre authority="marc">kit</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='c'"> ++ <genre authority="marc">art reproduction</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='d'"> ++ <genre authority="marc">diorama</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='f'"> ++ <genre authority="marc">filmstrip</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='g'"> ++ <genre authority="marc">legal article</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='i'"> ++ <genre authority="marc">picture</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='k'"> ++ <genre authority="marc">graphic</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='l'"> ++ <genre authority="marc">technical drawing</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='m'"> ++ <genre authority="marc">motion picture</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='n'"> ++ <genre authority="marc">chart</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='o'"> ++ <genre authority="marc">flash card</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='p'"> ++ <genre authority="marc">microscope slide</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='q' or marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='q']"> ++ <genre authority="marc">model</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='r'"> ++ <genre authority="marc">realia</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='s'"> ++ <genre authority="marc">slide</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='t'"> ++ <genre authority="marc">transparency</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='v'"> ++ <genre authority="marc">videorecording</genre> ++ </xsl:when> ++ <xsl:when test="$controlField008-33='w'"> ++ <genre authority="marc">toy</genre> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=655]"> ++ <genre authority="marc"> ++ <xsl:attribute name="authority"> ++ <xsl:value-of select="marc:subfield[@code='2']"/> ++ </xsl:attribute> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abvxyz</xsl:with-param> ++ <xsl:with-param name="delimeter">-</xsl:with-param> ++ </xsl:call-template> ++ </genre> ++ </xsl:for-each> ++ <originInfo> ++ <xsl:variable name="MARCpublicationCode" select="normalize-space(substring($controlField008,16,3))"></xsl:variable> ++ <xsl:if test="translate($MARCpublicationCode,'|','')"> ++ <place> ++ <placeTerm> ++ <xsl:attribute name="type">code</xsl:attribute> ++ <xsl:attribute name="authority">marccountry</xsl:attribute> ++ <xsl:value-of select="$MARCpublicationCode"/> ++ </placeTerm> ++ </place> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=044]/marc:subfield[@code='c']"> ++ <place> ++ <placeTerm> ++ <xsl:attribute name="type">code</xsl:attribute> ++ <xsl:attribute name="authority">iso3166</xsl:attribute> ++ <xsl:value-of select="."/> ++ </placeTerm> ++ </place> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=260]/marc:subfield[@code='a']"> ++ <place> ++ <placeTerm> ++ <xsl:attribute name="type">text</xsl:attribute> ++ <xsl:call-template name="chopPunctuationFront"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."/> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </placeTerm> ++ </place> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=046]/marc:subfield[@code='m']"> ++ <dateValid point="start"> ++ <xsl:value-of select="."/> ++ </dateValid> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=046]/marc:subfield[@code='n']"> ++ <dateValid point="end"> ++ <xsl:value-of select="."/> ++ </dateValid> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=046]/marc:subfield[@code='j']"> ++ <dateModified> ++ <xsl:value-of select="."/> ++ </dateModified> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=260]/marc:subfield[@code='b' or @code='c' or @code='g']"> ++ <xsl:choose> ++ <xsl:when test="@code='b'"> ++ <publisher> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."/> ++ <xsl:with-param name="punctuation"> ++ <xsl:text>:,;/ </xsl:text> ++ </xsl:with-param> ++ </xsl:call-template> ++ </publisher> ++ </xsl:when> ++ <xsl:when test="@code='c'"> ++ <dateIssued> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."/> ++ </xsl:call-template> ++ </dateIssued> ++ </xsl:when> ++ <xsl:when test="@code='g'"> ++ <dateCreated> ++ <xsl:value-of select="."/> ++ </dateCreated> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:for-each> ++ <xsl:variable name="dataField260c"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="marc:datafield[@tag=260]/marc:subfield[@code='c']"></xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:variable name="controlField008-7-10" select="normalize-space(substring($controlField008, 8, 4))"></xsl:variable> ++ <xsl:variable name="controlField008-11-14" select="normalize-space(substring($controlField008, 12, 4))"></xsl:variable> ++ <xsl:variable name="controlField008-6" select="normalize-space(substring($controlField008, 7, 1))"></xsl:variable> ++ <xsl:if test="$controlField008-6='e' or $controlField008-6='p' or $controlField008-6='r' or $controlField008-6='t' or $controlField008-6='s'"> ++ <xsl:if test="$controlField008-7-10 and ($controlField008-7-10 != $dataField260c)"> ++ <dateIssued encoding="marc"> ++ <xsl:value-of select="$controlField008-7-10"/> ++ </dateIssued> ++ </xsl:if> ++ </xsl:if> ++ <xsl:if test="$controlField008-6='c' or $controlField008-6='d' or $controlField008-6='i' or $controlField008-6='k' or $controlField008-6='m' or $controlField008-6='q' or $controlField008-6='u'"> ++ <xsl:if test="$controlField008-7-10"> ++ <dateIssued encoding="marc" point="start"> ++ <xsl:value-of select="$controlField008-7-10"/> ++ </dateIssued> ++ </xsl:if> ++ </xsl:if> ++ <xsl:if test="$controlField008-6='c' or $controlField008-6='d' or $controlField008-6='i' or $controlField008-6='k' or $controlField008-6='m' or $controlField008-6='q' or $controlField008-6='u'"> ++ <xsl:if test="$controlField008-11-14"> ++ <dateIssued encoding="marc" point="end"> ++ <xsl:value-of select="$controlField008-11-14"/> ++ </dateIssued> ++ </xsl:if> ++ </xsl:if> ++ <xsl:if test="$controlField008-6='q'"> ++ <xsl:if test="$controlField008-7-10"> ++ <dateIssued encoding="marc" point="start" qualifier="questionable"> ++ <xsl:value-of select="$controlField008-7-10"/> ++ </dateIssued> ++ </xsl:if> ++ </xsl:if> ++ <xsl:if test="$controlField008-6='q'"> ++ <xsl:if test="$controlField008-11-14"> ++ <dateIssued encoding="marc" point="end" qualifier="questionable"> ++ <xsl:value-of select="$controlField008-11-14"/> ++ </dateIssued> ++ </xsl:if> ++ </xsl:if> ++ <xsl:if test="$controlField008-6='t'"> ++ <xsl:if test="$controlField008-11-14"> ++ <copyrightDate encoding="marc"> ++ <xsl:value-of select="$controlField008-11-14"/> ++ </copyrightDate> ++ </xsl:if> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=033][@ind1=0 or @ind1=1]/marc:subfield[@code='a']"> ++ <dateCaptured encoding="iso8601"> ++ <xsl:value-of select="."/> ++ </dateCaptured> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=033][@ind1=2]/marc:subfield[@code='a'][1]"> ++ <dateCaptured encoding="iso8601" point="start"> ++ <xsl:value-of select="."/> ++ </dateCaptured> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=033][@ind1=2]/marc:subfield[@code='a'][2]"> ++ <dateCaptured encoding="iso8601" point="end"> ++ <xsl:value-of select="."/> ++ </dateCaptured> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=250]/marc:subfield[@code='a']"> ++ <edition> ++ <xsl:value-of select="."/> ++ </edition> ++ </xsl:for-each> ++ <xsl:for-each select="marc:leader"> ++ <issuance> ++ <xsl:choose> ++ <xsl:when test="$leader7='a' or $leader7='c' or $leader7='d' or $leader7='m'">monographic</xsl:when> ++ <xsl:when test="$leader7='b' or $leader7='i' or $leader7='s'">continuing</xsl:when> ++ </xsl:choose> ++ </issuance> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=310]|marc:datafield[@tag=321]"> ++ <frequency> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </frequency> ++ </xsl:for-each> ++ </originInfo> ++ <xsl:variable name="controlField008-35-37" select="normalize-space(translate(substring($controlField008,36,3),'|#',''))"></xsl:variable> ++ <xsl:if test="$controlField008-35-37"> ++ <language> ++ <languageTerm authority="iso639-2b" type="code"> ++ <xsl:value-of select="substring($controlField008,36,3)"/> ++ </languageTerm> ++ </language> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=041]"> ++ <xsl:for-each select="marc:subfield[@code='a' or @code='b' or @code='d' or @code='e' or @code='f' or @code='g' or @code='h']"> ++ <xsl:variable name="langCodes" select="."/> ++ <xsl:choose> ++ <xsl:when test="../marc:subfield[@code='2']='rfc3066'"> ++ <!-- not stacked but could be repeated --> ++ <xsl:call-template name="rfcLanguages"> ++ <xsl:with-param name="nodeNum"> ++ <xsl:value-of select="1"/> ++ </xsl:with-param> ++ <xsl:with-param name="usedLanguages"> ++ <xsl:text></xsl:text> ++ </xsl:with-param> ++ <xsl:with-param name="controlField008-35-37"> ++ <xsl:value-of select="$controlField008-35-37"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:otherwise> ++ <!-- iso --> ++ <xsl:variable name="allLanguages"> ++ <xsl:copy-of select="$langCodes"></xsl:copy-of> ++ </xsl:variable> ++ <xsl:variable name="currentLanguage"> ++ <xsl:value-of select="substring($allLanguages,1,3)"></xsl:value-of> ++ </xsl:variable> ++ <xsl:call-template name="isoLanguage"> ++ <xsl:with-param name="currentLanguage"> ++ <xsl:value-of select="substring($allLanguages,1,3)"></xsl:value-of> ++ </xsl:with-param> ++ <xsl:with-param name="remainingLanguages"> ++ <xsl:value-of select="substring($allLanguages,4,string-length($allLanguages)-3)"></xsl:value-of> ++ </xsl:with-param> ++ <xsl:with-param name="usedLanguages"> ++ <xsl:if test="$controlField008-35-37"> ++ <xsl:value-of select="$controlField008-35-37"></xsl:value-of> ++ </xsl:if> ++ </xsl:with-param> ++ </xsl:call-template> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:for-each> ++ </xsl:for-each> ++ <xsl:variable name="physicalDescription"> ++ <!--3.2 change tmee 007/11 --> ++ <xsl:if test="$typeOf008='CF' and marc:controlfield[@tag=007][substring(.,12,1)='a']"> ++ <digitalOrigin>reformatted digital</digitalOrigin> ++ </xsl:if> ++ <xsl:if test="$typeOf008='CF' and marc:controlfield[@tag=007][substring(.,12,1)='b']"> ++ <digitalOrigin>digitized microfilm</digitalOrigin> ++ </xsl:if> ++ <xsl:if test="$typeOf008='CF' and marc:controlfield[@tag=007][substring(.,12,1)='d']"> ++ <digitalOrigin>digitized other analog</digitalOrigin> ++ </xsl:if> ++ <xsl:variable name="controlField008-23" select="substring($controlField008,24,1)"></xsl:variable> ++ <xsl:variable name="controlField008-29" select="substring($controlField008,30,1)"></xsl:variable> ++ <xsl:variable name="check008-23"> ++ <xsl:if test="$typeOf008='BK' or $typeOf008='MU' or $typeOf008='SE' or $typeOf008='MM'"> ++ <xsl:value-of select="true()"></xsl:value-of> ++ </xsl:if> ++ </xsl:variable> ++ <xsl:variable name="check008-29"> ++ <xsl:if test="$typeOf008='MP' or $typeOf008='VM'"> ++ <xsl:value-of select="true()"></xsl:value-of> ++ </xsl:if> ++ </xsl:variable> ++ <xsl:choose> ++ <xsl:when test="($check008-23 and $controlField008-23='f') or ($check008-29 and $controlField008-29='f')"> ++ <form authority="marcform">braille</form> ++ </xsl:when> ++ <xsl:when test="($controlField008-23=' ' and ($leader6='c' or $leader6='d')) or (($typeOf008='BK' or $typeOf008='SE') and ($controlField008-23=' ' or $controlField008='r'))"> ++ <form authority="marcform">print</form> ++ </xsl:when> ++ <xsl:when test="$leader6 = 'm' or ($check008-23 and $controlField008-23='s') or ($check008-29 and $controlField008-29='s')"> ++ <form authority="marcform">electronic</form> ++ </xsl:when> ++ <xsl:when test="($check008-23 and $controlField008-23='b') or ($check008-29 and $controlField008-29='b')"> ++ <form authority="marcform">microfiche</form> ++ </xsl:when> ++ <xsl:when test="($check008-23 and $controlField008-23='a') or ($check008-29 and $controlField008-29='a')"> ++ <form authority="marcform">microfilm</form> ++ </xsl:when> ++ </xsl:choose> ++ <!-- 1/04 fix --> ++ <xsl:if test="marc:datafield[@tag=130]/marc:subfield[@code='h']"> ++ <form authority="gmd"> ++ <xsl:call-template name="chopBrackets"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:datafield[@tag=130]/marc:subfield[@code='h']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </form> ++ </xsl:if> ++ <xsl:if test="marc:datafield[@tag=240]/marc:subfield[@code='h']"> ++ <form authority="gmd"> ++ <xsl:call-template name="chopBrackets"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:datafield[@tag=240]/marc:subfield[@code='h']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </form> ++ </xsl:if> ++ <xsl:if test="marc:datafield[@tag=242]/marc:subfield[@code='h']"> ++ <form authority="gmd"> ++ <xsl:call-template name="chopBrackets"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:datafield[@tag=242]/marc:subfield[@code='h']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </form> ++ </xsl:if> ++ <xsl:if test="marc:datafield[@tag=245]/marc:subfield[@code='h']"> ++ <form authority="gmd"> ++ <xsl:call-template name="chopBrackets"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:datafield[@tag=245]/marc:subfield[@code='h']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </form> ++ </xsl:if> ++ <xsl:if test="marc:datafield[@tag=246]/marc:subfield[@code='h']"> ++ <form authority="gmd"> ++ <xsl:call-template name="chopBrackets"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:datafield[@tag=246]/marc:subfield[@code='h']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </form> ++ </xsl:if> ++ <xsl:if test="marc:datafield[@tag=730]/marc:subfield[@code='h']"> ++ <form authority="gmd"> ++ <xsl:call-template name="chopBrackets"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:datafield[@tag=730]/marc:subfield[@code='h']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </form> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=256]/marc:subfield[@code='a']"> ++ <form> ++ <xsl:value-of select="."></xsl:value-of> ++ </form> ++ </xsl:for-each> ++ <xsl:for-each select="marc:controlfield[@tag=007][substring(text(),1,1)='c']"> ++ <xsl:choose> ++ <xsl:when test="substring(text(),14,1)='a'"> ++ <reformattingQuality>access</reformattingQuality> ++ </xsl:when> ++ <xsl:when test="substring(text(),14,1)='p'"> ++ <reformattingQuality>preservation</reformattingQuality> ++ </xsl:when> ++ <xsl:when test="substring(text(),14,1)='r'"> ++ <reformattingQuality>replacement</reformattingQuality> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:for-each> ++ <!--3.2 change tmee 007/01 --> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='b']"> ++ <form authority="smd">chip cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='c']"> ++ <form authority="smd">computer optical disc cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='j']"> ++ <form authority="smd">magnetic disc</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='m']"> ++ <form authority="smd">magneto-optical disc</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='o']"> ++ <form authority="smd">optical disc</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='r']"> ++ <form authority="smd">remote</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='a']"> ++ <form authority="smd">tape cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='f']"> ++ <form authority="smd">tape cassette</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='c'][substring(text(),2,1)='h']"> ++ <form authority="smd">tape reel</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='d'][substring(text(),2,1)='a']"> ++ <form authority="smd">celestial globe</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='d'][substring(text(),2,1)='e']"> ++ <form authority="smd">earth moon globe</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='d'][substring(text(),2,1)='b']"> ++ <form authority="smd">planetary or lunar globe</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='d'][substring(text(),2,1)='c']"> ++ <form authority="smd">terrestrial globe</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='o'][substring(text(),2,1)='o']"> ++ <form authority="smd">kit</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='d']"> ++ <form authority="smd">atlas</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='g']"> ++ <form authority="smd">diagram</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='j']"> ++ <form authority="smd">map</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='q']"> ++ <form authority="smd">model</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='k']"> ++ <form authority="smd">profile</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='r']"> ++ <form authority="smd">remote-sensing image</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='s']"> ++ <form authority="smd">section</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='a'][substring(text(),2,1)='y']"> ++ <form authority="smd">view</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='a']"> ++ <form authority="smd">aperture card</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='e']"> ++ <form authority="smd">microfiche</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='f']"> ++ <form authority="smd">microfiche cassette</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='b']"> ++ <form authority="smd">microfilm cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='c']"> ++ <form authority="smd">microfilm cassette</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='d']"> ++ <form authority="smd">microfilm reel</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='h'][substring(text(),2,1)='g']"> ++ <form authority="smd">microopaque</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='m'][substring(text(),2,1)='c']"> ++ <form authority="smd">film cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='m'][substring(text(),2,1)='f']"> ++ <form authority="smd">film cassette</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='m'][substring(text(),2,1)='r']"> ++ <form authority="smd">film reel</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='n']"> ++ <form authority="smd">chart</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='c']"> ++ <form authority="smd">collage</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='d']"> ++ <form authority="smd">drawing</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='o']"> ++ <form authority="smd">flash card</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='e']"> ++ <form authority="smd">painting</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='f']"> ++ <form authority="smd">photomechanical print</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='g']"> ++ <form authority="smd">photonegative</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='h']"> ++ <form authority="smd">photoprint</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='i']"> ++ <form authority="smd">picture</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='j']"> ++ <form authority="smd">print</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='k'][substring(text(),2,1)='l']"> ++ <form authority="smd">technical drawing</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='q'][substring(text(),2,1)='q']"> ++ <form authority="smd">notated music</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='g'][substring(text(),2,1)='d']"> ++ <form authority="smd">filmslip</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='g'][substring(text(),2,1)='c']"> ++ <form authority="smd">filmstrip cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='g'][substring(text(),2,1)='o']"> ++ <form authority="smd">filmstrip roll</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='g'][substring(text(),2,1)='f']"> ++ <form authority="smd">other filmstrip type</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='g'][substring(text(),2,1)='s']"> ++ <form authority="smd">slide</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='g'][substring(text(),2,1)='t']"> ++ <form authority="smd">transparency</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='r'][substring(text(),2,1)='r']"> ++ <form authority="smd">remote-sensing image</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='e']"> ++ <form authority="smd">cylinder</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='q']"> ++ <form authority="smd">roll</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='g']"> ++ <form authority="smd">sound cartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='s']"> ++ <form authority="smd">sound cassette</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='d']"> ++ <form authority="smd">sound disc</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='t']"> ++ <form authority="smd">sound-tape reel</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='i']"> ++ <form authority="smd">sound-track film</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='s'][substring(text(),2,1)='w']"> ++ <form authority="smd">wire recording</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='f'][substring(text(),2,1)='c']"> ++ <form authority="smd">braille</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='f'][substring(text(),2,1)='b']"> ++ <form authority="smd">combination</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='f'][substring(text(),2,1)='a']"> ++ <form authority="smd">moon</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='f'][substring(text(),2,1)='d']"> ++ <form authority="smd">tactile, with no writing system</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='t'][substring(text(),2,1)='c']"> ++ <form authority="smd">braille</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='t'][substring(text(),2,1)='b']"> ++ <form authority="smd">large print</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='t'][substring(text(),2,1)='a']"> ++ <form authority="smd">regular print</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='t'][substring(text(),2,1)='d']"> ++ <form authority="smd">text in looseleaf binder</form> ++ </xsl:if> ++ ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='v'][substring(text(),2,1)='c']"> ++ <form authority="smd">videocartridge</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='v'][substring(text(),2,1)='f']"> ++ <form authority="smd">videocassette</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='v'][substring(text(),2,1)='d']"> ++ <form authority="smd">videodisc</form> ++ </xsl:if> ++ <xsl:if test="marc:controlfield[@tag=007][substring(text(),1,1)='v'][substring(text(),2,1)='r']"> ++ <form authority="smd">videoreel</form> ++ </xsl:if> ++ ++ <xsl:for-each select="marc:datafield[@tag=856]/marc:subfield[@code='q'][string-length(.)>1]"> ++ <internetMediaType> ++ <xsl:value-of select="."></xsl:value-of> ++ </internetMediaType> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=300]"> ++ <extent> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abce</xsl:with-param> ++ </xsl:call-template> ++ </extent> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:if test="string-length(normalize-space($physicalDescription))"> ++ <physicalDescription> ++ <xsl:copy-of select="$physicalDescription"></xsl:copy-of> ++ </physicalDescription> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=520]"> ++ <abstract> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </abstract> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=505]"> ++ <tableOfContents> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">agrt</xsl:with-param> ++ </xsl:call-template> ++ </tableOfContents> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=521]"> ++ <targetAudience> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </targetAudience> ++ </xsl:for-each> ++ <xsl:if test="$typeOf008='BK' or $typeOf008='CF' or $typeOf008='MU' or $typeOf008='VM'"> ++ <xsl:variable name="controlField008-22" select="substring($controlField008,23,1)"></xsl:variable> ++ <xsl:choose> ++ <!-- 01/04 fix --> ++ <xsl:when test="$controlField008-22='d'"> ++ <targetAudience authority="marctarget">adolescent</targetAudience> ++ </xsl:when> ++ <xsl:when test="$controlField008-22='e'"> ++ <targetAudience authority="marctarget">adult</targetAudience> ++ </xsl:when> ++ <xsl:when test="$controlField008-22='g'"> ++ <targetAudience authority="marctarget">general</targetAudience> ++ </xsl:when> ++ <xsl:when test="$controlField008-22='b' or $controlField008-22='c' or $controlField008-22='j'"> ++ <targetAudience authority="marctarget">juvenile</targetAudience> ++ </xsl:when> ++ <xsl:when test="$controlField008-22='a'"> ++ <targetAudience authority="marctarget">preschool</targetAudience> ++ </xsl:when> ++ <xsl:when test="$controlField008-22='f'"> ++ <targetAudience authority="marctarget">specialized</targetAudience> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:if> ++ <xsl:for-each select="marc:datafield[@tag=245]/marc:subfield[@code='c']"> ++ <note type="statement of responsibility"> ++ <xsl:value-of select="."></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=500]"> ++ <note> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ <xsl:call-template name="uri"></xsl:call-template> ++ </note> ++ </xsl:for-each> ++ ++ <!--3.2 change tmee additional note fields--> ++ ++ <xsl:for-each select="marc:datafield[@tag=506]"> ++ <note type="restrictions"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ <xsl:for-each select="marc:datafield[@tag=510]"> ++ <note type="citation/reference"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ ++ <xsl:for-each select="marc:datafield[@tag=511]"> ++ <note type="performers"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=518]"> ++ <note type="venue"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ <xsl:for-each select="marc:datafield[@tag=530]"> ++ <note type="additional physical form"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ <xsl:for-each select="marc:datafield[@tag=533]"> ++ <note type="reproduction"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ <xsl:for-each select="marc:datafield[@tag=534]"> ++ <note type="original version"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ <xsl:for-each select="marc:datafield[@tag=538]"> ++ <note type="system details"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ <xsl:for-each select="marc:datafield[@tag=583]"> ++ <note type="action"> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ ++ ++ ++ ++ ++ <xsl:for-each select="marc:datafield[@tag=501 or @tag=502 or @tag=504 or @tag=507 or @tag=508 or @tag=513 or @tag=514 or @tag=515 or @tag=516 or @tag=522 or @tag=524 or @tag=525 or @tag=526 or @tag=535 or @tag=536 or @tag=540 or @tag=541 or @tag=544 or @tag=545 or @tag=546 or @tag=547 or @tag=550 or @tag=552 or @tag=555 or @tag=556 or @tag=561 or @tag=562 or @tag=565 or @tag=567 or @tag=580 or @tag=581 or @tag=584 or @tag=585 or @tag=586]"> ++ <note> ++ <xsl:call-template name="uri"></xsl:call-template> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield[@code!='6' or @code!='8']"> ++ <xsl:value-of select="."></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=034][marc:subfield[@code='d' or @code='e' or @code='f' or @code='g']]"> ++ <subject> ++ <cartographics> ++ <coordinates> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">defg</xsl:with-param> ++ </xsl:call-template> ++ </coordinates> ++ </cartographics> ++ </subject> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=043]"> ++ <subject> ++ <xsl:for-each select="marc:subfield[@code='a' or @code='b' or @code='c']"> ++ <geographicCode> ++ <xsl:attribute name="authority"> ++ <xsl:if test="@code='a'"> ++ <xsl:text>marcgac</xsl:text> ++ </xsl:if> ++ <xsl:if test="@code='b'"> ++ <xsl:value-of select="following-sibling::marc:subfield[@code=2]"></xsl:value-of> ++ </xsl:if> ++ <xsl:if test="@code='c'"> ++ <xsl:text>iso3166</xsl:text> ++ </xsl:if> ++ </xsl:attribute> ++ <xsl:value-of select="self::marc:subfield"></xsl:value-of> ++ </geographicCode> ++ </xsl:for-each> ++ </subject> ++ </xsl:for-each> ++ <!-- tmee 2006/11/27 --> ++ <xsl:for-each select="marc:datafield[@tag=255]"> ++ <subject> ++ <xsl:for-each select="marc:subfield[@code='a' or @code='b' or @code='c']"> ++ <cartographics> ++ <xsl:if test="@code='a'"> ++ <scale> ++ <xsl:value-of select="."></xsl:value-of> ++ </scale> ++ </xsl:if> ++ <xsl:if test="@code='b'"> ++ <projection> ++ <xsl:value-of select="."></xsl:value-of> ++ </projection> ++ </xsl:if> ++ <xsl:if test="@code='c'"> ++ <coordinates> ++ <xsl:value-of select="."></xsl:value-of> ++ </coordinates> ++ </xsl:if> ++ </cartographics> ++ </xsl:for-each> ++ </subject> ++ </xsl:for-each> ++ ++ <xsl:apply-templates select="marc:datafield[653 >= @tag and @tag >= 600]"></xsl:apply-templates> ++ <xsl:apply-templates select="marc:datafield[@tag=656]"></xsl:apply-templates> ++ <xsl:for-each select="marc:datafield[@tag=752]"> ++ <subject> ++ <hierarchicalGeographic> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <country> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </country> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <state> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </state> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='c']"> ++ <county> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </county> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='d']"> ++ <city> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </city> ++ </xsl:for-each> ++ </hierarchicalGeographic> ++ </subject> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=045][marc:subfield[@code='b']]"> ++ <subject> ++ <xsl:choose> ++ <xsl:when test="@ind1=2"> ++ <temporal encoding="iso8601" point="start"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:subfield[@code='b'][1]"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </temporal> ++ <temporal encoding="iso8601" point="end"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:subfield[@code='b'][2]"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </temporal> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <temporal encoding="iso8601"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </temporal> ++ </xsl:for-each> ++ </xsl:otherwise> ++ </xsl:choose> ++ </subject> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=050]"> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <classification authority="lcc"> ++ <xsl:if test="../marc:subfield[@code='3']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:value-of select="../marc:subfield[@code='3']"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:value-of select="preceding-sibling::marc:subfield[@code='a'][1]"></xsl:value-of> ++ <xsl:text> </xsl:text> ++ <xsl:value-of select="text()"></xsl:value-of> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='a'][not(following-sibling::marc:subfield[@code='b'])]"> ++ <classification authority="lcc"> ++ <xsl:if test="../marc:subfield[@code='3']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:value-of select="../marc:subfield[@code='3']"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:value-of select="text()"></xsl:value-of> ++ </classification> ++ </xsl:for-each> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=082]"> ++ <classification authority="ddc"> ++ <xsl:if test="marc:subfield[@code='2']"> ++ <xsl:attribute name="edition"> ++ <xsl:value-of select="marc:subfield[@code='2']"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=080]"> ++ <classification authority="udc"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abx</xsl:with-param> ++ </xsl:call-template> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=060]"> ++ <classification authority="nlm"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=086][@ind1=0]"> ++ <classification authority="sudocs"> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=086][@ind1=1]"> ++ <classification authority="candoc"> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=086]"> ++ <classification> ++ <xsl:attribute name="authority"> ++ <xsl:value-of select="marc:subfield[@code='2']"></xsl:value-of> ++ </xsl:attribute> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=084]"> ++ <classification> ++ <xsl:attribute name="authority"> ++ <xsl:value-of select="marc:subfield[@code='2']"></xsl:value-of> ++ </xsl:attribute> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </classification> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=440]"> ++ <relatedItem type="series"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">av</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=490][@ind1=0]"> ++ <relatedItem type="series"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">av</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=510]"> ++ <relatedItem type="isReferencedBy"> ++ <note> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abcx3</xsl:with-param> ++ </xsl:call-template> ++ </note> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=534]"> ++ <relatedItem type="original"> ++ <xsl:call-template name="relatedTitle"></xsl:call-template> ++ <xsl:call-template name="relatedName"></xsl:call-template> ++ <xsl:if test="marc:subfield[@code='b' or @code='c']"> ++ <originInfo> ++ <xsl:for-each select="marc:subfield[@code='c']"> ++ <publisher> ++ <xsl:value-of select="."></xsl:value-of> ++ </publisher> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <edition> ++ <xsl:value-of select="."></xsl:value-of> ++ </edition> ++ </xsl:for-each> ++ </originInfo> ++ </xsl:if> ++ <xsl:call-template name="relatedIdentifierISSN"></xsl:call-template> ++ <xsl:for-each select="marc:subfield[@code='z']"> ++ <identifier type="isbn"> ++ <xsl:value-of select="."></xsl:value-of> ++ </identifier> ++ </xsl:for-each> ++ <xsl:call-template name="relatedNote"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=700][marc:subfield[@code='t']]"> ++ <relatedItem> ++ <xsl:call-template name="constituentOrRelatedType"></xsl:call-template> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">tfklmorsv</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="afterCodes">g</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ <name type="personal"> ++ <namePart> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">aq</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="beforeCodes">g</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:call-template name="termsOfAddress"></xsl:call-template> ++ <xsl:call-template name="nameDate"></xsl:call-template> ++ <xsl:call-template name="role"></xsl:call-template> ++ </name> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifierISSN"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=710][marc:subfield[@code='t']]"> ++ <relatedItem> ++ <xsl:call-template name="constituentOrRelatedType"></xsl:call-template> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">tfklmorsv</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="afterCodes">dg</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="relatedPartNumName"></xsl:call-template> ++ </titleInfo> ++ <name type="corporate"> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <xsl:variable name="tempNamePart"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">c</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="beforeCodes">dgn</xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:if test="normalize-space($tempNamePart)"> ++ <namePart> ++ <xsl:value-of select="$tempNamePart"></xsl:value-of> ++ </namePart> ++ </xsl:if> ++ <xsl:call-template name="role"></xsl:call-template> ++ </name> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifierISSN"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=711][marc:subfield[@code='t']]"> ++ <relatedItem> ++ <xsl:call-template name="constituentOrRelatedType"></xsl:call-template> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">tfklsv</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="afterCodes">g</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="relatedPartNumName"></xsl:call-template> ++ </titleInfo> ++ <name type="conference"> ++ <namePart> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">aqdc</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="beforeCodes">gn</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </name> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifierISSN"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=730][@ind2=2]"> ++ <relatedItem> ++ <xsl:call-template name="constituentOrRelatedType"></xsl:call-template> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">adfgklmorsv</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifierISSN"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=740][@ind2=2]"> ++ <relatedItem> ++ <xsl:call-template name="constituentOrRelatedType"></xsl:call-template> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=760]|marc:datafield[@tag=762]"> ++ <relatedItem type="series"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=765]|marc:datafield[@tag=767]|marc:datafield[@tag=777]|marc:datafield[@tag=787]"> ++ <relatedItem> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=775]"> ++ <relatedItem type="otherVersion"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=770]|marc:datafield[@tag=774]"> ++ <relatedItem type="constituent"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=772]|marc:datafield[@tag=773]"> ++ <relatedItem type="host"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=776]"> ++ <relatedItem type="otherFormat"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=780]"> ++ <relatedItem type="preceding"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=785]"> ++ <relatedItem type="succeeding"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=786]"> ++ <relatedItem type="original"> ++ <xsl:call-template name="relatedItem76X-78X"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=800]"> ++ <relatedItem type="series"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">tfklmorsv</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="afterCodes">g</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"></xsl:call-template> ++ </titleInfo> ++ <name type="personal"> ++ <namePart> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">aq</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="beforeCodes">g</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:call-template name="termsOfAddress"></xsl:call-template> ++ <xsl:call-template name="nameDate"></xsl:call-template> ++ <xsl:call-template name="role"></xsl:call-template> ++ </name> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=810]"> ++ <relatedItem type="series"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">tfklmorsv</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="afterCodes">dg</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="relatedPartNumName"></xsl:call-template> ++ </titleInfo> ++ <name type="corporate"> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <namePart> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">c</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="beforeCodes">dgn</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:call-template name="role"></xsl:call-template> ++ </name> ++ <xsl:call-template name="relatedForm"></xsl:call-template> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=811]"> ++ <relatedItem type="series"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">tfklsv</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="afterCodes">g</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="relatedPartNumName"/> ++ </titleInfo> ++ <name type="conference"> ++ <namePart> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="anyCodes">aqdc</xsl:with-param> ++ <xsl:with-param name="axis">t</xsl:with-param> ++ <xsl:with-param name="beforeCodes">gn</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:call-template name="role"/> ++ </name> ++ <xsl:call-template name="relatedForm"/> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='830']"> ++ <relatedItem type="series"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">adfgklmorsv</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:call-template name="part"/> ++ </titleInfo> ++ <xsl:call-template name="relatedForm"/> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='856'][@ind2='2']/marc:subfield[@code='q']"> ++ <relatedItem> ++ <internetMediaType> ++ <xsl:value-of select="."/> ++ </internetMediaType> ++ </relatedItem> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='020']"> ++ <xsl:call-template name="isInvalid"> ++ <xsl:with-param name="type">isbn</xsl:with-param> ++ </xsl:call-template> ++ <xsl:if test="marc:subfield[@code='a']"> ++ <identifier type="isbn"> ++ <xsl:value-of select="marc:subfield[@code='a']"/> ++ </identifier> ++ </xsl:if> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='024'][@ind1='0']"> ++ <xsl:call-template name="isInvalid"> ++ <xsl:with-param name="type">isrc</xsl:with-param> ++ </xsl:call-template> ++ <xsl:if test="marc:subfield[@code='a']"> ++ <identifier type="isrc"> ++ <xsl:value-of select="marc:subfield[@code='a']"/> ++ </identifier> ++ </xsl:if> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='024'][@ind1='2']"> ++ <xsl:call-template name="isInvalid"> ++ <xsl:with-param name="type">ismn</xsl:with-param> ++ </xsl:call-template> ++ <xsl:if test="marc:subfield[@code='a']"> ++ <identifier type="ismn"> ++ <xsl:value-of select="marc:subfield[@code='a']"/> ++ </identifier> ++ </xsl:if> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='024'][@ind1='4']"> ++ <xsl:call-template name="isInvalid"> ++ <xsl:with-param name="type">sici</xsl:with-param> ++ </xsl:call-template> ++ <identifier type="sici"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </identifier> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='022']"> ++ <xsl:call-template name="isInvalid"> ++ <xsl:with-param name="type">issn</xsl:with-param> ++ </xsl:call-template> ++ <identifier type="issn"> ++ <xsl:value-of select="marc:subfield[@code='a']"/> ++ </identifier> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='010']"> ++ <xsl:call-template name="isInvalid"> ++ <xsl:with-param name="type">lccn</xsl:with-param> ++ </xsl:call-template> ++ <identifier type="lccn"> ++ <xsl:value-of select="normalize-space(marc:subfield[@code='a'])"/> ++ </identifier> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='028']"> ++ <identifier> ++ <xsl:attribute name="type"> ++ <xsl:choose> ++ <xsl:when test="@ind1='0'">issue number</xsl:when> ++ <xsl:when test="@ind1='1'">matrix number</xsl:when> ++ <xsl:when test="@ind1='2'">music plate</xsl:when> ++ <xsl:when test="@ind1='3'">music publisher</xsl:when> ++ <xsl:when test="@ind1='4'">videorecording identifier</xsl:when> ++ </xsl:choose> ++ </xsl:attribute> ++ <!--<xsl:call-template name="isInvalid"/>--> <!-- no $z in 028 --> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes"> ++ <xsl:choose> ++ <xsl:when test="@ind1='0'">ba</xsl:when> ++ <xsl:otherwise>ab</xsl:otherwise> ++ </xsl:choose> ++ </xsl:with-param> ++ </xsl:call-template> ++ </identifier> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='037']"> ++ <identifier type="stock number"> ++ <!--<xsl:call-template name="isInvalid"/>--> <!-- no $z in 037 --> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">ab</xsl:with-param> ++ </xsl:call-template> ++ </identifier> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag='856'][marc:subfield[@code='u']]"> ++ <identifier> ++ <xsl:attribute name="type"> ++ <xsl:choose> ++ <xsl:when test="starts-with(marc:subfield[@code='u'],'urn:doi') or starts-with(marc:subfield[@code='u'],'doi')">doi</xsl:when> ++ <xsl:when test="starts-with(marc:subfield[@code='u'],'urn:hdl') or starts-with(marc:subfield[@code='u'],'hdl') or starts-with(marc:subfield[@code='u'],'http://hdl.loc.gov')">hdl</xsl:when> ++ <xsl:otherwise>uri</xsl:otherwise> ++ </xsl:choose> ++ </xsl:attribute> ++ <xsl:choose> ++ <xsl:when test="starts-with(marc:subfield[@code='u'],'urn:hdl') or starts-with(marc:subfield[@code='u'],'hdl') or starts-with(marc:subfield[@code='u'],'http://hdl.loc.gov') "> ++ <xsl:value-of select="concat('hdl:',substring-after(marc:subfield[@code='u'],'http://hdl.loc.gov/'))"></xsl:value-of> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:value-of select="marc:subfield[@code='u']"></xsl:value-of> ++ </xsl:otherwise> ++ </xsl:choose> ++ </identifier> ++ <xsl:if test="starts-with(marc:subfield[@code='u'],'urn:hdl') or starts-with(marc:subfield[@code='u'],'hdl')"> ++ <identifier type="hdl"> ++ <xsl:if test="marc:subfield[@code='y' or @code='3' or @code='z']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">y3z</xsl:with-param> ++ </xsl:call-template> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:value-of select="concat('hdl:',substring-after(marc:subfield[@code='u'],'http://hdl.loc.gov/'))"></xsl:value-of> ++ </identifier> ++ </xsl:if> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=024][@ind1=1]"> ++ <identifier type="upc"> ++ <xsl:call-template name="isInvalid"/> ++ <xsl:value-of select="marc:subfield[@code='a']"/> ++ </identifier> ++ </xsl:for-each> ++ <!-- 1/04 fix added $y --> ++ <xsl:for-each select="marc:datafield[@tag=856][marc:subfield[@code='u']]"> ++ <location> ++ <url> ++ <xsl:if test="marc:subfield[@code='y' or @code='3']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">y3</xsl:with-param> ++ </xsl:call-template> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:if test="marc:subfield[@code='z' ]"> ++ <xsl:attribute name="note"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">z</xsl:with-param> ++ </xsl:call-template> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:value-of select="marc:subfield[@code='u']"></xsl:value-of> ++ ++ </url> ++ </location> ++ </xsl:for-each> ++ ++ <!-- 3.2 change tmee 856z --> ++ ++ ++ <xsl:for-each select="marc:datafield[@tag=852]"> ++ <location> ++ <physicalLocation> ++ <xsl:call-template name="displayLabel"></xsl:call-template> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abje</xsl:with-param> ++ </xsl:call-template> ++ </physicalLocation> ++ </location> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=506]"> ++ <accessCondition type="restrictionOnAccess"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abcd35</xsl:with-param> ++ </xsl:call-template> ++ </accessCondition> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=540]"> ++ <accessCondition type="useAndReproduction"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abcde35</xsl:with-param> ++ </xsl:call-template> ++ </accessCondition> ++ </xsl:for-each> ++ <recordInfo> ++ <xsl:for-each select="marc:datafield[@tag=040]"> ++ <recordContentSource authority="marcorg"> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </recordContentSource> ++ </xsl:for-each> ++ <xsl:for-each select="marc:controlfield[@tag=008]"> ++ <recordCreationDate encoding="marc"> ++ <xsl:value-of select="substring(.,1,6)"></xsl:value-of> ++ </recordCreationDate> ++ </xsl:for-each> ++ <xsl:for-each select="marc:controlfield[@tag=005]"> ++ <recordChangeDate encoding="iso8601"> ++ <xsl:value-of select="."></xsl:value-of> ++ </recordChangeDate> ++ </xsl:for-each> ++ <xsl:for-each select="marc:controlfield[@tag=001]"> ++ <recordIdentifier> ++ <xsl:if test="../marc:controlfield[@tag=003]"> ++ <xsl:attribute name="source"> ++ <xsl:value-of select="../marc:controlfield[@tag=003]"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:value-of select="."></xsl:value-of> ++ </recordIdentifier> ++ </xsl:for-each> ++ <xsl:for-each select="marc:datafield[@tag=040]/marc:subfield[@code='b']"> ++ <languageOfCataloging> ++ <languageTerm authority="iso639-2b" type="code"> ++ <xsl:value-of select="."></xsl:value-of> ++ </languageTerm> ++ </languageOfCataloging> ++ </xsl:for-each> ++ </recordInfo> ++ </xsl:template> ++ <xsl:template name="displayForm"> ++ <xsl:for-each select="marc:subfield[@code='c']"> ++ <displayForm> ++ <xsl:value-of select="."></xsl:value-of> ++ </displayForm> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="affiliation"> ++ <xsl:for-each select="marc:subfield[@code='u']"> ++ <affiliation> ++ <xsl:value-of select="."></xsl:value-of> ++ </affiliation> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="uri"> ++ <xsl:for-each select="marc:subfield[@code='u']"> ++ <xsl:attribute name="xlink:href"> ++ <xsl:value-of select="."></xsl:value-of> ++ </xsl:attribute> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="role"> ++ <xsl:for-each select="marc:subfield[@code='e']"> ++ <role> ++ <roleTerm type="text"> ++ <xsl:value-of select="."></xsl:value-of> ++ </roleTerm> ++ </role> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='4']"> ++ <role> ++ <roleTerm authority="marcrelator" type="code"> ++ <xsl:value-of select="."></xsl:value-of> ++ </roleTerm> ++ </role> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="part"> ++ <xsl:variable name="partNumber"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">n</xsl:with-param> ++ <xsl:with-param name="anyCodes">n</xsl:with-param> ++ <xsl:with-param name="afterCodes">fgkdlmor</xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:variable name="partName"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">p</xsl:with-param> ++ <xsl:with-param name="anyCodes">p</xsl:with-param> ++ <xsl:with-param name="afterCodes">fgkdlmor</xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:if test="string-length(normalize-space($partNumber))"> ++ <partNumber> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="$partNumber"></xsl:with-param> ++ </xsl:call-template> ++ </partNumber> ++ </xsl:if> ++ <xsl:if test="string-length(normalize-space($partName))"> ++ <partName> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="$partName"></xsl:with-param> ++ </xsl:call-template> ++ </partName> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="relatedPart"> ++ <xsl:if test="@tag=773"> ++ <xsl:for-each select="marc:subfield[@code='g']"> ++ <part> ++ <text> ++ <xsl:value-of select="."></xsl:value-of> ++ </text> ++ </part> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='q']"> ++ <part> ++ <xsl:call-template name="parsePart"></xsl:call-template> ++ </part> ++ </xsl:for-each> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="relatedPartNumName"> ++ <xsl:variable name="partNumber"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">g</xsl:with-param> ++ <xsl:with-param name="anyCodes">g</xsl:with-param> ++ <xsl:with-param name="afterCodes">pst</xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:variable name="partName"> ++ <xsl:call-template name="specialSubfieldSelect"> ++ <xsl:with-param name="axis">p</xsl:with-param> ++ <xsl:with-param name="anyCodes">p</xsl:with-param> ++ <xsl:with-param name="afterCodes">fgkdlmor</xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:if test="string-length(normalize-space($partNumber))"> ++ <partNumber> ++ <xsl:value-of select="$partNumber"></xsl:value-of> ++ </partNumber> ++ </xsl:if> ++ <xsl:if test="string-length(normalize-space($partName))"> ++ <partName> ++ <xsl:value-of select="$partName"></xsl:value-of> ++ </partName> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="relatedName"> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <name> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </name> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedForm"> ++ <xsl:for-each select="marc:subfield[@code='h']"> ++ <physicalDescription> ++ <form> ++ <xsl:value-of select="."></xsl:value-of> ++ </form> ++ </physicalDescription> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedExtent"> ++ <xsl:for-each select="marc:subfield[@code='h']"> ++ <physicalDescription> ++ <extent> ++ <xsl:value-of select="."></xsl:value-of> ++ </extent> ++ </physicalDescription> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedNote"> ++ <xsl:for-each select="marc:subfield[@code='n']"> ++ <note> ++ <xsl:value-of select="."></xsl:value-of> ++ </note> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedSubject"> ++ <xsl:for-each select="marc:subfield[@code='j']"> ++ <subject> ++ <temporal encoding="iso8601"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </temporal> ++ </subject> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedIdentifierISSN"> ++ <xsl:for-each select="marc:subfield[@code='x']"> ++ <identifier type="issn"> ++ <xsl:value-of select="."></xsl:value-of> ++ </identifier> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedIdentifierLocal"> ++ <xsl:for-each select="marc:subfield[@code='w']"> ++ <identifier type="local"> ++ <xsl:value-of select="."></xsl:value-of> ++ </identifier> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedIdentifier"> ++ <xsl:for-each select="marc:subfield[@code='o']"> ++ <identifier> ++ <xsl:value-of select="."></xsl:value-of> ++ </identifier> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedItem76X-78X"> ++ <xsl:call-template name="displayLabel"></xsl:call-template> ++ <xsl:call-template name="relatedTitle76X-78X"></xsl:call-template> ++ <xsl:call-template name="relatedName"></xsl:call-template> ++ <xsl:call-template name="relatedOriginInfo"></xsl:call-template> ++ <xsl:call-template name="relatedLanguage"></xsl:call-template> ++ <xsl:call-template name="relatedExtent"></xsl:call-template> ++ <xsl:call-template name="relatedNote"></xsl:call-template> ++ <xsl:call-template name="relatedSubject"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifier"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifierISSN"></xsl:call-template> ++ <xsl:call-template name="relatedIdentifierLocal"></xsl:call-template> ++ <xsl:call-template name="relatedPart"></xsl:call-template> ++ </xsl:template> ++ <xsl:template name="subjectGeographicZ"> ++ <geographic> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </geographic> ++ </xsl:template> ++ <xsl:template name="subjectTemporalY"> ++ <temporal> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </temporal> ++ </xsl:template> ++ <xsl:template name="subjectTopic"> ++ <topic> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </topic> ++ </xsl:template> ++ <!-- 3.2 change tmee 6xx $v genre --> ++ <xsl:template name="subjectGenre"> ++ <genre> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </genre> ++ </xsl:template> ++ ++ <xsl:template name="nameABCDN"> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <namePart> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <xsl:if test="marc:subfield[@code='c'] or marc:subfield[@code='d'] or marc:subfield[@code='n']"> ++ <namePart> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">cdn</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="nameABCDQ"> ++ <namePart> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">aq</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ <xsl:with-param name="punctuation"> ++ <xsl:text>:,;/ </xsl:text> ++ </xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:call-template name="termsOfAddress"></xsl:call-template> ++ <xsl:call-template name="nameDate"></xsl:call-template> ++ </xsl:template> ++ <xsl:template name="nameACDEQ"> ++ <namePart> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">acdeq</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </xsl:template> ++ <xsl:template name="constituentOrRelatedType"> ++ <xsl:if test="@ind2=2"> ++ <xsl:attribute name="type">constituent</xsl:attribute> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="relatedTitle"> ++ <xsl:for-each select="marc:subfield[@code='t']"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="."></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ </titleInfo> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedTitle76X-78X"> ++ <xsl:for-each select="marc:subfield[@code='t']"> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="."></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:if test="marc:datafield[@tag!=773]and marc:subfield[@code='g']"> ++ <xsl:call-template name="relatedPartNumName"></xsl:call-template> ++ </xsl:if> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='p']"> ++ <titleInfo type="abbreviated"> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="."></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:if test="marc:datafield[@tag!=773]and marc:subfield[@code='g']"> ++ <xsl:call-template name="relatedPartNumName"></xsl:call-template> ++ </xsl:if> ++ </titleInfo> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='s']"> ++ <titleInfo type="uniform"> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="."></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </title> ++ <xsl:if test="marc:datafield[@tag!=773]and marc:subfield[@code='g']"> ++ <xsl:call-template name="relatedPartNumName"></xsl:call-template> ++ </xsl:if> ++ </titleInfo> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="relatedOriginInfo"> ++ <xsl:if test="marc:subfield[@code='b' or @code='d'] or marc:subfield[@code='f']"> ++ <originInfo> ++ <xsl:if test="@tag=775"> ++ <xsl:for-each select="marc:subfield[@code='f']"> ++ <place> ++ <placeTerm> ++ <xsl:attribute name="type">code</xsl:attribute> ++ <xsl:attribute name="authority">marcgac</xsl:attribute> ++ <xsl:value-of select="."></xsl:value-of> ++ </placeTerm> ++ </place> ++ </xsl:for-each> ++ </xsl:if> ++ <xsl:for-each select="marc:subfield[@code='d']"> ++ <publisher> ++ <xsl:value-of select="."></xsl:value-of> ++ </publisher> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <edition> ++ <xsl:value-of select="."></xsl:value-of> ++ </edition> ++ </xsl:for-each> ++ </originInfo> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="relatedLanguage"> ++ <xsl:for-each select="marc:subfield[@code='e']"> ++ <xsl:call-template name="getLanguage"> ++ <xsl:with-param name="langString"> ++ <xsl:value-of select="."></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="nameDate"> ++ <xsl:for-each select="marc:subfield[@code='d']"> ++ <namePart type="date"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="subjectAuthority"> ++ <xsl:if test="@ind2!=4"> ++ <xsl:if test="@ind2!=' '"> ++ <xsl:if test="@ind2!=8"> ++ <xsl:if test="@ind2!=9"> ++ <xsl:attribute name="authority"> ++ <xsl:choose> ++ <xsl:when test="@ind2=0">lcsh</xsl:when> ++ <xsl:when test="@ind2=1">lcshac</xsl:when> ++ <xsl:when test="@ind2=2">mesh</xsl:when> ++ <!-- 1/04 fix --> ++ <xsl:when test="@ind2=3">nal</xsl:when> ++ <xsl:when test="@ind2=5">csh</xsl:when> ++ <xsl:when test="@ind2=6">rvm</xsl:when> ++ <xsl:when test="@ind2=7"> ++ <xsl:value-of select="marc:subfield[@code='2']"></xsl:value-of> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:attribute> ++ </xsl:if> ++ </xsl:if> ++ </xsl:if> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="subjectAnyOrder"> ++ <xsl:for-each select="marc:subfield[@code='v' or @code='x' or @code='y' or @code='z']"> ++ <xsl:choose> ++ <xsl:when test="@code='v'"> ++ <xsl:call-template name="subjectGenre"></xsl:call-template> ++ </xsl:when> ++ <xsl:when test="@code='x'"> ++ <xsl:call-template name="subjectTopic"></xsl:call-template> ++ </xsl:when> ++ <xsl:when test="@code='y'"> ++ <xsl:call-template name="subjectTemporalY"></xsl:call-template> ++ </xsl:when> ++ <xsl:when test="@code='z'"> ++ <xsl:call-template name="subjectGeographicZ"></xsl:call-template> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:for-each> ++ </xsl:template> ++ <xsl:template name="specialSubfieldSelect"> ++ <xsl:param name="anyCodes"></xsl:param> ++ <xsl:param name="axis"></xsl:param> ++ <xsl:param name="beforeCodes"></xsl:param> ++ <xsl:param name="afterCodes"></xsl:param> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield"> ++ <xsl:if test="contains($anyCodes, @code) or (contains($beforeCodes,@code) and following-sibling::marc:subfield[@code=$axis]) or (contains($afterCodes,@code) and preceding-sibling::marc:subfield[@code=$axis])"> ++ <xsl:value-of select="text()"></xsl:value-of> ++ <xsl:text> </xsl:text> ++ </xsl:if> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-1)"></xsl:value-of> ++ </xsl:template> ++ ++ <!-- 3.2 change tmee 6xx $v genre --> ++ <xsl:template match="marc:datafield[@tag=600]"> ++ <subject> ++ <xsl:call-template name="subjectAuthority"></xsl:call-template> ++ <name type="personal"> ++ <xsl:call-template name="termsOfAddress"></xsl:call-template> ++ <namePart> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">aq</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:call-template name="nameDate"></xsl:call-template> ++ <xsl:call-template name="affiliation"></xsl:call-template> ++ <xsl:call-template name="role"></xsl:call-template> ++ </name> ++ <xsl:call-template name="subjectAnyOrder"></xsl:call-template> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=610]"> ++ <subject> ++ <xsl:call-template name="subjectAuthority"></xsl:call-template> ++ <name type="corporate"> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <xsl:for-each select="marc:subfield[@code='b']"> ++ <namePart> ++ <xsl:value-of select="."></xsl:value-of> ++ </namePart> ++ </xsl:for-each> ++ <xsl:if test="marc:subfield[@code='c' or @code='d' or @code='n' or @code='p']"> ++ <namePart> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">cdnp</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </xsl:if> ++ <xsl:call-template name="role"></xsl:call-template> ++ </name> ++ <xsl:call-template name="subjectAnyOrder"></xsl:call-template> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=611]"> ++ <subject> ++ <xsl:call-template name="subjectAuthority"></xsl:call-template> ++ <name type="conference"> ++ <namePart> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abcdeqnp</xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ <xsl:for-each select="marc:subfield[@code='4']"> ++ <role> ++ <roleTerm authority="marcrelator" type="code"> ++ <xsl:value-of select="."></xsl:value-of> ++ </roleTerm> ++ </role> ++ </xsl:for-each> ++ </name> ++ <xsl:call-template name="subjectAnyOrder"></xsl:call-template> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=630]"> ++ <subject> ++ <xsl:call-template name="subjectAuthority"></xsl:call-template> ++ <titleInfo> ++ <title> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">adfhklor</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ <xsl:call-template name="part"></xsl:call-template> ++ </title> ++ </titleInfo> ++ <xsl:call-template name="subjectAnyOrder"></xsl:call-template> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=650]"> ++ <subject> ++ <xsl:call-template name="subjectAuthority"></xsl:call-template> ++ <topic> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">abcd</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </topic> ++ <xsl:call-template name="subjectAnyOrder"></xsl:call-template> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=651]"> ++ <subject> ++ <xsl:call-template name="subjectAuthority"></xsl:call-template> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <geographic> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="."></xsl:with-param> ++ </xsl:call-template> ++ </geographic> ++ </xsl:for-each> ++ <xsl:call-template name="subjectAnyOrder"></xsl:call-template> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=653]"> ++ <subject> ++ <xsl:for-each select="marc:subfield[@code='a']"> ++ <topic> ++ <xsl:value-of select="."></xsl:value-of> ++ </topic> ++ </xsl:for-each> ++ </subject> ++ </xsl:template> ++ <xsl:template match="marc:datafield[@tag=656]"> ++ <subject> ++ <xsl:if test="marc:subfield[@code=2]"> ++ <xsl:attribute name="authority"> ++ <xsl:value-of select="marc:subfield[@code=2]"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ <occupation> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:subfield[@code='a']"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </occupation> ++ </subject> ++ </xsl:template> ++ <xsl:template name="termsOfAddress"> ++ <xsl:if test="marc:subfield[@code='b' or @code='c']"> ++ <namePart type="termsOfAddress"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">bc</xsl:with-param> ++ </xsl:call-template> ++ </xsl:with-param> ++ </xsl:call-template> ++ </namePart> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="displayLabel"> ++ <xsl:if test="marc:subfield[@code='i']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:value-of select="marc:subfield[@code='i']"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ <xsl:if test="marc:subfield[@code='3']"> ++ <xsl:attribute name="displayLabel"> ++ <xsl:value-of select="marc:subfield[@code='3']"></xsl:value-of> ++ </xsl:attribute> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="isInvalid"> ++ <xsl:param name="type"/> ++ <xsl:if test="marc:subfield[@code='z'] or marc:subfield[@code='y']"> ++ <identifier> ++ <xsl:attribute name="type"> ++ <xsl:value-of select="$type"/> ++ </xsl:attribute> ++ <xsl:attribute name="invalid"> ++ <xsl:text>yes</xsl:text> ++ </xsl:attribute> ++ <xsl:if test="marc:subfield[@code='z']"> ++ <xsl:value-of select="marc:subfield[@code='z']"/> ++ </xsl:if> ++ <xsl:if test="marc:subfield[@code='y']"> ++ <xsl:value-of select="marc:subfield[@code='y']"/> ++ </xsl:if> ++ </identifier> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="subtitle"> ++ <xsl:if test="marc:subfield[@code='b']"> ++ <subTitle> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString"> ++ <xsl:value-of select="marc:subfield[@code='b']"/> ++ <!--<xsl:call-template name="subfieldSelect"> ++ <xsl:with-param name="codes">b</xsl:with-param> ++ </xsl:call-template>--> ++ </xsl:with-param> ++ </xsl:call-template> ++ </subTitle> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="script"> ++ <xsl:param name="scriptCode"></xsl:param> ++ <xsl:attribute name="script"> ++ <xsl:choose> ++ <xsl:when test="$scriptCode='(3'">Arabic</xsl:when> ++ <xsl:when test="$scriptCode='(B'">Latin</xsl:when> ++ <xsl:when test="$scriptCode='$1'">Chinese, Japanese, Korean</xsl:when> ++ <xsl:when test="$scriptCode='(N'">Cyrillic</xsl:when> ++ <xsl:when test="$scriptCode='(2'">Hebrew</xsl:when> ++ <xsl:when test="$scriptCode='(S'">Greek</xsl:when> ++ </xsl:choose> ++ </xsl:attribute> ++ </xsl:template> ++ <xsl:template name="parsePart"> ++ <!-- assumes 773$q= 1:2:3<4 ++ with up to 3 levels and one optional start page ++ --> ++ <xsl:variable name="level1"> ++ <xsl:choose> ++ <xsl:when test="contains(text(),':')"> ++ <!-- 1:2 --> ++ <xsl:value-of select="substring-before(text(),':')"></xsl:value-of> ++ </xsl:when> ++ <xsl:when test="not(contains(text(),':'))"> ++ <!-- 1 or 1<3 --> ++ <xsl:if test="contains(text(),'<')"> ++ <!-- 1<3 --> ++ <xsl:value-of select="substring-before(text(),'<')"></xsl:value-of> ++ </xsl:if> ++ <xsl:if test="not(contains(text(),'<'))"> ++ <!-- 1 --> ++ <xsl:value-of select="text()"></xsl:value-of> ++ </xsl:if> ++ </xsl:when> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:variable name="sici2"> ++ <xsl:choose> ++ <xsl:when test="starts-with(substring-after(text(),$level1),':')"> ++ <xsl:value-of select="substring(substring-after(text(),$level1),2)"></xsl:value-of> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:value-of select="substring-after(text(),$level1)"></xsl:value-of> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:variable name="level2"> ++ <xsl:choose> ++ <xsl:when test="contains($sici2,':')"> ++ <!-- 2:3<4 --> ++ <xsl:value-of select="substring-before($sici2,':')"></xsl:value-of> ++ </xsl:when> ++ <xsl:when test="contains($sici2,'<')"> ++ <!-- 1: 2<4 --> ++ <xsl:value-of select="substring-before($sici2,'<')"></xsl:value-of> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:value-of select="$sici2"></xsl:value-of> ++ <!-- 1:2 --> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:variable name="sici3"> ++ <xsl:choose> ++ <xsl:when test="starts-with(substring-after($sici2,$level2),':')"> ++ <xsl:value-of select="substring(substring-after($sici2,$level2),2)"></xsl:value-of> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:value-of select="substring-after($sici2,$level2)"></xsl:value-of> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:variable name="level3"> ++ <xsl:choose> ++ <xsl:when test="contains($sici3,'<')"> ++ <!-- 2<4 --> ++ <xsl:value-of select="substring-before($sici3,'<')"></xsl:value-of> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:value-of select="$sici3"></xsl:value-of> ++ <!-- 3 --> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:variable> ++ <xsl:variable name="page"> ++ <xsl:if test="contains(text(),'<')"> ++ <xsl:value-of select="substring-after(text(),'<')"></xsl:value-of> ++ </xsl:if> ++ </xsl:variable> ++ <xsl:if test="$level1"> ++ <detail level="1"> ++ <number> ++ <xsl:value-of select="$level1"></xsl:value-of> ++ </number> ++ </detail> ++ </xsl:if> ++ <xsl:if test="$level2"> ++ <detail level="2"> ++ <number> ++ <xsl:value-of select="$level2"></xsl:value-of> ++ </number> ++ </detail> ++ </xsl:if> ++ <xsl:if test="$level3"> ++ <detail level="3"> ++ <number> ++ <xsl:value-of select="$level3"></xsl:value-of> ++ </number> ++ </detail> ++ </xsl:if> ++ <xsl:if test="$page"> ++ <extent unit="page"> ++ <start> ++ <xsl:value-of select="$page"></xsl:value-of> ++ </start> ++ </extent> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="getLanguage"> ++ <xsl:param name="langString"></xsl:param> ++ <xsl:param name="controlField008-35-37"></xsl:param> ++ <xsl:variable name="length" select="string-length($langString)"></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="$length=0"></xsl:when> ++ <xsl:when test="$controlField008-35-37=substring($langString,1,3)"> ++ <xsl:call-template name="getLanguage"> ++ <xsl:with-param name="langString" select="substring($langString,4,$length)"></xsl:with-param> ++ <xsl:with-param name="controlField008-35-37" select="$controlField008-35-37"></xsl:with-param> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:otherwise> ++ <language> ++ <languageTerm authority="iso639-2b" type="code"> ++ <xsl:value-of select="substring($langString,1,3)"></xsl:value-of> ++ </languageTerm> ++ </language> ++ <xsl:call-template name="getLanguage"> ++ <xsl:with-param name="langString" select="substring($langString,4,$length)"></xsl:with-param> ++ <xsl:with-param name="controlField008-35-37" select="$controlField008-35-37"></xsl:with-param> ++ </xsl:call-template> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:template> ++ <xsl:template name="isoLanguage"> ++ <xsl:param name="currentLanguage"></xsl:param> ++ <xsl:param name="usedLanguages"></xsl:param> ++ <xsl:param name="remainingLanguages"></xsl:param> ++ <xsl:choose> ++ <xsl:when test="string-length($currentLanguage)=0"></xsl:when> ++ <xsl:when test="not(contains($usedLanguages, $currentLanguage))"> ++ <language> ++ <xsl:if test="@code!='a'"> ++ <xsl:attribute name="objectPart"> ++ <xsl:choose> ++ <xsl:when test="@code='b'">summary or subtitle</xsl:when> ++ <xsl:when test="@code='d'">sung or spoken text</xsl:when> ++ <xsl:when test="@code='e'">libretto</xsl:when> ++ <xsl:when test="@code='f'">table of contents</xsl:when> ++ <xsl:when test="@code='g'">accompanying material</xsl:when> ++ <xsl:when test="@code='h'">translation</xsl:when> ++ </xsl:choose> ++ </xsl:attribute> ++ </xsl:if> ++ <languageTerm authority="iso639-2b" type="code"> ++ <xsl:value-of select="$currentLanguage"></xsl:value-of> ++ </languageTerm> ++ </language> ++ <xsl:call-template name="isoLanguage"> ++ <xsl:with-param name="currentLanguage"> ++ <xsl:value-of select="substring($remainingLanguages,1,3)"></xsl:value-of> ++ </xsl:with-param> ++ <xsl:with-param name="usedLanguages"> ++ <xsl:value-of select="concat($usedLanguages,$currentLanguage)"></xsl:value-of> ++ </xsl:with-param> ++ <xsl:with-param name="remainingLanguages"> ++ <xsl:value-of select="substring($remainingLanguages,4,string-length($remainingLanguages))"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:otherwise> ++ <xsl:call-template name="isoLanguage"> ++ <xsl:with-param name="currentLanguage"> ++ <xsl:value-of select="substring($remainingLanguages,1,3)"></xsl:value-of> ++ </xsl:with-param> ++ <xsl:with-param name="usedLanguages"> ++ <xsl:value-of select="concat($usedLanguages,$currentLanguage)"></xsl:value-of> ++ </xsl:with-param> ++ <xsl:with-param name="remainingLanguages"> ++ <xsl:value-of select="substring($remainingLanguages,4,string-length($remainingLanguages))"></xsl:value-of> ++ </xsl:with-param> ++ </xsl:call-template> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:template> ++ <xsl:template name="chopBrackets"> ++ <xsl:param name="chopString"></xsl:param> ++ <xsl:variable name="string"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="$chopString"></xsl:with-param> ++ </xsl:call-template> ++ </xsl:variable> ++ <xsl:if test="substring($string, 1,1)='['"> ++ <xsl:value-of select="substring($string,2, string-length($string)-2)"></xsl:value-of> ++ </xsl:if> ++ <xsl:if test="substring($string, 1,1)!='['"> ++ <xsl:value-of select="$string"></xsl:value-of> ++ </xsl:if> ++ </xsl:template> ++ <xsl:template name="rfcLanguages"> ++ <xsl:param name="nodeNum"></xsl:param> ++ <xsl:param name="usedLanguages"></xsl:param> ++ <xsl:param name="controlField008-35-37"></xsl:param> ++ <xsl:variable name="currentLanguage" select="."></xsl:variable> ++ <xsl:choose> ++ <xsl:when test="not($currentLanguage)"></xsl:when> ++ <xsl:when test="$currentLanguage!=$controlField008-35-37 and $currentLanguage!='rfc3066'"> ++ <xsl:if test="not(contains($usedLanguages,$currentLanguage))"> ++ <language> ++ <xsl:if test="@code!='a'"> ++ <xsl:attribute name="objectPart"> ++ <xsl:choose> ++ <xsl:when test="@code='b'">summary or subtitle</xsl:when> ++ <xsl:when test="@code='d'">sung or spoken text</xsl:when> ++ <xsl:when test="@code='e'">libretto</xsl:when> ++ <xsl:when test="@code='f'">table of contents</xsl:when> ++ <xsl:when test="@code='g'">accompanying material</xsl:when> ++ <xsl:when test="@code='h'">translation</xsl:when> ++ </xsl:choose> ++ </xsl:attribute> ++ </xsl:if> ++ <languageTerm authority="rfc3066" type="code"> ++ <xsl:value-of select="$currentLanguage"/> ++ </languageTerm> ++ </language> ++ </xsl:if> ++ </xsl:when> ++ <xsl:otherwise> ++ </xsl:otherwise> ++ </xsl:choose> ++ </xsl:template> ++ <xsl:template name="datafield"> ++ <xsl:param name="tag"/> ++ <xsl:param name="ind1"><xsl:text> </xsl:text></xsl:param> ++ <xsl:param name="ind2"><xsl:text> </xsl:text></xsl:param> ++ <xsl:param name="subfields"/> ++ <xsl:element name="marc:datafield"> ++ <xsl:attribute name="tag"> ++ <xsl:value-of select="$tag"/> ++ </xsl:attribute> ++ <xsl:attribute name="ind1"> ++ <xsl:value-of select="$ind1"/> ++ </xsl:attribute> ++ <xsl:attribute name="ind2"> ++ <xsl:value-of select="$ind2"/> ++ </xsl:attribute> ++ <xsl:copy-of select="$subfields"/> ++ </xsl:element> ++ </xsl:template> ++ ++ <xsl:template name="subfieldSelect"> ++ <xsl:param name="codes"/> ++ <xsl:param name="delimeter"><xsl:text> </xsl:text></xsl:param> ++ <xsl:variable name="str"> ++ <xsl:for-each select="marc:subfield"> ++ <xsl:if test="contains($codes, @code)"> ++ <xsl:value-of select="text()"/><xsl:value-of select="$delimeter"/> ++ </xsl:if> ++ </xsl:for-each> ++ </xsl:variable> ++ <xsl:value-of select="substring($str,1,string-length($str)-string-length($delimeter))"/> ++ </xsl:template> ++ ++ <xsl:template name="buildSpaces"> ++ <xsl:param name="spaces"/> ++ <xsl:param name="char"><xsl:text> </xsl:text></xsl:param> ++ <xsl:if test="$spaces>0"> ++ <xsl:value-of select="$char"/> ++ <xsl:call-template name="buildSpaces"> ++ <xsl:with-param name="spaces" select="$spaces - 1"/> ++ <xsl:with-param name="char" select="$char"/> ++ </xsl:call-template> ++ </xsl:if> ++ </xsl:template> ++ ++ <xsl:template name="chopPunctuation"> ++ <xsl:param name="chopString"/> ++ <xsl:param name="punctuation"><xsl:text>.:,;/ </xsl:text></xsl:param> ++ <xsl:variable name="length" select="string-length($chopString)"/> ++ <xsl:choose> ++ <xsl:when test="$length=0"/> ++ <xsl:when test="contains($punctuation, substring($chopString,$length,1))"> ++ <xsl:call-template name="chopPunctuation"> ++ <xsl:with-param name="chopString" select="substring($chopString,1,$length - 1)"/> ++ <xsl:with-param name="punctuation" select="$punctuation"/> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:when test="not($chopString)"/> ++ <xsl:otherwise><xsl:value-of select="$chopString"/></xsl:otherwise> ++ </xsl:choose> ++ </xsl:template> ++ ++ <xsl:template name="chopPunctuationFront"> ++ <xsl:param name="chopString"/> ++ <xsl:variable name="length" select="string-length($chopString)"/> ++ <xsl:choose> ++ <xsl:when test="$length=0"/> ++ <xsl:when test="contains('.:,;/[ ', substring($chopString,1,1))"> ++ <xsl:call-template name="chopPunctuationFront"> ++ <xsl:with-param name="chopString" select="substring($chopString,2,$length - 1)"/> ++ </xsl:call-template> ++ </xsl:when> ++ <xsl:when test="not($chopString)"/> ++ <xsl:otherwise><xsl:value-of select="$chopString"/></xsl:otherwise> ++ </xsl:choose> ++ </xsl:template> ++</xsl:stylesheet>$$ WHERE name = 'mods32'; ++ ++-- Currently, the only difference from naco_normalize is that search_normalize ++-- turns apostrophes into spaces, while naco_normalize collapses them. ++CREATE OR REPLACE FUNCTION public.search_normalize( TEXT, TEXT ) RETURNS TEXT AS $func$ ++ ++ use strict; ++ use Unicode::Normalize; ++ use Encode; ++ ++ my $str = decode_utf8(shift); ++ my $sf = shift; ++ ++ # Apply NACO normalization to input string; based on ++ # http://www.loc.gov/catdir/pcc/naco/SCA_PccNormalization_Final_revised.pdf ++ # ++ # Note that unlike a strict reading of the NACO normalization rules, ++ # output is returned as lowercase instead of uppercase for compatibility ++ # with previous versions of the Evergreen naco_normalize routine. ++ ++ # Convert to upper-case first; even though final output will be lowercase, doing this will ++ # ensure that the German eszett (Ã) and certain ligatures (ï¬, ï¬, ï¬, etc.) will be handled correctly. ++ # If there are any bugs in Perl's implementation of upcasing, they will be passed through here. ++ $str = uc $str; ++ ++ # remove non-filing strings ++ $str =~ s/\x{0098}.*?\x{009C}//g; ++ ++ $str = NFKD($str); ++ ++ # additional substitutions - 3.6. ++ $str =~ s/\x{00C6}/AE/g; ++ $str =~ s/\x{00DE}/TH/g; ++ $str =~ s/\x{0152}/OE/g; ++ $str =~ tr/\x{0110}\x{00D0}\x{00D8}\x{0141}\x{2113}\x{02BB}\x{02BC}][/DDOLl/d; ++ ++ # transformations based on Unicode category codes ++ $str =~ s/[\p{Cc}\p{Cf}\p{Co}\p{Cs}\p{Lm}\p{Mc}\p{Me}\p{Mn}]//g; ++ ++ if ($sf && $sf =~ /^a/o) { ++ my $commapos = index($str, ','); ++ if ($commapos > -1) { ++ if ($commapos != length($str) - 1) { ++ $str =~ s/,/\x07/; # preserve first comma ++ } ++ } ++ } ++ ++ # since we've stripped out the control characters, we can now ++ # use a few as placeholders temporarily ++ $str =~ tr/+&@\x{266D}\x{266F}#/\x01\x02\x03\x04\x05\x06/; ++ $str =~ s/[\p{Pc}\p{Pd}\p{Pe}\p{Pf}\p{Pi}\p{Po}\p{Ps}\p{Sk}\p{Sm}\p{So}\p{Zl}\p{Zp}\p{Zs}]/ /g; ++ $str =~ tr/\x01\x02\x03\x04\x05\x06\x07/+&@\x{266D}\x{266F}#,/; ++ ++ # decimal digits ++ $str =~ tr/\x{0660}-\x{0669}\x{06F0}-\x{06F9}\x{07C0}-\x{07C9}\x{0966}-\x{096F}\x{09E6}-\x{09EF}\x{0A66}-\x{0A6F}\x{0AE6}-\x{0AEF}\x{0B66}-\x{0B6F}\x{0BE6}-\x{0BEF}\x{0C66}-\x{0C6F}\x{0CE6}-\x{0CEF}\x{0D66}-\x{0D6F}\x{0E50}-\x{0E59}\x{0ED0}-\x{0ED9}\x{0F20}-\x{0F29}\x{1040}-\x{1049}\x{1090}-\x{1099}\x{17E0}-\x{17E9}\x{1810}-\x{1819}\x{1946}-\x{194F}\x{19D0}-\x{19D9}\x{1A80}-\x{1A89}\x{1A90}-\x{1A99}\x{1B50}-\x{1B59}\x{1BB0}-\x{1BB9}\x{1C40}-\x{1C49}\x{1C50}-\x{1C59}\x{A620}-\x{A629}\x{A8D0}-\x{A8D9}\x{A900}-\x{A909}\x{A9D0}-\x{A9D9}\x{AA50}-\x{AA59}\x{ABF0}-\x{ABF9}\x{FF10}-\x{FF19}/0-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-90-9/; ++ ++ # intentionally skipping step 8 of the NACO algorithm; if the string ++ # gets normalized away, that's fine. ++ ++ # leading and trailing spaces ++ $str =~ s/\s+/ /g; ++ $str =~ s/^\s+//; ++ $str =~ s/\s+$//g; ++ ++ return lc $str; ++$func$ LANGUAGE 'plperlu' STRICT IMMUTABLE; ++ ++CREATE OR REPLACE FUNCTION public.search_normalize_keep_comma( TEXT ) RETURNS TEXT AS $func$ ++ SELECT public.search_normalize($1,'a'); ++$func$ LANGUAGE SQL STRICT IMMUTABLE; ++ ++CREATE OR REPLACE FUNCTION public.search_normalize( TEXT ) RETURNS TEXT AS $func$ ++ SELECT public.search_normalize($1,''); ++$func$ LANGUAGE 'sql' STRICT IMMUTABLE; ++ ++INSERT INTO config.index_normalizer (name, description, func, param_count) VALUES ( ++ 'Search Normalize', ++ 'Apply search normalization rules to the extracted text. A less extreme version of NACO normalization.', ++ 'search_normalize', ++ 0 ++); ++ ++UPDATE config.metabib_field_index_norm_map ++ SET norm = ( ++ SELECT id FROM config.index_normalizer WHERE func = 'search_normalize' ++ ) ++ WHERE norm = ( ++ SELECT id FROM config.index_normalizer WHERE func = 'naco_normalize' ++ ) ++; ++ ++COMMIT; ++ ++-- This could take a long time if you have a very non-English bib database ++-- Run it outside of a transaction to avoid lock escalation ++SELECT metabib.reingest_metabib_field_entries(record) ++ FROM metabib.full_rec ++ WHERE tag = '245' ++ AND subfield = 'a' ++ AND value LIKE '%''%' ++;