source: src/Observer/Channels.cpp@ dd7c44

Last change on this file since dd7c44 was 1f96ec, checked in by Frederik Heber <heber@…>, 10 years ago

Channels has its own mutex now, too.

  • Property mode set to 100644
File size: 2.3 KB
RevLine 
[e2e035e]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010 University of Bonn. All rights reserved.
5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * Channels.cpp
10 *
11 * Created on: Dec 1, 2011
12 * Author: heber
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
[9b8fa4]20#include "CodePatterns/MemDebug.hpp"
[e2e035e]21
[1f96ec]22#include <boost/thread/locks.hpp>
23
[9b8fa4]24#include "CodePatterns/Assert.hpp"
[e2e035e]25
[9b8fa4]26#include "CodePatterns/Observer/Channels.hpp"
27#include "CodePatterns/Observer/Notification.hpp"
[e2e035e]28
29
30Channels::Channels()
31{}
32
33Channels::~Channels()
34{
[1f96ec]35 boost::recursive_mutex::scoped_lock guard(ChannelLock);
[e2e035e]36 // free all present Notifications
37 for(NotificationTypetoRefMap::iterator iter = ChannelMap.begin();
38 !ChannelMap.empty(); iter = ChannelMap.begin()) {
[1c291d]39 removeChannel(iter->first);
[e2e035e]40 }
41}
42
43void Channels::addChannel(size_t no)
44{
[1f96ec]45 boost::recursive_mutex::scoped_lock guard(ChannelLock);
[454bc54]46#ifndef NDEBUG
[e2e035e]47 NotificationTypetoRefMap::const_iterator iter = ChannelMap.find(no);
48 ASSERT(iter == ChannelMap.end(),
49 "Channels::addChannel() - channel "+toString(int(no))+" is already present in ChannelMap.");
[1c291d]50#endif
[e2e035e]51 ChannelMap.insert( std::make_pair(no, new Notification(no)) );
52}
53
54void Channels::removeChannel(size_t no)
55{
[1f96ec]56 boost::recursive_mutex::scoped_lock guard(ChannelLock);
[e2e035e]57 NotificationTypetoRefMap::iterator iter = ChannelMap.find(no);
58 ASSERT(iter != ChannelMap.end(),
59 "Channels::removeChannel() - channel "+toString(int(no))+" not present in ChannelMap.");
60 delete iter->second;
61 ChannelMap.erase(iter);
62}
63
[1c291d]64void Channels::subjectKilled(Observable * const publisher)
65{
[1f96ec]66 boost::recursive_mutex::scoped_lock guard(ChannelLock);
[1c291d]67 for(NotificationTypetoRefMap::iterator iter = ChannelMap.begin();
68 iter != ChannelMap.end();++iter) {
69 iter->second->subjectKilled(publisher);
70 }
71}
72
[e2e035e]73Notification_ptr Channels::getChannel(size_t no) const
74{
[1f96ec]75 boost::recursive_mutex::scoped_lock guard(ChannelLock);
[e2e035e]76 NotificationTypetoRefMap::const_iterator iter = ChannelMap.find(no);
77 ASSERT(iter != ChannelMap.end(),
78 "Channels::getChannel() - channel "+toString(int(no))+" not present in ChannelMap.");
79 return iter->second;
80}
81
82size_t Channels::getType(Notification_ptr channel) const
83{
[1f96ec]84 boost::recursive_mutex::scoped_lock guard(ChannelLock);
[e2e035e]85 return channel->getChannelNo();
86}
87
Note: See TracBrowser for help on using the repository browser.