Mercurial > repos > marpiech > norwich_tools_docking2
comparison tools/rdock/bin/sdmodify @ 1:30e2440b2173 draft
planemo upload
author | marpiech |
---|---|
date | Mon, 29 Aug 2016 08:38:19 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
0:4cc079c67fab | 1:30e2440b2173 |
---|---|
1 #!/usr/bin/perl | |
2 # Script to set the first title line equal to a given data field | |
3 # | |
4 # Usage: sdmodify -f<DataField> [sdFiles] | |
5 # | |
6 # If sdFiles not given, reads from standard input | |
7 # Output is to standard output | |
8 | |
9 use lib "$ENV{'RBT_ROOT'}/lib"; | |
10 | |
11 use SDRecord; | |
12 | |
13 my $SDMODKEY = "ID"; | |
14 | |
15 #Print help if no command line arguments | |
16 printHelpAndExit() if (scalar(@ARGV) == 0); | |
17 | |
18 #Parse command line arguments | |
19 my @files; | |
20 while (scalar(@ARGV)) { | |
21 my $arg = shift @ARGV; | |
22 printHelpAndExit() if ($arg eq '-h'); | |
23 if (index($arg,'-f')==0) { | |
24 $SDMODKEY = substr($arg,2);#modification key | |
25 } | |
26 else { | |
27 push @files,$arg;#must be a filename | |
28 } | |
29 } | |
30 push @ARGV,@files;#put the filenames back in the arg list | |
31 | |
32 #read records | |
33 my $sdRec = new SDRecord; | |
34 my $nRec=0; | |
35 while ($sdRec->readRec('DATA'=>1,'LINES'=>1)) { | |
36 $sdRec->addData('_REC' => ++$nRec);#add record# as temp data field | |
37 #set the first line equal to the given data field | |
38 my $nLines = scalar (@{$sdRec->{'LINES'}}); | |
39 if ($nLines > 0) { | |
40 ${$sdRec->{'LINES'}}[0] = $sdRec->{'DATA'}->{$SDMODKEY}; | |
41 } | |
42 $sdRec->writeRec(); | |
43 } | |
44 | |
45 #!/usr/bin/perl | |
46 # Script to set the first title line equal to a given data field | |
47 # | |
48 # Usage: sdmodify -f<DataField> [sdFiles] | |
49 # | |
50 # If sdFiles not given, reads from standard input | |
51 # Output is to standard output | |
52 | |
53 sub printHelpAndExit { | |
54 print "\nScript to set the first title line equal to a given data field.\n"; | |
55 print "\nUsage:\tsdmodify -f<DataField> [sdFiles]\n"; | |
56 print "\n\tIf sdFiles not given, reads from standard input.\n"; | |
57 print "\n\tOutput is to standard output.\n\n"; | |
58 exit; | |
59 } |