-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathget_abdecks-storm.sh
executable file
·127 lines (98 loc) · 3.33 KB
/
get_abdecks-storm.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#!/bin/bash
###########################################################################
### Author: Panagiotis Velissariou <[email protected]>
###
### Version - 1.0 Mon Nov 16 2020
###########################################################################
###====================
# Make sure that the current working directory is in the PATH
[[ ! :$PATH: == *:".":* ]] && export PATH="${PATH}:."
# Get the directory where the script is located
if [[ $(uname -s) == Darwin ]]; then
# readonly scrDIR="$(cd "$(dirname "$(greadlink -f -n "${BASH_SOURCE[0]}" )" )" && pwd -P)"
readonly scrNAME="$( grealpath -s "${BASH_SOURCE[0]}" )"
readonly scrDIR="$(cd "$(dirname "${scrNAME}" )" && pwd -P)"
else
# readonly scrDIR="$(cd "$(dirname "$(readlink -f -n "${BASH_SOURCE[0]}" )" )" && pwd -P)"
readonly scrNAME="$( realpath -s "${BASH_SOURCE[0]}" )"
readonly scrDIR="$(cd "$(dirname "$(realpath -s "${BASH_SOURCE[0]}")" )" && pwd -P)"
fi
funcs="$( find . -type f -name "functions_build" | head -n 1 )"
if [ -f "${funcs}" ]; then
source "${funcs}"
else
echo " ### ERROR:: in ${scrNAME}"
echo " Cannot load the required file: ${funcs}"
echo " Exiting now ..."
echo
exit 1
fi
unset funcs
###====================
USE_ADECK=0
#########
# Call ParseArgs to get the user input.
ParseArgsTracs "${@}"
##########
# Set the variables for this script
if [ -z "${MY_ROOTDIR:-}" ]; then
echo "The data directory is not specified."
echo "Run: \"$(basename ${scrNAME}) -h\" to see available options."
echo "Exiting ..."
exit 1
fi
if [ -z "${MY_BASIN:-}" ]; then
echo "The basin where the storm occured is not specified."
echo "Run: \"$(basename ${scrNAME}) -h\" to see available options."
echo "Exiting ..."
exit 1
fi
if [ -z "${MY_STORMNAME:-}" ]; then
echo "The name of the storm is not specified."
echo "Run: \"$(basename ${scrNAME}) -h\" to see available options."
echo "Exiting ..."
exit 1
fi
if [ -z "${MY_YEAR:-}" ]; then
echo "The year of the storm is not specified."
echo "Run: \"$(basename ${scrNAME}) -h\" to see available options."
echo "Exiting ..."
exit 1
fi
##########
############################################################
### START THE CALCULATIONS
############################################################
datDIR="${MY_ROOTDIR}"
deckCHAR="b"
[ ${USE_ADECK:-0} -gt 0 ] && deckCHAR="a"
outFILE="`toLOWER ${MY_STORMNAME}`${MY_YEAR}-${deckCHAR}deck.dat"
lbasin="$( toLOWER "${MY_BASIN}" )"
datIDS=( $( grep -H -m 1 -i "${MY_BASIN},.*,.*${MY_YEAR}.*${MY_STORMNAME}" ${datDIR}/${deckCHAR}${lbasin}* 2>/dev/null \
| head -1 | sed -e "s@[:,]@ @g" ) )
datFILE="${datIDS[0]}"
strmBas="${datIDS[1]}"
strmNum="${datIDS[2]}"
strmYear="${MY_YEAR}"
if [ ! -e "${datFILE}" ]; then
echo
echo "The data file \"${datFILE}\" does not exist."
echo "Adjust the variable datFILE in the script"
echo "Exiting now ..."
echo
exit 1
fi
grep_cmd="grep \"^${strmBas},.*${strmNum},.*${strmYear}\" ${datFILE} > ${outFILE}"
eval ${grep_cmd}
err=$?
if [ ${err:-0} -eq 0 ]; then
echo "Created the data file: ${outFILE}"
else
echo "ERROR :: Could not find a proper storm block in the file: ${datFILE}"
echo "Used: BASIN = ${MY_BASIN}"
echo " YEAR = ${MY_YEAR}"
echo " STORM = ${MY_STORMNAME}"
echo "Command used: ${grep_cmd}"
[ -e "${outFILE}" ] && rm -f ${outFILE}
fi
exit 0