All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jodd.petite.scope.Scope Maven / Gradle / Ivy

// Copyright (c) 2003-present, Jodd Team (http://jodd.org)
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.

package jodd.petite.scope;

import jodd.petite.BeanDefinition;

/**
 * Petite container bean scope. Scopes actually represents wrapper over none, one or many internal
 * bean pools. Which pool is used depends on scopes behaviour and external data.
 * 

* Scopes are instantiated once on their first usage and stored within one container. */ public interface Scope { /** * Lookups for bean name. Returns null if bean is not * found or yet registered. */ Object lookup(String name); /** * Registers the bean within the current scope. * Usually registers it by its name from {@link jodd.petite.BeanDefinition}. * Also it may register destroy methods of a bean within this scope. */ void register(BeanDefinition beanDefinition, Object bean); /** * Removes the bean from the scope entirely. Destroy methods are not * called as it is assumed that bean is destroyed manually. */ void remove(String name); /** * Returns true if a bean of referenced scope can be * injected into target bean of this scope. Otherwise, returns * false, which may be a sign for scoped proxy to be * injected. *

* In general, injection of 'shorter' reference scopes * into the 'longer' target scopes should not be accepted. * In other words, if reference scope is 'longer' or equal (same), * this method should return true. *

* Helpful is to ask the following question: "May the reference scope * bean be injected into bean of this scope?". */ boolean accept(Scope referenceScope); /** * Shutdowns the scope by removing all beans and calling * destroy methods. */ void shutdown(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy