runeblog 0.1.98 → 0.2.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (505) 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 +105 -61
  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 +120 -50
  15. data/lib/runeblog_version.rb +1 -1
  16. data/lib/view.rb +8 -0
  17. data/runeblog.gemspec +1 -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/{themes/standard/sidebar → test/.blogs/views/around_austin/remote/widgets/calendar}/calendar.lt3 +0 -0
  72. data/{themes/standard/sidebar/news.lt3 → test/.blogs/views/around_austin/remote/widgets/news/list.data} +2 -5
  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 +2 -2
  83. data/{themes/standard/sidebar → test/.blogs/views/around_austin/remote/widgets/tag-cloud}/tag-cloud.lt3 +2 -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 +9 -5
  485. data/themes/standard/blog/index.lt3 +3 -2
  486. data/themes/standard/blog/recent.lt3 +2 -0
  487. data/themes/standard/post/generate.lt3 +0 -2
  488. data/themes/standard/sidebar/README +3 -0
  489. data/themes/standard/widgets/ad/ad.lt3 +15 -0
  490. data/themes/standard/widgets/calendar/calendar.lt3 +6 -0
  491. data/themes/standard/widgets/news/list.data +4 -0
  492. data/themes/standard/widgets/news/news.lt3 +2 -0
  493. data/themes/standard/widgets/pages/disclaim.html +6 -0
  494. data/themes/standard/widgets/pages/disclaim.lt3 +2 -3
  495. data/themes/standard/widgets/pages/faq.html +7 -0
  496. data/themes/standard/widgets/pages/faq.lt3 +1 -1
  497. data/themes/standard/widgets/pages/lifestory.html +7 -0
  498. data/themes/standard/widgets/pages/lifestory.lt3 +1 -1
  499. data/themes/standard/widgets/pages/like-dislike.html +7 -0
  500. data/themes/standard/widgets/pages/like-dislike.lt3 +1 -1
  501. data/themes/standard/widgets/pages/list.data +4 -4
  502. data/themes/standard/widgets/pages/pages.lt3 +2 -0
  503. data/themes/standard/widgets/tag-cloud/tag-cloud.lt3 +12 -0
  504. metadata +486 -7
  505. data/themes/standard/sidebar/ad.lt3 +0 -5
@@ -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
+
@@ -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,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
- str = "[["
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} = #{val} "
109
+ str << "#{iv}: #{val} "
102
110
  end
103
- str << "]]"
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 = "#@root/views/#{arg}/"
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
- @vdir = ".."
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
- save = Dir.pwd
280
- Dir.chdir(self.view.dir)
281
- # change to create_draft ?
282
- post = Post.create(title: title, teaser: teaser, body: body, other_views: other_views)
283
- post.edit unless testing
284
- post.build
285
- meta = post.meta
286
- Dir.chdir(save)
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
- debug "=== generate_index view = #{view.to_s}"
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
- vdir = self.view.dir
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
- staging = viewdir + "/staging"
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
- copy!("#{@theme}/*", "#{staging}")
386
- copy(lt3, staging)
440
+ # copy!("#{@theme}/*", "#{staging}")
441
+ # copy(lt3, staging)
442
+ copy(lt3, remote)
387
443
  html = noext[5..-1]
388
- livetext draft, html
389
- copy(draft, "../../staging/post/index.html")
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
- Dir.chdir(staging) do
396
- File.open("vars.lt3", "w") {|f| f.puts vars }
397
- livetext "post/generate.lt3", html
398
- copy html, "../remote"
399
- livetext "post/permalink.lt3", "../remote/permalink/#{html}"
400
- collect_recent_posts("recent.html")
401
- copy("recent.html", "../remote")
402
- copy!("navbar/*html", "../remote/navbar/")
403
- livetext "blog/generate", "../remote/index"
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-]/, '')