|
1 #!/usr/bin/expect -f |
|
2 #====================================================================== |
|
3 # E N D L A D C P 2 |
|
4 # doc: Wed Mar 10 22:23:52 2004 |
|
5 # dlm: Wed Nov 19 15:13:20 2008 |
|
6 # (c) 2004 A.M. Thurnherr |
|
7 # uE-Info: 32 14 NIL 0 0 72 2 2 8 NIL ofnI |
|
8 #====================================================================== |
|
9 |
|
10 # HISTORY: |
|
11 # Mar 10, 2004: - begun |
|
12 # Mar 18, 2004: - released |
|
13 # Mar 20, 2004: - changed hwconfig file names |
|
14 # Jun 18, 2004: - BUG: could not handle stn 008 |
|
15 # Jan 25, 2005: - BUG: bbabble could not be in relative path (on MacOSX) |
|
16 # Feb 14, 2006: - BUG: log files were written to bin dir |
|
17 # Oct 4, 2006: - adapted to older expect version |
|
18 # Oct 28, 2006: - allowed for lrb downcasing filenames |
|
19 # Nov 6, 2006: - BUG: error when master download finished much before slave |
|
20 # Nov 19, 2008: - added version |
|
21 |
|
22 |
|
23 #---------------------------------------------------------------------- |
|
24 # Setup |
|
25 #---------------------------------------------------------------------- |
|
26 |
|
27 log_user 0; |
|
28 source DEFAULTS.expect; |
|
29 regsub {dir1} [exec which dir1] {libBB.expect} path; |
|
30 source $path; |
|
31 |
|
32 print_version; |
|
33 |
|
34 if ![file isdirectory $raw_dir] { |
|
35 error "directory $raw_dir does not exist"; |
|
36 } |
|
37 |
|
38 if {$argc != 0} { |
|
39 if {![affirm "downloading files to directory [lindex $argv 0] --- ok (y/N)? " 10]} { |
|
40 exit; |
|
41 } |
|
42 } |
|
43 |
|
44 #---------------------------------------------------------------------- |
|
45 # Get Station Number |
|
46 #---------------------------------------------------------------------- |
|
47 |
|
48 spawn bbabble -ms $tty0 $tty1; |
|
49 |
|
50 set_color; |
|
51 send_user "Connecting to instruments..."; |
|
52 wait_for_startup; |
|
53 reset_two_instruments; |
|
54 |
|
55 send_user "\nGetting station number..."; |
|
56 select_master 0; |
|
57 set master_deployment_name [get_deployment_name]; |
|
58 if {[scan $master_deployment_name $master_deployment_name_fmt master_stn] != 1} { |
|
59 send_error "$master_deployment_name $master_deployment_name_fmt"; |
|
60 error "Can't get station number of master"; |
|
61 } |
|
62 select_slave; set slave_deployment_name [get_deployment_name]; |
|
63 set slave_deployment_name [get_deployment_name]; |
|
64 if {[scan $slave_deployment_name $slave_deployment_name_fmt slave_stn] != 1} { |
|
65 error "Can't get station number of slave"; |
|
66 } |
|
67 if {$master_stn != $slave_stn} { |
|
68 select_master; put_to_sleep; select_slave; put_to_sleep; |
|
69 error "Master/slave stations disagree"; |
|
70 } |
|
71 set stn [format $stn_format $master_stn]; |
|
72 send_user "\[$stn\]"; |
|
73 |
|
74 set cast_dir [format %s/%s $raw_dir $stn]; |
|
75 if {![file isdirectory $cast_dir]} { |
|
76 select_master; put_to_sleep; select_slave; put_to_sleep; |
|
77 error "cast directory $cast_dir does not exist!"; |
|
78 } |
|
79 regsub {^[^/]} [exec which bbabble] "[exec pwd]/&" bbabble; |
|
80 if {$argc == 1} { # override download directory |
|
81 set cast_dir [lindex $argv 0]; |
|
82 if {![file isdir $cast_dir]} {exec mkdir $cast_dir} |
|
83 } |
|
84 |
|
85 cd $cast_dir; |
|
86 if {[llength [glob -nocomplain {*.[0-9][0-9][0-9]}]] > 0} { |
|
87 select_master; put_to_sleep; select_slave; put_to_sleep; |
|
88 error "cast directory [pwd] contains RDI data files!"; |
|
89 } |
|
90 |
|
91 send \004; |
|
92 |
|
93 #---------------------------------------------------------------------- |
|
94 # Download Data |
|
95 #---------------------------------------------------------------------- |
|
96 |
|
97 regsub {.*/} $argv0 {} basename; |
|
98 start_logging [format %s_%03d.log $basename $master_stn]; |
|
99 |
|
100 spawn $bbabble -ms $tty0 $tty1; |
|
101 wait_for_startup; |
|
102 |
|
103 send_user "\nSaving hardware configurations..."; |
|
104 select_master; save_hardware_config [format %s000.LOG $master_deployment_name]; |
|
105 resume_logging [format %s_%03d.log $basename $master_stn]; |
|
106 select_slave; save_hardware_config [format %s000.LOG $slave_deployment_name]; |
|
107 resume_logging [format %s_%03d.log $basename $master_stn]; |
|
108 |
|
109 send_user "\nStarting parallel downloads..."; |
|
110 select_master; start_download; |
|
111 select_slave; start_download; |
|
112 |
|
113 # NB: slave is assumed to download faster => finish it first, coz otherwise |
|
114 # it may auto-sleep and cause problems later on |
|
115 |
|
116 send_user "\n"; |
|
117 set_color 1; log_user 1; wait_for_download_finish $master_stn $download_timeout; |
|
118 log_user 0; set_color; |
|
119 send_user "\nPutting slave to sleep..."; put_to_sleep; send_user "\n"; |
|
120 |
|
121 toggle_instrument; |
|
122 set_color 0; log_user 1; wait_for_download_finish $master_stn $download_timeout; |
|
123 log_user 0; set_color; |
|
124 send_user "\nPutting master to sleep..."; ensure_sleep; send_user "\n"; |
|
125 |
|
126 #---------------------------------------------------------------------- |
|
127 # Check and Backup Data |
|
128 #---------------------------------------------------------------------- |
|
129 |
|
130 send_user "\nChecking data files...\n"; |
|
131 set_color 0; check_data [format %s000.000 [format $master_deployment_name_fmt $master_stn]]; |
|
132 set_color 1; check_data [format %s000.000 [format $slave_deployment_name_fmt $slave_stn]]; |
|
133 set_color; |
|
134 |
|
135 send_user "Backing up data files..."; |
|
136 backup_master_data $master_stn; |
|
137 backup_slave_data $master_stn; |
|
138 |
|
139 send_user "\nDone\n" |