object: fix module name testing

This commit is contained in:
Grissiom 2014-12-16 12:05:53 +08:00
parent 9a1126e4a4
commit c045281ee2

View File

@ -417,7 +417,7 @@ rt_object_t rt_object_find(const char *name, rt_uint8_t type)
{
const char *name_ptr;
int module_name_length;
name_ptr = name;
while ((*name_ptr != '\0') && (*name_ptr != '/'))
name_ptr ++;
@ -434,13 +434,13 @@ rt_object_t rt_object_find(const char *name, rt_uint8_t type)
/* find module */
information = &rt_object_container[RT_Object_Class_Module];
for (node = information->object_list.next;
for (node = information->object_list.next;
node != &(information->object_list);
node = node->next)
{
object = rt_list_entry(node, struct rt_object, list);
if ((rt_strncmp(object->name, name, module_name_length) == 0) &&
module_name_length == RT_NAME_MAX || object->name[module_name_length] == '\0')
(module_name_length == RT_NAME_MAX || object->name[module_name_length] == '\0'))
{
/* get module */
module = (struct rt_module*)object;
@ -450,7 +450,7 @@ rt_object_t rt_object_find(const char *name, rt_uint8_t type)
rt_exit_critical();
/* there is no this module inside the system */
if (module == RT_NULL) return RT_NULL;
if (module == RT_NULL) return RT_NULL;
/* get the object pool of module */
information = &(module->module_object[type]);