servlib/contacts/InterfaceTable.h
changeset 0 2b3e5ec03512
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/servlib/contacts/InterfaceTable.h	Thu Apr 21 14:57:45 2011 +0100
@@ -0,0 +1,108 @@
+/*
+ *    Copyright 2004-2006 Intel Corporation
+ * 
+ *    Licensed under the Apache License, Version 2.0 (the "License");
+ *    you may not use this file except in compliance with the License.
+ *    You may obtain a copy of the License at
+ * 
+ *        http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ *    Unless required by applicable law or agreed to in writing, software
+ *    distributed under the License is distributed on an "AS IS" BASIS,
+ *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ *    See the License for the specific language governing permissions and
+ *    limitations under the License.
+ */
+
+#ifndef _INTERFACE_TABLE_H_
+#define _INTERFACE_TABLE_H_
+
+#include <string>
+#include <list>
+#include <oasys/debug/DebugUtils.h>
+#include <oasys/util/StringBuffer.h>
+
+namespace dtn {
+
+class ConvergenceLayer;
+class Interface;
+
+/**
+ * The list of interfaces.
+ */
+typedef std::list<Interface*> InterfaceList;
+
+/**
+ * Class for the in-memory interface table.
+ */
+class InterfaceTable : public oasys::Logger {
+public:
+    /**
+     * Singleton instance accessor.
+     */
+    static InterfaceTable* instance() {
+        if (instance_ == NULL) {
+            PANIC("InterfaceTable::init not called yet");
+        }
+        return instance_;
+    }
+
+    /**
+     * Boot time initializer that takes as a parameter the actual
+     * storage instance to use.
+     */
+    static void init() {
+        if (instance_ != NULL) {
+            PANIC("InterfaceTable::init called multiple times");
+        }
+        instance_ = new InterfaceTable();
+    }
+
+    /**
+     * Constructor
+     */
+    InterfaceTable();
+
+    /**
+     * Destructor
+     */
+    virtual ~InterfaceTable();
+
+    /**
+     * Add a new interface to the table. Returns true if the interface
+     * is successfully added, false if the interface specification is
+     * invalid (or it already exists).
+     */
+    bool add(const std::string& name, ConvergenceLayer* cl, const char* proto,
+             int argc, const char* argv[]);
+    
+    /**
+     * Remove the specified interface.
+     */
+    bool del(const std::string& name);
+    
+    /**
+     * List the current interfaces.
+     */
+    void list(oasys::StringBuffer *buf);
+
+protected:
+    static InterfaceTable* instance_;
+
+    /**
+     * All interfaces are tabled in-memory in a flat list. It's
+     * non-obvious what else would be better since we need to do a
+     * prefix match on demux strings in matching_interfaces.
+     */
+    InterfaceList iflist_;
+
+    /**
+     * Internal method to find the location of the given interface in
+     * the list.
+     */
+    bool find(const std::string& name, InterfaceList::iterator* iter);
+};
+
+} // namespace dtn
+
+#endif /* _INTERFACE_TABLE_H_ */