Helper   A
last analyzed

Complexity

Total Complexity 6

Size/Duplication

Total Lines 60
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Importance

Changes 0
Metric Value
dl 0
loc 60
rs 10
c 0
b 0
f 0
wmc 6
lcom 0
cbo 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 6 1
A getInstance() 0 9 2
A getDirname() 0 4 1
A getHandler() 0 15 2
1
<?php
2
3
namespace XoopsModules\Smallworld;
4
5
/*
6
 * You may not change or alter any portion of this comment or credits
7
 * of supporting developers from this source code or any supporting source code
8
 * which is considered copyrighted (c) material of the original comment or credit authors.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13
 */
14
15
/**
16
 * @copyright    XOOPS Project https://xoops.org/
17
 * @license      GNU GPL 2 or later (http://www.gnu.org/licenses/gpl-2.0.html)
18
 * @package
19
 * @since
20
 * @author       XOOPS Development Team
21
 */
22
23
/**
24
 * Class Helper
25
 */
26
class Helper extends \Xmf\Module\Helper
27
{
28
    public $debug;
29
30
    /**
31
     * @param bool $debug
32
     */
33
    public function __construct($debug = false)
34
    {
35
        $this->debug   = $debug;
36
        $moduleDirName = basename(dirname(__DIR__));
37
        parent::__construct($moduleDirName);
38
    }
39
40
    /**
41
     * @param bool $debug
42
     *
43
     * @return \XoopsModules\Smallworld\Helper
44
     */
45
    public static function getInstance($debug = false)
46
    {
47
        static $instance;
48
        if (null === $instance) {
49
            $instance = new static($debug);
50
        }
51
52
        return $instance;
53
    }
54
55
    /**
56
     * @return string
57
     */
58
    public function getDirname()
59
    {
60
        return $this->dirname;
61
    }
62
63
    /**
64
     * Get an Object Handler
65
     *
66
     * @param string $name name of handler to load
67
     *
68
     * @return bool|\XoopsObjectHandler|\XoopsPersistableObjectHandler
0 ignored issues
show
Documentation introduced by
Should the return type not be object?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
69
     */
70
    public function getHandler($name)
71
    {
72
        $ret = false;
0 ignored issues
show
Unused Code introduced by
$ret is not used, you could remove the assignment.

This check looks for variable assignements that are either overwritten by other assignments or where the variable is not used subsequently.

$myVar = 'Value';
$higher = false;

if (rand(1, 6) > 3) {
    $higher = true;
} else {
    $higher = false;
}

Both the $myVar assignment in line 1 and the $higher assignment in line 2 are dead. The first because $myVar is never used and the second because $higher is always overwritten for every possible time line.

Loading history...
73
74
        $class = __NAMESPACE__ . '\\' . $name . 'Handler';
75
        if (!class_exists($class)) {
76
            throw new \RuntimeException("Class '$class' not found");
77
        }
78
        /** @var \XoopsMySQLDatabase $db */
79
        $db     = \XoopsDatabaseFactory::getDatabaseConnection();
80
        $helper = self::getInstance();
81
        $ret    = new $class($db, $helper);
82
        $this->addLog("Getting handler '{$name}'");
83
        return $ret;
84
    }
85
}
86
//require  dirname(dirname(__DIR__)) . '/mainfile.php';
87