The kernelemu's open_module_list() now also takes the built-in modules in to
account. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@23772 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
481c884164
commit
1245d1a3de
@ -110,11 +110,11 @@ public:
|
|||||||
status_t PutModule(const char *path);
|
status_t PutModule(const char *path);
|
||||||
|
|
||||||
status_t GetNextLoadedModuleName(uint32 *cookie, char *buffer,
|
status_t GetNextLoadedModuleName(uint32 *cookie, char *buffer,
|
||||||
size_t *bufferSize);
|
size_t *bufferSize);
|
||||||
|
|
||||||
module_name_list *OpenModuleList(const char *prefix);
|
module_name_list *OpenModuleList(const char *prefix);
|
||||||
status_t ReadNextModuleName(module_name_list *list, char *buffer,
|
status_t ReadNextModuleName(module_name_list *list, char *buffer,
|
||||||
size_t *bufferSize);
|
size_t *bufferSize);
|
||||||
status_t CloseModuleList(module_name_list *list);
|
status_t CloseModuleList(module_name_list *list);
|
||||||
|
|
||||||
status_t AddBuiltInModule(module_info *info);
|
status_t AddBuiltInModule(module_info *info);
|
||||||
@ -124,7 +124,8 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
void _FindModules(BDirectory &dir, const char *moduleDir,
|
void _FindModules(BDirectory &dir, const char *moduleDir,
|
||||||
module_name_list *list);
|
module_name_list *list);
|
||||||
|
void _FindBuiltInModules(const char *prefix, module_name_list *list);
|
||||||
|
|
||||||
status_t _GetAddOn(const char *path, ModuleAddOn **addon);
|
status_t _GetAddOn(const char *path, ModuleAddOn **addon);
|
||||||
void _PutAddOn(ModuleAddOn *addon);
|
void _PutAddOn(ModuleAddOn *addon);
|
||||||
@ -451,7 +452,7 @@ ModuleManager::PutModule(const char *path)
|
|||||||
// GetNextLoadedModuleName
|
// GetNextLoadedModuleName
|
||||||
status_t
|
status_t
|
||||||
ModuleManager::GetNextLoadedModuleName(uint32 *cookie, char *buffer,
|
ModuleManager::GetNextLoadedModuleName(uint32 *cookie, char *buffer,
|
||||||
size_t *bufferSize)
|
size_t *bufferSize)
|
||||||
{
|
{
|
||||||
status_t error = (cookie && buffer && bufferSize ? B_OK : B_BAD_VALUE);
|
status_t error = (cookie && buffer && bufferSize ? B_OK : B_BAD_VALUE);
|
||||||
if (error == B_OK) {
|
if (error == B_OK) {
|
||||||
@ -478,6 +479,8 @@ ModuleManager::OpenModuleList(const char *prefix)
|
|||||||
module_name_list *list = NULL;
|
module_name_list *list = NULL;
|
||||||
if (prefix) {
|
if (prefix) {
|
||||||
list = new module_name_list;
|
list = new module_name_list;
|
||||||
|
_FindBuiltInModules(prefix, list);
|
||||||
|
|
||||||
for (int32 i = 0; gModuleDirs[i]; i++) {
|
for (int32 i = 0; gModuleDirs[i]; i++) {
|
||||||
BPath path;
|
BPath path;
|
||||||
BDirectory dir;
|
BDirectory dir;
|
||||||
@ -486,6 +489,7 @@ ModuleManager::OpenModuleList(const char *prefix)
|
|||||||
_FindModules(dir, gModuleDirs[i], list);
|
_FindModules(dir, gModuleDirs[i], list);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
list->it = list->names.begin();
|
list->it = list->names.begin();
|
||||||
}
|
}
|
||||||
return list;
|
return list;
|
||||||
@ -494,7 +498,7 @@ ModuleManager::OpenModuleList(const char *prefix)
|
|||||||
// ReadNextModuleName
|
// ReadNextModuleName
|
||||||
status_t
|
status_t
|
||||||
ModuleManager::ReadNextModuleName(module_name_list *list, char *buffer,
|
ModuleManager::ReadNextModuleName(module_name_list *list, char *buffer,
|
||||||
size_t *bufferSize)
|
size_t *bufferSize)
|
||||||
{
|
{
|
||||||
status_t error = (list && buffer && bufferSize ? B_OK : B_BAD_VALUE);
|
status_t error = (list && buffer && bufferSize ? B_OK : B_BAD_VALUE);
|
||||||
if (error == B_OK) {
|
if (error == B_OK) {
|
||||||
@ -530,6 +534,7 @@ ModuleManager::AddBuiltInModule(module_info *info)
|
|||||||
{
|
{
|
||||||
BAutolock _lock(fModules);
|
BAutolock _lock(fModules);
|
||||||
|
|
||||||
|
TRACE(("add module %p, \"%s\"\n", info, info->name));
|
||||||
return fModules.AddModule(new Module(NULL, info)) ? B_OK : B_ERROR;
|
return fModules.AddModule(new Module(NULL, info)) ? B_OK : B_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -596,7 +601,21 @@ ModuleManager::_FindModules(BDirectory &dir, const char *moduleDir,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// _GetAddOn
|
|
||||||
|
void
|
||||||
|
ModuleManager::_FindBuiltInModules(const char *prefix, module_name_list *list)
|
||||||
|
{
|
||||||
|
uint32 count = fModules.CountModules();
|
||||||
|
uint32 prefixLength = strlen(prefix);
|
||||||
|
|
||||||
|
for (uint32 i = 0; i < count; i++) {
|
||||||
|
Module *module = fModules.ModuleAt(i);
|
||||||
|
if (!strncmp(module->Info()->name, prefix, prefixLength))
|
||||||
|
list->names.insert(module->Info()->name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
ModuleManager::_GetAddOn(const char *name, ModuleAddOn **_addon)
|
ModuleManager::_GetAddOn(const char *name, ModuleAddOn **_addon)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user