/** * GRANITE DATA SERVICES * Copyright (C) 2006-2015 GRANITE DATA SERVICES S.A.S. * * This file is part of the Granite Data Services Platform. * * Granite Data Services is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * Granite Data Services 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 Lesser * General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, * USA, or see <http://www.gnu.org/licenses/>. */ //======================================================================== //$Id: WaitingContinuation.java,v 1.1 2005/11/14 17:45:56 gregwilkins Exp $ //Copyright 2004-2005 Mort Bay Consulting Pty. Ltd. //------------------------------------------------------------------------ //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. //======================================================================== package org.granite.gravity.generic; import org.granite.logging.Logger; /* Extract from Jetty 6.1 to support other servlet containers */ public class WaitingContinuation { private static final Logger log = Logger.getLogger(WaitingContinuation.class); Object _mutex; Object _object; boolean _new=true; boolean _resumed=false; boolean _pending=false; boolean _expired=false; public WaitingContinuation() { _mutex=this; } public WaitingContinuation(Object mutex) { _mutex=mutex==null?this:mutex; } public void resume() { synchronized (_mutex) { _resumed=true; _mutex.notify(); } } public void reset() { synchronized (_mutex) { _resumed=false; _pending=false; _expired=false; _mutex.notify(); } } public boolean isNew() { return _new; } public boolean suspend(long timeout) { synchronized (_mutex) { _new=false; _pending=true; boolean result; try { log.debug("Continuation suspend " + timeout); if (!_resumed && timeout>=0) { if (timeout==0) _mutex.wait(); else if (timeout>0) _mutex.wait(timeout); } } catch (InterruptedException e) { _expired=true; log.debug("Continuation timeout"); } finally { result=_resumed; _resumed=false; _pending=false; } return result; } } public boolean isPending() { synchronized (_mutex) { return _pending; } } public boolean isResumed() { synchronized (_mutex) { return _resumed; } } public boolean isExpired() { synchronized (_mutex) { return _expired; } } public Object getObject() { return _object; } public void setObject(Object object) { _object = object; } public Object getMutex() { return _mutex; } public void setMutex(Object mutex) { if (!_new && _mutex!=this && _pending) throw new IllegalStateException(); _mutex = mutex==null ? this : mutex; } @Override public String toString() { synchronized (this) { return "WaitingContinuation@"+hashCode()+ (_new?",new":"")+ (_pending?",pending":"")+ (_resumed?",resumed":"")+ (_expired?",expired":""); } } }