linchpin / phpdocumentor-template-markdown
phpDocumentor Template for github Wiki. Forked from oliveratgithub/phpDocumentor-Template-ghwiki
Installs: 12 663
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 1
Language:Twig
pkg:composer/linchpin/phpdocumentor-template-markdown
This package is auto-updated.
Last update: 2025-10-19 23:09:13 UTC
README
Introduction
This is a custom template to use with phpDocumentor.
It is intended to create the code documentation as markdown files, fully compatible to serve as a GitHub Wiki in a GitHub repository of your choice.
Example
You can find a live example in this GitHub repository: zorgch/zorg-code/wiki
Installation
- Via composer composer require linchpin/phpdocumentor-template-markdown
- Download the latest release
Pre-requisites
- phpDocumentor must be installed or available using its .phar
- You have a GitHub Wiki cloned locally
Generate GitHub Wiki Markdown from your code
- Specifiy this template phpdocumentor-template-markdownwhile generating your code documentation usingphpDocumentor:php ./phpDocumentor.phar -d "/path/to/my/sourcecode" -t "/path/to/local/github-wiki" --template="/vendor/linchpin/phpdocumentor-template-markdown" --cache-folder "/path/to/store/cache" --title "My code project"
- NOTE: you may get an error at the end of the parsing - which you can just ignore, all work was done:
ERROR In PathGenerator.php line 120: Variable substitution in path /namespaces/{{name}}.md failed, variable "name" did not return a value
- The target directory /github-wikiconsists of various markdown (.md) files now
- Review, commit & push your local GitHub Wiki repository changes
- Browse to the Wiki on the corresponding GitHub repository to see your code documentation online
Result
Consider that GitHub Wiki pages are in a flat file hierarchy. Fortunately you still can use folders in the repository itself - so you can have a clean structure in the Wiki repository, but when linking between files it must behave like all Wiki pages are in a single, flat hierarchy.
Outputted file hierarchy
The output consists of the following files hierarchy:
GitHub Wiki pages handling
As mentioned, due to GitHub Wiki pages behaving not within any hierarchy, linking between Wiki pages is done...
- by referencing the file name of the page
- leaving away the .mdextension
So use class-MyClass to link to the file /wiki/classes/class-MyClass.md.
Or file-myconfigs.inc.php to link to the file /wiki/files/file-myconfigs.inc.php.md.