From ee103902c141cdc3dce565af453b589fd1fc7a82 Mon Sep 17 00:00:00 2001 From: Louie Shprung Date: Mon, 21 Nov 2022 22:00:04 -0800 Subject: Rewrite in POSIX shell --- src/index.sh | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100755 src/index.sh (limited to 'src/index.sh') diff --git a/src/index.sh b/src/index.sh new file mode 100755 index 0000000..f4d898e --- /dev/null +++ b/src/index.sh @@ -0,0 +1,43 @@ +#!/usr/bin/env sh + +DB_PATH="$1" +shift + +get_title() { + FILE="$1" + + PATTERN=".*\(automake\).*" + + #Find pattern in file + grep -Eo "$PATTERN" "$FILE" | + #Remove tag + sed 's/<[^>]*>//g' | \ + #Remove '(automake)' + sed 's/(automake)//g' | \ + #Remove trailing space + sed 's/[ ]*$//g' | \ + #Replace '&' with '&' + sed 's/&/&/g' +} + +insert() { + NAME="$1" + TYPE="$2" + PAGE_PATH="$3" + + sqlite3 "$DB_PATH" "INSERT INTO searchIndex(name, type, path) VALUES (\"$NAME\",\"$TYPE\",\"$PAGE_PATH\");" +} + +# Create table +sqlite3 "$DB_PATH" "CREATE TABLE searchIndex(id INTEGER PRIMARY KEY, name TEXT, type TEXT, path TEXT);" +sqlite3 "$DB_PATH" "CREATE UNIQUE INDEX anchor ON searchIndex (name, type, path);" + +# Get title and insert into table for each html file +while [ -n "$1" ]; do + unset PAGE_NAME + PAGE_NAME="$(get_title "$1")" + if [ -n "$PAGE_NAME" ]; then + insert "$PAGE_NAME" "Guide" "$(basename "$1")" + fi + shift +done -- cgit