X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=pb;h=7905b54c34ad079cc1343be2f00f6fd691cfb5b9;hb=eb9cbcb1755771257e005eb86c1225113365fae8;hp=64972875d8d95ac5761e06ed23d5e44377fae8ab;hpb=2a037724047c4f54023651b5bf81b4171356409e;p=pb.git
diff --git a/pb b/pb
index 6497287..7905b54 100755
--- a/pb
+++ b/pb
@@ -1,14 +1,11 @@
#!/bin/sh
-
# 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"
rss_file="rss.xml"
-
blog_template="template.html"
index_template="index_entry.html"
rolling_template="rolling_entry.html"
@@ -18,34 +15,28 @@ rss_template="rss_entry.html"
init() {
read -p "Initialize blog here? [y/n] " ask
- [ "$ask" != "y" ] && exit 0
-
- mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates"
+ [ "$ask" != "y" ] && echo "Cancelled init" && exit 0
- echo '
{{TITLE}}
' >> "$data_dir/templates/$index_template"
- echo -e '' >> "$data_dir/templates/$rolling_template"
+ mkdir -p "$data_dir/drafts" "$data_dir/published" "$data_dir/html" "$data_dir/templates" "$data_dir/backups"
+ echo '{{TITLE}}
' >> "$data_dir/templates/$index_template"
+ echo -e '\n
{{TITLE}}
\n
{{DATE}}
\n
{{BODY}}
\n
' >> "$data_dir/templates/$rolling_template"
echo -e '- \n{{TITLE}}\n\n<\description>\n<\item>' \
>> "$data_dir/templates/$rss_template"
- echo "Created blog files"
+ echo "Successfully 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)
- 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."
+backup() {
+ backup_name=`mktemp --tmpdir="$data_dir/backups" -d "backup_$(date +'%b-%d')_XXX"`
+ echo "Creating backup, will be placed in $backup_name"
+ cp -r "$data_dir/drafts/" "$backup_name"
+ cp -r "$data_dir/published/" "$backup_name"
}
new() {
[ -z "$1" ] && echo "Please give your blog post a name (you should put it inside quotations)" && exit 1
- sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'| sed -e 's/ /-/g'`
+ sanitized=`echo -n "$1" | sed -e 's/[^A-Za-z0-9 _-]//g'`
+ [ -f "$data_dir/drafts/$sanitized.draft.html" ] && echo "Blog of that name already exists." && exit 1
$EDITOR "$data_dir/drafts/$sanitized.draft.html"
}
@@ -61,7 +52,7 @@ sub() {
}
# $1 is directory
-choose() { # working on abstraction
+choose() {
options=`ls -1 "$1" | sed 's/\.draft\.html$//;s/\.html$//'`
[ -z "$options" ] && echo "No drafts to publish" && exit 0
echo "$options" | nl
@@ -71,14 +62,13 @@ choose() { # working on abstraction
}
publish() {
-
choose "$data_dir/drafts"
to_publish=${chosen%.draft.html}
- cat $blog_template | sub "$to_publish" \
- > "$data_dir/html/$to_publish.html"
+ cat $blog_template | sub "$to_publish" > "$data_dir/html/$to_publish.html"
- temp_index="$(mktemp)" # probably bad idea
+ # make this part less horrendous
+ temp_index="$(mktemp)"
cat "$data_dir/templates/$index_template" | sub "$to_publish" >> $temp_index
temp_rolling="$(mktemp)"
cat "$data_dir/templates/$rolling_template" | sub "$to_publish" >> $temp_rolling
@@ -91,9 +81,7 @@ publish() {
sed -i "//r $temp_rss" "$rss_file"
mv "$data_dir/drafts/$to_publish.draft.html" "$data_dir/published/"
-
echo "Successfully published $to_publish"
-
}
delete() {
@@ -112,17 +100,13 @@ delete() {
# 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; }
-# possibly also check to see if index and rolling have the proper headers
-
-
# check if blog dir exists
-[ ! -d $data_dir ] && init && exit
+[ ! -d $data_dir ] && init && exit 0
case $1 in
n|new) new "$2";;
p|publish) publish;;
d|delete) delete;;
- r|refresh) refresh;;
- h|*) echo "helper";;
+ b|backup) backup;;
+ h|*) echo -e "=-=-=-=-=-=-= Pb =-=-=-=-=-=-=\nAvailable commands:\nn - new blog post\np - publish existing blog post\nd - deletes published post\nb - creates a backup";;
esac
-