-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathgsman_build_index.sh
executable file
·104 lines (88 loc) · 2.52 KB
/
gsman_build_index.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
#!/bin/bash
## /*
# @description
# This script is called when the --build-index option is passed to the
# gsman command. It cycles through all paths which have been specified
# to have gcsommented files in them and creates the help files for those
# commands and adds them to an index which is easily parsed when a user
# runs "gsman <command>".
# description@
#
# @options
# user Build only the user index
# main Build only the main index
# options@
#
# @notes
# - This script is not intended to be used on it's own.
# notes@
#
# @file gsman_build_index.sh
## */
declare -a paths
# user might want to build one of two indexes
if [ -n "$1" ]; then
[ "$1" == "user" ] && paths[0]="${gsman_paths_user}" && userOnly=true
[ "$1" == "main" ] && paths[0]="${gsman_paths_default}" && mainOnly=true
fi
# if paths has an element, then the passed-in argument was validated.
# otherwise, build all by default.
if [ ${#paths[@]} -eq 0 ]; then
paths[0]="${gsman_paths_default}"
paths[1]="${gsman_paths_user}"
fi
docPath="${gitscripts_doc_path}"
tmp="${gitscripts_temp_path}gsmantemp"
[ ! -d "${gitscripts_temp_path}" ] && mkdir "${gitscripts_temp_path}"
echo ${X}
echo ${H1}${H1HL}
echo " Beginning GSMan index build. Please wait... "
echo ${H1HL}${X}
echo
for (( i = 0; i < ${#paths[@]}; i++ )); do
docPathPrefix=
{ [ $userOnly ] || [ $i -eq 1 ]; } && docPathPrefix="user/"
docPath="${docPath}${docPathPrefix}"
[ ! -d "$docPath" ] && mkdir "$docPath"
docIndex="${docPath}gsman_index.txt"
: > "$docIndex"
for path in ${paths[i]}; do
echo "Indexing files in: $path"
for file in "$path"*; do
if [ ! -d "$file" ]; then
j=0
docType=""
docName=""
awk -f "${gitscripts_awk_path}gsman_parse.awk" "${file}" > "$tmp"
while read line; do
# first line -- type:...
if [ $j -eq 0 ]; then
docType="${line:5}"
[ -z "$docType" ] && docType="main"
if [ ! -d "${docPath}${docType}" ]; then
mkdir "${docPath}${docType}"
fi
# second line -- name:...
elif [ $j -eq 1 ]; then
docName="${line:5}"
if [ -n "$docName" ] && [ "$docName" != "source" ]; then
fileName="${docPath}${docType}/${docName}.txt"
rFileName="${fileName#${gitscripts_path}}"
echo "${docName}:${rFileName}" >> "$docIndex"
else
break
fi
# all other lines are the gsman comments
elif [ -n "$rFileName" ]; then
[ $j -eq 2 ] && : > "$fileName"
echo "$line" >> "$fileName"
fi
(( j++ ))
done <"$tmp"
fi
done
done
done
# clean up
rm "$tmp"
exit