Vanity is a tool for generating high-quality, user-friendly documentation from PHP source code. Vanity was written to address the user-hostile and generally unhelpful output that most existing documentation tools generate.
Vanity came from the experience of working alongside users over nearly a decade of open-source software development, and has been heavily inspired by Rails API, jQ API, jQuery source viewer, Cocoa Developer Reference and Ingredients.app.
Follow progress at @vanitydoc.
Vanity was born out of a need to provide users of my CloudFusion project a vastly improved documentation experience. After jumping from PHPDocumentor, to Doxygen, to NaturalDocs, I decided to sit down and write something completely from scratch. Thus, Vanity 1.0 was born.
The biggest problem I had with existing API reference generators was the inability to write my own templates. Most of them offer alternate "styles" (as in, different CSS files). PHPDocumentor supposedly enabled users to write custom templates, but the documentation was so obtuse that I gave up after a couple of weeks of trying to decypher what the hell was going on.
During this time, I learned a lot about how to make a better documentation generator. At the same time, Amazon Web Services forked CloudFusion and hired me to work on the AWS SDK for PHP. As the software grew, Vanity 1.0 started showing its cracks. So I took the lessons I'd learned the first time around, and built something better. I call this Vanity 2.
I would encourage you to peruse the wiki for deeper details.
http://vanitydoc.org | @VanityDoc
- Fast generation of documentation.
- Has an attractive default template.
- Has a well-defined approach to designing and defining your own HTML templates.
- Produces documentation in HTML, JSON, XML and Serialized PHP by default. This enables third-party developers to build even cooler stuff on top of your documentation.
- Vanity keeps a cached copy of the PHP.net documentation on-hand. If you have a class that inherits from one of PHP's built-in classes, those inherited methods are also documented using the PHP.net content.
- You can inject custom "partials" into the default template without touching the default template itself. This is perfect for metric tracking tools, copyright notices and similar project-specific things.
- Lover of YAML for configuration; Markdown and HTML for content.
- Also generates content with "smart punctuation" -- curly quotes, curly apostrophes, em- and en-dashes, ellipses and more!
- You are strongly encouraged to use real, live unit tests as code samples in your documentation.
- Usage examples and method source code is parsed by a syntax highlighter for prettier code.
- Has built-in support for the simple, lightweight PHPT unit test format.
- If you're already invested in PHPUnit or SimpleTest, you can keep using those for tests. However, all usage examples are defined using the simple, lightweight PHPT test syntax.
- Support for Examplify! enables you to leverage a comment-based syntax for hiding certain lines of your tests, or replacing strings in your tests before they are used for example/instructional purposes in your documentation.
- Vanity is sensitive to projects that have generated code instead of hand-written code. As such, you can plug-in custom data without having to edit your generated PHP code.
- You can define how to group together related methods with the
@see
tag or an externalgroups.yml
file. - You can define See Also links with the
@link
tag or an externalseealso.yml
file. - You can define changes to specific methods (e.g., backwards-incompatible changes) using the
@changelog
tag or an externalchangelog.yml
file. - You can also pass a series of configuration options via the command line, or you can store a set in a
config.yml
file.
- You can define how to group together related methods with the
- Has built-in support for GitHub projects. This is relied upon for viewing the source code for an entire file.
- Supports excluding classes and methods from being documented.
- Describes each class' inheritance chain and implemented interfaces, if any.
Technically, Vanity supports any tag your little heart could ever wish to create. However, Vanity doesn't necessarily understand all tags. Understood tags are specifically accounted for and handled. Tags that are not understood are still pulled in, but are treated as metadata.
These are PHPDocumentor tags that Vanity understands.
- @author
- Used to define the author of a class.
- @link
- Used to define an off-site link.
- @param
- Used to define a method parameter.
- @return
- Used to define the return type of a method.
- @see
- Used to reference another method within the software you're documenting, or a native PHP function/method.
- @since
- Used to define when a method came to exist.
These are ideas that PHPDocumentor implements with tags, but Vanity handles in a different way.
@example
- Uses a file called
examples.yml
to refer to either real, live PHPT unit tests, or a PHPT-formatted file. @filesource
- All methods have their source, file, and starting/ending line numbers pulled into the documentation. This is unavoidable.
@ignore
- Any classes or methods that you want to ignore are defined in the
config.yml
file, and supports PCRE regular expression matching. @tutorial
- Treated the same way as
@example
. @uses
- Use
@see
instead. @version
- Use
@changelog
instead. You can also define changelogs for specific methods in achangelog.yml
file.
These are tags I may add support for eventually. I've not made up my mind one way or another. Want me to add it? Convince me why it's a worthwhile investment of my time and I'll consider it.
@deprecated
- The word "deprecated" will show up somewhere in the page, and can be styled independently via a CSS classname hook of "deprecated". Maybe it should have a bright red background?
@category
@copyright
@global
- Since Vanity uses PHP's Reflection API, it doesn't pick up global variables and functions.
@internal
@license
@package
@property
@subpackage
@todo
- I will definitely add support for some sort of list of
@todo
s. @var
- Couldn't hurt. Not a bad idea.
These are tags that are completely off the discussion board because they're no longer needed in PHP 5 with the advent of the Reflection API.
@abstract
@access
@final
@method
@static
@staticvar
- Currently, Vanity determines which classes to document by diffing
get_declared_classes()
before and after loading all classes into memory. There are much better ways of doing this. I haven't yet tested any packages that leverage PHP 5.3 namespaces. I'm not even sure what would happen.I haven't intentionally done anything to support namespaces yet.- ComplexPie uses namespaces extensively. It seems like these should be turned into subfolders in the browse tree. I'm not yet sure how to treat class names: keep backslashes or not?
- While Vanity tries to be responsible with the memory it uses, it still relies on loading a bunch of code into memory. This makes large projects explode violently. (e.g., Zend Framework)
- Vanity doesn't do a very good job of handling code with a crap-ton of dependencies, complex autoloading rules, or things that rely on the magic of
PATH
definitions. (e.g., Zend Framework) - As of this moment, I've only tested Vanity on the AWS SDK for PHP, SimplePie, ComplexPie and Zend Framework. Zend Framework exploded. I still have a lot more testing to do.
A list of other TODOs is here: https://github.com/skyzyx/vanity/issues