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
|
<?php
declare(strict_types=1);
namespace Doctrine\ORM\Persisters\Collection;
use Doctrine\Common\Collections\Criteria;
use Doctrine\ORM\PersistentCollection;
/**
* Define the behavior that should be implemented by all collection persisters.
*/
interface CollectionPersister
{
/**
* Deletes the persistent state represented by the given collection.
*
* @return void
*/
public function delete(PersistentCollection $collection);
/**
* Updates the given collection, synchronizing its state with the database
* by inserting, updating and deleting individual elements.
*
* @return void
*/
public function update(PersistentCollection $collection);
/**
* Counts the size of this persistent collection.
*
* @return int
*/
public function count(PersistentCollection $collection);
/**
* Slices elements.
*
* @param int $offset
* @param int|null $length
*
* @return mixed[]
*/
public function slice(PersistentCollection $collection, $offset, $length = null);
/**
* Checks for existence of an element.
*
* @param object $element
*
* @return bool
*/
public function contains(PersistentCollection $collection, $element);
/**
* Checks for existence of a key.
*
* @param mixed $key
*
* @return bool
*/
public function containsKey(PersistentCollection $collection, $key);
/**
* Gets an element by key.
*
* @param mixed $index
*
* @return mixed
*/
public function get(PersistentCollection $collection, $index);
/**
* Loads association entities matching the given Criteria object.
*
* @return mixed[]
*/
public function loadCriteria(PersistentCollection $collection, Criteria $criteria);
}
|