// -*- c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t -*-
// Copyright (c) 2001-2007 International Computer Science Institute
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software")
// to deal in the Software without restriction, subject to the conditions
// listed in the XORP LICENSE file. These conditions include: you must
// preserve this copyright notice, and you cannot mention the copyright
// holders in advertising related to the Software without their permission.
// The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This
// notice is a summary of the XORP LICENSE file; the license in that file is
// legally binding.
#ident "$XORP: xorp/rtrmgr/generic_module_manager.cc,v 1.9 2007/02/16 22:47:22 pavlin Exp $"
#include "rtrmgr_module.h"
#include "libxorp/xorp.h"
#include "libxorp/xlog.h"
#include "libxorp/debug.h"
#include "libxorp/c_format.hh"
#include "libxorp/eventloop.hh"
#include "generic_module_manager.hh"
GenericModule::GenericModule(const string& name)
: _name(name),
_status(MODULE_NOT_STARTED)
{
}
GenericModule::~GenericModule()
{
}
void
GenericModule::new_status(ModuleStatus new_status)
{
_status = new_status;
}
string
GenericModule::str() const
{
string s;
s = c_format("Module %s\n", _name.c_str());
if (_status != MODULE_NOT_STARTED && _status != MODULE_FAILED)
s += c_format("Module is running\n");
else
s += "Module is not running\n";
return s;
}
//
// XXX: this file merely provides dummy definitions for the module manager
// for use in xorpsh, as xorpsh never actually starts any modules, but
// the template commands need to know about a module manager.
//
GenericModuleManager::GenericModuleManager(EventLoop& eventloop, bool verbose)
: _eventloop(eventloop),
_verbose(verbose)
{
}
GenericModuleManager::~GenericModuleManager()
{
while (! _modules.empty()) {
GenericModule* module = _modules.begin()->second;
delete module;
_modules.erase(_modules.begin());
}
}
bool
GenericModuleManager::store_new_module(GenericModule *module,
string& error_msg)
{
map<string, GenericModule *>::iterator iter;
iter = _modules.find(module->name());
if (iter == _modules.end()) {
_modules[module->name()] = module;
return true;
} else {
error_msg = c_format("Module %s already exists",
module->name().c_str());
XLOG_TRACE(_verbose, "%s", error_msg.c_str());
return false;
}
}
GenericModule*
GenericModuleManager::find_module(const string& module_name)
{
map<string, GenericModule *>::iterator iter;
iter = _modules.find(module_name);
if (iter == _modules.end()) {
debug_msg("GenericModuleManager: Failed to find module %s\n",
module_name.c_str());
return NULL;
} else {
debug_msg("GenericModuleManager: Found module %s\n",
module_name.c_str());
return iter->second;
}
}
const GenericModule*
GenericModuleManager::const_find_module(const string& module_name) const
{
map<string, GenericModule *>::const_iterator iter;
iter = _modules.find(module_name);
if (iter == _modules.end()) {
return NULL;
} else {
return iter->second;
}
}
bool
GenericModuleManager::module_exists(const string& module_name) const
{
return _modules.find(module_name) != _modules.end();
}
GenericModule::ModuleStatus
GenericModuleManager::module_status(const string& module_name) const
{
const GenericModule* module = const_find_module(module_name);
if (module != NULL) {
return module->status();
} else {
return GenericModule::NO_SUCH_MODULE;
}
}
syntax highlighted by Code2HTML, v. 0.9.1