-
-
Notifications
You must be signed in to change notification settings - Fork 28
/
CompileNextra.sh
146 lines (136 loc) · 4.86 KB
/
CompileNextra.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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#!/bin/bash
# new script to output content for nextra
# Compiles individual latex diagrams into individual markdown files
# To be served with saber
function usage {
echo -e "\033[0;35mIll-formed arguments. Use the following format.\033[0m"
echo "Usage: $0 [-r <int>] [-p <int>] [-l <int>] [-o <string>]"
echo "-r Create a markdown file with tex source. 1 for yes, 0 for no. Default=1"
echo "-p Method that to convert pdf to png. 0= Imagemagick, 1=pdftopng. Default = 0"
echo "-l Use latexmk to compile documents. 1 for yes, 0 for no. Default=1"
echo "-o Output File for Markdown documentation of tex files. Default=ReadMe.md"
exit 1
}
# Defaults
GEN_README=1
M_PDF2PNG=0
USE_LTMK=1
OUTPUT_FILE="ReadMe.md"
# raw tex file link
TEX_FILE_BASE_URL="https://raw.githubusercontent.com/FriendlyUser/LatexDiagrams/master"
# Get options
while getopts ":r:p:l:o:" o; do
case "${o}" in
r)
GEN_README=${OPTARG}
;;
p)
M_PDF2PNG=${OPTARG}
;;
l)
USE_LTMK=${OPTARG}
;;
o)
OUTPUT_FILE=${OPTARG}
;;
*)
usage
;;
esac
done
shift $((OPTIND-1))
# Validate options
# testing for empty strings, and ensuring numbers are within max ranges
if [[ "$GEN_README" > 1 || "$M_PDF2PNG" > 2 || "$USE_LTMK" > 1 ]]; then
usage
fi
dir=$(pwd)
# For now just copy pages over
if [ $GEN_README == 1 ]
then
# index page made manually
OUTPUT_DIR="saber"
IMAGE_DIR="$OUTPUT_DIR/public"
MD_DIR="$OUTPUT_DIR/pages"
# Remove pages directory, recreate every time
rm -rf $OUTPUT_DIR
# Make new markdown file every run
mkdir -vp $OUTPUT_DIR
prev_dir=''
# Generate markdown file containing relative url to image and perhaps path to tex code.
for tex in $(find $dir -name "*.tex")
do
cur_dir=$(dirname $tex)
rel_folder_path=$(realpath --relative-to="$dir" "$cur_dir")
rel_path_file=$(realpath --relative-to="$dir" "$tex")
if [ "$prev_dir" != "$rel_folder_path" ]
then
prev_dir=$rel_folder_path
else
echo "Parsing $rel_path_file from $rel_folder_path"
fi
# make markdown file
rel_image_path=$(basename "$rel_path_file" | cut -d. -f1)
# copy image files to new folder
mkdir -vp $MD_DIR/$rel_folder_path
mkdir -vp $IMAGE_DIR/$rel_folder_path
single_file_output=$MD_DIR/$rel_folder_path/$rel_image_path.mdx
web_image_path="$(basename -- $rel_folder_path/$rel_image_path.png)"
cp $rel_folder_path/$rel_image_path.png $IMAGE_DIR/$rel_folder_path/$rel_image_path.png
# Yaml header, saber throws errors without one of these in the md files
# temp copy of file
# Copy first 20 lines
# TEMPFILE="temp.file"
# SMALLFILE="parse.file"
# # need a better system for keyword extraction
# head -10 $tex >> $TEMPFILE
# tr -d '\n' < "temp.file" >> $SMALLFILE
# words=$(grep -o -E '\w+' "temp.file" | sort -u -f)
# stripped_words=$(printf '%s' "$words" | sed 's/[0-9]//g')
# purged_words=$(printf '%s' "$stripped_words" | sed 's/em//g; s/pt/ab/g; s///g; s/documentclass//g;
# s/usepackage//g; s/usetikzlibrary//g; s/and//g;')
# long_words=$(printf '%s' "$purged_words" | sed -E 's/\b\w{1,3}\b//g')
# rm $TEMPFILE
# rm $SMALLFILE
echo "import {OverleafDeployButton} from \"@/components/deployToOverleaf\"" >> $single_file_output
echo "" >> $single_file_output
echo "" >> $single_file_output
# description file with $rel_folder_path/$rel_image_path
description_file=$rel_folder_path/${rel_image_path}_description.txt
if [ -f $description_file ]
then
echo "# Description" >> $single_file_output
cat $description_file >> $single_file_output
echo "" >> $single_file_output
echo "Description file: $description_file"
else
echo "No description file found for $description_file"
fi
echo "" >> $single_file_output
keywords_file=$rel_folder_path/${rel_image_path}_keywords.txt
# check if file keywords.txt exists
if [ -f $keywords_file ]
then
echo "## Keywords" >> $single_file_output
cat $keywords_file >> $single_file_output
echo "" >> $single_file_output
fi
echo "" >> $single_file_output
echo "## Source Code" >> $single_file_output
echo "" >> $single_file_output
echo "" >> $single_file_output
echo "![$rel_folder_path](/$rel_folder_path/$rel_image_path.png \""$rel_image_path"\")" >> $single_file_output
echo "" >> $single_file_output
### Add code to markdown file
echo "\`\`\`tex copy" >> $single_file_output
cat $rel_path_file >> $single_file_output
echo "" >> $single_file_output
echo "\`\`\`" >> $single_file_output
echo "" >> $single_file_output
echo "<OverleafDeployButton texFilePath=\"$TEX_FILE_BASE_URL/$rel_folder_path/$rel_image_path.tex\"/>" >> $single_file_output
echo "" >> $single_file_output
# Go to directory with pdf files
# Go back to root directory
# cd $dir
done
fi