starting v2
[pb.git] / pb
diff --git a/pb b/pb
index 0f87d74..13201c2 100755 (executable)
--- a/pb
+++ b/pb
 #!/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="<!-- BLOG START -->"
-end_token="<!-- BLOG END -->"
-
-[ ! -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 '<p id="{{TITLE}}">{{TITLE}}</p>' >> "$data_dir/templates/$index_template"
-    echo -e '<div id="{{TITLE}}">\n<h2>{{TITLE}}</h2>\n<p>{{DATE}}</p></div>' >> "$data_dir/templates/$rolling_template"
-    echo -e '<item>\n<title>{{TITLE}}</title>\n<link></link>\n<description><\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 '<li><a href="{{URL}}">{{DATE}} - {{TITLE}}</a></li>' > "$index_template"
+    printf '<div>\n<h2>{{TITLE}}</h2>\n<p>{{DATE}}</p>\n<p>{{BODY}}</p>\n</div>\n' > "$rolling_template"
+    printf '<item>\n<title>{{TITLE}}</title>\n<link>{{URL}}</link>\n<description></description>\n{{BODY}}\n</item>\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\
-        <!-- ID:$to_publish START -->\n`cat "$data_dir/templates/$index_template" | sub "$to_publish"`\n<!-- ID:$to_publish END -->" "$blog_index_file"
-
-    sed -i "/$start_token/ a\
-        <!-- ID:$to_publish START -->\n`cat "$data_dir/templates/$rolling_template" | sub "$to_publish"`\n<!-- ID:$to_publish END -->" "$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 "/<!-- ID:$to_delete START -->/,/<!-- ID:$to_delete END -->/ d" "$blog_index_file"
-    sed -i "/<!-- ID:$to_delete START -->/,/<!-- ID:$to_delete END -->/ 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
 
+
+