X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Foidtoc.tcl;h=2e72d033a177d3b305b68bdd9f7d599f708f196a;hp=7ef102c03ef266526d6af68d26d62c0b14e8a823;hb=e33389ee14d909d3a1b9874a40aa1b53c3fe42be;hpb=53862bf9e7756842158d38b1bb25f2c094b8d3d7 diff --git a/src/oidtoc.tcl b/src/oidtoc.tcl index 7ef102c..2e72d03 100644 --- a/src/oidtoc.tcl +++ b/src/oidtoc.tcl @@ -1,8 +1,7 @@ # This file is part of the YAZ toolkit -# Copyright (c) Index Data 2006-2007 +# Copyright (C) Index Data # See the file LICENSE for details. # -# $Id: oidtoc.tcl,v 1.3 2007-04-24 12:55:15 adam Exp $ # # Converts a CSV file with Object identifiers to C @@ -34,8 +33,70 @@ proc readoids {input} { return $oids } +proc constant_var {oid} { + set lname [string tolower [lindex $oid 2]] + set lname [string map {- _ . _ { } _ ( {} ) {}} $lname] + set prefix [string tolower [lindex $oid 0]] + + return yaz_oid_${prefix}_${lname} +} + +proc oid_to_xml {srcdir input xname} { + set oids [readoids "${input}"] + set xfile [open "${xname}" w] + + puts $xfile "" + puts $xfile {} + puts $xfile {} + puts $xfile {} + puts $xfile {} + puts $xfile {} + puts $xfile {} + puts $xfile {} + puts $xfile {Name} + puts $xfile {Class} + puts $xfile {Constant / OID} + puts $xfile {} + puts $xfile {} + puts $xfile {} + + foreach oid $oids { + puts $xfile {} + + puts $xfile {} + puts $xfile [lindex $oid 2] + puts $xfile {} + + + puts $xfile {} + puts $xfile [lindex $oid 0] + puts $xfile {} + + puts $xfile {} + set v [constant_var $oid] + puts $xfile $v + puts $xfile {} + + + puts $xfile {} + puts $xfile {} + + puts $xfile {} + puts $xfile [lindex $oid 1] + puts $xfile {} + + puts $xfile {} + } + + puts $xfile {} + puts $xfile {} + + puts $xfile {} + close $xfile +} + proc oid_to_c {srcdir input cname hname} { - set oids [readoids "${srcdir}/${input}"] + set oids [readoids "${input}"] set cfile [open "${srcdir}/${cname}" w] set hfile [open "${srcdir}/../include/yaz/${hname}" w] @@ -48,8 +109,10 @@ proc oid_to_c {srcdir input cname hname} { puts $hfile "\#ifndef OID_STD_H" puts $hfile "\#define OID_STD_H" - # Define this. So that we don't get duplicate declartions with MSVC - puts $cfile "\#define OID_STD_H" + puts $cfile "\#if HAVE_CONFIG_H" + puts $cfile "\#include " + puts $cfile "\#endif" + puts $cfile "\#include " puts $cfile "" # To avoid LNK4049 @@ -61,26 +124,23 @@ proc oid_to_c {srcdir input cname hname} { puts $hfile "YAZ_BEGIN_CDECL" foreach oid $oids { - set lname [string tolower [lindex $oid 2]] - set lname [string map {- _ . _ { } _ ( {} ) {}} $lname] - set prefix [string tolower [lindex $oid 0]] + + set v [constant_var $oid] - puts -nonewline $cfile "YAZ_EXPORT const int yaz_oid_${prefix}_${lname}\[\] = \{" + puts -nonewline $cfile "YAZ_EXPORT const Odr_oid $v\[\] = \{" puts -nonewline $cfile [string map {. ,} [lindex $oid 1]] puts $cfile ",-1\};" - puts $hfile "OID_EXPORT extern const int yaz_oid_${prefix}_${lname}\[\];" + puts $hfile "OID_EXPORT extern const Odr_oid $v\[\];" } puts $cfile "YAZ_EXPORT struct yaz_oid_entry yaz_oid_standard_entries\[\] =" puts $cfile "\{" foreach oid $oids { - set lname [string tolower [lindex $oid 2]] - set lname [string map {- _ . _ { } _ ( {} ) {}} $lname] - set prefix [string tolower [lindex $oid 0]] + set v [constant_var $oid] puts -nonewline $cfile "\t\{CLASS_[lindex $oid 0], " - puts -nonewline $cfile "yaz_oid_${prefix}_${lname}, " + puts -nonewline $cfile "$v, " puts -nonewline $cfile \"[lindex $oid 2]\" puts $cfile "\}," } @@ -95,8 +155,11 @@ proc oid_to_c {srcdir input cname hname} { close $hfile } -if {[llength $argv] != 4} { +if {[llength $argv] == 4} { + oid_to_c [lindex $argv 0] [lindex $argv 1] [lindex $argv 2] [lindex $argv 3] +} elseif {[llength $argv] == 3} { + oid_to_xml [lindex $argv 0] [lindex $argv 1] [lindex $argv 2] +} else { puts "oidtoc.tcl srcdir csv cfile hfile" exit 1 } -oid_to_c [lindex $argv 0] [lindex $argv 1] [lindex $argv 2] [lindex $argv 3]