* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Predis\Pipeline; use Predis\ServerException; use Predis\CommunicationException; use Predis\Network\IConnection; /** * Implements a pipeline executor strategy that does not fail when an error is * encountered, but adds the returned error in the replies array. * * @author Daniele Alessandri */ class SafeExecutor implements IPipelineExecutor { /** * {@inheritdoc} */ public function execute(IConnection $connection, &$commands) { $sizeofPipe = count($commands); $values = array(); foreach ($commands as $command) { try { $connection->writeCommand($command); } catch (CommunicationException $exception) { return array_fill(0, $sizeofPipe, $exception); } } for ($i = 0; $i < $sizeofPipe; $i++) { $command = $commands[$i]; unset($commands[$i]); try { $response = $connection->readResponse($command); $values[] = $response instanceof \Iterator ? iterator_to_array($response) : $response; } catch (ServerException $exception) { $values[] = $exception->toResponseError(); } catch (CommunicationException $exception) { $toAdd = count($commands) - count($values); $values = array_merge($values, array_fill(0, $toAdd, $exception)); break; } } return $values; } }