/** * Copyright 2010 CosmoCode GmbH * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** s * palava - a java-php-bridge * Copyright (C) 2007-2010 CosmoCode GmbH * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package de.cosmocode.palava.ipc; import com.google.inject.Provider; import com.google.inject.Scope; /** * A Custom {@link Scope} for one single {@linkplain IpcCall call}. * * @author Willi Schoenborn * @author Tobias Sarnowski */ public interface IpcCallScope extends Scope, Provider<IpcCall> { /** * Enters this scope. * * @param call the incoming call * @throws NullPointerException if call is null * @throws IllegalStateException if there is already a call scope block in progress */ void enter(IpcCall call); /** * Checks the current state. * * @return true if this scope is currently in progress, false otherwise */ boolean isActive(); /** * Exists this scope. This method just returns * if there is currently no scoping block in progress. * The current ipc call will be cleared after this method returns, * in clear words: {@link IpcCall#clear()} will be called. */ void exit(); }