aboutsummaryrefslogtreecommitdiff
path: root/data/storeSelect.sh
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