diff -r 000000000000 -r 2b3e5ec03512 servlib/contacts/ScheduledLink.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/servlib/contacts/ScheduledLink.h Thu Apr 21 14:57:45 2011 +0100 @@ -0,0 +1,91 @@ +/* + * Copyright 2004-2006 Intel Corporation + * + * 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. + */ + +#ifndef _SCHEDULED_LINK_H_ +#define _SCHEDULED_LINK_H_ + +#include "Link.h" +#include + +namespace dtn { + +/** + * Abstraction for a SCHEDULED link. + * + * Scheduled links have a list of future contacts. + * +*/ + +class FutureContact; + +class ScheduledLink : public Link { +public: + typedef std::set FutureContactSet; + + /** + * Constructor / Destructor + */ + ScheduledLink(std::string name, ConvergenceLayer* cl, + const char* nexthop); + + virtual ~ScheduledLink(); + + /** + * Return the list of future contacts that exist on the link + */ + FutureContactSet* future_contacts() { return fcts_; } + + // Add a future contact + void add_fc(FutureContact* fc) ; + + // Remove a future contact + void delete_fc(FutureContact* fc) ; + + // Convert a future contact to an active contact + void convert_fc(FutureContact* fc) ; + + // Return list of all future contacts + FutureContactSet* future_contacts_list() { return fcts_; } + +protected: + FutureContactSet* fcts_; +}; + +/** + * Abstract base class for FutureContact + * Relevant only for scheduled links. + */ +class FutureContact { +public: + /** + * Constructor / Destructor + */ + FutureContact() + : start_(0), duration_(0) + { + } + + /// Time at which contact starts, 0 value means not defined + time_t start_; + + /// Duration for this future contact, 0 value means not defined + time_t duration_; +}; + + +} // namespace dtn + +#endif /* _SCHEDULED_LINK_H_ */