X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=13201c223cd9423e7c6b4580df85420e8f9c009f;hp=a221306aee845f6a6d9ec46ffccae0c60128f410;hb=199e6e727a023bc8a8e1bd217cbfeda5874b2d1a;hpb=afdc3b16d6d77fb03df04c5ed1883e48064e0672
diff --git a/pb b/pb
index a221306..13201c2 100755
--- a/pb
+++ b/pb
@@ -1,112 +1,56 @@
#!/bin/sh
+# pinosaur's blog script v2!
-# pinosaur's blog script
-
-blog_index_file="blogindex.html"
+data_dir="blog"
+website_url="https://www.youtube.com/watch?v=oHg5SJYRHA0/"
rolling_file="rolling.html"
-template_file="template.html"
+blog_index_file="blogindex.html"
rss_file="rss.xml"
-data_dir="blog"
-
-[ ! -z "$EDITOR" ] && EDITOR="vim"
-
+blog_template="template.html"
+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" &&\
- mkdir -p "$data_dir/published" &&\
- mkdir -p "$data_dir/html"
+ mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates"
- 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
-
- # delete everything between tokens
- sed -i "/$start_token/,/$end_token/{/$start_token/!{/$end_token/!d}}" "$blog_index_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
+ 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"
+ 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"`
- [ -z "$to_publish" ] && echo "Invalid choice" && exit 1
-
- cat $template_file |\
- sed -e "s/{{TITLE}}/$to_publish/g;
- s/{{DATE}}/`date +'%a, %b %d %H:%M'`/g" |\
- sed -e "/{{BODY}}/r $data_dir/drafts/$to_publish" |\
- sed -e "/{{BODY}}/d" \
- > "$data_dir/html/${to_publish%.draft.html}.html"
-
- mv "$data_dir/drafts/$to_publish" "$data_dir/published/"
-
- # Add new entry to blog index (do something about indent??)
- sed -i "// a $to_publish<\\/h3>" "$blog_index_file"
-
+ 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"`
- [ -z "$to_delete" ] && echo "Invalid choice" && exit 1
-
- mv "$data_dir/published/$to_delete" "$data_dir/drafts/" &&\
- rm "$data_dir/html/${to_delete%.draft.html}.html"
-
- # remove entry from blog index
+ printf 'delete\n'
}
-# check to see if all required files are present
-[ ! -f $blog_index_file ] && echo "missing $blog_index_file" && exit 1
-[ ! -f $rolling_file ] && echo "missing $rolling_file" && exit 1
-[ ! -f $template_file ] && echo "missing $template_file" && exit 1
-[ ! -f $rss_file ] && echo "missing $rss_file" && 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
+
+