ApiGen

PHP 7.1 ready Smart and Simple Documentation for your PHP project

Github星跟踪图

Smart and Readable Documentation for your PHP project

Build Status
Coverage Status
Downloads
Latest stable

ApiGen is the simplest, the easiest to use and the most modern api doc generator. It is all PHP 7.1 features ready
easy to extend with own Finder, Annotation Subscriber or even Generator.

Just look at ApiGen API:

ApiGen Preview

Your Help is Needed to Finish 5.x Release

:heart: We need your help to test new version of ApiGen.

How to install it?

Add to your composer.json:

{
    "require": {
        "apigen/apigen": "dev-master",
        "roave/better-reflection": "dev-master#c87d856"
    }
}

then update:

composer update

Test it, report issues or send PRs.

:skull: Version 4.x is not supported, since there was huge change of Reflection library and the code was almost completely rewritten.

Built on Shoulders of Giants

Install

composer require apigen/apigen --dev

Usage

Generate API docs by passing single source and destination options:

vendor/bin/apigen generate src --destination docs

Or generate API docs for multiple directories:

vendor/bin/apigen generate src tests --destination docs

Configuration

Below is a minimal example configuration. Save it as a apigen.yml file in
the root of your project:

parameters:
    visibility_levels: [public, protected] # array
    annotation_groups: [todo, deprecated] # array
    title: "ApiGen Docs" # string
    base_url: "http://apigen.org/api" # string
    overwrite: false # bool

What Annotations Have Extra Care?

@see, @covers, @uses

Reference to Class, Function, Property, Method etc. element.

In Code

/**
 * @see SomeClass
 * @see SomeClass::$propety
 * @see SomeClass::someFunction()
 */

Generated

@see <a href="class-SomeClass.html">SomeClass</a>
@see <a href="class-SomeClass.html#$someProperty">SomeClass::$property</a>
@see <a href="class-SomeClass.html#_someFunction">SomeClass::someFunction()</a>

A website url.

In Code

/**
 * This is already mentioned on Wiki.
 * @link https://en.wikipedia.org/wiki/United_we_stand,_divided_we_fall Click to see a cool quote
 */

Generated

This is already mentioned on Wiki.
@link <a href="https://en.wikipedia.org/wiki/United_we_stand,_divided_we_fall">Click to see a cool quote</a>

@internal

Associated element is internal, so ApiGen hides it.

Themes

To enable a custom theme just provide theme_directory configuration option in your apigen.yml:

parameters:
    theme_directory: path/to/theme # path to theme's config file

Contributing

Rules are simple:

  • new feature needs tests
  • all tests must pass
    composer complete-check
    
  • 1 feature per PR

We would be happy to merge your feature then.

主要指标

概览
名称与所有者ApiGen/ApiGen
主编程语言PHP
编程语言PHP (语言数: 5)
平台
许可证Other
所有者活动
创建于2011-02-26 20:23:53
推送于2025-02-21 14:28:13
最后一次提交2025-02-21 15:27:46
发布数43
最新版本名称v7.0.0-alpha.6 (发布于 )
第一版名称2.0.0beta (发布于 2011-05-09 17:29:48)
用户参与
星数2.2k
关注者数102
派生数310
提交数3.9k
已启用问题?
问题数699
打开的问题数21
拉请求数295
打开的拉请求数3
关闭的拉请求数107
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?