Mercurial > hg > isophonics-drupal-site
annotate vendor/symfony/console/Command/LockableTrait.php @ 8:50b0d041100e
Further files for download
author | Chris Cannam |
---|---|
date | Mon, 05 Feb 2018 10:56:40 +0000 |
parents | 4c8ae668cc8c |
children | 1fec387a4317 |
rev | line source |
---|---|
Chris@0 | 1 <?php |
Chris@0 | 2 |
Chris@0 | 3 /* |
Chris@0 | 4 * This file is part of the Symfony package. |
Chris@0 | 5 * |
Chris@0 | 6 * (c) Fabien Potencier <fabien@symfony.com> |
Chris@0 | 7 * |
Chris@0 | 8 * For the full copyright and license information, please view the LICENSE |
Chris@0 | 9 * file that was distributed with this source code. |
Chris@0 | 10 */ |
Chris@0 | 11 |
Chris@0 | 12 namespace Symfony\Component\Console\Command; |
Chris@0 | 13 |
Chris@0 | 14 use Symfony\Component\Console\Exception\LogicException; |
Chris@0 | 15 use Symfony\Component\Console\Exception\RuntimeException; |
Chris@0 | 16 use Symfony\Component\Filesystem\LockHandler; |
Chris@0 | 17 |
Chris@0 | 18 /** |
Chris@0 | 19 * Basic lock feature for commands. |
Chris@0 | 20 * |
Chris@0 | 21 * @author Geoffrey Brier <geoffrey.brier@gmail.com> |
Chris@0 | 22 */ |
Chris@0 | 23 trait LockableTrait |
Chris@0 | 24 { |
Chris@0 | 25 private $lockHandler; |
Chris@0 | 26 |
Chris@0 | 27 /** |
Chris@0 | 28 * Locks a command. |
Chris@0 | 29 * |
Chris@0 | 30 * @return bool |
Chris@0 | 31 */ |
Chris@0 | 32 private function lock($name = null, $blocking = false) |
Chris@0 | 33 { |
Chris@0 | 34 if (!class_exists(LockHandler::class)) { |
Chris@0 | 35 throw new RuntimeException('To enable the locking feature you must install the symfony/filesystem component.'); |
Chris@0 | 36 } |
Chris@0 | 37 |
Chris@0 | 38 if (null !== $this->lockHandler) { |
Chris@0 | 39 throw new LogicException('A lock is already in place.'); |
Chris@0 | 40 } |
Chris@0 | 41 |
Chris@0 | 42 $this->lockHandler = new LockHandler($name ?: $this->getName()); |
Chris@0 | 43 |
Chris@0 | 44 if (!$this->lockHandler->lock($blocking)) { |
Chris@0 | 45 $this->lockHandler = null; |
Chris@0 | 46 |
Chris@0 | 47 return false; |
Chris@0 | 48 } |
Chris@0 | 49 |
Chris@0 | 50 return true; |
Chris@0 | 51 } |
Chris@0 | 52 |
Chris@0 | 53 /** |
Chris@0 | 54 * Releases the command lock if there is one. |
Chris@0 | 55 */ |
Chris@0 | 56 private function release() |
Chris@0 | 57 { |
Chris@0 | 58 if ($this->lockHandler) { |
Chris@0 | 59 $this->lockHandler->release(); |
Chris@0 | 60 $this->lockHandler = null; |
Chris@0 | 61 } |
Chris@0 | 62 } |
Chris@0 | 63 } |