void echo(std::ostream & output, senf::console::ParseCommandInfo const & command)
{
- typedef senf::console::ParseCommandInfo::ArgumentsRange::iterator iterator;
- iterator i (command.arguments().begin());
- iterator i_end (command.arguments().end());
+ typedef senf::console::ParseCommandInfo::TokensRange::iterator iterator;
+ iterator i (command.tokens().begin());
+ iterator i_end (command.tokens().end());
for (; i != i_end; ++i) {
- iterator::value_type::iterator j (i->begin());
- iterator::value_type::iterator j_end (i->end());
- for (; j != j_end; ++j)
- output << j->value() << ' ';
+ output << i->value() << ' ';
}
output << "\n";
}
throw senf::console::Executor::ExitException();
}
+void enableLogging(std::ostream & os)
+{
+ senf::console::Client::get(os).route<senf::log::NOTICE>();
+}
+
int main(int, char **)
{
::signal(SIGPIPE, SIG_IGN);
- senf::log::ConsoleTarget::instance().route< senf::SenfLog, senf::log::NOTICE >();
+ senf::log::ConsoleTarget::instance().route< senf::log::VERBOSE >();
senf::console::root()
.doc("This is the console test application");
+
senf::console::root()
- .mkdir("test")
- .doc("Network related settings");
+ .mkdir("console")
+ .doc("Console settings");
+
+ senf::console::DirectoryNode & serverDir (
+ senf::console::root()
+ .mkdir("server")
+ .doc("server commands") );
+
+ senf::console::ScopedDirectory<> testDir;
senf::console::root()
- .mkdir("server");
- senf::console::root()["server"]
+ .add("test", testDir)
+ .doc("Test functions");
+
+ senf::console::root()["console"]
+ .add("showlog", &enableLogging)
+ .doc("Enable display of log messages on the current console");
+
+ serverDir
.add("shutdown", &shutdownServer)
.doc("Terminate server application");
- senf::console::root()["test"]
+
+ testDir
.add("echo", &echo)
.doc("Example of a function utilizing manual argument parsing");
TestObject test;
- senf::console::root()
- .add("testob", test.dir)
+ testDir
+ .add("extra", test.dir)
.doc("Example of an instance directory");
- senf::console::Server::start( senf::INet4SocketAddress(23232) )
+ senf::console::Server::start( senf::INet4SocketAddress(23232u) )
.name("testServer");
senf::Scheduler::instance().process();