sed substitution stuff
[pb.git] / pb
diff --git a/pb b/pb
index ef4799c..c62e24d 100755 (executable)
--- a/pb
+++ b/pb
@@ -12,25 +12,42 @@ data_dir="blog"
 
 
 init() {
-    echo 1
+    echo "initing blog"
+    mkdir -p "$data_dir/drafts" &&\
+    mkdir -p "$data_dir/published" &&\
+    touch "$data_dir/database" 
 }
 
-purge() {
+refresh() {
     echo 1
     # add a confirmation of sorts here
 }
 
 new() {
-    [ -z $1 ] && echo "please supply a name" && exit 1 
+    [ -z "$1" ] && echo "please supply a name" && exit 1 
+
+    # sanitize input
+    sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'| sed -e 's/ /-/g'`
 
-    # do some sed stuff here
-    cp $template_file "$data_dir/drafts/$1"
+    # open in editor
+    $EDITOR "$data_dir/drafts/$sanitized"
 
 }
 
 publish() {
     echo "Select which post to publish"
     ls -1 "$data_dir/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" |\
+        sed -e "s/{{DATE}}/`date +'%a, %b %d %H:%M'`/g" |\
+        sed -e "/{{BODY}}/r $data_dir/drafts/$to_publish" |\
+        sed -e "/{{BODY}}/d" # rly ugly for now
+
 }
 
 delete() {
@@ -48,17 +65,14 @@ delete() {
 
 
 # check if blog dir exists
-[ ! -d $data_dir ] && echo "initing blog" &&\
-    mkdir -p "$data_dir/drafts" &&\
-    mkdir -p "$data_dir/published" &&\
-    touch "$data_dir/database" 
+[ ! -d $data_dir ]  && init
 
 case $1 in
-    i|init) echo "init";;
-    n|new) new $2;;
+    i|init) init;;
+    n|new) new "$2";;
     p|publish) publish;;
     d|delete) echo "delete";;
-    D|purge) echo "purge";;
+    r|refresh) echo "refresh";;
     *) echo "helper" && exit 1;;
 esac