X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=formats%2Fmedium.tcl;h=cc22d03e425cac6e3af498a72c7f4ea9a0367ba1;hb=HEAD;hp=189d509223c1379601ae7443ee0ee5e7a56e4c1f;hpb=a15a80e995220dc483d5c997e74ec0fb4ec4a225;p=ir-tcl-moved-to-github.git diff --git a/formats/medium.tcl b/formats/medium.tcl index 189d509..cc22d03 100644 --- a/formats/medium.tcl +++ b/formats/medium.tcl @@ -4,7 +4,29 @@ # Sebastian Hammer, Adam Dickmeiss # # $Log: medium.tcl,v $ -# Revision 1.8 1995-10-17 10:58:09 adam +# Revision 1.15 1997-11-19 11:22:10 adam +# Object identifiers can be accessed in GRS-1 records. +# +# Revision 1.14 1996/04/12 13:45:49 adam +# Minor changes. +# +# Revision 1.13 1996/04/12 12:25:27 adam +# Modified display of GRS-1 records to include headings for standard +# tag sets. +# +# Revision 1.12 1996/03/29 16:05:36 adam +# Bug fix: GRS records wasn't recognized. +# +# Revision 1.11 1996/01/23 15:24:23 adam +# Wrore more comments. +# +# Revision 1.10 1996/01/11 09:31:05 quinn +# Small. +# +# Revision 1.9 1995/10/17 14:18:10 adam +# Minor changes in presentation formats. +# +# Revision 1.8 1995/10/17 10:58:09 adam # More work on presentation formats. # # Revision 1.7 1995/10/16 17:01:03 adam @@ -30,24 +52,53 @@ # # proc display-grs-medium {w r i} { + global tagSet + foreach e $r { - for {set j 0} {$j < $i} {incr j} { - insertWithTags $w " " marc-tag + if {[tk4]} { + set start [$w index insert] + } else { + for {set j 0} {$j < $i} {incr j} { + insertWithTags $w " " marc-tag + } + } + set ttype [lindex $e 0] + set tval [lindex $e 2] + if {$ttype == 3} { + insertWithTags $w "$tval " marc-pref + } elseif {[info exists tagSet($ttype,$tval)]} { + insertWithTags $w "$tagSet($ttype,$tval) " marc-pref + } else { + insertWithTags $w "($ttype,$tval) " marc-tag } - insertWithTags $w "([lindex $e 0]:[lindex $e 2]) " marc-tag if {[lindex $e 3] == "string"} { insertWithTags $w [lindex $e 4] marc-text - insertWithTags $w "\n" marc-text + insertWithTags $w "\n" } elseif {[lindex $e 3] == "subtree"} { - insertWithTags $w "\n" marc-text - display-grs-medium $w [lindex $e 4] [expr $i+1] + insertWithTags $w "\n" } else { - insertWithTags [lindex $e 4] {} - insertWithTags $w " ?\n" {} + insertWithTags $w [lindex $e 4] {} + insertWithTags $w " \n" {} + } + if {[tk4]} { + $w tag configure indent$i \ + -lmargin1 [expr $i * 16] \ + -lmargin2 [expr $i * 16 + 8] + $w tag add indent$i $start insert + } + if {[lindex $e 3] == "subtree"} { + display-grs-medium $w [lindex $e 4] [expr $i+1] } } } +# Procedure display-medium {sno no w hflag} +# sno result set number (integer) +# no record position (integer) +# w text widget in which the record should be displayed +# hflag header flag. If true a header showing the record position +# should be displayed. +# This procedure attempts to display records in a medium-sized format. proc display-medium {sno no w hflag} { if {$hflag} { insertWithTags $w " $no " marc-head @@ -74,7 +125,7 @@ proc display-medium {sno no w hflag} { $w insert end "\n" return } - if {$rtype == "GRS1"} { + if {$rtype == "GRS-1"} { display-grs-medium $w [z39.$sno getGrs $no] 0 return } @@ -82,7 +133,7 @@ proc display-medium {sno no w hflag} { insertWithTags $w "Unknown record type: $rtype\n" marc-id return } - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "Title " marc-pref insertWithTags $w [string trimright [lindex $i 0] /] marc-text set i [z39.$sno getMarc $no field 245 * b] @@ -92,10 +143,10 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 700 * a] - if {"x$i" == "x"} { + if {![llength $i]} { set i [z39.$sno getMarc $no field 100 * a] } - if {"x$i" != "x"} { + if {[llength $i]} { if {[llength $i] > 1} { insertWithTags $w "Authors " marc-pref } else { @@ -107,7 +158,7 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 110 * *] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "Co-Author " marc-pref foreach x $i { insertWithTags $w $x marc-text @@ -116,7 +167,7 @@ proc display-medium {sno no w hflag} { } set i [z39.$sno getMarc $no field 650 * *] - if {"x$i" != "x"} { + if {[llength $i]} { set n 0 insertWithTags $w "Keywords " marc-pref foreach x $i { @@ -130,7 +181,7 @@ proc display-medium {sno no w hflag} { } set i [concat [z39.$sno getMarc $no field 260 * a] \ [z39.$sno getMarc $no field 260 * b]] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "Publisher " marc-pref foreach x $i { insertWithTags $w $x marc-text @@ -138,7 +189,7 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 020 * a] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "ISBN " marc-pref foreach x $i { insertWithTags $w $x marc-text @@ -146,7 +197,7 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 022 * a] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "ISSN " marc-pref foreach x $i { insertWithTags $w $x marc-text @@ -154,7 +205,7 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 030 * a] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "CODEN " marc-pref foreach x $i { insertWithTags $w $x marc-text @@ -162,7 +213,7 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 015 * a] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "Ctl number " marc-pref foreach x $i { insertWithTags $w $x marc-text @@ -170,11 +221,19 @@ proc display-medium {sno no w hflag} { $w insert end "\n" } set i [z39.$sno getMarc $no field 010 * a] - if {"x$i" != "x"} { + if {[llength $i]} { insertWithTags $w "LC number " marc-pref foreach x $i { insertWithTags $w $x marc-text } $w insert end "\n" } + set i [z39.$sno getMarc $no field 710 * a] + if {[llength $i]} { + insertWithTags $w "Corporate name " marc-pref + foreach x $i { + insertWithTags $w $x marc-text + } + $w insert end "\n" + } }