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 '
\n

{{TITLE}}

\n

{{DATE}}

' >> "$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