Maslosoft Addendum API
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
<?php
/**
* This software package is licensed under AGPL, Commercial license.
*
* @package maslosoft/addendum
* @licence AGPL, Commercial
* @copyright Copyright (c) Piotr Masełkowski <pmaselkowski@gmail.com> (Meta container, further improvements, bugfixes)
* @copyright Copyright (c) Maslosoft (Meta container, further improvements, bugfixes)
* @copyright Copyright (c) Jan Suchal (Original version, builder, parser)
* @link https://maslosoft.com/addendum/ - maslosoft addendum
* @link https://code.google.com/p/addendum/ - original addendum project
*/
namespace Maslosoft\Addendum\Helpers;
use ReflectionClass;
use ReflectionObject;
use Reflector;
/**
* Coarse check for annotations.
*
* @author Piotr Maselkowski <pmaselkowski at gmail.com>
*/
class CoarseChecker
{
/**
* Check if file contains annotations,
* by checking if it contains @[A-Z] regular expression.
*
* It does not ensure that file really contains anniotations.
*
* @param string|Reflector|object $entity
* @return bool
*/
public static function mightHaveAnnotations($entity)
{
if (is_object($entity))
{
if ($entity instanceof Reflector)
{
if ($entity instanceof ReflectionClass)
{
$file = $entity->getFileName();
}
else
{
$file = $entity->getDeclaringClass()->getFileName();
}
}
else
{
$file = (new ReflectionObject($entity))->getFileName();
}
}
else
{
$file = $entity;
}
if (empty($file) || !is_string($file))
{
return false;
}
$content = file_get_contents($file);
return !!preg_match('~@[A-Z]~', $content);
}
}
API documentation generated by ApiGen