author | A.M. Thurnherr <ant@ldeo.columbia.edu> |
Fri, 07 Jan 2011 23:25:51 +0000 | |
changeset 10 | 5873914adea7 |
parent 5 | f41d45fe7ae9 |
child 11 | c39e37d59638 |
permissions | -rwxr-xr-x |
0 | 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 | 5 |
# dlm: Wed Dec 1 03:15:23 2010 |
0 | 6 |
# (c) 2004 A.M. Thurnherr |
5 | 7 |
# uE-Info: 103 35 NIL 0 0 72 2 2 8 NIL ofnI |
0 | 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 |
|
4
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
21 |
# Aug 25, 2010: - DEFAULTS.expect -> CRUISE_SETUP.expect |
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
22 |
# - libBB.expect -> libRDI.expect |
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
23 |
# Aug 26, 2010: - added support for ymodem_download_cmd |
5 | 24 |
# Dec 1, 2010: - BUG: ymodem_receive_cmd instead of ymodem_download_cmd |
0 | 25 |
|
26 |
#---------------------------------------------------------------------- |
|
27 |
# Setup |
|
28 |
#---------------------------------------------------------------------- |
|
29 |
||
30 |
log_user 0; |
|
4
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
31 |
source CRUISE_SETUP.expect; |
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
32 |
regsub {dir1} [exec which dir1] {libRDI.expect} path; |
0 | 33 |
source $path; |
34 |
||
35 |
print_version; |
|
36 |
||
37 |
if ![file isdirectory $raw_dir] { |
|
38 |
error "directory $raw_dir does not exist"; |
|
39 |
} |
|
40 |
||
41 |
if {$argc != 0} { |
|
42 |
if {![affirm "downloading files to directory [lindex $argv 0] --- ok (y/N)? " 10]} { |
|
43 |
exit; |
|
44 |
} |
|
45 |
} |
|
46 |
||
47 |
#---------------------------------------------------------------------- |
|
48 |
# Get Station Number |
|
49 |
#---------------------------------------------------------------------- |
|
50 |
||
51 |
spawn bbabble -ms $tty0 $tty1; |
|
52 |
||
53 |
set_color; |
|
54 |
send_user "Connecting to instruments..."; |
|
55 |
wait_for_startup; |
|
56 |
reset_two_instruments; |
|
57 |
||
58 |
send_user "\nGetting station number..."; |
|
59 |
select_master 0; |
|
60 |
set master_deployment_name [get_deployment_name]; |
|
61 |
if {[scan $master_deployment_name $master_deployment_name_fmt master_stn] != 1} { |
|
62 |
send_error "$master_deployment_name $master_deployment_name_fmt"; |
|
63 |
error "Can't get station number of master"; |
|
64 |
} |
|
65 |
select_slave; set slave_deployment_name [get_deployment_name]; |
|
66 |
set slave_deployment_name [get_deployment_name]; |
|
67 |
if {[scan $slave_deployment_name $slave_deployment_name_fmt slave_stn] != 1} { |
|
68 |
error "Can't get station number of slave"; |
|
69 |
} |
|
70 |
if {$master_stn != $slave_stn} { |
|
71 |
select_master; put_to_sleep; select_slave; put_to_sleep; |
|
72 |
error "Master/slave stations disagree"; |
|
73 |
} |
|
74 |
set stn [format $stn_format $master_stn]; |
|
75 |
send_user "\[$stn\]"; |
|
76 |
||
77 |
set cast_dir [format %s/%s $raw_dir $stn]; |
|
78 |
if {![file isdirectory $cast_dir]} { |
|
79 |
select_master; put_to_sleep; select_slave; put_to_sleep; |
|
80 |
error "cast directory $cast_dir does not exist!"; |
|
81 |
} |
|
82 |
regsub {^[^/]} [exec which bbabble] "[exec pwd]/&" bbabble; |
|
83 |
if {$argc == 1} { # override download directory |
|
84 |
set cast_dir [lindex $argv 0]; |
|
85 |
if {![file isdir $cast_dir]} {exec mkdir $cast_dir} |
|
86 |
} |
|
87 |
||
88 |
cd $cast_dir; |
|
89 |
if {[llength [glob -nocomplain {*.[0-9][0-9][0-9]}]] > 0} { |
|
90 |
select_master; put_to_sleep; select_slave; put_to_sleep; |
|
91 |
error "cast directory [pwd] contains RDI data files!"; |
|
92 |
} |
|
93 |
||
94 |
send \004; |
|
95 |
||
96 |
#---------------------------------------------------------------------- |
|
97 |
# Download Data |
|
98 |
#---------------------------------------------------------------------- |
|
99 |
||
100 |
regsub {.*/} $argv0 {} basename; |
|
101 |
start_logging [format %s_%03d.log $basename $master_stn]; |
|
102 |
||
5 | 103 |
spawn $bbabble -msy $ymodem_receive_cmd $tty0 $tty1; |
0 | 104 |
wait_for_startup; |
105 |
||
106 |
send_user "\nSaving hardware configurations..."; |
|
107 |
select_master; save_hardware_config [format %s000.LOG $master_deployment_name]; |
|
108 |
resume_logging [format %s_%03d.log $basename $master_stn]; |
|
109 |
select_slave; save_hardware_config [format %s000.LOG $slave_deployment_name]; |
|
110 |
resume_logging [format %s_%03d.log $basename $master_stn]; |
|
111 |
||
112 |
send_user "\nStarting parallel downloads..."; |
|
113 |
select_master; start_download; |
|
114 |
select_slave; start_download; |
|
115 |
||
116 |
# NB: slave is assumed to download faster => finish it first, coz otherwise |
|
117 |
# it may auto-sleep and cause problems later on |
|
118 |
||
119 |
send_user "\n"; |
|
120 |
set_color 1; log_user 1; wait_for_download_finish $master_stn $download_timeout; |
|
121 |
log_user 0; set_color; |
|
122 |
send_user "\nPutting slave to sleep..."; put_to_sleep; send_user "\n"; |
|
123 |
||
124 |
toggle_instrument; |
|
125 |
set_color 0; log_user 1; wait_for_download_finish $master_stn $download_timeout; |
|
126 |
log_user 0; set_color; |
|
127 |
send_user "\nPutting master to sleep..."; ensure_sleep; send_user "\n"; |
|
128 |
||
129 |
#---------------------------------------------------------------------- |
|
130 |
# Check and Backup Data |
|
131 |
#---------------------------------------------------------------------- |
|
132 |
||
133 |
send_user "\nChecking data files...\n"; |
|
134 |
set_color 0; check_data [format %s000.000 [format $master_deployment_name_fmt $master_stn]]; |
|
135 |
set_color 1; check_data [format %s000.000 [format $slave_deployment_name_fmt $slave_stn]]; |
|
136 |
set_color; |
|
137 |
||
138 |
send_user "Backing up data files..."; |
|
139 |
backup_master_data $master_stn; |
|
140 |
backup_slave_data $master_stn; |
|
141 |
||
142 |
send_user "\nDone\n" |