X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;fp=pb;h=0f87d74386756b9c953377bf09d10b245216c124;hp=7754f03a51041d846a03f52476c7b82aa34df780;hb=2bd0312dbe43e71cb47b06f851b1168054a325de;hpb=adcadf190dca4ecef87ae0e3cb3d2f2affd46542
diff --git a/pb b/pb
index 7754f03..0f87d74 100755
--- a/pb
+++ b/pb
@@ -2,15 +2,22 @@
# pinosaur's blog script
+data_dir="blog"
+website_url="https://www.youtube.com/watch?v=oHg5SJYRHA0/"
+
blog_index_file="blogindex.html"
rolling_file="rolling.html"
-template_file="template.html"
-index_entry_template="index_entry.html"
rss_file="rss.xml"
-data_dir="blog"
-[ ! -z "$EDITOR" ] && EDITOR="vim"
+blog_template="template.html"
+index_template="index_entry.html"
+rolling_template="rolling_entry.html"
+rss_template="rss_entry.html"
+start_token=""
+end_token=""
+
+[ ! -z "$EDITOR" ] && EDITOR="vim"
init() {
read -p "Initialize blog? [y/n] " ask
@@ -18,14 +25,15 @@ init() {
mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates"
- echo '
{{TITLE}}
' >> "$data_dir/templates/$index_entry_template"
+ echo '{{TITLE}}
' >> "$data_dir/templates/$index_template"
+ echo -e '' >> "$data_dir/templates/$rolling_template"
+ echo -e '- \n{{TITLE}}\n\n<\description>\n<\item>' \
+ >> "$data_dir/templates/$rss_template"
echo "Created blog files"
}
refresh() {
- start_token=""
- end_token=""
read -p "Are you sure you want to refresh? [y/n] " ask
[ "$ask" != "y" ] && exit 0
@@ -36,6 +44,7 @@ refresh() {
sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$rss_file"
# deletes all html files and republishes all published files
+ echo "Refreshed."
}
new() {
@@ -50,10 +59,11 @@ new() {
sub() {
cat - |\
- sed -e "s/{{TITLE}}/$1/g;
- s/{{DATE}}/`date +'%a, %b %d %H:%M'`/g" |\
- sed -e "/{{BODY}}/r $data_dir/drafts/$1" |\
- sed -e "/{{BODY}}/d"
+ sed "s/{{TITLE}}/$1/g;
+ s/{{DATE}}/`date +'%a, %b %d %H:%M'`/g;
+ s/{{URL}}/$website_url\\/$1/g" |\
+ sed "/{{BODY}}/r $data_dir/drafts/$1" |\
+ sed "/{{BODY}}/d"
}
publish() {
@@ -69,13 +79,15 @@ publish() {
to_publish=${to_publish%.draft.html}
[ -z "$to_publish" ] && echo "Invalid choice" && exit 1
- cat $template_file | sub "$to_publish" \
+ cat $blog_template | sub "$to_publish" \
> "$data_dir/html/$to_publish.html"
# Add new entry to blog index (do something about indent??)
- sed -i "// a\
- `cat "$data_dir/templates/$index_entry_template" | sub "$to_publish"`" "$blog_index_file"
- #also clean up this bracket mess ^
+ sed -i "/$start_token/ a\
+ \n`cat "$data_dir/templates/$index_template" | sub "$to_publish"`\n" "$blog_index_file"
+
+ sed -i "/$start_token/ a\
+ \n`cat "$data_dir/templates/$rolling_template" | sub "$to_publish"`\n" "$rolling_file"
mv "$data_dir/drafts/$to_publish.draft.html" "$data_dir/published/"
@@ -96,13 +108,14 @@ delete() {
mv "$data_dir/published/$to_delete.draft.html" "$data_dir/drafts/" &&\
rm "$data_dir/html/$to_delete.html"
- # remove entry from blog index (broken rn)
- #entry=`cat "$data_dir/templates/$index_entry_template" | sub "$to_publish"`
- #sed -i "/$entry/ d" "$blog_index_file"
+ # remove entry from blog index
+ sed -i "//,// d" "$blog_index_file"
+ sed -i "//,// d" "$rolling_file"
+
}
# check to see if all required files are present
-[ -f $blog_index_file ] && [ -f $rolling_file ] && [ -f $template_file ] && [ -f $rss_file ] || { echo "You are missing a file, please check that you have $blog_index_file, $template_file, $rolling_file and $rss_file in your home directory" && exit 1; }
+[ -f $blog_index_file ] && [ -f $rolling_file ] && [ -f $blog_template ] && [ -f $rss_file ] || { echo "You are missing a file, please check that you have $blog_index_file, $template_file, $rolling_file and $rss_file in your home directory" && exit 1; }
# possibly also check to see if index and rolling have the proper headers