X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=c62e24d23c2b3911d3e718b8462ace7bd3c83de9;hp=ef4799ca2dc18bc33041a7f60513fa3ecc18ed62;hb=0c0d61384bc81e685153b014b67de33cb514e8fd;hpb=36f17adad2a26a270a8e6c4d02bdd320dda708e7 diff --git a/pb b/pb index ef4799c..c62e24d 100755 --- 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