Overview

Namespaces

  • LeanMapper
    • Bridges
      • Nette
        • DI
    • Exception
    • Reflection
    • Relationship

Classes

  • LeanMapper\Bridges\Nette\DI\LeanMapperExtension
  • LeanMapper\Caller
  • LeanMapper\Connection
  • LeanMapper\DataDifference
  • LeanMapper\DefaultEntityFactory
  • LeanMapper\DefaultMapper
  • LeanMapper\Entity
  • LeanMapper\EntityDataDecoder
  • LeanMapper\Events
  • LeanMapper\Filtering
  • LeanMapper\FilteringResult
  • LeanMapper\FilteringResultDecorator
  • LeanMapper\Fluent
  • LeanMapper\ImplicitFilters
  • 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\PropertyMethods
  • LeanMapper\Reflection\PropertyPasses
  • LeanMapper\Reflection\PropertyType
  • LeanMapper\Reflection\PropertyValuesEnum
  • LeanMapper\Relationship\BelongsTo
  • LeanMapper\Relationship\BelongsToMany
  • LeanMapper\Relationship\BelongsToOne
  • LeanMapper\Relationship\HasMany
  • LeanMapper\Relationship\HasOne
  • LeanMapper\Repository
  • LeanMapper\Result
  • LeanMapper\ResultProxy
  • LeanMapper\Row

Interfaces

  • LeanMapper\IEntityFactory
  • LeanMapper\IMapper

Exceptions

  • LeanMapper\Exception\Exception
  • LeanMapper\Exception\InvalidAnnotationException
  • LeanMapper\Exception\InvalidArgumentException
  • LeanMapper\Exception\InvalidMethodCallException
  • LeanMapper\Exception\InvalidStateException
  • LeanMapper\Exception\InvalidValueException
  • LeanMapper\Exception\MemberAccessException
  • 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: 73: 74: 75: 76: 77: 78: 79: 80: 81: 82: 83: 84: 85: 86: 87: 88: 89: 90: 91: 92: 93: 94: 95: 96: 97: 
<?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.md that was distributed with this source code.
 */

namespace LeanMapper\Reflection;

use LeanMapper\Exception\InvalidAnnotationException;

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

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

    /** @var array */
    private $targetedArgs = [];



    /**
     * @param string $definition
     * @throws InvalidAnnotationException
     */
    public function __construct($definition)
    {
        foreach (preg_split('#\s*\|\s*#', trim($definition)) as $set) {
            if ($set === '') {
                $this->filters[] = $this->targetedArgs[] = [];
                continue;
            }
            $filters = $targetedArgs = [];
            foreach (preg_split('#\s*,\s*#', $set) as $filter) {
                $matches = [];
                preg_match('~^([a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*)(?:#(.*))?$~', $filter, $matches);
                if (empty($matches)) {
                    throw new InvalidAnnotationException("Malformed filter name given: '$filter'.");
                }
                $filterName = $matches[1];
                if (isset($filters[$filterName])) {
                    unset($filters[$filterName], $targetedArgs[$filterName]);
                }
                $filters[$filterName] = $filterName;
                if (isset($matches[2])) {
                    $targetedArgs[$filterName] = [$matches[2]];
                }
            }
            $this->filters[] = $filters;
            $this->targetedArgs[] = $targetedArgs;
        }
    }



    /**
     * Gets array of entity's filters (array of filter names)
     *
     * @param int $index
     * @return array
     */
    public function getFilters($index = 0)
    {
        if (!isset($this->filters[$index])) {
            return [];
        }
        return $this->filters[$index];
    }



    /**
     * Gets filters arguments hard-coded in annotation
     *
     * @param int $index
     * @return array
     */
    public function getFiltersTargetedArgs($index = 0)
    {
        if (!isset($this->targetedArgs[$index])) {
            return [];
        }
        return $this->targetedArgs[$index];
    }

}
tharos/leanmapper v3.1.1 API documentation API documentation generated by ApiGen