summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLouie Shprung <lshprung@scu.edu>2023-03-26 13:58:50 -0700
committerLouie Shprung <lshprung@scu.edu>2023-03-26 13:58:50 -0700
commit3c530aafe415db3515465e8b0662373065afd925 (patch)
tree3d6a4407c10d1b25abc17b3729c94c27b15488b2
parent78056b724b9a5591ea2361429ed2d83b2e528dcf (diff)
Index terms
-rw-r--r--Makefile10
-rwxr-xr-xsrc/index-page.sh (renamed from src/index.sh)23
-rwxr-xr-xsrc/index-terms.sh38
-rw-r--r--src/lib/create_table6
-rw-r--r--src/lib/insert9
5 files changed, 68 insertions, 18 deletions
diff --git a/Makefile b/Makefile
index 7f47fab..5ab2219 100644
--- a/Makefile
+++ b/Makefile
@@ -80,9 +80,15 @@ $(DOCUMENTS_DIR): $(RESOURCES_DIR) $(MANUAL_FILE)
$(INFO_PLIST_FILE): src/Info.plist $(CONTENTS_DIR)
cp src/Info.plist $@
-$(INDEX_FILE): src/index.sh $(DOCUMENTS_DIR)
+$(INDEX_FILE): src/index-page.sh src/index-terms.sh $(DOCUMENTS_DIR)
rm -f $@
- src/index.sh $@ $(DOCUMENTS_DIR)/*.html
+ src/index-page.sh $@ $(DOCUMENTS_DIR)/*.html
+ src/index-terms.sh "Entry" $@ $(DOCUMENTS_DIR)/Concept-Index.html
+ src/index-terms.sh "Function" $@ $(DOCUMENTS_DIR)/Index-of-Functions-and-Macros.html
+ src/index-terms.sh "Variable" $@ $(DOCUMENTS_DIR)/Index-of-Variables.html
+ src/index-terms.sh "Type" $@ $(DOCUMENTS_DIR)/Index-of-Data-Types.html
+ src/index-terms.sh "Hook" $@ $(DOCUMENTS_DIR)/Index-of-Hooks.html
+ src/index-terms.sh "Option" $@ $(DOCUMENTS_DIR)/Index-of-Scanner-Options.html # TODO remove duplicates
$(ICON_FILE): src/icon.png $(DOCSET_DIR)
cp $(SRC_ICON) $@
diff --git a/src/index.sh b/src/index-page.sh
index 5aca876..e26cdf8 100755
--- a/src/index.sh
+++ b/src/index-page.sh
@@ -1,14 +1,13 @@
#!/usr/bin/env sh
+# shellcheck source=./lib/create_table
+. "$(dirname "$0")"/lib/create_table
+# shellcheck source=./lib/insert
+. "$(dirname "$0")"/lib/insert
+
DB_PATH="$1"
shift
-create_table() {
- sqlite3 "$DB_PATH" "CREATE TABLE IF NOT EXISTS searchIndex(id INTEGER PRIMARY KEY, name TEXT, type TEXT, path TEXT);"
- sqlite3 "$DB_PATH" "CREATE UNIQUE INDEX IF NOT EXISTS anchor ON searchIndex (name, type, path);"
-}
-
-
get_title() {
FILE="$1"
@@ -30,14 +29,6 @@ get_type() {
esac
}
-insert() {
- NAME="$1"
- TYPE="$2"
- PAGE_PATH="$3"
-
- sqlite3 "$DB_PATH" "INSERT INTO searchIndex(name, type, path) VALUES (\"$NAME\",\"$TYPE\",\"$PAGE_PATH\");"
-}
-
insert_pages() {
# Get title and insert into table for each html file
while [ -n "$1" ]; do
@@ -60,11 +51,11 @@ insert_pages() {
esac
if [ -n "$PAGE_NAME" ]; then
- insert "$PAGE_NAME" "$PAGE_TYPE" "$(basename "$1")"
+ insert "$DB_PATH" "$PAGE_NAME" "$PAGE_TYPE" "$(basename "$1")"
fi
shift
done
}
-create_table
+create_table "$DB_PATH"
insert_pages "$@"
diff --git a/src/index-terms.sh b/src/index-terms.sh
new file mode 100755
index 0000000..8ac3163
--- /dev/null
+++ b/src/index-terms.sh
@@ -0,0 +1,38 @@
+#!/usr/bin/env sh
+
+# shellcheck source=./lib/create_table
+. "$(dirname "$0")"/lib/create_table
+# shellcheck source=./lib/insert
+. "$(dirname "$0")"/lib/insert
+
+TYPE="$1"
+shift
+DB_PATH="$1"
+shift
+
+insert_index_terms() {
+ # Get each term from an index page and insert
+ while [ -n "$1" ]; do
+ grep -Eo "<a href.*</a>:" "$1" | while read -r line; do
+ insert_term "$line"
+ done
+
+ shift
+ done
+}
+
+insert_term() {
+ LINK="$1"
+ NAME="$(echo "$LINK" | pup -p 'a text{}' | sed 's/\"\"//g' | tr -d \\n)"
+ PAGE_PATH="$(echo "$LINK" | pup -p 'a attr{href}')"
+
+ # DEBUG
+ #echo "$NAME"
+ #echo "$PAGE_PATH"
+ #echo
+
+ insert "$DB_PATH" "$NAME" "$TYPE" "$PAGE_PATH"
+}
+
+create_table "$DB_PATH"
+insert_index_terms "$@"
diff --git a/src/lib/create_table b/src/lib/create_table
new file mode 100644
index 0000000..cdeb477
--- /dev/null
+++ b/src/lib/create_table
@@ -0,0 +1,6 @@
+create_table() {
+ DB_PATH="$1"
+
+ sqlite3 "$DB_PATH" "CREATE TABLE IF NOT EXISTS searchIndex(id INTEGER PRIMARY KEY, name TEXT, type TEXT, path TEXT);"
+ sqlite3 "$DB_PATH" "CREATE UNIQUE INDEX IF NOT EXISTS anchor ON searchIndex (name, type, path);"
+}
diff --git a/src/lib/insert b/src/lib/insert
new file mode 100644
index 0000000..2e4dd8c
--- /dev/null
+++ b/src/lib/insert
@@ -0,0 +1,9 @@
+insert() {
+ DB_PATH="$1"
+ NAME="$2"
+ TYPE="$3"
+ PAGE_PATH="$4"
+
+ sqlite3 "$DB_PATH" "INSERT INTO searchIndex(name, type, path) VALUES (\"$NAME\",\"$TYPE\",\"$PAGE_PATH\");"
+}
+