X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=c3bee842fcc5d1c4232c7c4167545751b5d7abb2;hp=a221306aee845f6a6d9ec46ffccae0c60128f410;hb=8642e09f89ab92d4d883dd882629cf5d8abee83f;hpb=afdc3b16d6d77fb03df04c5ed1883e48064e0672 diff --git a/pb b/pb index a221306..c3bee84 100755 --- a/pb +++ b/pb @@ -2,107 +2,118 @@ # pinosaur's blog script +data_dir="blog" +website_url="https://www.youtube.com/watch?v=oHg5SJYRHA0/" + blog_index_file="blogindex.html" rolling_file="rolling.html" -template_file="template.html" rss_file="rss.xml" -data_dir="blog" -[ ! -z "$EDITOR" ] && EDITOR="vim" +blog_template="template.html" +index_template="index_entry.html" +rolling_template="rolling_entry.html" +rss_template="rss_entry.html" +[ ! -z "$EDITOR" ] && EDITOR="vim" init() { - read -p "Initialize blog? [y/n] " ask + read -p "Initialize blog here? [y/n] " ask [ "$ask" != "y" ] && 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 '

{{TITLE}}

' >> "$data_dir/templates/$index_template" + echo -e '
\n

{{TITLE}}

\n

{{DATE}}

' >> "$data_dir/templates/$rolling_template" + echo -e '\n{{TITLE}}\n\n<\description>\n<\item>' \ + >> "$data_dir/templates/$rss_template" 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" + # delete everything between tokens (remove dupe code) + echo -e "$blog_index_file\n$rolling_file\n$rss_file" | xargs sed -i "//,//{//!{//!d}}" # deletes all html files and republishes all published files + + echo "Refreshed." } 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" +} + +# $1 is directory +choose() { # working on abstraction + options=`ls -1 "$1" | sed 's/\.draft\.html$//;s/\.html$//'` + [ -z "$options" ] && echo "No drafts to publish" && exit 0 + echo "$options" | nl + read -p 'Choose an entry by number > ' choice + chosen=`ls -1 "$1" | sed -n "$choice p"` + [ -z "$chosen" ] && echo "Invalid choice" && exit 1 +} + publish() { - drafts=`ls -1 "$data_dir/drafts" | sed -e 's/\.draft\.html$//'` - [ -z "$drafts" ] && echo "No drafts to publish" && exit 0 + choose "$data_dir/drafts" + to_publish=${chosen%.draft.html} - echo "Select which draft to publish" - echo "$drafts" | nl + cat $blog_template | sub "$to_publish" \ + > "$data_dir/html/$to_publish.html" - read -p '> ' choice - to_publish=`ls -1 "$data_dir/drafts/" | sed -n "$choice p"` - [ -z "$to_publish" ] && echo "Invalid choice" && exit 1 + index_entry="$(cat "$data_dir/templates/$index_template" | sub "$to_publish")" - 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/" + #sed is breaking when trying to add multiple lines for some reason # Add new entry to blog index (do something about indent??) - sed -i "// a

$to_publish<\\/h3>" "$blog_index_file" -} + # echo -e "//a \n\n$index_entry\n" + sed -i "//a \n${index_entry}\n" "$blog_index_file" + mv "$data_dir/drafts/$to_publish.draft.html" "$data_dir/published/" -delete() { - published=`ls -1 "$data_dir/published" | sed -e 's/\.draft\.html$//'` - [ -z "$published" ] && echo "No posts to delete" && exit 0 + echo "Successfully published $to_publish" + +} - echo "Select which post to delete" - echo "$published" | nl +delete() { + choose "$data_dir/published" + to_delete=${chosen%.draft.html} - 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.draft.html" "$data_dir/drafts/" &&\ + rm "$data_dir/html/$to_delete.html" - mv "$data_dir/published/$to_delete" "$data_dir/drafts/" &&\ - rm "$data_dir/html/${to_delete%.draft.html}.html" + # remove entries from files + echo -e "$blog_index_file\n$rolling_file\n$rss_file" | xargs sed -i "//,// d" - # remove entry from blog index + echo "Successfully deleted $to_delete" } # 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 $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; } # possibly also check to see if index and rolling have the proper headers # check if blog dir exists -[ ! -d $data_dir ] && init +[ ! -d $data_dir ] && init && exit case $1 in - i|init) init;; n|new) new "$2";; p|publish) publish;; d|delete) delete;;