runeblog 0.2.1 → 0.2.7

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