Fixed off-by-one error that prevented finding nodes using wildcard names, like DVB*
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@17467 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
5fbc62e3eb
commit
4cf01e2ecc
@ -474,18 +474,17 @@ NodeManager::GetLiveNodes(Stack<live_node_info> *livenodes, int32 maxcount, cons
|
|||||||
// determine the count of byte to compare when checking for a name with(out) wildcard
|
// determine the count of byte to compare when checking for a name with(out) wildcard
|
||||||
if (name) {
|
if (name) {
|
||||||
namelen = strlen(name);
|
namelen = strlen(name);
|
||||||
if (name[namelen] == '*')
|
if (namelen > 0 && name[namelen - 1] == '*')
|
||||||
namelen--; // compares without the '*'
|
namelen--; // compares without the '*'
|
||||||
else
|
} else {
|
||||||
namelen++; // also compares the terminating NULL
|
|
||||||
} else
|
|
||||||
namelen = 0;
|
namelen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
for (fRegisteredNodeMap->Rewind(); (maxcount > 0) && fRegisteredNodeMap->GetNext(&rn); ) {
|
for (fRegisteredNodeMap->Rewind(); (maxcount > 0) && fRegisteredNodeMap->GetNext(&rn); ) {
|
||||||
if ((rn->kinds & require_kinds) != require_kinds)
|
if ((rn->kinds & require_kinds) != require_kinds)
|
||||||
continue;
|
continue;
|
||||||
if (namelen) {
|
if (namelen) {
|
||||||
if (0 != memcmp(name, rn->name, namelen))
|
if (0 != strncmp(name, rn->name, namelen))
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (inputformat) {
|
if (inputformat) {
|
||||||
@ -746,12 +745,11 @@ NodeManager::GetDormantNodes(dormant_node_info * out_info,
|
|||||||
// determine the count of byte to compare when checking for a name with(out) wildcard
|
// determine the count of byte to compare when checking for a name with(out) wildcard
|
||||||
if (name) {
|
if (name) {
|
||||||
namelen = strlen(name);
|
namelen = strlen(name);
|
||||||
if (name[namelen] == '*')
|
if (namelen > 0 && name[namelen - 1] == '*')
|
||||||
namelen--; // compares without the '*'
|
namelen--; // compares without the '*'
|
||||||
else
|
} else {
|
||||||
namelen++; // also compares the terminating NULL
|
|
||||||
} else
|
|
||||||
namelen = 0;
|
namelen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
maxcount = *io_count;
|
maxcount = *io_count;
|
||||||
*io_count = 0;
|
*io_count = 0;
|
||||||
@ -767,7 +765,7 @@ NodeManager::GetDormantNodes(dormant_node_info * out_info,
|
|||||||
if ((dfi->kinds & deny_kinds) != 0)
|
if ((dfi->kinds & deny_kinds) != 0)
|
||||||
continue;
|
continue;
|
||||||
if (namelen) {
|
if (namelen) {
|
||||||
if (0 != memcmp(name, dfi->name, namelen))
|
if (0 != strncmp(name, dfi->name, namelen))
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (has_input) {
|
if (has_input) {
|
||||||
|
Loading…
Reference in New Issue
Block a user