NAME

mira - static site generator

VERSION

This document describes mira version 0.07.

DESCRIPTION

mira is an integrated content management framework for create multiple websites

you can create your blogs, photoblogs, image galleries, podcasts, books, portfolio, docs, manuals, projects pages and... in mira's floors. each floor is a separate website which can have its own config, template and fields or use main floor settings.

mira is cool?

simple

No need databases, just static content flies and a template body. mira performs all other tasks

modern

Write your contetnt's body whatever you like, Markdown, Textile, BBcode, HTML or just simple texts.

flexible

no limit for make archive lists like categories, tags, seassions, chapters and... or single fields like title, sub title, thumbs and... just keep dreaming about what you need, mira will make them

NOTE

simple, fast & perlish multiple website generator

mira structure based in floors, each folder in content directory is a separate site, which can have them config and template, or use main config seting

start

mkdir mira_Site_name
cd mira_Site_name
mira init

now you have a mira site in your mira_Site_name folder

edit config.yml

title: YOUR MAIN SITE TITLE
description: A Description about your site
author: your name
email: your-email@domain.com
url: PUBLISH.ADDRESS.COM      # or something else like http://localhost:80
root: /                       # root address of your site, leave it / if you dont like publish in subfolders like ADDRES.COM/SUB/
static: /static               # the site static files address, content of 'statics' folder in your root mira_Site_name folder will be copy here, ADDRES.COM/static
imageurl: /static/img         # in your entries if you use [% img %] will be replaced by this address
permalink: :year/:month/:day/:title/ #your entry address static address follow this path

default_body_format: markdown # default markup for your entry body, but you can change it for each post in header field: body_format
default_floor: blog           # default floor for when you use 'mira new' without --floor switch
template: THEME_NAME          # body template for make your static HTMLs, your template folder name in template directory in mira root
lists:                        # the fields which your archive based on them
  - categories
  - tags
  - author

you can make config file for each floor in config directory in mira root, e.x: config/YOUR_FLOOR.yml

SYNOPSIS

    mira <CoMMand> [-?h] [options]
	-? -h --help  show help

Available commands:

commands: list the application's commands help : display a command's help screen build : site builder init : mira structure generator new : new entry maker

available options:

command 'new' options: -f, --floor : make new post in your floor

usage

new post

mira new -t "YOUR POST TITLE" -f "FLOOR_NAME"
this command your content file in: content/FLOOR_NAME/yy-mm-dd-YOUR_POST_TITLE.pen
in header this file have your fields structures, from structure/FLOOR_NAME + utid, title, date...

NOTE: never edit utid

build

mira build

mira make your sites in public directory, if your floor have them config file, mira use it for make your floor, and if no config file mira make it in public/FLOOR_NAME by default configs stored in main config.yml

preview

mira view [--host 127.0.0.1] [--port 5000]

a simple static file server based on your public directory

AUTHOR

kiavash <kiavash@cpan.org>

COPYRIGHT AND LICENSE

mira is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.