![]() |
User Manual, Developers Guide and API Documentation |
![]() |
00001 /******************************************************************************* 00002 * This file is part of openWNS (open Wireless Network Simulator) 00003 * _____________________________________________________________________________ 00004 * 00005 * Copyright (C) 2004-2007 00006 * Chair of Communication Networks (ComNets) 00007 * Kopernikusstr. 5, D-52074 Aachen, Germany 00008 * phone: ++49-241-80-27910, 00009 * fax: ++49-241-80-22242 00010 * email: info@openwns.org 00011 * www: http://www.openwns.org 00012 * _____________________________________________________________________________ 00013 * 00014 * openWNS is free software; you can redistribute it and/or modify it under the 00015 * terms of the GNU Lesser General Public License version 2 as published by the 00016 * Free Software Foundation; 00017 * 00018 * openWNS is distributed in the hope that it will be useful, but WITHOUT ANY 00019 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR 00020 * A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more 00021 * details. 00022 * 00023 * You should have received a copy of the GNU Lesser General Public License 00024 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00025 * 00026 ******************************************************************************/ 00027 00028 #include <WNS/ldk/RoundRobinConnector.hpp> 00029 #include <WNS/ldk/FunctionalUnit.hpp> 00030 00031 using namespace wns::ldk; 00032 00033 bool 00034 RoundRobinConnector::hasAcceptor(const CompoundPtr& compound) 00035 { 00036 if(recs.size() == 1) { 00037 return recs.current()->isAccepting(compound); 00038 } 00039 00040 bool result = false; 00041 00042 recs.startRound(); 00043 while(recs.hasNext()) { 00044 IConnectorReceptacle* it = recs.next(); 00045 00046 if(it->isAccepting(compound)) { 00047 result = true; 00048 break; 00049 } 00050 } 00051 recs.cancelRound(); 00052 return result; 00053 } // hasAcceptor 00054 00055 00056 IConnectorReceptacle* 00057 RoundRobinConnector::getAcceptor(const CompoundPtr& compound) 00058 { 00059 assure(!recs.empty(), "Called getAcceptor even though no FU available"); 00060 00061 if(recs.size() == 1) { 00062 assure(recs.current()->isAccepting(compound), "Called getAcceptor although no FU is accepting"); 00063 return recs.current(); 00064 } 00065 00066 IConnectorReceptacle* candidate = NULL; 00067 00068 recs.startRound(); 00069 while(recs.hasNext()) { 00070 candidate = recs.next(); 00071 if(candidate->isAccepting(compound)) { 00072 break; 00073 } else { 00074 // not a candidate if not accpeting 00075 candidate = NULL; 00076 } 00077 } 00078 recs.endRound(); 00079 00080 assure(candidate, "getAcceptor call, but there is no valid candidate."); 00081 return candidate; 00082 } // getAcceptor 00083
1.5.5