AddonVendor::Authors()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 0
1
<?php
2
/**
3
 * An add-one vendor, derived from the vendor part of a package name,
4
 */
5
class AddonVendor extends DataObject
6
{
7
8
    public static $db = array(
9
        'Name' => 'Varchar(255)'
10
    );
11
12
    public static $has_many = array(
13
        'Addons' => 'Addon'
14
    );
15
16
    public function Authors()
17
    {
18
        return $this->Addons()->relation('Versions')->relation('Authors');
0 ignored issues
show
Documentation Bug introduced by
The method Addons does not exist on object<AddonVendor>? Since you implemented __call, maybe consider adding a @method annotation.

If you implement __call and you know which methods are available, you can improve IDE auto-completion and static analysis by adding a @method annotation to the class.

This is often the case, when __call is implemented by a parent class and only the child class knows which methods exist:

class ParentClass {
    private $data = array();

    public function __call($method, array $args) {
        if (0 === strpos($method, 'get')) {
            return $this->data[strtolower(substr($method, 3))];
        }

        throw new \LogicException(sprintf('Unsupported method: %s', $method));
    }
}

/**
 * If this class knows which fields exist, you can specify the methods here:
 *
 * @method string getName()
 */
class SomeClass extends ParentClass { }
Loading history...
19
    }
20
}
21