author | A.M. Thurnherr <athurnherr@yahoo.com> |
Fri, 03 Jul 2020 10:25:08 -0400 | |
changeset 12 | 5e67754f6457 |
parent 11 | c39e37d59638 |
permissions | -rwxr-xr-x |
0 | 1 |
#!/usr/bin/expect -f |
2 |
#====================================================================== |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
3 |
# E N D L A D C P 2 |
0 | 4 |
# doc: Wed Mar 10 22:23:52 2004 |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
5 |
# dlm: Fri Jul 3 10:22:21 2020 |
0 | 6 |
# (c) 2004 A.M. Thurnherr |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
7 |
# uE-Info: 19 70 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 |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
19 |
# Nov 6, 2006: - BUG: error when DL download finished much before UL |
0 | 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 |
11 | 25 |
# Nov 10, 2013: - added directory listing before download |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
26 |
# Jul 3, 2020: - expunged master/slave terminology |
0 | 27 |
|
28 |
#---------------------------------------------------------------------- |
|
29 |
# Setup |
|
30 |
#---------------------------------------------------------------------- |
|
31 |
||
32 |
log_user 0; |
|
4
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
33 |
source CRUISE_SETUP.expect; |
fda11de1826e
version left on Poseidon at end of P403
A.M. Thurnherr <ant@ldeo.columbia.edu>
parents:
0
diff
changeset
|
34 |
regsub {dir1} [exec which dir1] {libRDI.expect} path; |
0 | 35 |
source $path; |
36 |
||
37 |
print_version; |
|
38 |
||
39 |
if ![file isdirectory $raw_dir] { |
|
40 |
error "directory $raw_dir does not exist"; |
|
41 |
} |
|
42 |
||
43 |
if {$argc != 0} { |
|
44 |
if {![affirm "downloading files to directory [lindex $argv 0] --- ok (y/N)? " 10]} { |
|
45 |
exit; |
|
46 |
} |
|
47 |
} |
|
48 |
||
49 |
#---------------------------------------------------------------------- |
|
11 | 50 |
# List Memory Contents |
0 | 51 |
#---------------------------------------------------------------------- |
52 |
||
53 |
spawn bbabble -ms $tty0 $tty1; |
|
54 |
||
55 |
set_color; |
|
56 |
send_user "Connecting to instruments..."; |
|
57 |
wait_for_startup; |
|
58 |
reset_two_instruments; |
|
59 |
||
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
60 |
select_DL 0; send_user "\n"; list_dir; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
61 |
select_UL; send_user "\n"; list_dir; |
11 | 62 |
|
63 |
#---------------------------------------------------------------------- |
|
64 |
# Get Station Number & Carry Out Sanity Check |
|
65 |
#---------------------------------------------------------------------- |
|
66 |
||
0 | 67 |
send_user "\nGetting station number..."; |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
68 |
select_DL; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
69 |
set DL_deployment_name [get_deployment_name]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
70 |
if {[scan $DL_deployment_name $DL_deployment_name_fmt DL_stn] != 1} { |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
71 |
send_error "$DL_deployment_name $DL_deployment_name_fmt"; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
72 |
error "Can't get station number of DL"; |
0 | 73 |
} |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
74 |
select_UL; set UL_deployment_name [get_deployment_name]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
75 |
set UL_deployment_name [get_deployment_name]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
76 |
if {[scan $UL_deployment_name $UL_deployment_name_fmt UL_stn] != 1} { |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
77 |
error "Can't get station number of UL"; |
0 | 78 |
} |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
79 |
if {$DL_stn != $UL_stn} { |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
80 |
select_DL; put_to_sleep; select_UL; put_to_sleep; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
81 |
error "DL/UL stations disagree"; |
0 | 82 |
} |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
83 |
set stn [format $stn_format $DL_stn]; |
0 | 84 |
send_user "\[$stn\]"; |
85 |
||
86 |
set cast_dir [format %s/%s $raw_dir $stn]; |
|
87 |
if {![file isdirectory $cast_dir]} { |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
88 |
select_DL; put_to_sleep; select_UL; put_to_sleep; |
0 | 89 |
error "cast directory $cast_dir does not exist!"; |
90 |
} |
|
91 |
regsub {^[^/]} [exec which bbabble] "[exec pwd]/&" bbabble; |
|
92 |
if {$argc == 1} { # override download directory |
|
93 |
set cast_dir [lindex $argv 0]; |
|
94 |
if {![file isdir $cast_dir]} {exec mkdir $cast_dir} |
|
95 |
} |
|
96 |
||
97 |
cd $cast_dir; |
|
98 |
if {[llength [glob -nocomplain {*.[0-9][0-9][0-9]}]] > 0} { |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
99 |
select_DL; put_to_sleep; select_UL; put_to_sleep; |
0 | 100 |
error "cast directory [pwd] contains RDI data files!"; |
101 |
} |
|
102 |
||
103 |
send \004; |
|
104 |
||
105 |
#---------------------------------------------------------------------- |
|
106 |
# Download Data |
|
107 |
#---------------------------------------------------------------------- |
|
108 |
||
109 |
regsub {.*/} $argv0 {} basename; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
110 |
start_logging [format %s_%03d.log $basename $DL_stn]; |
0 | 111 |
|
5 | 112 |
spawn $bbabble -msy $ymodem_receive_cmd $tty0 $tty1; |
0 | 113 |
wait_for_startup; |
114 |
||
115 |
send_user "\nSaving hardware configurations..."; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
116 |
select_DL; save_hardware_config [format %s000.LOG $DL_deployment_name]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
117 |
resume_logging [format %s_%03d.log $basename $DL_stn]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
118 |
select_UL; save_hardware_config [format %s000.LOG $UL_deployment_name]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
119 |
resume_logging [format %s_%03d.log $basename $DL_stn]; |
0 | 120 |
|
121 |
send_user "\nStarting parallel downloads..."; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
122 |
select_DL; start_download; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
123 |
select_UL; start_download; |
0 | 124 |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
125 |
# NB: UL is assumed to download faster => finish it first, coz otherwise |
0 | 126 |
# it may auto-sleep and cause problems later on |
127 |
||
128 |
send_user "\n"; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
129 |
set_color 1; log_user 1; wait_for_download_finish $DL_stn $download_timeout; |
0 | 130 |
log_user 0; set_color; |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
131 |
send_user "\nPutting UL to sleep..."; put_to_sleep; send_user "\n"; |
0 | 132 |
|
133 |
toggle_instrument; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
134 |
set_color 0; log_user 1; wait_for_download_finish $DL_stn $download_timeout; |
0 | 135 |
log_user 0; set_color; |
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
136 |
send_user "\nPutting DL to sleep..."; ensure_sleep; send_user "\n"; |
0 | 137 |
|
138 |
#---------------------------------------------------------------------- |
|
139 |
# Check and Backup Data |
|
140 |
#---------------------------------------------------------------------- |
|
141 |
||
142 |
send_user "\nChecking data files...\n"; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
143 |
set_color 0; check_data [format %s000.000 [format $DL_deployment_name_fmt $DL_stn]]; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
144 |
set_color 1; check_data [format %s000.000 [format $UL_deployment_name_fmt $UL_stn]]; |
0 | 145 |
set_color; |
146 |
||
147 |
send_user "Backing up data files..."; |
|
12
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
148 |
backup_DL_data $DL_stn; |
5e67754f6457
V1.6: no more master/slave terminology
A.M. Thurnherr <athurnherr@yahoo.com>
parents:
11
diff
changeset
|
149 |
backup_UL_data $DL_stn; |
0 | 150 |
|
151 |
send_user "\nDone\n" |