X-Git-Url: https://git.danieliu.xyz/?p=pb.git;a=blobdiff_plain;f=pb;h=3bc32e98e517587a0eb7181828a06fce90a4993c;hp=a79e1c7cc3ba1b16ca9695d0192f34a2a7cb448b;hb=45bbbdd54e52f76ac3d9c1a03b807f9337d0a559;hpb=0165e977bd372d0c1e162867961a1102ec6eadce
diff --git a/pb b/pb
index a79e1c7..3bc32e9 100755
--- a/pb
+++ b/pb
@@ -17,13 +17,13 @@ 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" "$data_dir/published" "$data_dir/html" "$data_dir/templates"
- echo '
{{TITLE}}
' >> "$data_dir/templates/$index_template"
- echo -e '' >> "$data_dir/templates/$rolling_template"
+ 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"
@@ -33,24 +33,26 @@ init() {
refresh() {
read -p "Are you sure you want to refresh? [y/n] " ask
- [ "$ask" != "y" ] && exit 0
+ [ "$ask" != "y" ] && echo "Aborting..." && 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."
+ echo "Successfully refreshed."
}
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"
}
sub() {
cat - |\
+ sed "1i " |\
+ sed "\$a " |\
sed "s|{{TITLE}}|$1|g;
s|{{DATE}}|`date +'%a, %b %d %H:%M'`|g;
s|{{URL}}|$website_url/$1|g" |\
@@ -76,12 +78,22 @@ publish() {
cat $blog_template | sub "$to_publish" \
> "$data_dir/html/$to_publish.html"
+ temp_index="$(mktemp)" # probably bad idea
+ 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
+ temp_rss="$(mktemp)"
+ cat "$data_dir/templates/$rss_template" | sub "$to_publish" >> $temp_rss
+
# Add new entry to blog index (do something about indent??)
- sed -i "// a\
- \n`cat "$data_dir/templates/$index_template" | sub "$to_publish"`\n" "$blog_index_file"
+ sed -i "//r $temp_index" "$blog_index_file"
+ sed -i "//r $temp_rolling" "$rolling_file"
+ sed -i "//r $temp_rss" "$rss_file"
mv "$data_dir/drafts/$to_publish.draft.html" "$data_dir/published/"
+ echo "Successfully published $to_publish"
+
}
delete() {
@@ -94,6 +106,7 @@ delete() {
# remove entries from files
echo -e "$blog_index_file\n$rolling_file\n$rss_file" | xargs sed -i "//,// d"
+ echo "Successfully deleted $to_delete"
}
# check to see if all required files are present
@@ -103,10 +116,9 @@ delete() {
# 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;;