No description
Find a file
2015-03-01 13:29:55 -08:00
ablog Fixed issues with using unicode in py3. 2015-03-01 13:29:55 -08:00
docs Edited README. 2015-02-25 23:24:19 -08:00
.gitignore Udpated gitignore. 2015-02-23 22:19:55 -08:00
.travis.yml Removed virtualenv option. 2015-03-01 13:06:02 -08:00
LICENSE.txt Added license. 2014-04-27 17:00:35 -07:00
MANIFEST.in Fixes, revisions. 2015-01-31 19:10:31 -08:00
README.rst Update README.rst 2015-03-01 12:47:56 -08:00
setup.py Changed requires to install_requires. 2015-03-01 10:10:10 -08:00

ABlog for Sphinx
================

ABlog is a Sphinx extension that converts any documentation or personal
website project into a full-fledged blog with:

  * `Atom feeds`_
  * `Archive pages`_
  * `Blog sidebars`_
  * `Disqus integration`_
  * `Font-Awesome integration`_

Looking for an example? Take a look at `ABlog documentation <http://ablog.readthedocs.org>`_ 
where each manual and release is a blog post ;) 

.. _Atom feeds: http://ablog.readthedocs.org/blog/atom.xml
.. _Archive pages: http://ablog.readthedocs.org/blog/
.. _Blog sidebars: http://ablog.readthedocs.org/manual/ablog-configuration-options/#sidebars
.. _Disqus integration: http://ablog.readthedocs.org/manual/ablog-configuration-options/#disqus-integration
.. _Font-Awesome integration: http://ablog.readthedocs.org/manual/ablog-configuration-options/#fa

Installation
------------

You can install ABlog using pip_::

    pip install -U ablog

This will install Sphinx_ and Werkzeug_ as well, respectively required for 
building your website and generating feeds.

If you are starting a new Sphinx project, you might want to also install 
Alabaster_ to have a good looking website::

  pip install Alabaster

.. _pip: https://pip.pypa.io
.. _Sphinx: http://sphinx-doc.org/
.. _Werkzeug: http://werkzeug.pocoo.org/
.. _Alabaster: https://github.com/bitprophet/alabaster


Getting Started
---------------

If you are starting a new project, see `ABlog Quick Start`_ guide.

If you already have a project, enable blogging by making following changes in ``conf.py``:

.. code-block:: python

  # 1. Append 'ablog' to list of extensions
  extensions = [
      '...',
      'ablog'
  ]
  
  # 2a. Append templates path to `templates_path`
  import ablog
  templates_path.append(ablog.get_html_templates_path())

  # 2b. If `templates_path` is not defined before
  templates_path = [ablog.get_html_templates_path()]

If you also installed Alabaster_, see how to configure it here_.

.. _ABlog Quick Start: http://ablog.readthedocs.org/manual/ablog-quick-start
.. _here: https://github.com/bitprophet/alabaster#installation

How it works
------------

If you are new to Sphinx_ and reStructuredText markup language, 
you might find `reStructuredText Primer`_ useful. Once you have
some content (in ``.rst`` files), you can post *any page* using 
the ``post`` directive as follows:

.. code-block:: rst

  .. post:: Apr 15, 2014
     :tags: earth, love, peace
     :category: python
     :author: me
     :location: SF
     :language: en     

ABlog will index all files posted as above. When building HTML pages,
it will create archives and feeds that list these posts as 
specified by ``:tag:``, ``:category:``, etc. options. 

You can also include a list of posts using ``postlist`` directive:

.. code-block:: rst

  .. postlist:: 5
     :category: Manual
     :reverse:

For ABlog documentation, this converts to the following list of links that you
can follow to learn more about configuring and using ABlog:

  * `Posting and Listing <http://ablog.readthedocs.org/manual/posting-and-listing/>`_ 
  * `ABlog Configuration Options <http://ablog.readthedocs.org/manual/ablog-configuration-options/>`_ 
  * `Cross-referencing Blog Pages <http://ablog.readthedocs.org/manual/cross-referencing-blog-pages/>`_
  * `Post Excerpts and Images <http://ablog.readthedocs.org/manual/post-excerpts-and-images/>`_
  * `Posting Sections <http://ablog.readthedocs.org/manual/posting-and-listing/#posting-sections>`_
  

.. _reStructuredText Primer: http://sphinx-doc.org/rest.html

For existing projects, it is important to note that ABlog does not intertere 
with any Sphinx operations. Since you can post any page from any folder,
you do not need to change how you organize project contents.