source: ThirdParty/CodePatterns/src/Observer/Channels.cpp@ 9b32071

Adding_StructOpt_integration_tests AutomationFragmentation_failures Candidate_v1.6.1 Candidate_v1.7.0 ChemicalSpaceEvaluator Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Exclude_Hydrogens_annealWithBondGraph ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_contraction-expansion Gui_displays_atomic_force_velocity JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool PythonUI_with_named_parameters StoppableMakroAction TremoloParser_IncreasedPrecision stable
Last change on this file since 9b32071 was 9eb71b3, checked in by Frederik Heber <frederik.heber@…>, 8 years ago

Commented out MemDebug include and Memory::ignore.

  • MemDebug clashes with various allocation operators that use a specific placement in memory. It is so far not possible to wrap new/delete fully. Hence, we stop this effort which so far has forced us to put ever more includes (with clashes) into MemDebug and thereby bloat compilation time.
  • MemDebug does not add that much usefulness which is not also provided by valgrind.
  • Property mode set to 100644
File size: 2.3 KB
Line 
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
20//#include "CodePatterns/MemDebug.hpp"
21
22#include <boost/thread/locks.hpp>
23
24#include "CodePatterns/Assert.hpp"
25
26#include "CodePatterns/Observer/Channels.hpp"
27#include "CodePatterns/Observer/Notification.hpp"
28
29
30Channels::Channels()
31{}
32
33Channels::~Channels()
34{
35 boost::recursive_mutex::scoped_lock guard(ChannelLock);
36 // free all present Notifications
37 for(NotificationTypetoRefMap::iterator iter = ChannelMap.begin();
38 !ChannelMap.empty(); iter = ChannelMap.begin()) {
39 removeChannel(iter->first);
40 }
41}
42
43void Channels::addChannel(size_t no)
44{
45 boost::recursive_mutex::scoped_lock guard(ChannelLock);
46#ifndef NDEBUG
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.");
50#endif
51 ChannelMap.insert( std::make_pair(no, new Notification(no)) );
52}
53
54void Channels::removeChannel(size_t no)
55{
56 boost::recursive_mutex::scoped_lock guard(ChannelLock);
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
64void Channels::subjectKilled(Observable * const publisher)
65{
66 boost::recursive_mutex::scoped_lock guard(ChannelLock);
67 for(NotificationTypetoRefMap::iterator iter = ChannelMap.begin();
68 iter != ChannelMap.end();++iter) {
69 iter->second->subjectKilled(publisher);
70 }
71}
72
73Notification_ptr Channels::getChannel(size_t no) const
74{
75 boost::recursive_mutex::scoped_lock guard(ChannelLock);
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{
84 boost::recursive_mutex::scoped_lock guard(ChannelLock);
85 return channel->getChannelNo();
86}
87
Note: See TracBrowser for help on using the repository browser.