Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/modules/notifications/Notification.h @ 7456

Last change on this file since 7456 was 7456, checked in by dafrick, 14 years ago

Reviewing documentation fo Questsystem, moving documentation fully into doxygen.
Added some files to modules they belong to.

  • Property svn:eol-style set to native
File size: 3.1 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Damian 'Mozork' Frick
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
30    @file Notification.h
31    @brief Definition of the Notification class.
32    @ingroup Notifications
33*/
34
35#ifndef _Notification_H__
36#define _Notification_H__
37
38#include "notifications/NotificationsPrereqs.h"
39
40#include <string>
41#include "core/BaseObject.h"
42#include "network/synchronisable/Synchronisable.h"
43
44namespace orxonox
45{
46
47    /**
48    @brief
49        A Notification is a short message used to inform the player about something that just happened. A Notification can be sent from any part of orxonox and is then displayed in the proper NotificationQueue (depending on which senders the specific NotificationQueue accepts).
50    @author
51        Damian 'Mozork' Frick
52    */
53    class _NotificationsExport Notification : public BaseObject, public Synchronisable
54    {
55        public:
56            Notification(BaseObject* creator);
57            Notification(BaseObject* creator, const std::string & message);
58            virtual ~Notification();
59
60            bool send(unsigned int clientId, const std::string & sender); //!< Sends the Notification to the Notificationmanager.
61            bool sendHelper(const std::string& sender);
62
63            /**
64            @brief Checks whether the Notification was sent.
65            @return Returns true if the Notification was sent already.
66            */
67            inline bool isSent(void) const
68                { return this->sent_; }
69            /**
70            @brief Returns the message of the Notification.
71            @return Returns the message of the Notification.
72            */
73            inline const std::string & getMessage(void) const
74                { return this->message_; }
75
76            inline const std::string & getSender(void) const
77                { return this->sender_; }
78
79            bool setMessage(const std::string & message); //!< Sets the message of the notification.
80
81        private:
82            std::string message_; //!< The Notification message.
83            std::string sender_; //!< The sender of the notification.
84            bool sent_; //!< Whether Notification has been sent, if so it cannot be changed.
85
86            void initialize(void);
87            void registerVariables(void);
88
89    };
90
91}
92
93#endif /* _Notification_H__ */
Note: See TracBrowser for help on using the repository browser.