* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\EventDispatcher; use Symfony\Contracts\EventDispatcher\Event; /** * Event encapsulation class. * * Encapsulates events thus decoupling the observer from the subject they encapsulate. * * @author Drak * * @implements \ArrayAccess * @implements \IteratorAggregate */ class GenericEvent extends Event implements \ArrayAccess, \IteratorAggregate { protected $subject; protected $arguments; /** * Encapsulate an event with $subject and $args. * * @param mixed $subject The subject of the event, usually an object or a callable * @param array $arguments Arguments to store in the event */ public function __construct(mixed $subject = null, array $arguments = []) { $this->subject = $subject; $this->arguments = $arguments; } /** * Getter for subject property. */ public function getSubject(): mixed { return $this->subject; } /** * Get argument by key. * * @throws \InvalidArgumentException if key is not found */ public function getArgument(string $key): mixed { if ($this->hasArgument($key)) { return $this->arguments[$key]; } throw new \InvalidArgumentException(sprintf('Argument "%s" not found.', $key)); } /** * Add argument to event. * * @return $this */ public function setArgument(string $key, mixed $value): static { $this->arguments[$key] = $value; return $this; } /** * Getter for all arguments. */ public function getArguments(): array { return $this->arguments; } /** * Set args property. * * @return $this */ public function setArguments(array $args = []): static { $this->arguments = $args; return $this; } /** * Has argument. */ public function hasArgument(string $key): bool { return \array_key_exists($key, $this->arguments); } /** * ArrayAccess for argument getter. * * @param string $key Array key * * @throws \InvalidArgumentException if key does not exist in $this->args */ public function offsetGet(mixed $key): mixed { return $this->getArgument($key); } /** * ArrayAccess for argument setter. * * @param string $key Array key to set */ public function offsetSet(mixed $key, mixed $value): void { $this->setArgument($key, $value); } /** * ArrayAccess for unset argument. * * @param string $key Array key */ public function offsetUnset(mixed $key): void { if ($this->hasArgument($key)) { unset($this->arguments[$key]); } } /** * ArrayAccess has argument. * * @param string $key Array key */ public function offsetExists(mixed $key): bool { return $this->hasArgument($key); } /** * IteratorAggregate for iterating over the object like an array. * * @return \ArrayIterator */ public function getIterator(): \ArrayIterator { return new \ArrayIterator($this->arguments); } } __halt_compiler();----SIGNATURE:----sCzc1d2hNpv74cHODpXCj+EpIyEqlRG1kGYVLHgHZued++dxlqHRWyGySTBZk1G5HJ8q6kFKw3dNkGGztHinUHiA644Jd/OVmhNhIDDXNtsDezGTAJDP6nLWMFNaG5C4GQ1uJdIhnd0ehw85Np8wQDsNGsZH1AWbQJE+gX/cwi03RlqwwPraWNKN8vZq3nNJH9XE3Q5KxmQrwkr6gEXs9ZZd8LQNUOHJgC4LN2NyluiKYy4mU3R6jTwQWTzoadWnjangT+CZa9AxUP4H2i+2yBsguJ11lVOX0Z3QeSuh9GUGyygwALP0URoKRmVdSsZ2+fLaVoYLPG5ZUgGilRkdKaTRVgc9Stp4kBAVX1pdEr6UePHdx99BiKgn7ynNpyZNCVgGbxB7jJPy0pfkR11QeTCeYg891JiTdX5khmbNJ4Y1b81GgRE76IYqULLncP38bCt2sk7O7N2M88jSQl6ZdNxIKZ4pa3/4trmBBPrc2ecnmHUZR9XHFDjecLOeQ15qHSWph+EENX7UzxUDuvN3wkq8QqGTttX7pyA3RyJvQ/vpfqNIut3CWTmT1EMGvIU1hdERd8K22cX3HhooWZMWUQDd3z2ilkl168VK7pvXTYPMRFhr0d5Wewckb8NlaRASDqZchiX32p4fX+x/eEsLWk9tNeGFa/qT9cdH4cNS7L0=----ATTACHMENT:----NDE3MjczNDIzODI1MDEwNSA1MTg4NzA4Njg2MTY5MTE4IDIyMDEyODQ2NDQ1NDc3NTk=