X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=13201c223cd9423e7c6b4580df85420e8f9c009f;hp=0f87d74386756b9c953377bf09d10b245216c124;hb=199e6e727a023bc8a8e1bd217cbfeda5874b2d1a;hpb=2bd0312dbe43e71cb47b06f851b1168054a325de
diff --git a/pb b/pb
index 0f87d74..13201c2 100755
--- a/pb
+++ b/pb
@@ -1,134 +1,56 @@
#!/bin/sh
-
-# pinosaur's blog script
+# pinosaur's blog script v2!
data_dir="blog"
website_url="https://www.youtube.com/watch?v=oHg5SJYRHA0/"
-
-blog_index_file="blogindex.html"
rolling_file="rolling.html"
+blog_index_file="blogindex.html"
rss_file="rss.xml"
-
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"
+database_file="$data_dir/database"
+index_template="$data_dir/templates/index_entry.html"
+rolling_template="$data_dir/templates/rolling_entry.html"
+rss_template="$data_dir/templates/rss_entry.html"
init() {
- read -p "Initialize blog? [y/n] " ask
- [ "$ask" != "y" ] && exit 0
+ read -p "Initialize blog here? [y/n] " ask
+ [ "$ask" != "y" ] && printf "Initialization cancelled.\n" && exit 0
mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates"
- 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() {
-
- read -p "Are you sure you want to refresh? [y/n] " ask
- [ "$ask" != "y" ] && exit 0
-
- # delete everything between tokens (remove dupe code)
- sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$blog_index_file"
- sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$rolling_file"
- sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$rss_file"
+ printf '{{DATE}} - {{TITLE}}' > "$index_template"
+ printf '
\n
{{TITLE}}
\n
{{DATE}}
\n
{{BODY}}
\n
\n' > "$rolling_template"
+ printf '- \n{{TITLE}}\n{{URL}}\n\n{{BODY}}\n
\n' > "$rss_template"
+ touch "$database_file"
- # deletes all html files and republishes all published files
- echo "Refreshed."
+ printf 'Successfully initialized pb.\n'
}
new() {
- [ -z "$1" ] && echo "Please give your blog post a name (you should put it inside quotations)" && exit 1
-
- # sanitize input
- sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'| sed -e 's/ /-/g'`
-
- # open in editor
- $EDITOR "$data_dir/drafts/$sanitized.draft.html"
-}
-
-sub() {
- cat - |\
- 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"
+ printf 'new\n'
}
publish() {
-
- drafts=`ls -1 "$data_dir/drafts" | sed -e 's/\.draft\.html$//'`
- [ -z "$drafts" ] && echo "No drafts to publish" && exit 0
-
- echo "Select which draft to publish"
- echo "$drafts" | nl
-
- read -p '> ' choice
- to_publish=`ls -1 "$data_dir/drafts/" | sed -n "$choice p"`
- to_publish=${to_publish%.draft.html}
- [ -z "$to_publish" ] && echo "Invalid choice" && exit 1
-
- cat $blog_template | sub "$to_publish" \
- > "$data_dir/html/$to_publish.html"
-
- # Add new entry to blog index (do something about indent??)
- 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/"
-
+ printf 'publish\n'
}
delete() {
- published=`ls -1 "$data_dir/published" | sed -e 's/\.draft\.html$//'`
- [ -z "$published" ] && echo "No posts to delete" && exit 0
-
- echo "Select which post to delete"
- echo "$published" | nl
-
- read -p '> ' choice
- to_delete=`ls -1 "$data_dir/published/" | sed -n "$choice p"`
- to_delete=${to_delete%.draft.html}
- [ -z "$to_delete" ] && echo "Invalid choice" && exit 1
-
- mv "$data_dir/published/$to_delete.draft.html" "$data_dir/drafts/" &&\
- rm "$data_dir/html/$to_delete.html"
-
- # remove entry from blog index
- sed -i "//,// d" "$blog_index_file"
- sed -i "//,// d" "$rolling_file"
-
+ printf 'delete\n'
}
-# check to see if all required files are present
-[ -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; }
+[ -f $blog_index_file ] && [ -f $rolling_file ] && [ -f $rss_file ] && [ -f $blog_template ] || { echo "You are missing a file, please check that you have $blog_index_file, $blog_template, $rolling_file and $rss_file in your home directory" && exit 1; }
-# possibly also check to see if index and rolling have the proper headers
+[ -f $blog ]
-
-# check if blog dir exists
-[ ! -d $data_dir ] && init
+[ ! -d $data_dir ] && init && exit 0
case $1 in
- i|init) init;;
- n|new) new "$2";;
+ n|new) new;;
p|publish) publish;;
d|delete) delete;;
- r|refresh) refresh;;
- h|*) echo "helper";;
+ r|refresh) printf 'refresh\n';;
+ h|*) printf 'help\n';;
esac
+
+