A (com)Pendium for all your markdown files
This is a web app for all your markdown files, you can use it for reading them in web way, share them through the interwebs or you can even create a personal ( or not so personal ) wiki with just a bunch of files ( you can link them together nicely ).
Powered by Python 2.7
Flask
Markdown
yapsy
GitPython # Optional for git support
docutils # Optional for rest documents
pygments # Optional for python documents
mdx_smartypants # Optional for smartypants, don't forget to read the doc bellow
To get yourself up and running you only need to run these commands:
git clone git://github.com/LuRsT/Pendium.git
cd Pendium
pip install -r requirements.txt
Optional step (install optional requirements):
pip install -r opt_requirements.txt
Note: Pendium was hacked in python 2.7, so use the appropriate command to install de dependencies e.g. in arch linux it's 'pip2'. Note2: Remember to install the optional requirements in order to unleash the full power of Pendium.
If you want to change the config, copy the pendium/default_config.py file to config.py
cp pendium/default_config.py config.py
Check the Wiki for config help.
Fear not, for python's markdown module has that extension, in order to activate it, you'll need first to install the extension since it does not come with markdown:
pip install mdx_smartypants
Once installed, add 'smartypants' to the markdown extension dict in your config file:
WIKI_PLUGINS_CONFIG = { "Markdown" : { 'extensions' : [ 'headerid', 'toc',
'tables', 'footnotes',
'fenced_code', 'codehilite',
'smartypants' # <- here, don't forget the comma
]
},
}
Python's markdown modules comes with other extensions which you can activate the same way, you did ( or did not ) with smartypants, by adding it to the WIKI_PLUGINS_CONFIG, markdown extensions array.
Good link about markdown extensions
Before you do anything be sure to enable git support in the config file ( config.py ):
WIKI_GIT_SUPPORT = True
To get the git support, run these commands afterwards ( if you don't have a remote git repo, go to the next step ):
cd wiki
git init
git remote add origin <your_remote_git_repo>
git branch --set-upstream master origin/master
git pull #Optional, just to check if everything is okay and to get your files immediately
I'm assuming you already have a remote git repo up and running on the previous step, if you do not, do this:
cd <repo_dir>
git init --bare
with this you made yourself a git repo, now run these:
cd wiki_dir # by default: <pendium_dir>/wiki
git clone <path_to_previous_repo> <path_to_wiki_folder>
touch home.md
git add home.md
git commit -m "Initial commit"
git push -u origin master
To use Pendium simply execute the run.py file:
python run.py
By default it should read the files from the wiki dir inside the pendium directory, change the directory in the config file or symlink your own dir.
Note: Pendium was hacked in python 2.7, so use the appropriate command to run it e.g. in arch linux it's 'python2' Note2: You can run Pendium from anyplace besides the project dir BUT you have to provide WIKI_DIR your wiki's absolute path. ( remember that Git plugin needs the correct basepath too)
If you'd like to deploy your pendium to a proper webserver (I'll use apache as an example), here are some very basic instructions to do so:
Create a file called .wsgi at the root of Pendium with this contents:
import sys
from pendium import app as application
sys.path.insert(0, "/<path_to_>/Pendium")
Now in your webserver config ( Apache as example) add this:
<Directory /<path_to_>/Pendium>
Order allow,deny
Allow from all
</Directory>
WSGIScriptAlias /pendium /<path_to_>/Pendium/<something>.wsgi
And you should be good to go. These are only quick and dirty steps you can take in order to use Pendium as a not-started-via-console app, but if you want some serious stuff, please refer to flask docs.
Discover a better styleGit integration404 pretty errorSub wikisGrep-like searchEdit filesCreate filesCreate dirsDelete files/dirsKeyboard shortcuts- Better editor
Note: The fact that something is striked does NOT mean that it's bugless or that does all the stuff that I want it to do.