Deprecate ResourceInterface::getResource()
The return value of this method does not make sense if you do not exactly know about the type of resource at hand. For example, it may be [an array](b49fa129bd/src/Symfony/Component/HttpKernel/Config/EnvParametersResource.php (L57)
) or a [file path](87800ae47e/src/Symfony/Component/Config/Resource/FileResource.php (L51)
). As all usages of getResource() within Symfony are in tests of particular Resource implementations anyway, deprecating and later removing this interface helps us with simplifying the ResourceInterface (https://github.com/symfony/symfony/issues/7176).
This commit is contained in:
parent
dacbfe9699
commit
87c0c7d400
@ -23,6 +23,10 @@ After: the code will work as expected and it will restrict the values of the
|
||||
|
||||
* deprecated the `ResourceInterface::isFresh()` method. If you implement custom resource types and they
|
||||
can be validated that way, make them implement the new `SelfCheckingResourceInterface`.
|
||||
* deprecated the getResource() method in ResourceInterface. You can still call this method
|
||||
on concrete classes implementing the interface, but it does not make sense at the interface
|
||||
level as you need to know about the particular type of resource at hand to understand the
|
||||
semantics of the returned value.
|
||||
|
||||
2.7.0
|
||||
-----
|
||||
|
@ -47,6 +47,12 @@ interface ResourceInterface
|
||||
* Returns the tied resource.
|
||||
*
|
||||
* @return mixed The resource
|
||||
*
|
||||
* @deprecated since 2.8, to be removed in 3.0. As there are many different kinds of resource,
|
||||
* a single getResource() method does not make sense at the interface level. You
|
||||
* can still call getResource() on implementing classes, probably after performing
|
||||
* a type check. If you know the concrete type of Resource at hand, the return value
|
||||
* of this method may make sense to you.
|
||||
*/
|
||||
public function getResource();
|
||||
}
|
||||
|
Reference in New Issue
Block a user