]> git.llucax.com Git - z.facultad/75.74/practicos.git/blobdiff - practicas/pipi/src/routetable.cpp
No se crea más la cola porque la crea el mismo DevQue.
[z.facultad/75.74/practicos.git] / practicas / pipi / src / routetable.cpp
index 66ccd80c97199893c0bb4827248aed65df26701d..43e3377257d1da18324f7100d44c20d8647cb62b 100644 (file)
@@ -1,12 +1,22 @@
 #include "routetable.h"
+#include <string>
+#include <sstream>
+#ifdef DEBUG
+#include <iostream>
+#endif
 
 RouteTable::RouteTable(Dev& default_iface): default_iface(default_iface)
 {
 }
 
-void RouteTable::add(const IPAddr& net, const IPAddr& gw, unsigned metric, Dev& iface)
+void RouteTable::add(const IPAddr& net, const IPAddr& gw, unsigned mtu,
+        unsigned metric, Dev& iface)
 {
-    table[net] = Route(gw, metric, iface);
+    table[net] = Route(gw, metric, mtu, iface);
+#ifdef DEBUG
+    //std::cout << "Se agregó tabla para " << net << ": gw = " << gw
+    //    << ", metric = " << metric << "\n";
+#endif
 }
 
 void RouteTable::del(const IPAddr& net)
@@ -22,4 +32,21 @@ RouteTable::Route* RouteTable::get(const IPAddr& dst)
     return &table[dst];
 }
 
+void add_routes(RouteTable& rt, std::istream& is, Dev& dev)
+{
+    std::string line;
+    while (std::getline(is, line))
+    {
+        std::istringstream iss(line);
+        std::string net;
+        std::string gw;
+        unsigned mtu;
+        unsigned metric;
+        iss >> net >> gw >> mtu >> metric;
+        if (net == "0") net = "0.0.0.0";
+        if (gw == "0") gw = "0.0.0.0";
+        rt.add(net, gw, metric, mtu, dev);
+    }
+}
+
 // vim: set et sw=4 sts=4 :