001/**
002 *
003 * Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
004 *
005 * This library is free software; you can redistribute it and/or
006 * modify it under the terms of the GNU Lesser General Public
007 * License as published by the Free Software Foundation; either 
008 * version 2.1 of the License, or (at your option) any later version.
009 * 
010 * This library is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
013 * Lesser General Public License for more details.
014 * 
015 * You should have received a copy of the GNU Lesser General Public 
016 * License along with this library.  If not, see <http://www.gnu.org/licenses/>.
017 * 
018 **/
019package lucee.runtime.type.scope;
020
021import lucee.runtime.config.ConfigServer;
022import lucee.runtime.exp.PageException;
023
024public interface ClusterRemote {
025        
026        /**
027         * broadcast data on stack and clear stack
028         */
029        public void broadcastEntries();
030        
031        /**
032         * set entry on stack
033         * @param entry
034         */
035        public void addEntry(ClusterEntry entry);
036        
037        
038        /**
039         * check if the value can distributed over the "cluster"
040         * @param value
041         * @throws PageException 
042         */
043        public boolean checkValue(Object value);
044
045        /**
046         * duplicate this object
047         * @return duplicated object
048         */
049        public ClusterRemote duplicate();
050        
051        /**
052         * @param configServer
053         * @param cluster
054         */
055        public void init(ConfigServer configServer,Cluster cluster);
056        
057}