Laravel version update
Laravel version update
This commit is contained in:
		| @@ -11,8 +11,8 @@ The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", | ||||
| interpreted as described in [RFC 2119][]. | ||||
|  | ||||
| The word `implementor` in this document is to be interpreted as someone | ||||
| implementing the `ContainerInterface` in a depency injection-related library or framework. | ||||
| Users of dependency injections containers (DIC) are refered to as `user`. | ||||
| implementing the `ContainerInterface` in a dependency injection-related library or framework. | ||||
| Users of dependency injections containers (DIC) are referred to as `user`. | ||||
|  | ||||
| [RFC 2119]: http://tools.ietf.org/html/rfc2119 | ||||
|  | ||||
| @@ -31,50 +31,52 @@ Users of dependency injections containers (DIC) are refered to as `user`. | ||||
|   `user` SHOULD NOT rely on getting the same value on 2 successive calls. | ||||
|   While `ContainerInterface` only defines one mandatory parameter in `get()`, implementations | ||||
|   MAY accept additional optional parameters. | ||||
|    | ||||
|  | ||||
| - `has` takes one unique parameter: an entry identifier. It MUST return `true` | ||||
|   if an entry identifier is known to the container and `false` if it is not. | ||||
|    | ||||
|   `has($id)` returning true does not mean that `get($id)` will not throw an exception. | ||||
|   It does however mean that `get($id)` will not throw a `NotFoundException`. | ||||
|  | ||||
| ### 1.2 Exceptions | ||||
|  | ||||
| Exceptions directly thrown by the container MUST implement the  | ||||
| Exceptions directly thrown by the container MUST implement the | ||||
| [`Interop\Container\Exception\ContainerException`](../src/Interop/Container/Exception/ContainerException.php). | ||||
|  | ||||
| A call to the `get` method with a non-existing id should throw a | ||||
| A call to the `get` method with a non-existing id SHOULD throw a | ||||
| [`Interop\Container\Exception\NotFoundException`](../src/Interop/Container/Exception/NotFoundException.php). | ||||
|  | ||||
| ### 1.3 Additional features | ||||
|  | ||||
| This section describes additional features that MAY be added to a container. Containers are not  | ||||
| This section describes additional features that MAY be added to a container. Containers are not | ||||
| required to implement these features to respect the ContainerInterface. | ||||
|  | ||||
| #### 1.3.1 Delegate lookup feature | ||||
|  | ||||
| The goal of the *delegate lookup* feature is to allow several containers to share entries.  | ||||
| The goal of the *delegate lookup* feature is to allow several containers to share entries. | ||||
| Containers implementing this feature can perform dependency lookups in other containers. | ||||
|  | ||||
| Containers implementing this feature will offer a greater lever of interoperability  | ||||
| Containers implementing this feature will offer a greater lever of interoperability | ||||
| with other containers. Implementation of this feature is therefore RECOMMENDED. | ||||
|  | ||||
| A container implementing this feature: | ||||
|  | ||||
| - MUST implement the `ContainerInterface` | ||||
| - MUST provide a way to register a delegate container (using a constructor parameter, or a setter,  | ||||
| - MUST provide a way to register a delegate container (using a constructor parameter, or a setter, | ||||
|   or any possible way). The delegate container MUST implement the `ContainerInterface`. | ||||
|  | ||||
| When a container is configured to use a delegate container for dependencies: | ||||
|  | ||||
| - Calls to the `get` method should only return an entry if the entry is part of the container.  | ||||
|   If the entry is not part of the container, an exception should be thrown  | ||||
| - Calls to the `get` method should only return an entry if the entry is part of the container. | ||||
|   If the entry is not part of the container, an exception should be thrown | ||||
|   (as requested by the `ContainerInterface`). | ||||
| - Calls to the `has` method should only return `true` if the entry is part of the container. | ||||
|   If the entry is not part of the container, `false` should be returned. | ||||
| - If the fetched entry has dependencies, **instead** of performing  | ||||
| - If the fetched entry has dependencies, **instead** of performing | ||||
|   the dependency lookup in the container, the lookup is performed on the *delegate container*. | ||||
|  | ||||
| Important! By default, the lookup SHOULD be performed on the delegate container **only**, not on the container itself. | ||||
|  | ||||
| It is however allowed for containers to provide exception cases for special entries, and a way to lookup  | ||||
| It is however allowed for containers to provide exception cases for special entries, and a way to lookup | ||||
| into the same container (or another container) instead of the delegate container. | ||||
|  | ||||
| 2. Package | ||||
| @@ -114,6 +116,9 @@ interface ContainerInterface | ||||
|      * Returns true if the container can return an entry for the given identifier. | ||||
|      * Returns false otherwise. | ||||
|      * | ||||
|      * `has($id)` returning true does not mean that `get($id)` will not throw an exception. | ||||
|      * It does however mean that `get($id)` will not throw a `NotFoundException`. | ||||
|      * | ||||
|      * @param string $id Identifier of the entry to look for. | ||||
|      * | ||||
|      * @return boolean | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Manish Verma
					Manish Verma