for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
/**
* This file is part of ninja-mutex.
*
* (C) Kamil Dziedzic <[email protected]>
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace NinjaMutex\Lock;
* Lock implementor using mkdir
* @author Jan Voracek <[email protected]>
class DirectoryLock extends LockAbstract
{
protected $dirname;
* @param string $dirname
public function __construct($dirname)
parent::__construct();
$this->dirname = $dirname;
}
* @param string $name
* @param bool $blocking
* @return bool
protected function getLock($name, $blocking)
return @mkdir($this->getDirectoryPath($name));
* Release lock
* @param string $name name of lock
public function releaseLock($name)
if (isset($this->locks[$name])) {
rmdir($this->getDirectoryPath($name));
unset($this->locks[$name]);
return true;
return false;
* @return string
protected function getDirectoryPath($name)
return $this->dirname . DIRECTORY_SEPARATOR . $name . '.lock';
* Check if lock is locked
public function isLocked($name)
if ($this->acquireLock($name, false)) {
false
boolean
null|integer
It seems like the type of the argument is not accepted by the function/method which you are calling.
In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.
We suggest to add an explicit type cast like in the following example:
function acceptsInteger($int) { } $x = '123'; // string "123" // Instead of acceptsInteger($x); // we recommend to use acceptsInteger((integer) $x);
return !$this->releaseLock($name);
It seems like the type of the argument is not accepted by the function/method which you are calling.
In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.
We suggest to add an explicit type cast like in the following example: