.mixin markdown .h1 runeblog Runeblog is a blogging tool written in Ruby. It has these basic characteristics: .list It is usable entirely from the command line It publishes web pages as static HTML So far, yes, like Jekyll It's based on Livetext (highly extensible Ruby-based markup) It has the concept of multiple "views" for a blog .end The multiple views are in effect multiple blogs managed with the same backend. .h2 What is Livetext? Livetext is a markup format that is a throwback to the old, old days of text formatters such as ``nroff. It's very flexible, and it is extensible _[in Ruby]. It is far from mature or full-featured, but it is usable. Runeblog uses Livetext, along with some custom definitions, to try to ease the formatting of a blog entry. .h2 What are "views"? Think of them as multiple separate blogs with the same backend. Why would you want to do this? Maybe you wouldn't, but I do. The purpose is to present different "faces" to different audiences. In my case, my computing-related stuff would go into one view, and my hometown-related things would go into another. There might be a view that only old friends or close friends can see. There might be a view purely for reviews of music, books, and movies. But the important points are these: .list _All the views will be managed the same way in the same place, and they will all share common data. Any post can easily be included in a single view, in more than one, or in all of them. Each view can have its own look and feel, and it can be linked/published separately from the others. Each view can be hosted in a different location and/or a different server and domain Any post can be in more than one view .end .h2 The `blog environment There is a command-line tool called `blog which is a REPL (read-eval-print loop). Note that this tool is a curses-based environment (mainly so it can display menus and such to the user). The help message looks like this: .mono Commands: h, help This message q, quit Exit the program change view _view Change current view new view Create a new view list views List all views available lsv Same as: list views p, post Create a new post new post Same as post (create a post) lsp, list posts List posts in current view lsd, list drafts List all posts regardless of view rm _id Remove a post edit _id Edit a post preview Look at current (local) view in browser browse Look at current (deployed) view in browser relink Regenerate index for all views (MAY CHANGE) rebuild Regenerate all posts and relink (MAY CHANGE) deploy Deploy (current view) .end .h2 Getting started But when you first run the REPL, it checks for an existing blog under the `.blog directory. If it doesn't find one, it asks whether you want to create a new blog. If you enter `y for yes, it creates a sort of "skeleton" with a single view called ``test_view. The next thing you should do is to create at least one view of your own. Use the `[new view] command for this. (new view) (new post) (preview) (publishing one-time setup - server, ssh keys, etc.) (publish) (browse) (and so on...) *[To be continued] .h2 Changing the default templates *TBD .h2 Basics of Livetext *TBD (bold, italics, etc.) (common dot commands) (predefined functions and variables) .h2 Runeblog-specific features (Liveblog) *TBD (dot commands) (variables and functions) .h2 Defining your own features (dot commands) (variables and functions) *TBD .h2 *TBD .h2 More later... *TBD