Overview

Namespaces

  • LeanMapper
    • Exception
    • Reflection
    • Relationship

Classes

  • LeanMapper\Entity
  • LeanMapper\Reflection\Aliases
  • LeanMapper\Reflection\AliasesBuilder
  • LeanMapper\Reflection\AliasesParser
  • LeanMapper\Reflection\AnnotationsParser
  • LeanMapper\Reflection\EntityReflection
  • LeanMapper\Reflection\Property
  • LeanMapper\Reflection\PropertyFactory
  • LeanMapper\Reflection\PropertyFilters
  • LeanMapper\Reflection\PropertyType
  • LeanMapper\Relationship\BelongsTo
  • LeanMapper\Relationship\BelongsToMany
  • LeanMapper\Relationship\BelongsToOne
  • LeanMapper\Relationship\HasMany
  • LeanMapper\Relationship\HasOne
  • LeanMapper\Repository
  • LeanMapper\Result
  • LeanMapper\Row

Exceptions

  • LeanMapper\Exception\InvalidAnnotationException
  • LeanMapper\Exception\InvalidArgumentException
  • LeanMapper\Exception\InvalidMethodCallException
  • LeanMapper\Exception\InvalidStateException
  • LeanMapper\Exception\InvalidValueException
  • LeanMapper\Exception\MemberAccessException
  • LeanMapper\Exception\RuntimeException
  • LeanMapper\Exception\UtilityClassException
  • Overview
  • Namespace
  • Class
 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: 72: 
<?php

/**
 * This file is part of the Lean Mapper library (http://www.leanmapper.com)
 *
 * Copyright (c) 2013 Vojtěch Kohout (aka Tharos)
 *
 * For the full copyright and license information, please view the file
 * license-mit.txt that was distributed with this source code.
 */

namespace LeanMapper\Reflection;

use LeanMapper\Exception\InvalidAnnotationException;
use LeanMapper\Exception\RuntimeException;

/**
 * Set of entity filters
 *
 * @author Vojtěch Kohout
 */
class PropertyFilters
{

    /** @var string[] */
    private $filters = array();


    public function __construct($definition, Aliases $aliases)
    {
        $pieces = preg_split('#\s*,\s*#', trim($definition));
        foreach ($pieces as $filter) {
            if ($filter === '') {
                throw new InvalidAnnotationException('Empty filter definition given.');
            }
            $matches = array();
            preg_match('#^(?:((?:\\\\?[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*)+)::)?((?:\\\\?[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*)+)$#', $filter, $matches);
            if (empty($matches) or ($matches[1] !== '' and strpos($matches[2], '\\') !== false)) {
                throw new InvalidAnnotationException('Invalid filter definition given: ' . $filter);
            }
            $function = $matches[2];
            if ($matches[1] !== '') {
                $class = $matches[1];
                if (substr($class, 0, 1) === '\\') {
                    $class = substr($class, 1);
                } else {
                    $class = $aliases->translate($class);
                }
                $this->filters[] = $class . '::' . $function;
            } else {
                if (substr($function, 0, 1) === '\\') {
                    $function = substr($function, 1);
                } else {
                    $function = $aliases->translate($function);
                }
                $this->filters[] = $function;
            }
        }
    }

    /**
     * Returns array of entity filters (array of callable strings)
     *
     * @return string[]
     */
    public function getFilters()
    {
        return $this->filters;
    }

}
tharos/leanmapper v1.3.0 API documentation API documentation generated by ApiGen