runeblog 0.1.98 → 0.2.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/empty_view.tgz +0 -0
- data/lib/BAD.liveblog.rb +724 -0
- data/lib/KEEP.liveblog +646 -0
- data/lib/NEW-liveblog.rb +757 -0
- data/lib/OLD-liveblog.rb +661 -0
- data/lib/default.rb +1 -0
- data/lib/global.rb +5 -0
- data/lib/helpers-blog.rb +41 -6
- data/lib/liveblog.rb +105 -61
- data/lib/logging.rb +58 -0
- data/lib/post.rb +9 -0
- data/lib/publish.rb +7 -0
- data/lib/runeblog.rb +120 -50
- data/lib/runeblog_version.rb +1 -1
- data/lib/view.rb +8 -0
- data/runeblog.gemspec +1 -1
- data/test/.blogs/VERSION +2 -0
- data/test/.blogs/config +3 -0
- data/test/.blogs/drafts/0001-whats-at-stubbs.lt3 +16 -0
- data/test/.blogs/drafts/0002-the-new-amphitheatre-is-overrated.lt3 +16 -0
- data/test/.blogs/drafts/0003-elixir-conf-coming-up.lt3 +17 -0
- data/test/.blogs/drafts/0004-does-indie-still-matter.lt3 +16 -0
- data/test/.blogs/drafts/0005-the-genius-of-scenic.lt3 +16 -0
- data/test/.blogs/drafts/0006-the-future-of-coding.lt3 +16 -0
- data/test/.blogs/drafts/0007-the-graffiti-wall.lt3 +17 -0
- data/test/.blogs/drafts/0008-the-waller-creek-project.lt3 +16 -0
- data/test/.blogs/drafts/0009-life-on-sabine-street.lt3 +16 -0
- data/test/.blogs/drafts/0010-remember-modest-mouse.lt3 +17 -0
- data/test/.blogs/sequence +1 -0
- data/test/.blogs/views/around_austin/last_published +1 -0
- data/test/.blogs/views/around_austin/posts/0001-whats-at-stubbs/0001-whats-at-stubbs.lt3 +16 -0
- data/test/.blogs/views/around_austin/posts/0001-whats-at-stubbs/metadata.txt +6 -0
- data/test/.blogs/views/around_austin/posts/0001-whats-at-stubbs/teaser.txt +1 -0
- data/test/.blogs/views/around_austin/posts/0001-whats-at-stubbs/whats-at-stubbs.html +11 -0
- data/test/.blogs/views/around_austin/posts/0002-the-new-amphitheatre-is-overrated/0002-the-new-amphitheatre-is-overrated.lt3 +16 -0
- data/test/.blogs/views/around_austin/posts/0002-the-new-amphitheatre-is-overrated/metadata.txt +6 -0
- data/test/.blogs/views/around_austin/posts/0002-the-new-amphitheatre-is-overrated/teaser.txt +1 -0
- data/test/.blogs/views/around_austin/posts/0002-the-new-amphitheatre-is-overrated/the-new-amphitheatre-is-overrated.html +11 -0
- data/test/.blogs/views/around_austin/posts/0007-the-graffiti-wall/0007-the-graffiti-wall.lt3 +17 -0
- data/test/.blogs/views/around_austin/posts/0007-the-graffiti-wall/metadata.txt +6 -0
- data/test/.blogs/views/around_austin/posts/0007-the-graffiti-wall/teaser.txt +1 -0
- data/test/.blogs/views/around_austin/posts/0007-the-graffiti-wall/the-graffiti-wall.html +12 -0
- data/test/.blogs/views/around_austin/posts/0008-the-waller-creek-project/0008-the-waller-creek-project.lt3 +16 -0
- data/test/.blogs/views/around_austin/posts/0008-the-waller-creek-project/metadata.txt +6 -0
- data/test/.blogs/views/around_austin/posts/0008-the-waller-creek-project/teaser.txt +1 -0
- data/test/.blogs/views/around_austin/posts/0008-the-waller-creek-project/the-waller-creek-project.html +11 -0
- data/test/.blogs/views/around_austin/posts/0009-life-on-sabine-street/0009-life-on-sabine-street.lt3 +16 -0
- data/test/.blogs/views/around_austin/posts/0009-life-on-sabine-street/life-on-sabine-street.html +11 -0
- data/test/.blogs/views/around_austin/posts/0009-life-on-sabine-street/metadata.txt +6 -0
- data/test/.blogs/views/around_austin/posts/0009-life-on-sabine-street/teaser.txt +1 -0
- data/test/.blogs/views/around_austin/publish +5 -0
- data/test/.blogs/views/around_austin/remote/etc/blog.css +34 -0
- data/test/.blogs/views/around_austin/remote/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/around_austin/remote/etc/externals.lt3 +19 -0
- data/test/.blogs/views/around_austin/remote/etc/favicon.ico +0 -0
- data/test/.blogs/views/around_austin/remote/etc/misc.js +6 -0
- data/test/.blogs/views/around_austin/remote/life-on-sabine-street.html +10 -0
- data/test/.blogs/views/around_austin/remote/permalink/life-on-sabine-street.html +10 -0
- data/test/.blogs/views/around_austin/remote/permalink/the-graffiti-wall.html +10 -0
- data/test/.blogs/views/around_austin/remote/permalink/the-new-amphitheatre-is-overrated.html +50 -0
- data/test/.blogs/views/around_austin/remote/permalink/the-waller-creek-project.html +50 -0
- data/test/.blogs/views/around_austin/remote/permalink/whats-at-stubbs.html +50 -0
- data/test/.blogs/views/around_austin/remote/recent.html +104 -0
- data/test/.blogs/views/around_austin/remote/the-graffiti-wall.html +10 -0
- data/test/.blogs/views/around_austin/remote/the-new-amphitheatre-is-overrated.html +50 -0
- data/test/.blogs/views/around_austin/remote/the-waller-creek-project.html +50 -0
- data/test/.blogs/views/around_austin/remote/whats-at-stubbs.html +50 -0
- data/test/.blogs/views/around_austin/remote/widgets/README +4 -0
- data/test/.blogs/views/around_austin/remote/widgets/ad/ad.lt3 +12 -0
- data/{themes/standard/sidebar → test/.blogs/views/around_austin/remote/widgets/calendar}/calendar.lt3 +0 -0
- data/{themes/standard/sidebar/news.lt3 → test/.blogs/views/around_austin/remote/widgets/news/list.data} +2 -5
- data/test/.blogs/views/around_austin/remote/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/README +2 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/list.data +4 -0
- data/test/.blogs/views/around_austin/remote/widgets/pages/main.html +9 -0
- data/{themes/standard → test/.blogs/views/around_austin/remote}/widgets/pages/main.lt3 +2 -2
- data/{themes/standard/sidebar → test/.blogs/views/around_austin/remote/widgets/tag-cloud}/tag-cloud.lt3 +2 -0
- data/test/.blogs/views/around_austin/staging/0001-whats-at-stubbs.lt3 +16 -0
- data/test/.blogs/views/around_austin/staging/0002-the-new-amphitheatre-is-overrated.lt3 +16 -0
- data/test/.blogs/views/around_austin/staging/0007-the-graffiti-wall.lt3 +17 -0
- data/test/.blogs/views/around_austin/staging/0008-the-waller-creek-project.lt3 +16 -0
- data/test/.blogs/views/around_austin/staging/0009-life-on-sabine-street.lt3 +16 -0
- data/test/.blogs/views/around_austin/staging/README +59 -0
- data/test/.blogs/views/around_austin/staging/blog/generate.lt3 +17 -0
- data/test/.blogs/views/around_austin/staging/blog/head.lt3 +9 -0
- data/test/.blogs/views/around_austin/staging/blog/index.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/around_austin/staging/etc/blog.css +34 -0
- data/test/.blogs/views/around_austin/staging/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/around_austin/staging/etc/externals.lt3 +19 -0
- data/test/.blogs/views/around_austin/staging/etc/favicon.ico +0 -0
- data/test/.blogs/views/around_austin/staging/etc/misc.js +6 -0
- data/test/.blogs/views/around_austin/staging/global.lt3 +22 -0
- data/test/.blogs/views/around_austin/staging/life-on-sabine-street.html +10 -0
- data/test/.blogs/views/around_austin/staging/navbar/about.html +6 -0
- data/test/.blogs/views/around_austin/staging/navbar/contact.html +6 -0
- data/test/.blogs/views/around_austin/staging/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/post/generate.lt3 +26 -0
- data/test/.blogs/views/around_austin/staging/post/head.lt3 +4 -0
- data/test/.blogs/views/around_austin/staging/post/index.html +16 -0
- data/test/.blogs/views/around_austin/staging/post/index.lt3 +16 -0
- data/test/.blogs/views/around_austin/staging/post/permalink.lt3 +26 -0
- data/test/.blogs/views/around_austin/staging/recent.html +104 -0
- data/test/.blogs/views/around_austin/staging/sidebar/README +3 -0
- data/test/.blogs/views/around_austin/staging/the-graffiti-wall.html +10 -0
- data/test/.blogs/views/around_austin/staging/the-new-amphitheatre-is-overrated.html +50 -0
- data/test/.blogs/views/around_austin/staging/the-waller-creek-project.html +50 -0
- data/test/.blogs/views/around_austin/staging/vars.lt3 +2 -0
- data/test/.blogs/views/around_austin/staging/whats-at-stubbs.html +50 -0
- data/test/.blogs/views/around_austin/staging/widgets/README +4 -0
- data/test/.blogs/views/around_austin/staging/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/around_austin/staging/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/widgets/news/list.data +4 -0
- data/test/.blogs/views/around_austin/staging/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/README +2 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/list.data +4 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/main.html +9 -0
- data/test/.blogs/views/around_austin/staging/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/around_austin/staging/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/around_austin/themes/standard/README +59 -0
- data/test/.blogs/views/around_austin/themes/standard/blog/generate.lt3 +17 -0
- data/test/.blogs/views/around_austin/themes/standard/blog/head.lt3 +9 -0
- data/test/.blogs/views/around_austin/themes/standard/blog/index.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/around_austin/themes/standard/etc/blog.css +34 -0
- data/test/.blogs/views/around_austin/themes/standard/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/around_austin/themes/standard/etc/externals.lt3 +19 -0
- data/test/.blogs/views/around_austin/themes/standard/etc/favicon.ico +0 -0
- data/test/.blogs/views/around_austin/themes/standard/etc/misc.js +6 -0
- data/test/.blogs/views/around_austin/themes/standard/global.lt3 +22 -0
- data/test/.blogs/views/around_austin/themes/standard/navbar/about.html +6 -0
- data/test/.blogs/views/around_austin/themes/standard/navbar/contact.html +6 -0
- data/test/.blogs/views/around_austin/themes/standard/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/post/generate.lt3 +26 -0
- data/test/.blogs/views/around_austin/themes/standard/post/head.lt3 +4 -0
- data/test/.blogs/views/around_austin/themes/standard/post/index.lt3 +16 -0
- data/test/.blogs/views/around_austin/themes/standard/post/permalink.lt3 +26 -0
- data/test/.blogs/views/around_austin/themes/standard/sidebar/README +3 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/README +4 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/news/list.data +4 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/README +2 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/list.data +4 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/main.html +9 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/around_austin/themes/standard/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/computing/last_published +1 -0
- data/test/.blogs/views/computing/posts/0003-elixir-conf-coming-up/0003-elixir-conf-coming-up.lt3 +17 -0
- data/test/.blogs/views/computing/posts/0003-elixir-conf-coming-up/elixir-conf-coming-up.html +12 -0
- data/test/.blogs/views/computing/posts/0003-elixir-conf-coming-up/metadata.txt +6 -0
- data/test/.blogs/views/computing/posts/0003-elixir-conf-coming-up/teaser.txt +1 -0
- data/test/.blogs/views/computing/posts/0005-the-genius-of-scenic/0005-the-genius-of-scenic.lt3 +16 -0
- data/test/.blogs/views/computing/posts/0005-the-genius-of-scenic/metadata.txt +6 -0
- data/test/.blogs/views/computing/posts/0005-the-genius-of-scenic/teaser.txt +1 -0
- data/test/.blogs/views/computing/posts/0005-the-genius-of-scenic/the-genius-of-scenic.html +11 -0
- data/test/.blogs/views/computing/posts/0006-the-future-of-coding/0006-the-future-of-coding.lt3 +16 -0
- data/test/.blogs/views/computing/posts/0006-the-future-of-coding/metadata.txt +6 -0
- data/test/.blogs/views/computing/posts/0006-the-future-of-coding/teaser.txt +1 -0
- data/test/.blogs/views/computing/posts/0006-the-future-of-coding/the-future-of-coding.html +11 -0
- data/test/.blogs/views/computing/publish +5 -0
- data/test/.blogs/views/computing/remote/elixir-conf-coming-up.html +51 -0
- data/test/.blogs/views/computing/remote/etc/blog.css +34 -0
- data/test/.blogs/views/computing/remote/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/computing/remote/etc/externals.lt3 +19 -0
- data/test/.blogs/views/computing/remote/etc/favicon.ico +0 -0
- data/test/.blogs/views/computing/remote/etc/misc.js +6 -0
- data/test/.blogs/views/computing/remote/permalink/elixir-conf-coming-up.html +51 -0
- data/test/.blogs/views/computing/remote/permalink/the-future-of-coding.html +50 -0
- data/test/.blogs/views/computing/remote/permalink/the-genius-of-scenic.html +50 -0
- data/test/.blogs/views/computing/remote/recent.html +64 -0
- data/test/.blogs/views/computing/remote/the-future-of-coding.html +50 -0
- data/test/.blogs/views/computing/remote/the-genius-of-scenic.html +50 -0
- data/test/.blogs/views/computing/remote/widgets/README +4 -0
- data/test/.blogs/views/computing/remote/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/computing/remote/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/computing/remote/widgets/news/list.data +4 -0
- data/test/.blogs/views/computing/remote/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/computing/remote/widgets/pages/README +2 -0
- data/test/.blogs/views/computing/remote/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/computing/remote/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/computing/remote/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/computing/remote/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/computing/remote/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/computing/remote/widgets/pages/list.data +4 -0
- data/test/.blogs/views/computing/remote/widgets/pages/main.html +9 -0
- data/test/.blogs/views/computing/remote/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/computing/remote/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/computing/staging/0003-elixir-conf-coming-up.lt3 +17 -0
- data/test/.blogs/views/computing/staging/0005-the-genius-of-scenic.lt3 +16 -0
- data/test/.blogs/views/computing/staging/0006-the-future-of-coding.lt3 +16 -0
- data/test/.blogs/views/computing/staging/README +59 -0
- data/test/.blogs/views/computing/staging/blog/generate.lt3 +17 -0
- data/test/.blogs/views/computing/staging/blog/head.lt3 +9 -0
- data/test/.blogs/views/computing/staging/blog/index.lt3 +6 -0
- data/test/.blogs/views/computing/staging/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/computing/staging/elixir-conf-coming-up.html +51 -0
- data/test/.blogs/views/computing/staging/etc/blog.css +34 -0
- data/test/.blogs/views/computing/staging/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/computing/staging/etc/externals.lt3 +19 -0
- data/test/.blogs/views/computing/staging/etc/favicon.ico +0 -0
- data/test/.blogs/views/computing/staging/etc/misc.js +6 -0
- data/test/.blogs/views/computing/staging/global.lt3 +22 -0
- data/test/.blogs/views/computing/staging/navbar/about.html +6 -0
- data/test/.blogs/views/computing/staging/navbar/contact.html +6 -0
- data/test/.blogs/views/computing/staging/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/computing/staging/post/generate.lt3 +26 -0
- data/test/.blogs/views/computing/staging/post/head.lt3 +4 -0
- data/test/.blogs/views/computing/staging/post/index.html +16 -0
- data/test/.blogs/views/computing/staging/post/index.lt3 +16 -0
- data/test/.blogs/views/computing/staging/post/permalink.lt3 +26 -0
- data/test/.blogs/views/computing/staging/recent.html +64 -0
- data/test/.blogs/views/computing/staging/sidebar/README +3 -0
- data/test/.blogs/views/computing/staging/the-future-of-coding.html +50 -0
- data/test/.blogs/views/computing/staging/the-genius-of-scenic.html +50 -0
- data/test/.blogs/views/computing/staging/vars.lt3 +2 -0
- data/test/.blogs/views/computing/staging/widgets/README +4 -0
- data/test/.blogs/views/computing/staging/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/computing/staging/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/computing/staging/widgets/news/list.data +4 -0
- data/test/.blogs/views/computing/staging/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/computing/staging/widgets/pages/README +2 -0
- data/test/.blogs/views/computing/staging/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/computing/staging/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/computing/staging/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/computing/staging/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/computing/staging/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/computing/staging/widgets/pages/list.data +4 -0
- data/test/.blogs/views/computing/staging/widgets/pages/main.html +9 -0
- data/test/.blogs/views/computing/staging/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/computing/staging/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/computing/themes/standard/README +59 -0
- data/test/.blogs/views/computing/themes/standard/blog/generate.lt3 +17 -0
- data/test/.blogs/views/computing/themes/standard/blog/head.lt3 +9 -0
- data/test/.blogs/views/computing/themes/standard/blog/index.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/computing/themes/standard/etc/blog.css +34 -0
- data/test/.blogs/views/computing/themes/standard/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/computing/themes/standard/etc/externals.lt3 +19 -0
- data/test/.blogs/views/computing/themes/standard/etc/favicon.ico +0 -0
- data/test/.blogs/views/computing/themes/standard/etc/misc.js +6 -0
- data/test/.blogs/views/computing/themes/standard/global.lt3 +22 -0
- data/test/.blogs/views/computing/themes/standard/navbar/about.html +6 -0
- data/test/.blogs/views/computing/themes/standard/navbar/contact.html +6 -0
- data/test/.blogs/views/computing/themes/standard/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/post/generate.lt3 +26 -0
- data/test/.blogs/views/computing/themes/standard/post/head.lt3 +4 -0
- data/test/.blogs/views/computing/themes/standard/post/index.lt3 +16 -0
- data/test/.blogs/views/computing/themes/standard/post/permalink.lt3 +26 -0
- data/test/.blogs/views/computing/themes/standard/sidebar/README +3 -0
- data/test/.blogs/views/computing/themes/standard/widgets/README +4 -0
- data/test/.blogs/views/computing/themes/standard/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/computing/themes/standard/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/widgets/news/list.data +4 -0
- data/test/.blogs/views/computing/themes/standard/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/README +2 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/list.data +4 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/main.html +9 -0
- data/test/.blogs/views/computing/themes/standard/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/computing/themes/standard/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/music/last_published +1 -0
- data/test/.blogs/views/music/posts/0004-does-indie-still-matter/0004-does-indie-still-matter.lt3 +16 -0
- data/test/.blogs/views/music/posts/0004-does-indie-still-matter/does-indie-still-matter.html +11 -0
- data/test/.blogs/views/music/posts/0004-does-indie-still-matter/metadata.txt +6 -0
- data/test/.blogs/views/music/posts/0004-does-indie-still-matter/teaser.txt +1 -0
- data/test/.blogs/views/music/posts/0010-remember-modest-mouse/0010-remember-modest-mouse.lt3 +17 -0
- data/test/.blogs/views/music/posts/0010-remember-modest-mouse/metadata.txt +6 -0
- data/test/.blogs/views/music/posts/0010-remember-modest-mouse/remember-modest-mouse.html +12 -0
- data/test/.blogs/views/music/posts/0010-remember-modest-mouse/teaser.txt +1 -0
- data/test/.blogs/views/music/publish +5 -0
- data/test/.blogs/views/music/remote/does-indie-still-matter.html +50 -0
- data/test/.blogs/views/music/remote/etc/blog.css +34 -0
- data/test/.blogs/views/music/remote/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/music/remote/etc/externals.lt3 +19 -0
- data/test/.blogs/views/music/remote/etc/favicon.ico +0 -0
- data/test/.blogs/views/music/remote/etc/misc.js +6 -0
- data/test/.blogs/views/music/remote/permalink/does-indie-still-matter.html +50 -0
- data/test/.blogs/views/music/remote/permalink/remember-modest-mouse.html +51 -0
- data/test/.blogs/views/music/remote/recent.html +44 -0
- data/test/.blogs/views/music/remote/remember-modest-mouse.html +51 -0
- data/test/.blogs/views/music/remote/widgets/README +4 -0
- data/test/.blogs/views/music/remote/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/music/remote/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/music/remote/widgets/news/list.data +4 -0
- data/test/.blogs/views/music/remote/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/music/remote/widgets/pages/README +2 -0
- data/test/.blogs/views/music/remote/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/music/remote/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/music/remote/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/music/remote/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/music/remote/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/music/remote/widgets/pages/list.data +4 -0
- data/test/.blogs/views/music/remote/widgets/pages/main.html +9 -0
- data/test/.blogs/views/music/remote/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/music/remote/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/music/staging/0004-does-indie-still-matter.lt3 +16 -0
- data/test/.blogs/views/music/staging/0010-remember-modest-mouse.lt3 +17 -0
- data/test/.blogs/views/music/staging/README +59 -0
- data/test/.blogs/views/music/staging/blog/generate.lt3 +17 -0
- data/test/.blogs/views/music/staging/blog/head.lt3 +9 -0
- data/test/.blogs/views/music/staging/blog/index.lt3 +6 -0
- data/test/.blogs/views/music/staging/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/music/staging/does-indie-still-matter.html +50 -0
- data/test/.blogs/views/music/staging/etc/blog.css +34 -0
- data/test/.blogs/views/music/staging/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/music/staging/etc/externals.lt3 +19 -0
- data/test/.blogs/views/music/staging/etc/favicon.ico +0 -0
- data/test/.blogs/views/music/staging/etc/misc.js +6 -0
- data/test/.blogs/views/music/staging/global.lt3 +22 -0
- data/test/.blogs/views/music/staging/navbar/about.html +6 -0
- data/test/.blogs/views/music/staging/navbar/contact.html +6 -0
- data/test/.blogs/views/music/staging/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/music/staging/post/generate.lt3 +26 -0
- data/test/.blogs/views/music/staging/post/head.lt3 +4 -0
- data/test/.blogs/views/music/staging/post/index.html +17 -0
- data/test/.blogs/views/music/staging/post/index.lt3 +16 -0
- data/test/.blogs/views/music/staging/post/permalink.lt3 +26 -0
- data/test/.blogs/views/music/staging/recent.html +44 -0
- data/test/.blogs/views/music/staging/remember-modest-mouse.html +51 -0
- data/test/.blogs/views/music/staging/sidebar/README +3 -0
- data/test/.blogs/views/music/staging/vars.lt3 +2 -0
- data/test/.blogs/views/music/staging/widgets/README +4 -0
- data/test/.blogs/views/music/staging/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/music/staging/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/music/staging/widgets/news/list.data +4 -0
- data/test/.blogs/views/music/staging/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/music/staging/widgets/pages/README +2 -0
- data/test/.blogs/views/music/staging/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/music/staging/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/music/staging/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/music/staging/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/music/staging/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/music/staging/widgets/pages/list.data +4 -0
- data/test/.blogs/views/music/staging/widgets/pages/main.html +9 -0
- data/test/.blogs/views/music/staging/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/music/staging/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/music/themes/standard/README +59 -0
- data/test/.blogs/views/music/themes/standard/blog/generate.lt3 +17 -0
- data/test/.blogs/views/music/themes/standard/blog/head.lt3 +9 -0
- data/test/.blogs/views/music/themes/standard/blog/index.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/music/themes/standard/etc/blog.css +34 -0
- data/test/.blogs/views/music/themes/standard/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/music/themes/standard/etc/externals.lt3 +19 -0
- data/test/.blogs/views/music/themes/standard/etc/favicon.ico +0 -0
- data/test/.blogs/views/music/themes/standard/etc/misc.js +6 -0
- data/test/.blogs/views/music/themes/standard/global.lt3 +22 -0
- data/test/.blogs/views/music/themes/standard/navbar/about.html +6 -0
- data/test/.blogs/views/music/themes/standard/navbar/contact.html +6 -0
- data/test/.blogs/views/music/themes/standard/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/post/generate.lt3 +26 -0
- data/test/.blogs/views/music/themes/standard/post/head.lt3 +4 -0
- data/test/.blogs/views/music/themes/standard/post/index.lt3 +16 -0
- data/test/.blogs/views/music/themes/standard/post/permalink.lt3 +26 -0
- data/test/.blogs/views/music/themes/standard/sidebar/README +3 -0
- data/test/.blogs/views/music/themes/standard/widgets/README +4 -0
- data/test/.blogs/views/music/themes/standard/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/music/themes/standard/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/widgets/news/list.data +4 -0
- data/test/.blogs/views/music/themes/standard/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/README +2 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/list.data +4 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/main.html +9 -0
- data/test/.blogs/views/music/themes/standard/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/music/themes/standard/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/test_view/last_published +1 -0
- data/test/.blogs/views/test_view/publish +5 -0
- data/test/.blogs/views/test_view/remote/etc/blog.css +34 -0
- data/test/.blogs/views/test_view/remote/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/test_view/remote/etc/externals.lt3 +19 -0
- data/test/.blogs/views/test_view/remote/etc/favicon.ico +0 -0
- data/test/.blogs/views/test_view/remote/etc/misc.js +6 -0
- data/test/.blogs/views/test_view/remote/widgets/README +4 -0
- data/test/.blogs/views/test_view/remote/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/test_view/remote/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/test_view/remote/widgets/news/list.data +4 -0
- data/test/.blogs/views/test_view/remote/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/README +2 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/list.data +4 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/main.html +9 -0
- data/test/.blogs/views/test_view/remote/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/test_view/remote/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/test_view/staging/README +59 -0
- data/test/.blogs/views/test_view/staging/blog/generate.lt3 +17 -0
- data/test/.blogs/views/test_view/staging/blog/head.lt3 +9 -0
- data/test/.blogs/views/test_view/staging/blog/index.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/test_view/staging/etc/blog.css +34 -0
- data/test/.blogs/views/test_view/staging/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/test_view/staging/etc/externals.lt3 +19 -0
- data/test/.blogs/views/test_view/staging/etc/favicon.ico +0 -0
- data/test/.blogs/views/test_view/staging/etc/misc.js +6 -0
- data/test/.blogs/views/test_view/staging/global.lt3 +22 -0
- data/test/.blogs/views/test_view/staging/navbar/about.html +6 -0
- data/test/.blogs/views/test_view/staging/navbar/contact.html +6 -0
- data/test/.blogs/views/test_view/staging/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/post/generate.lt3 +26 -0
- data/test/.blogs/views/test_view/staging/post/head.lt3 +4 -0
- data/test/.blogs/views/test_view/staging/post/index.lt3 +16 -0
- data/test/.blogs/views/test_view/staging/post/permalink.lt3 +26 -0
- data/test/.blogs/views/test_view/staging/sidebar/README +3 -0
- data/test/.blogs/views/test_view/staging/widgets/README +4 -0
- data/test/.blogs/views/test_view/staging/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/test_view/staging/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/widgets/news/list.data +4 -0
- data/test/.blogs/views/test_view/staging/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/README +2 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/list.data +4 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/main.html +9 -0
- data/test/.blogs/views/test_view/staging/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/test_view/staging/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/.blogs/views/test_view/themes/standard/README +59 -0
- data/test/.blogs/views/test_view/themes/standard/blog/generate.lt3 +17 -0
- data/test/.blogs/views/test_view/themes/standard/blog/head.lt3 +9 -0
- data/test/.blogs/views/test_view/themes/standard/blog/index.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/blog/post_entry.lt3 +19 -0
- data/test/.blogs/views/test_view/themes/standard/etc/blog.css +34 -0
- data/test/.blogs/views/test_view/themes/standard/etc/blog.css.lt3 +36 -0
- data/test/.blogs/views/test_view/themes/standard/etc/externals.lt3 +19 -0
- data/test/.blogs/views/test_view/themes/standard/etc/favicon.ico +0 -0
- data/test/.blogs/views/test_view/themes/standard/etc/misc.js +6 -0
- data/test/.blogs/views/test_view/themes/standard/global.lt3 +22 -0
- data/test/.blogs/views/test_view/themes/standard/navbar/about.html +6 -0
- data/test/.blogs/views/test_view/themes/standard/navbar/contact.html +6 -0
- data/test/.blogs/views/test_view/themes/standard/navbar/navbar.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/post/generate.lt3 +26 -0
- data/test/.blogs/views/test_view/themes/standard/post/head.lt3 +4 -0
- data/test/.blogs/views/test_view/themes/standard/post/index.lt3 +16 -0
- data/test/.blogs/views/test_view/themes/standard/post/permalink.lt3 +26 -0
- data/test/.blogs/views/test_view/themes/standard/sidebar/README +3 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/README +4 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/ad/ad.lt3 +12 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/calendar/calendar.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/news/list.data +4 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/news/news.lt3 +3 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/README +2 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/disclaim.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/faq.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/generated.lt3 +4 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/lifestory.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/like-dislike.lt3 +6 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/list.data +4 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/main.html +9 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/pages/main.lt3 +18 -0
- data/test/.blogs/views/test_view/themes/standard/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- data/test/config +3 -0
- data/test/make_blog.rb +9 -5
- data/themes/standard/blog/index.lt3 +3 -2
- data/themes/standard/blog/recent.lt3 +2 -0
- data/themes/standard/post/generate.lt3 +0 -2
- data/themes/standard/sidebar/README +3 -0
- data/themes/standard/widgets/ad/ad.lt3 +15 -0
- data/themes/standard/widgets/calendar/calendar.lt3 +6 -0
- data/themes/standard/widgets/news/list.data +4 -0
- data/themes/standard/widgets/news/news.lt3 +2 -0
- data/themes/standard/widgets/pages/disclaim.html +6 -0
- data/themes/standard/widgets/pages/disclaim.lt3 +2 -3
- data/themes/standard/widgets/pages/faq.html +7 -0
- data/themes/standard/widgets/pages/faq.lt3 +1 -1
- data/themes/standard/widgets/pages/lifestory.html +7 -0
- data/themes/standard/widgets/pages/lifestory.lt3 +1 -1
- data/themes/standard/widgets/pages/like-dislike.html +7 -0
- data/themes/standard/widgets/pages/like-dislike.lt3 +1 -1
- data/themes/standard/widgets/pages/list.data +4 -4
- data/themes/standard/widgets/pages/pages.lt3 +2 -0
- data/themes/standard/widgets/tag-cloud/tag-cloud.lt3 +12 -0
- metadata +486 -7
- data/themes/standard/sidebar/ad.lt3 +0 -5
data/lib/logging.rb
ADDED
@@ -0,0 +1,58 @@
|
|
1
|
+
unless self.respond_to?("log!")
|
2
|
+
$logging = true
|
3
|
+
$log = File.new("/tmp/runeblog}.log","w")
|
4
|
+
|
5
|
+
def log!(str: "", enter: nil, args: [], pwd: false, dir: false)
|
6
|
+
return unless $logging
|
7
|
+
time = Time.now.strftime("%H:%M:%S")
|
8
|
+
|
9
|
+
meth = ""
|
10
|
+
meth = "#{enter}" if enter
|
11
|
+
|
12
|
+
para = "(#{args.inspect[1..-2]})"
|
13
|
+
|
14
|
+
source = caller[0].sub(/.*\//, " in ").sub(/:/, " line ").sub(/:.*/, "")
|
15
|
+
source = "in #{source} (probably liveblog.rb)" if source.include? "(eval)"
|
16
|
+
|
17
|
+
str = " ... #{str}" unless str.empty?
|
18
|
+
indent = " "*12
|
19
|
+
|
20
|
+
$log.puts "#{time} #{meth}#{para}"
|
21
|
+
$log.puts "#{indent} #{str} " unless str.empty?
|
22
|
+
$log.puts "#{indent} #{source}"
|
23
|
+
$log.puts "#{indent} pwd = #{Dir.pwd} " if pwd
|
24
|
+
if dir
|
25
|
+
files = (Dir.entries('.') - %w[. ..]).join(" ")
|
26
|
+
$log.puts "#{indent} dir/* = #{files}"
|
27
|
+
end
|
28
|
+
# $log.puts "#{indent} livetext params = #{livedata.inpect} " unless livedata.nil?
|
29
|
+
$log.puts
|
30
|
+
$log.close
|
31
|
+
$log = File.new("/tmp/runeblog.log","a")
|
32
|
+
end
|
33
|
+
|
34
|
+
def log(str: "", enter: nil, args: [], pwd: false, dir: false)
|
35
|
+
return unless $logging
|
36
|
+
time = Time.now.strftime("%H:%M:%S")
|
37
|
+
meth = ""
|
38
|
+
meth = "#{enter}" if enter
|
39
|
+
para = " args: #{args.inspect[1..-2]}"
|
40
|
+
source = caller[0].sub(/.*\//, " in ").sub(/:/, " line ").sub(/:.*/, "")
|
41
|
+
source = " in #{source} (probably liveblog.rb)" if source.include? "(eval)"
|
42
|
+
str = " ... #{str}" unless str.empty?
|
43
|
+
indent = " "*12
|
44
|
+
STDERR.puts "#{time} #{str} #{meth}"
|
45
|
+
STDERR.puts "#{indent} #{source}"
|
46
|
+
STDERR.puts "#{indent} pwd = #{Dir.pwd} " if pwd
|
47
|
+
if dir
|
48
|
+
files = (Dir.entries('.') - %w[. ..]).join(" ")
|
49
|
+
STDERR.puts "#{indent} dir/* = #{files}"
|
50
|
+
end
|
51
|
+
STDERR.puts "#{indent} #{para} " unless args.empty?
|
52
|
+
# STDERR.puts "#{indent} livetext params = #{livedata.inpect} " unless livedata.nil?
|
53
|
+
STDERR.puts
|
54
|
+
# $log.close
|
55
|
+
# $log = File.new("/tmp/runeblog.log","a")
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
data/lib/post.rb
CHANGED
@@ -11,12 +11,14 @@ class RuneBlog::Post
|
|
11
11
|
include RuneBlog::Helpers
|
12
12
|
|
13
13
|
def self.files(num, root)
|
14
|
+
log!(enter: __method__, args: [num, root])
|
14
15
|
files = Find.find(root).to_a
|
15
16
|
result = files.grep(/#{prefix(num)}-/)
|
16
17
|
result
|
17
18
|
end
|
18
19
|
|
19
20
|
def self.load(post)
|
21
|
+
log!(enter: __method__, args: [post])
|
20
22
|
raise "Doesn't work right now"
|
21
23
|
raise NoBlogAccessor if RuneBlog.blog.nil?
|
22
24
|
# "post" is a slug
|
@@ -41,6 +43,7 @@ class RuneBlog::Post
|
|
41
43
|
end
|
42
44
|
|
43
45
|
def write_metadata(meta) # FIXME ???
|
46
|
+
log!(enter: __method__, args: [meta])
|
44
47
|
debug "=== write_metadata:"
|
45
48
|
debug "-----\n#{meta.inspect}\n-----"
|
46
49
|
fname2 = "metadata.txt"
|
@@ -63,12 +66,14 @@ class RuneBlog::Post
|
|
63
66
|
end
|
64
67
|
|
65
68
|
def initialize
|
69
|
+
log!(enter: __method__)
|
66
70
|
@blog = RuneBlog.blog || raise(NoBlogAccessor)
|
67
71
|
@meta = OpenStruct.new
|
68
72
|
end
|
69
73
|
|
70
74
|
def self.create(title:, teaser:, body:, pubdate: Time.now.strftime("%Y-%m-%d"),
|
71
75
|
other_views:[])
|
76
|
+
log!(enter: __method__, args: [title, teaser, body, pubdate, other_views])
|
72
77
|
post = self.new
|
73
78
|
# ONLY place next_sequence is called!
|
74
79
|
num = post.meta.num = post.blog.next_sequence
|
@@ -97,6 +102,7 @@ class RuneBlog::Post
|
|
97
102
|
end
|
98
103
|
|
99
104
|
def edit
|
105
|
+
log!(enter: __method__)
|
100
106
|
verify(File.exist?(@draft) => "File #{@draft} not found")
|
101
107
|
result = system("vi #@draft +8") # TODO improve this
|
102
108
|
raise EditorProblem(draft) unless result
|
@@ -106,6 +112,7 @@ class RuneBlog::Post
|
|
106
112
|
end
|
107
113
|
|
108
114
|
def build
|
115
|
+
log!(enter: __method__)
|
109
116
|
post = self
|
110
117
|
views = post.meta.views
|
111
118
|
text = File.read(@draft)
|
@@ -118,6 +125,7 @@ class RuneBlog::ViewPost
|
|
118
125
|
:teaser_text
|
119
126
|
|
120
127
|
def initialize(view, postdir)
|
128
|
+
log!(enter: __method__, args: [view, postdir])
|
121
129
|
# Assumes already parsed/processed
|
122
130
|
@blog = RuneBlog.blog || raise(NoBlogAccessor)
|
123
131
|
@path = postdir.dup
|
@@ -133,6 +141,7 @@ class RuneBlog::ViewPost
|
|
133
141
|
end
|
134
142
|
|
135
143
|
def get_dirs
|
144
|
+
log!(enter: __method__, args: [view, postdir])
|
136
145
|
fname = File.basename(draft)
|
137
146
|
noext = fname.sub(/.lt3$/, "")
|
138
147
|
vdir = "#@root/views/#{view}"
|
data/lib/publish.rb
CHANGED
@@ -9,6 +9,7 @@ class RuneBlog::Publishing
|
|
9
9
|
BadRemotePerms = Exception.new("Bad remote permissions")
|
10
10
|
|
11
11
|
def initialize(*params)
|
12
|
+
log!(enter: __method__, args: [*params])
|
12
13
|
@blog = RuneBlog.blog
|
13
14
|
# Clunky...
|
14
15
|
if params.size == 1 && params[0].is_a?(OpenStruct)
|
@@ -22,21 +23,25 @@ class RuneBlog::Publishing
|
|
22
23
|
end
|
23
24
|
|
24
25
|
def to_h
|
26
|
+
log!(enter: __method__)
|
25
27
|
{user: @user, server: @server, docroot: @docroot,
|
26
28
|
path: @path, proto: @proto}
|
27
29
|
end
|
28
30
|
|
29
31
|
def url
|
32
|
+
log!(enter: __method__)
|
30
33
|
vname = @blog.view.name # .gsub(/_/, "\\_")
|
31
34
|
url = "#@proto://#@server/#@path/#{vname}"
|
32
35
|
end
|
33
36
|
|
34
37
|
def system!(str)
|
38
|
+
log!(enter: __method__, args: [str])
|
35
39
|
rc = system(str)
|
36
40
|
rc
|
37
41
|
end
|
38
42
|
|
39
43
|
def publish(files, assets=[])
|
44
|
+
log!(enter: __method__, args: [files, assets])
|
40
45
|
dir = "#@docroot/#@path"
|
41
46
|
view_name = @blog.view.name
|
42
47
|
viewpath = "#{dir}/#{view_name}"
|
@@ -60,6 +65,7 @@ class RuneBlog::Publishing
|
|
60
65
|
end
|
61
66
|
|
62
67
|
def remote_login?
|
68
|
+
log!(enter: __method__)
|
63
69
|
cmd = "ssh -o BatchMode=yes #@user@#@server -x date >/dev/null 2>&1"
|
64
70
|
result = system(cmd)
|
65
71
|
return nil unless result
|
@@ -67,6 +73,7 @@ class RuneBlog::Publishing
|
|
67
73
|
end
|
68
74
|
|
69
75
|
def remote_permissions?
|
76
|
+
log!(enter: __method__)
|
70
77
|
dir = "#@docroot/#@path"
|
71
78
|
temp = "#@path/__only_testing"
|
72
79
|
try1 = system("ssh -o BatchMode=yes -o ConnectTimeout=1 #@user@#@server -x mkdir -p #{temp} >/dev/null 2>&1")
|
data/lib/runeblog.rb
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
require 'date'
|
2
2
|
|
3
|
+
require 'logging'
|
4
|
+
|
3
5
|
require 'runeblog_version'
|
4
6
|
require 'global'
|
5
7
|
require 'helpers-blog'
|
@@ -26,7 +28,6 @@ class RuneBlog
|
|
26
28
|
make_exception(:NoSuchView, "No such view: $1")
|
27
29
|
make_exception(:NoBlogAccessor, "Runeblog.blog is not set")
|
28
30
|
|
29
|
-
|
30
31
|
class << self
|
31
32
|
attr_accessor :blog
|
32
33
|
include Helpers
|
@@ -40,6 +41,7 @@ class RuneBlog
|
|
40
41
|
include Helpers
|
41
42
|
|
42
43
|
def self.create_new_blog_repo(dir = ".blogs")
|
44
|
+
log!(enter: __method__, args: [dir])
|
43
45
|
raise ArgumentError unless dir.is_a?(String) && ! dir.empty?
|
44
46
|
root_dir = Dir.pwd + "/" + dir
|
45
47
|
self.create(dir)
|
@@ -49,6 +51,7 @@ class RuneBlog
|
|
49
51
|
end
|
50
52
|
|
51
53
|
def self.create(root = ".blogs")
|
54
|
+
log!(enter: __method__, args: [root])
|
52
55
|
# Crude - FIXME later - # What views are there? Publishing, etc.
|
53
56
|
self.blog = self # Weird. Like a singleton - dumbass circular dependency?
|
54
57
|
$_blog = self # Dumber still?
|
@@ -56,6 +59,8 @@ class RuneBlog
|
|
56
59
|
raise BlogRepoAlreadyExists if Dir.exist?(root)
|
57
60
|
create_dirs(root)
|
58
61
|
Dir.chdir(root) do
|
62
|
+
# puts " pwd = #{Dir.pwd} Trying: cp #{RuneBlog::Path}/../empty_view.tgz ."
|
63
|
+
system("cp #{RuneBlog::Path}/../empty_view.tgz .")
|
59
64
|
create_dirs(:drafts, :views)
|
60
65
|
new_sequence
|
61
66
|
end
|
@@ -66,6 +71,7 @@ class RuneBlog
|
|
66
71
|
end
|
67
72
|
|
68
73
|
def self.open(root = ".blogs")
|
74
|
+
log!(enter: __method__, args: [root])
|
69
75
|
# Crude - FIXME later - # What views are there? Publishing, etc.
|
70
76
|
self.blog = self # Weird. Like a singleton - dumbass circular dependency?
|
71
77
|
$_blog = self # Dumber still?
|
@@ -74,6 +80,7 @@ class RuneBlog
|
|
74
80
|
end
|
75
81
|
|
76
82
|
def initialize(root_dir = ".blogs") # always assumes existing blog
|
83
|
+
log!(enter: "initialize", args: [root_dir])
|
77
84
|
# Crude - FIXME later - # What views are there? Publishing, etc.
|
78
85
|
self.class.blog = self # Weird. Like a singleton - dumbass circular dependency?
|
79
86
|
$_blog = self # Dumber still?
|
@@ -94,32 +101,37 @@ class RuneBlog
|
|
94
101
|
end
|
95
102
|
|
96
103
|
def inspect
|
97
|
-
|
104
|
+
log!(enter: __method__)
|
105
|
+
str = "blog: "
|
98
106
|
ivars = ["@root", "@sequence"] # self.instance_variables
|
99
107
|
ivars.each do |iv|
|
100
108
|
val = self.instance_variable_get(iv)
|
101
|
-
str << "#{iv}
|
109
|
+
str << "#{iv}: #{val} "
|
102
110
|
end
|
103
|
-
|
111
|
+
# str << "]]"
|
104
112
|
str
|
105
113
|
end
|
106
114
|
|
107
115
|
def view?(name)
|
116
|
+
log!(enter: __method__, args: [name])
|
108
117
|
raise ArgumentError unless name.is_a?(String) && ! name.empty?
|
109
118
|
views.any? {|x| x.name == name }
|
110
119
|
end
|
111
120
|
|
112
121
|
def view(name = nil)
|
122
|
+
log!(enter: __method__, args: [name])
|
113
123
|
raise ArgumentError unless name.nil? || (name.is_a?(String) && ! name.empty?)
|
114
124
|
name.nil? ? @view : str2view(name)
|
115
125
|
end
|
116
126
|
|
117
127
|
def str2view(str)
|
128
|
+
log!(enter: __method__, args: [str])
|
118
129
|
raise ArgumentError unless str.is_a?(String) && ! str.empty?
|
119
130
|
@views.find {|x| x.name == str }
|
120
131
|
end
|
121
132
|
|
122
133
|
def _set_publisher
|
134
|
+
log!(enter: __method__)
|
123
135
|
file = @view.dir + "/publish"
|
124
136
|
@view.publisher = nil
|
125
137
|
return unless File.exist?(file)
|
@@ -127,6 +139,7 @@ class RuneBlog
|
|
127
139
|
end
|
128
140
|
|
129
141
|
def view=(arg)
|
142
|
+
log!(enter: __method__, args: [arg])
|
130
143
|
case arg
|
131
144
|
when RuneBlog::View
|
132
145
|
@view = arg
|
@@ -142,16 +155,19 @@ class RuneBlog
|
|
142
155
|
end
|
143
156
|
|
144
157
|
def get_sequence
|
158
|
+
log!(enter: __method__)
|
145
159
|
File.read(root + "/sequence").to_i
|
146
160
|
end
|
147
161
|
|
148
162
|
def next_sequence
|
163
|
+
log!(enter: __method__)
|
149
164
|
@sequence += 1
|
150
165
|
dump(@sequence, "#@root/sequence")
|
151
166
|
@sequence
|
152
167
|
end
|
153
168
|
|
154
169
|
def viewdir(v = nil) # delete?
|
170
|
+
log!(enter: __method__, args: [v])
|
155
171
|
v = str2view(v) if v.is_a?(String)
|
156
172
|
raise ArgumentError unless v.nil? || v.is_a?(RuneBlog::View)
|
157
173
|
v ||= @view
|
@@ -159,36 +175,62 @@ class RuneBlog
|
|
159
175
|
end
|
160
176
|
|
161
177
|
def self.exist?
|
178
|
+
log!(enter: __method__)
|
162
179
|
Dir.exist?(DotDir) && File.exist?(DotDir + "/" + ConfigFile)
|
163
180
|
end
|
164
181
|
|
182
|
+
def _copy_to_staging
|
183
|
+
copy!("themes/standard/", "staging/")
|
184
|
+
copy!("themes/standard/widgets/", "staging/")
|
185
|
+
end
|
186
|
+
|
187
|
+
def _copy_to_remote
|
188
|
+
copy!("themes/standard/etc", "remote/")
|
189
|
+
copy!("themes/standard/assets", "remote/")
|
190
|
+
copy!("themes/standard/widgets", "remote/")
|
191
|
+
end
|
192
|
+
|
165
193
|
def create_view(arg)
|
194
|
+
log!(enter: __method__, args: [arg])
|
166
195
|
raise ArgumentError unless arg.is_a?(String) && ! arg.empty?
|
167
196
|
|
168
197
|
names = self.views.map(&:to_s)
|
169
198
|
raise ViewAlreadyExists(arg) if names.include?(arg)
|
170
199
|
|
171
|
-
vdir =
|
200
|
+
vdir = arg.dup
|
172
201
|
raise DirAlreadyExists(vdir) if Dir.exist?(vdir)
|
173
|
-
create_dirs(vdir)
|
174
|
-
up = Dir.pwd
|
175
|
-
|
176
|
-
Dir.chdir(vdir) do
|
177
|
-
x = RuneBlog::Default
|
178
|
-
copy!("#{Themes}", "themes")
|
179
|
-
create_dirs(:assets, :posts)
|
180
|
-
create_dirs(:staging, "remote/permalink", "remote/navbar")
|
181
|
-
livetext "themes/standard/etc/blog.css.lt3" # strip ext
|
182
|
-
copy!("themes/standard/*", "staging/")
|
183
|
-
copy!("themes/standard/etc", "remote/")
|
184
|
-
copy!("themes/standard/assets", "remote/")
|
185
202
|
|
203
|
+
# puts "cv: pwd = #{Dir.pwd} file = #{`ls`}"
|
204
|
+
Dir.chdir(@root) do
|
205
|
+
# puts "---- (#{arg}) tar operation..."
|
206
|
+
|
207
|
+
# system("bash")
|
208
|
+
cmd1 = "tar zxvf empty_view.tgz >/dev/null 2>&1"
|
209
|
+
cmd2 = "cp -r empty_view views/#{arg}"
|
210
|
+
system(cmd1)
|
211
|
+
# puts " pwd = #{Dir.pwd}"
|
212
|
+
# puts " . => #{`echo *`}"
|
213
|
+
# puts " ./views => #{`ls views`}"
|
214
|
+
# puts " #{cmd1}\n #{cmd2}"
|
215
|
+
system(cmd2)
|
216
|
+
end
|
217
|
+
# create_dirs(vdir)
|
218
|
+
|
219
|
+
# puts "vdir = #{vdir} pwd = #{Dir.pwd}"
|
220
|
+
Dir.chdir("#@root/views/#{vdir}") do
|
221
|
+
# system("bash")
|
222
|
+
# x = RuneBlog::Default
|
223
|
+
# copy!("#{Themes}", "themes")
|
224
|
+
# create_dirs(:assets, :posts, :staging, "remote/permalink", "remote/navbar")
|
225
|
+
# livetext "themes/standard/etc/blog.css.lt3" # strip ext
|
226
|
+
# _copy_to_staging
|
227
|
+
# _copy_to_remote
|
228
|
+
livetext "themes/standard/blog/generate", "remote/index"
|
186
229
|
pub = "user: xxx\nserver: xxx\ndocroot: xxx\npath: xxx\nproto: xxx\n"
|
187
230
|
dump(pub, "publish")
|
188
231
|
|
189
232
|
view = RuneBlog::View.new(arg)
|
190
233
|
self.view = view
|
191
|
-
vdir = self.view.dir
|
192
234
|
dump("Initial creation", "last_published")
|
193
235
|
end
|
194
236
|
@views << view
|
@@ -196,6 +238,7 @@ class RuneBlog
|
|
196
238
|
end
|
197
239
|
|
198
240
|
def delete_view(name, force = false)
|
241
|
+
log!(enter: __method__, args: [name, force])
|
199
242
|
raise ArgumentError unless name.is_a?(String) && ! name.empty?
|
200
243
|
if force
|
201
244
|
system("rm -rf #@root/views/#{name}")
|
@@ -204,6 +247,7 @@ class RuneBlog
|
|
204
247
|
end
|
205
248
|
|
206
249
|
def view_files
|
250
|
+
log!(enter: __method__)
|
207
251
|
vdir = self.view.dir
|
208
252
|
files = ["#{vdir}/index.html"]
|
209
253
|
files += posts.map {|x| "#{vdir}/#{x}" }
|
@@ -212,6 +256,7 @@ class RuneBlog
|
|
212
256
|
end
|
213
257
|
|
214
258
|
def post_lookup(postid) # side-effect?
|
259
|
+
log!(enter: __method__, args: [postid])
|
215
260
|
# .. = templates, ../.. = views/thisview
|
216
261
|
slug = title = date = teaser_text = nil
|
217
262
|
|
@@ -227,6 +272,7 @@ class RuneBlog
|
|
227
272
|
end
|
228
273
|
|
229
274
|
def teaser(slug)
|
275
|
+
log!(enter: __method__, args: [slug])
|
230
276
|
id = slug.to_i
|
231
277
|
text = nil
|
232
278
|
post_entry_name = @theme + "/blog/post_entry.lt3"
|
@@ -244,7 +290,7 @@ class RuneBlog
|
|
244
290
|
end
|
245
291
|
|
246
292
|
def collect_recent_posts(file)
|
247
|
-
|
293
|
+
log!(enter: __method__, args: [file])
|
248
294
|
posts = nil
|
249
295
|
dir_posts = @vdir + "/posts"
|
250
296
|
entries = Dir.entries(dir_posts)
|
@@ -267,24 +313,24 @@ class RuneBlog
|
|
267
313
|
text << teaser(postid) # side effect! calls _out
|
268
314
|
end
|
269
315
|
text << "</body></html>"
|
270
|
-
File.write(file, text) # FIXME ???
|
316
|
+
File.write("#@vdir/remote/"+file, text) # FIXME ???
|
271
317
|
iframe_text = <<-HTML
|
272
318
|
<iframe name="main" style="width: 100vw;height: 100vh;position: relative;"
|
273
319
|
src='recent.html' width=100% frameborder="0" allowfullscreen>
|
274
320
|
</iframe>
|
275
321
|
HTML
|
322
|
+
# FIXME ^ serves no purpose??
|
276
323
|
end
|
277
324
|
|
278
325
|
def create_new_post(title, testing = false, teaser: nil, body: nil, other_views: [])
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
meta.num ||= 999 # ??
|
326
|
+
log!(enter: __method__, args: [title, testing, teaser, body, other_views])
|
327
|
+
meta = nil
|
328
|
+
Dir.chdir(self.view.dir) do
|
329
|
+
post = Post.create(title: title, teaser: teaser, body: body, other_views: other_views)
|
330
|
+
post.edit unless testing
|
331
|
+
post.build
|
332
|
+
meta = post.meta
|
333
|
+
end
|
288
334
|
return meta.num
|
289
335
|
rescue => err
|
290
336
|
puts err
|
@@ -292,6 +338,7 @@ class RuneBlog
|
|
292
338
|
end
|
293
339
|
|
294
340
|
def edit_initial_post(file, testing = false)
|
341
|
+
log!(enter: __method__, args: [file, testing])
|
295
342
|
debug "=== edit_initial_post #{file.inspect} => #{sourcefile}"
|
296
343
|
sourcefile = "#@root/drafts/#{file}"
|
297
344
|
result = system("#@editor #{sourcefile} +8") unless testing
|
@@ -302,17 +349,20 @@ class RuneBlog
|
|
302
349
|
end
|
303
350
|
|
304
351
|
def posts
|
352
|
+
log!(enter: __method__)
|
305
353
|
dir = self.view.dir + "/posts"
|
306
354
|
posts = Dir.entries(dir).grep(/^\d{4}/)
|
307
355
|
posts
|
308
356
|
end
|
309
357
|
|
310
358
|
def drafts
|
359
|
+
log!(enter: __method__)
|
311
360
|
dir = "#@root/drafts"
|
312
361
|
drafts = Dir.entries(dir).grep(/^\d{4}.*/)
|
313
362
|
end
|
314
363
|
|
315
364
|
def change_view(view)
|
365
|
+
log!(enter: __method__, args: [view])
|
316
366
|
raise ArgumentError unless view.is_a?(String) || view.is_a?(RuneBlog::View)
|
317
367
|
x = OpenStruct.new
|
318
368
|
x.root, x.current_view, x.editor = @root, view.to_s, @editor # dumb - FIXME later
|
@@ -321,20 +371,22 @@ class RuneBlog
|
|
321
371
|
end
|
322
372
|
|
323
373
|
def generate_index(view) # FIXME delete?
|
324
|
-
|
374
|
+
log!(enter: __method__, args: [view], pwd: true, dir: true)
|
325
375
|
raise ArgumentError unless view.is_a?(String) || view.is_a?(RuneBlog::View)
|
326
|
-
|
327
|
-
|
328
|
-
dir0 = "#{vdir}/themes/standard/blog"
|
329
|
-
rescue => err
|
330
|
-
error(err)
|
331
|
-
exit
|
376
|
+
@vdir = @root + "/views/#{view}"
|
377
|
+
collect_recent_posts("recent.html")
|
332
378
|
end
|
333
379
|
|
334
380
|
def generate_view(view) # huh?
|
381
|
+
log!(enter: __method__, args: [view])
|
382
|
+
generate_index(view)
|
383
|
+
Dir.chdir(@root + "/views/#{view}/themes/standard") do
|
384
|
+
livetext "blog/generate.lt3", "../../remote/index.html"
|
385
|
+
end
|
335
386
|
end
|
336
387
|
|
337
388
|
def _get_views(draft)
|
389
|
+
log!(enter: __method__, args: [draft])
|
338
390
|
# FIXME dumb code
|
339
391
|
view_line = File.readlines(draft).grep(/^.views /)
|
340
392
|
raise "More than one .views call!" if view_line.size > 1
|
@@ -361,6 +413,7 @@ class RuneBlog
|
|
361
413
|
# livetext VIEW/blog/generate.lt3 ??
|
362
414
|
|
363
415
|
def _copy_get_dirs(draft, view)
|
416
|
+
log!(enter: __method__, args: [draft, view])
|
364
417
|
fname = File.basename(draft)
|
365
418
|
noext = fname.sub(/.lt3$/, "")
|
366
419
|
vdir = "#@root/views/#{view}"
|
@@ -373,44 +426,56 @@ class RuneBlog
|
|
373
426
|
end
|
374
427
|
|
375
428
|
def generate_post(draft)
|
429
|
+
log!(enter: __method__, args: [draft])
|
376
430
|
views = _get_views(draft)
|
377
431
|
views.each do |view|
|
378
432
|
noext, viewdir, slugdir, aslug, @theme = _copy_get_dirs(draft, view)
|
379
|
-
|
433
|
+
# staging = viewdir + "/staging"
|
434
|
+
remote = viewdir + "/remote"
|
380
435
|
Dir.chdir(slugdir) do
|
381
436
|
copy(draft, ".")
|
382
437
|
lt3 = draft.split("/")[-1]
|
383
438
|
# Remember: Some posts may be in more than one view -- careful with links back
|
384
439
|
# system("livetext #{draft} >staging/#{name}/index.html") # permalink?
|
385
|
-
|
386
|
-
|
440
|
+
# copy!("#{@theme}/*", "#{staging}")
|
441
|
+
# copy(lt3, staging)
|
442
|
+
copy(lt3, remote)
|
387
443
|
html = noext[5..-1]
|
388
|
-
livetext draft, html
|
389
|
-
|
444
|
+
livetext draft, html # livetext "foobar.lt3", "foobar.html"
|
445
|
+
# copy(html, "../../staging/post/index.html")
|
446
|
+
copy(html, "../../remote/post/index.html")
|
390
447
|
title_line = File.readlines(draft).grep(/^.title /).first
|
391
448
|
title = title_line.split(" ", 2)[1]
|
392
449
|
excerpt = File.read("teaser.txt")
|
393
450
|
vars = %[.set title="#{title.chomp}"\n] +
|
394
451
|
%[.set teaser="#{excerpt.chomp}"]
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
452
|
+
theme = "../../theme/standard"
|
453
|
+
File.open("vars.lt3", "w") {|f| f.puts vars }
|
454
|
+
livetext "#{theme}/post/generate.lt3", "#{remote}/#{html}"
|
455
|
+
livetext "#{theme}/post/permalink.lt3", "#{remote}/permalink/#{html}"
|
456
|
+
# puts <<-TEXT
|
457
|
+
# File.open("vars.lt3", "w") {|f| f.puts vars }
|
458
|
+
# livetext "../post/generate.lt3", "#{remote}/#{html}"
|
459
|
+
# livetext "../post/permalink.lt3", "#{remote}/permalink/#{html}"
|
460
|
+
# TEXT
|
461
|
+
# system("bash")
|
462
|
+
log!(str: "About to enter remote/", pwd: true, dir: true)
|
463
|
+
Dir.chdir(remote) do
|
464
|
+
log!(str: "Now in remote/", pwd: true, dir: true)
|
465
|
+
system("cp -r ../themes/standard/widgets .")
|
466
|
+
log!(str: "finished with remote/", pwd: true, dir: true)
|
404
467
|
end
|
405
468
|
end
|
406
469
|
end
|
407
470
|
end
|
408
471
|
|
409
472
|
def relink
|
473
|
+
log!(enter: __method__)
|
410
474
|
self.views.each {|view| generate_index(view) }
|
411
475
|
end
|
412
476
|
|
413
477
|
def index_entry(view, meta)
|
478
|
+
log!(enter: __method__, args: [view, meta])
|
414
479
|
debug "=== index_entry #{view.to_s.inspect} #{meta.num} #{meta.title.inspect}"
|
415
480
|
check_meta(meta, "index_entry1")
|
416
481
|
raise ArgumentError unless view.is_a?(String) || view.is_a?(RuneBlog::View)
|
@@ -431,6 +496,7 @@ class RuneBlog
|
|
431
496
|
end
|
432
497
|
|
433
498
|
def rebuild_post(file)
|
499
|
+
log!(enter: __method__, args: [file])
|
434
500
|
raise "Doesn't currently work"
|
435
501
|
debug "Called rebuild_post(#{file.inspect})"
|
436
502
|
raise ArgumentError unless file.is_a?(String)
|
@@ -445,6 +511,7 @@ class RuneBlog
|
|
445
511
|
end
|
446
512
|
|
447
513
|
def remove_post(num)
|
514
|
+
log!(enter: __method__, args: [num])
|
448
515
|
raise ArgumentError unless num.is_a?(Integer)
|
449
516
|
tag = prefix(num)
|
450
517
|
files = Find.find(self.view.dir).to_a
|
@@ -460,6 +527,7 @@ class RuneBlog
|
|
460
527
|
end
|
461
528
|
|
462
529
|
def undelete_post(num)
|
530
|
+
log!(enter: __method__, args: [num])
|
463
531
|
raise ArgumentError unless num.is_a?(Integer)
|
464
532
|
files = Find.find("#@root/views/").to_a
|
465
533
|
tag = prefix(num)
|
@@ -475,12 +543,14 @@ class RuneBlog
|
|
475
543
|
end
|
476
544
|
|
477
545
|
def delete_draft(num)
|
546
|
+
log!(enter: __method__, args: [num])
|
478
547
|
raise ArgumentError unless num.is_a?(Integer)
|
479
548
|
tag = prefix(num)
|
480
549
|
system("rm -rf #@root/drafts/#{tag}-*")
|
481
550
|
end
|
482
551
|
|
483
552
|
def make_slug(meta)
|
553
|
+
log!(enter: __method__, args: [meta])
|
484
554
|
raise ArgumentError unless meta.title.is_a?(String)
|
485
555
|
label = '%04d' % meta.num # FIXME can do better
|
486
556
|
slug0 = meta.title.downcase.strip.gsub(' ', '-').gsub(/[^\w-]/, '')
|