source: src/Atom/AtomObserver.cpp@ 97dff0

Last change on this file since 97dff0 was cd9a59, checked in by Frederik Heber <heber@…>, 12 years ago

Added TrajectoryChanged channel to atom_observable.

  • 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) 2012 University of Bonn. All rights reserved.
5 * Copyright (C) 2013 Frederik Heber. All rights reserved.
6 *
7 *
8 * This file is part of MoleCuilder.
9 *
10 * MoleCuilder is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * MoleCuilder is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
22 */
23
24/*
25 * AtomObserver.cpp
26 *
27 * Created on: Nov 30, 2011
28 * Author: heber
29 */
30
31// include config.h
32#ifdef HAVE_CONFIG_H
33#include <config.h>
34#endif
35
36#include "CodePatterns/MemDebug.hpp"
37
38#include "AtomObserver.hpp"
39
40#include "CodePatterns/Singleton_impl.hpp"
41
42#include "Atom/atom.hpp"
43#include "Atom/atom_observable.hpp"
44
45
46/** Private constructor of class AtomObserver.
47 *
48 */
49AtomObserver::AtomObserver() :
50 Relay(std::string("AtomObserver"))
51{
52 Channels *OurChannel = new Channels();
53 NotificationChannels.insert( std::make_pair(static_cast<Observable *>(this), OurChannel) );
54 OurChannel->addChannel(AtomObservable::PositionChanged);
55 OurChannel->addChannel(AtomObservable::ElementChanged);
56 OurChannel->addChannel(AtomObservable::TrajectoryChanged);
57}
58
59/** Private Destructor of class AtomObserver.
60 *
61 */
62AtomObserver::~AtomObserver()
63{}
64
65/** Function to call when a new atom has been created.
66 *
67 * @param res
68 */
69void AtomObserver::AtomInserted(atom *res)
70{
71 res->signOn(this, AtomObservable::PositionChanged);
72 res->signOn(this, AtomObservable::ElementChanged);
73 res->signOn(this, AtomObservable::TrajectoryChanged);
74}
75
76/** Function to call when an atom is about to get deleted.
77 *
78 * @param res
79 */
80void AtomObserver::AtomRemoved(atom *res)
81{
82 res->signOff(this, AtomObservable::PositionChanged);
83 res->signOff(this, AtomObservable::ElementChanged);
84 res->signOff(this, AtomObservable::TrajectoryChanged);
85}
86
87CONSTRUCT_SINGLETON(AtomObserver)
Note: See TracBrowser for help on using the repository browser.