-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgenerate_docs.sh
executable file
·185 lines (149 loc) · 6.6 KB
/
generate_docs.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
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
#!/bin/bash
set -e # Exit immediately if a command exits with a non-zero status.
# Define the root directory of your Java source files
ROOT_DIR="src/main/java"
# Define the output directory for Markdown files
OUTPUT_DIR="docs"
# Create the output directory if it doesn't exist
mkdir -p "$OUTPUT_DIR"
# Create the main index.md for the docs folder
cat <<EOF > "$OUTPUT_DIR/index.md"
# Webslate - Java Basics
Welcome to the Webslate documentation for Java Basics.
## Table of Contents
EOF
# Function to process each directory
process_directory() {
local dir="$1"
local relative_path="${dir#$ROOT_DIR/}"
local output_dir="$OUTPUT_DIR/$relative_path"
# Skip the root source directory itself
if [[ "$dir" == "$ROOT_DIR" ]]; then
return
fi
# Remove trailing slashes to prevent double slashes in paths
output_dir="${output_dir%/}"
# Create the output directory if it doesn't exist
mkdir -p "$output_dir"
# Create or merge an index.md for the current directory
local md_file="$output_dir/index.md"
# Function to convert underscore_case back to Title Case
convert_to_title_case() {
echo "$1" | sed -E 's/_/ /g' | awk '{for(i=1;i<=NF;i++) $i=toupper(substr($i,1,1)) substr($i,2); print}'
}
# Start with the title and basic content
echo "# $(convert_to_title_case "$(basename "$dir")")" > "$md_file"
echo "" >> "$md_file"
echo "This section covers $(basename "$dir")." >> "$md_file"
echo "" >> "$md_file"
# Check if the index.md already exists in the source and merge with existing content
if [[ -f "$dir/index.md" ]]; then
echo "Merging content from existing $dir/index.md into $md_file"
cat "$dir/index.md" >> "$md_file"
echo "" >> "$md_file"
fi
# Flag to track if any Java files were found
local java_found=false
# Function to convert PascalCase to underscore_case
convert_to_underscore() {
echo "$1" | sed -E 's/([a-z])([A-Z])/\1_\2/g' | tr '[:upper:]' '[:lower:]'
}
# Add links to index.md for each .java file in the directory
for java_file in "$dir"/*.java; do
if [[ -f "$java_file" ]]; then
local file_name=$(basename "$java_file")
local link_name=$(convert_to_underscore "${file_name%.java}").md # Convert filename to underscore_case and change extension to .md
# Extract Markdown comments from the Java file
local comments=$(awk '/\/\*\*/,/\*\//' "$java_file" | sed 's/\/\*\*//;s/\*\///;s/\* //g' | sed '/^$/d')
# Remove multi-line comments from the Java code
local code=$(sed '/\/\*\*/,/\*\//d' "$java_file")
# Create a Markdown file for this Java file with syntax highlighting and comments at the bottom.
{
echo "> File Name: $file_name"
echo '```java'
echo "$code" # Include the actual code here without comments.
echo -e '\n```'
echo "" # Add an empty line before comments
# Append extracted comments at the bottom.
if [[ -n "$comments" ]]; then
echo "## Problem Description"
echo "$comments"
fi
} > "$output_dir/$link_name"
echo "Markdown file created: $output_dir/$link_name"
java_found=true
# Add link to index.md for this Java file's documentation.
echo "- [$link_name](./$link_name)" >> "$md_file"
fi
done
# Only create index.md if Java files were found
if ! $java_found; then
rm "$md_file" # Remove the empty index file
echo "No Java files found in $dir, removed empty index.md"
fi
# Recursively process subdirectories
for subdir in "$dir"/*/; do
if [[ -d "$subdir" ]]; then
process_directory "$subdir"
# Check if the subdirectory has any Java files before adding a link.
if compgen -G "$subdir/*.java" > /dev/null || [[ -f "$subdir/index.md" ]]; then
local subdir_name=$(basename "$subdir")
echo "- [$subdir_name](./$subdir_name/index.html)" >> "$md_file"
fi
fi
done
# Copy existing .md files (like intro.md) to the output directory, excluding index.md.
for existing_md in "$dir"/*.md; do
if [[ -f "$existing_md" && "$(basename "$existing_md")" != "index.md" ]]; then
cp "$existing_md" "$output_dir/"
echo "Copied existing Markdown file: $output_dir/$(basename "$existing_md")"
fi
done
# Add link to the main docs/index.md, linking to index.html.
if [[ -n "$relative_path" ]]; then # Check if relative_path is not empty.
local dir_name=$(basename "$dir")
echo "- [$dir_name](./$relative_path/index.html)" >> "$OUTPUT_DIR/index.md"
fi
}
# Start processing from the root directory, skipping src/main/java itself.
for dir in $ROOT_DIR/*; do
if [[ -d $dir ]]; then
process_directory "$dir"
fi
done
# Create the mkdocs.yml file outside the docs directory with theme settings.
cat <<EOF > mkdocs.yml
site_name: 'Webslate - Java Basics'
site_url: 'https://web-slate.github.io/java-basics/'
theme:
name: material # Use a theme that supports sidebar navigation.
features:
- navigation.sections # Enable sections in the sidebar.
- navigation.footer # Enable footer navigation for next/previous links.
- search.suggest # Enable search suggestions.
- search.highlight # Enable highlighting of search terms.
- search.share # Enable sharing of search results.
- content.code.copy
plugins:
- search
- gen_nav:
enabled: true
- mkdocstrings
markdown_extensions:
- pymdownx.highlight:
use_pygments: true
linenums: true
- pymdownx.superfences
nav:
- Basics: basics/introduction.md # Link to Basics section
- Data Types: data_types/introduction.md # Link to Data Types section
- Methods: basics/methods/introduction.md # Link to Methods section
- Recursions: basics/recursions/introduction.md # Link to Recursion section
- Data Structures: data_structures/introduction.md # Link to Data Structures section
- OOPs: oops/introduction.md # Link to OOPs section
- Algorithms: algorithms/introduction.md # Link to Algorithms section
- Leet Code: leet_code/introduction.md # Link to Leet Code section
EOF
# Correct specific paths in mkdocs.yml (make sure this is valid).
sed -i '' 's|docs/src/main/java/docs|docs|g' mkdocs.yml || true
echo "Generated mkdocs.yml for MkDocs."