mfn / docblock-normalize
Extracts doc blocks and normalizes the references classes based on the current namespace and use-aliases
Requires
- php: >=5.6
Requires (Dev)
- phing/phing: ^2.12
- phpunit/phpunit: ^5.0
This package is auto-updated.
Last update: 2025-01-16 17:21:21 UTC
README
Homepage: https://github.com/mfn/php-docblock-normalize
Blurb
This library extracts docblocks from source files and normalizes all type
descriptions within. That is, they're turned into full qualified symbol names
taking the current namespace
and use
-aliases into consideration.
Requirements
PHP 5.6
Install
Using composer: composer.phar require mfn/docblock-normalize 0.1
Example
sample.php
:
<?php namespace Foo; use Bar as Baz; /** * @param Foo $param1 * @param Bar $param2 * @param Baz $param3 * @param \Foo $param4 * @param string $param5 */
Parse and output the docblock with its types normalized:
$parser = new \Mfn\DocblockNormalize\Parser( new \Mfn\DocblockNormalize\TokenParser ); $docblocks = $parser->parseFile('sample.php'); echo $docblocks[0]->getNormalizedContent();
Will return:
/**
* @param Foo\Foo $param1
* @param Foo\Bar $param2
* @param Bar $param3
* @param Foo $param4
* @param string $param5
*/
Note: namespace
and use
statements for the docblock must appear
before it!
Note 2: the normalization also removes leading backslashes, this is expected!
Contribute
Fork it, hack on a feature branch, create a pull request, be awesome!
No developer is an island so adhere to these standards:
© Markus Fischer markus@fischer.name