// Custom includes
#include <iostream>
#include "Server.hh"
+#include "Node.hh"
+#include "ObjectDirectory.hh"
#include "../Scheduler/Scheduler.hh"
#include "../Utils/Logger/SenfLog.hh"
#define prefix_
///////////////////////////////cc.p////////////////////////////////////////
+namespace {
+
+ void fn(std::ostream & output,
+ senf::console::CommandNode::Arguments const & arguments) {
+ senf::console::CommandNode::Arguments::iterator i (arguments.begin());
+ senf::console::CommandNode::Arguments::iterator i_end (arguments.end());
+ for (; i != i_end; ++i) {
+ senf::console::CommandNode::Arguments::value_type::iterator j (i->begin());
+ senf::console::CommandNode::Arguments::value_type::iterator j_end (i->end());
+ for (; j != j_end; ++j)
+ output << j->value() << ' ';
+ }
+ output << "\n";
+ }
+
+ struct TestObject
+ {
+ senf::console::ObjectDirectory<TestObject> dir;
+
+ TestObject() : dir(this) {
+ dir.add("blub", &TestObject::blub)
+ .doc("Example of a member function");
+ }
+
+ void blub(std::ostream & output, senf::console::CommandNode::Arguments const & args) {
+ output << "blub\n";
+ }
+ };
+
+}
+
int main(int, char const **)
{
senf::log::ConsoleTarget::instance().route< senf::SenfLog, senf::log::NOTICE >();
+ senf::console::root().doc("This is the console test application");
+ senf::console::root().mkdir("network")
+ .doc("Network related settings");
+ senf::console::root()["network"].mkdir("eth0")
+ .doc("Ethernet device eth0");
+ senf::console::root().mkdir("server");
+ senf::console::root()["network"].add("route", &fn)
+ .doc("Example of a directly registered function");
+
+ TestObject test;
+ senf::console::root().add("testob", test.dir)
+ .doc("Example of an instance directory");
+
senf::console::Server::start( senf::INet4SocketAddress("127.0.0.1:23232") )
- .name("testServer ");
+ .name("testServer");
senf::Scheduler::instance().process();
}