blob: ae57447d60d4fac61eebfbd3ffb7d6f40675bc42 (
plain)
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
|
#!/bin/sh
#
# Apunta datos interactivamente.
#
# Estructura del archivo con información sobre cada tabla y primera línea de este archivo:
# # Name # File # AddDate # AddTime # Separator # Prompts...
# El primer caracter de esta primera línea se toma como el caracter de separación entre campos.
# AddDate y AddTime son verdaderos cuando su valor es 'y' y falsos en cualquier otro caso.
# Los _ en los prompts se sustituyen por espacios
storesDataFile="$HOME/data/stores.dat"
[ ! -f "$storesDataFile" ] &&
printf "Error: store data file \"${storesDataFile}\" not found.\n" >&2 &&
exit 1
dataFileSeparator="$(sed '1q' "$storesDataFile" | grep -Eo '^.')"
blankLineMarker='@BLANKLINEMARKER@'
gatherData () {
shift 1 # table name
file="$1"
shift 1
addDate=''
[ "$1" = 'y' ] && addDate='-d'
shift 1
addTime=''
[ "$1" = 'y' ] && addTime='-t'
shift 1
separator="$1"
[ "$1" = "$blankLineMarker" ] && separator="' '"
shift 1
data=''
for prompt in "$@"; do
fixedPrompt=$(echo "$prompt" | tr '_' ' ')
printf "${fixedPrompt}: " >&2
read newData
[ -z "$newData" ] && exit 1
data="${data} ${newData}"
done
store.sh -f "'${file}'" "$addDate" "$addTime" -s "$separator" $data
}
table="$(grep -Eo "^[^${dataFileSeparator}]+" "$storesDataFile" | fzf)"
[ -z "$table" ] && exit 0
tableLine="$(grep "^${table}${dataFileSeparator}" "$storesDataFile")"
tableData=$(echo $tableLine |
tr "$dataFileSeparator" '\n' |
sed "s/^\s*$/${blankLineMarker}/")
gatherData $tableData
|