#! /usr/bin/perl
#
#  gtb2l/gtl2b  : gtool $B%G!<%?$N%(%s%G%#%"%sJQ49(B (97/02/19 S.Takehiro)
#         usage : gtb2l filename 
#
open(STDIN,$ARGV[0]) || die "Can't open $ARGV[0]: $!\n"
      if $ARGV[0];
#
    if ( $0 =~ "l2b" ) { $convert = "Little -> Big"; }
    if ( $0 =~ "b2l" ) { $convert = "Big -> Little"; }
    printf STDERR "Endian conversion of gtool data, %s.\n", $convert;  
#
# $B@hF,(B 4 $B%P%$%H$r$^$:FI$s$G(B, $B%G!<%?$NB8:_$rH=CG(B
#
   while(  ( $len = read(STDIN,$data,4) ) == 4 ) {
       &conv_print;
#
#                     gtool $B%X%C%@!<It$rFI$`(B
#
       for ( $i = 1; $i <= 64 ; $i++ ){
           read(STDIN,$gthead[$i],16);
           print $gthead[$i];
#           print $i, " ", $gthead[$i], "\n";
         }

       $dtitle = $gthead[3];
       $dfmt = $gthead[38];
       $size = $gthead[64];
       $size =~ s/  +//g;
       printf STDERR "### READ %s size = %s\n", $dtitle, $size;

       read(STDIN,$data,4);
       &conv_print;
#
#                     $B%G!<%?It$rFI$`(B
#
       read(STDIN,$data,4);  
       &conv_print;
       for ( $i = 1; $i<= $size ; $i++ ) {
           if    ( $dfmt =~ 'UR4' ) { read(STDIN,$data,4);&conv_print; }
           elsif ( $dfmt =~ 'UR8' ) { read(STDIN,$data,8);&conv2_print; }
           else { print STDERR "DATA FORMAT INVALID\n"; exit(1); }
         }
       read(STDIN,$data,4);
       &conv_print;
   }
######################################################################
#               $B%3%^%s%IL>$K$h$C$FJQ49$rDj5A(B
# $BC1@:EY(B
#
  sub conv_print {
       if ( $0 =~ "l2b" ) { &l2ben_print; }
       if ( $0 =~ "b2l" ) { &b2len_print; }
   }

  sub l2ben_print {
       @array = unpack('V', $data );
       $data = pack('N', @array);
       print $data;
   }
  sub b2len_print {
       @array = unpack('N', $data );
       $data = pack('V', @array);
       print $data;
   }
#
# $BG\@:EY(B
#
  sub conv2_print {
       if ( $0 =~ "l2b" ) { &l2ben2_print; }
       if ( $0 =~ "b2l" ) { &b2len2_print; }
   }

  sub l2ben2_print {
       @array = unpack('V2', $data );
       @array = ( $array[1], $array[0] );
       $data = pack('N2', @array);
       print $data;
   }
  sub b2len2_print {
       @array = unpack('N2', $data );
       @array = ( $array[1], $array[0] );
       $data = pack('V2', @array);
       print $data;
   }

