Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

PHPStorm: correct PHPDoc for a Collection of Objects?

I'm using the PHPStorm IDE, and run into trouble when I run the code inspection.

I have a method which returns a collection of objects. The Collection itself is an object, which has its own methods, and implements the Traversable interface:

class Repository {     public function findByCustomer(Customer $user)     {         // ...         return new Collection($orders);     } } 

If I document findByUser() to return a Collection, the code inspection understands the methods on this object, but doesn't understand what objects the collection contains:

/**  * @return Collection  */ public function findByCustomer() { ... } 

Method getTotal() not found in class Collection

If I document findByUser() to return a collection of Order objects, the code inspection now understands what's inside the collection, but not the methods on the Collection itself:

/**  * @return Order[]  */ public function findByCustomer() { ... } 

Method slice() not found in class Order[]

Is there a way to specify both at the same time, something like Java's syntax?

/**  * @return Collection<Order>  */ public function findByCustomer() { ... } 
like image 308
BenMorel Avatar asked May 22 '12 17:05

BenMorel


1 Answers

You can combine them (both types) together. May not be ideal in some situations, but works and you may consider it better than manually specifying type via @var PHPDoc comment.

/** @return Collection|Order[] */ 
like image 118
LazyOne Avatar answered Sep 20 '22 23:09

LazyOne