A Discrete-Event Network Simulator
API
config-store.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2009 INRIA
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Mathieu Lacage <mathieu.lacage@cutebugs.net>
19  */
20 
21 #ifndef CONFIG_STORE_H
22 #define CONFIG_STORE_H
23 
24 #include "ns3/object-base.h"
25 #include "file-config.h"
26 
27 namespace ns3 {
28 
59 class ConfigStore : public ObjectBase
60 {
61 public:
66  enum Mode {
70  };
75  enum FileFormat {
77  XML,
79  };
80 
85  static TypeId GetTypeId (void);
86  virtual TypeId GetInstanceTypeId (void) const;
87 
88  ConfigStore ();
89  ~ConfigStore ();
90 
95  void SetMode (enum Mode mode);
100  void SetFileFormat (enum FileFormat format);
105  void SetFilename (std::string filename);
106 
110  void ConfigureDefaults (void);
114  void ConfigureAttributes (void);
115 
116 private:
117  enum Mode m_mode;
119  std::string m_filename;
121 };
122 
127 std::ostream & operator << (std::ostream & os, ConfigStore::Mode & mode);
128 std::ostream & operator << (std::ostream & os, ConfigStore::FileFormat & format);
131 } // namespace ns3
132 
133 #endif /* CONFIG_STORE_H */
FileConfig * m_file
configuration file
Definition: config-store.h:120
Introspection did not find any typical Config paths.
Definition: config-store.h:59
void SetFilename(std::string filename)
Set the filename.
static TypeId GetTypeId(void)
Get the type ID.
Definition: config-store.cc:48
Mode
for ConfigStore operation
Definition: config-store.h:66
Anchor the ns-3 type and attribute system.
Definition: object-base.h:119
base class for ConfigStore classes using files
Definition: file-config.h:33
enum Mode m_mode
store mode
Definition: config-store.h:117
void ConfigureDefaults(void)
Configure the default values.
std::ostream & operator<<(std::ostream &os, const Angles &a)
print a struct Angles to output
Definition: angles.cc:42
void SetFileFormat(enum FileFormat format)
Set the file format.
void SetMode(enum Mode mode)
Set the mode of operation.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
FileFormat
store format
Definition: config-store.h:76
enum FileFormat m_fileFormat
store format
Definition: config-store.h:118
void ConfigureAttributes(void)
Configure the attribute values.
virtual TypeId GetInstanceTypeId(void) const
Get the most derived TypeId for this Object.
Definition: config-store.cc:75
std::string m_filename
store file name
Definition: config-store.h:119
a unique identifier for an interface.
Definition: type-id.h:58