1
0
mirror of https://github.com/Ylianst/MeshAgent synced 2025-12-22 11:13:21 +00:00

Added NULL checks

This commit is contained in:
Bryan Roe
2021-01-26 13:47:20 -08:00
parent eca6b61df5
commit a728ba40de
7 changed files with 58 additions and 32 deletions

View File

@@ -1630,7 +1630,7 @@ void* ILibDuktape_GlobalGenericCallback_Process(int numParms, ...)
while (node != NULL)
{
data = (Duktape_GlobalGeneric_Data*)ILibLinkedList_GetDataFromNode(node);
refList[count++] = data;
if (data != NULL) { refList[count++] = data; }
node = ILibLinkedList_GetNextNode(node);
}
ILibLinkedList_UnLock(GlobalCallbackList);
@@ -2045,7 +2045,7 @@ duk_ret_t ILibDuktape_GenericMarshal_Finalizer(duk_context *ctx)
while (node != NULL)
{
Duktape_GlobalGeneric_Data *data = (Duktape_GlobalGeneric_Data*)ILibLinkedList_GetDataFromNode(node);
if (data->chain == duk_ctx_chain(ctx) && data->ctxnonce == duk_ctx_nonce(ctx))
if (data != NULL && data->chain == duk_ctx_chain(ctx) && data->ctxnonce == duk_ctx_nonce(ctx))
{
ILibMemory_Free(data);
void *next = ILibLinkedList_GetNextNode(node);

View File

@@ -778,8 +778,11 @@ void Duktape_SafeDestroyHeap(duk_context *ctx)
int i = 0;
void *node;
while ((node = ILibLinkedList_GetNode_Head(ctxd->threads)) != NULL)
{
if (ILibLinkedList_GetDataFromNode(node) != NULL)
{
threadList[i++] = ILibLinkedList_GetDataFromNode(node);
}
ILibLinkedList_Remove(node);
}
while (WaitForMultipleObjectsEx(i, threadList, TRUE, 1000, TRUE) == WAIT_IO_COMPLETION);
@@ -793,11 +796,13 @@ void Duktape_SafeDestroyHeap(duk_context *ctx)
ILibThread_ms2ts(5000, &ts);
while ((node = ILibLinkedList_GetNode_Head(ctxd->threads)) != NULL)
{
thr = ILibLinkedList_GetDataFromNode(node);
if ((thr = ILibLinkedList_GetDataFromNode(node)) != NULL)
{
if ((rv = ILibThread_TimedJoinEx(thr, &ts)) != 0)
{
break;
}
}
ILibLinkedList_Remove(node);
}
#endif

View File

@@ -1747,8 +1747,11 @@ void ILibChain_SignalSink(int signum)
{
void *node = ILibLinkedList_GetNode_Head(g_signalHandlers[signum]);
while (node != NULL)
{
if (ILibLinkedList_GetDataFromNode(node) != NULL)
{
ignore_result(write(((ILibChain_SignalHandlerData*)ILibLinkedList_GetDataFromNode(node))->ipc[1], " ", 1));
}
node = ILibLinkedList_GetNextNode(node);
}
}
@@ -1935,6 +1938,7 @@ void ILibChain_SafeRemoveEx(void *chain, void *object)
*/
void ILibChain_SafeRemove(void *chain, void *object)
{
if (object == NULL) { return; }
((ILibChain_Link*)object)->RESERVED = 0xFFFFFFFF;
if (ILibIsChainBeingDestroyed(chain) == 0)
{
@@ -3303,7 +3307,11 @@ char *ILibChain_GetMetadataForTimers(void *chain)
node = ILibLinkedList_GetNode_Head(LifeTimeMonitor->ObjectList);
while (node != NULL)
{
Temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node);
if ((Temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node)) == NULL)
{
node = ILibLinkedList_GetNextNode(node);
continue;
}
double ex = (double)(Temp->ExpirationTick - current);
char *units = "milliseconds";
@@ -7418,8 +7426,10 @@ long long ILibLifeTime_GetExpiration(void *LifetimeMonitorObject, void *data)
node = ILibLinkedList_GetNode_Head(LifeTimeMonitor->ObjectList);
while (node != NULL)
{
temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node);
if ((temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node)) != NULL)
{
if (temp->data == data) return temp->ExpirationTick;
}
node = ILibLinkedList_GetNextNode(node);
}
return -1;
@@ -7484,12 +7494,14 @@ ILibLifeTime_Token ILibLifeTime_AddEx4(void *LifetimeMonitorObject, void *data,
{
while (node != NULL)
{
temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node);
if ((temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node)) != NULL)
{
if (ltms->ExpirationTick < temp->ExpirationTick)
{
ILibLinkedList_InsertBefore(node, ltms);
break;
}
}
node = ILibLinkedList_GetNextNode(node);
}
if (node == NULL)
@@ -7566,7 +7578,11 @@ void ILibLifeTime_Check(void *LifeTimeMonitorObject, fd_set *readset, fd_set *wr
node = ILibLinkedList_GetNode_Head(LifeTimeMonitor->ObjectList);
while (node != NULL)
{
Temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node);
if ((Temp = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node)) == NULL)
{
node = ILibLinkedList_GetNextNode(node);
continue;
}
if (Temp->ExpirationTick == 0 || Temp->ExpirationTick < CurrentTick)
{
ILibQueue_EnQueue(EventQueue, Temp);
@@ -7648,7 +7664,7 @@ void ILibLifeTime_Remove(void *LifeTimeToken, void *data)
while (node != NULL)
{
evt = (struct LifeTimeMonitorData*)ILibLinkedList_GetDataFromNode(node);
if (evt->data == data)
if (evt!=NULL && evt->data == data)
{
ILibQueue_EnQueue(EventQueue, evt);
node = ILibLinkedList_Remove(node);
@@ -8736,10 +8752,11 @@ void* ILibSparseArray_GetEx(ILibSparseArray sarray, int index, int remove)
{
// Need to check the Linked List
void *listNode = ILibLinkedList_GetNode_Search(root->bucket[i].ptr, &ILibSparseArray_Comparer, (void*)&index);
retVal = listNode != NULL ? ((ILibSparseArray_Node*)ILibLinkedList_GetDataFromNode(listNode))->ptr : NULL;
retVal = listNode == NULL ? NULL : (ILibLinkedList_GetDataFromNode(listNode) == NULL ? NULL : ((ILibSparseArray_Node*)ILibLinkedList_GetDataFromNode(listNode))->ptr);
if(remove!=0 && listNode!=NULL)
{
free(ILibLinkedList_GetDataFromNode(listNode));
if (ILibLinkedList_GetDataFromNode(listNode) != NULL) { free(ILibLinkedList_GetDataFromNode(listNode)); }
ILibLinkedList_Remove(listNode);
if(ILibLinkedList_GetCount(root->bucket[i].ptr)==0)
{
@@ -8811,8 +8828,11 @@ void ILibSparseArray_ClearEx2(ILibSparseArray sarray, ILibSparseArray_OnValue on
while(node != NULL)
{
ILibSparseArray_Node *sn = (ILibSparseArray_Node*)ILibLinkedList_GetDataFromNode(node);
if (sn != NULL)
{
if (onClear != NULL) { onClear(sarray, sn->index, sn->ptr, user); }
if (nonZeroWillDelete != 0) { free(sn); }
}
node = ILibLinkedList_GetNextNode(node);
}
if (nonZeroWillDelete != 0) { ILibLinkedList_Destroy(root->bucket[i].ptr); }

View File

@@ -190,7 +190,7 @@ char * ILibProcessPipe_Manager_OnQuery(void *chain, void *object, int fd, size_t
if (node != NULL)
{
ILibProcessPipe_PipeObject *pj = (ILibProcessPipe_PipeObject*)ILibLinkedList_GetDataFromNode(node);
if (pj->metadata != NULL)
if (pj!=NULL && pj->metadata != NULL)
{
*dataLen = strnlen_s(pj->metadata, 1024);
ret = pj->metadata;

View File

@@ -3048,7 +3048,7 @@ void ILibWebClient_CancelRequestEx2(ILibWebClient_StateObject wcdo, void *userRe
nextnode = ILibLinkedList_GetNextNode(node);
wr = (struct ILibWebRequest*)ILibLinkedList_GetDataFromNode(node);
if (wr->requestToken == userRequest)
if (wr != NULL && wr->requestToken == userRequest)
{
if (node == head)
{

View File

@@ -3168,7 +3168,7 @@ int ILibStun_SctpAddSackChunk(struct ILibStun_Module *obj, int session, char* pa
// Skip all packets with a low TSN. We do ths bacause we have not processed them yet, but will after adding this SACK
void *node = ILibLinkedList_GetNode_Head(obj->dTlsSessions[session]->receiveHoldBuffer);
while(node!=NULL && ntohl(((ILibSCTP_DataPayload*)ILibLinkedList_GetDataFromNode(node))->TSN) <= obj->dTlsSessions[session]->userTSN)
while(node!=NULL && ILibLinkedList_GetDataFromNode(node) != NULL && ntohl(((ILibSCTP_DataPayload*)ILibLinkedList_GetDataFromNode(node))->TSN) <= obj->dTlsSessions[session]->userTSN)
{
node = ILibLinkedList_GetNextNode(node);
}
@@ -3177,9 +3177,9 @@ int ILibStun_SctpAddSackChunk(struct ILibStun_Module *obj, int session, char* pa
while (node != NULL)
{
ILibSCTP_DataPayload *p = (ILibSCTP_DataPayload*)ILibLinkedList_GetDataFromNode(node);
unsigned int gstart = ntohl(p->TSN);
unsigned int gstart = (p == NULL ? 0 : ntohl(p->TSN));
unsigned int gend = gstart;
bytecount += ntohs(p->length);
bytecount += (p == NULL ? 0 : ntohs(p->length));
node = ILibLinkedList_GetNextNode(node);
while (node != NULL && (p = (ILibSCTP_DataPayload*)ILibLinkedList_GetDataFromNode(node))!=NULL)
@@ -3638,7 +3638,7 @@ void ILibStun_SctpDisconnect_Final(void *obj)
node = ILibLinkedList_GetNode_Head(o->receiveHoldBuffer);
while(node != NULL)
{
free(ILibLinkedList_GetDataFromNode(node));
if (ILibLinkedList_GetDataFromNode(node) != NULL) { free(ILibLinkedList_GetDataFromNode(node)); }
node = ILibLinkedList_GetNextNode(node);
}
ILibLinkedList_Destroy(o->receiveHoldBuffer);
@@ -5205,7 +5205,7 @@ void ILibStun_ProcessSctpPacket(struct ILibStun_Module *obj, int session, char*
rqptr = ILibLinkedList_GetNode_Head(o->receiveHoldBuffer);
while (rqptr != NULL)
{
unsigned int tsnx = ntohl(((ILibSCTP_DataPayload*)ILibLinkedList_GetDataFromNode(rqptr))->TSN);
unsigned int tsnx = (ILibLinkedList_GetDataFromNode(rqptr) == NULL ? 0 : ntohl(((ILibSCTP_DataPayload*)ILibLinkedList_GetDataFromNode(rqptr))->TSN));
if (tsnx != o->intsn + 1) break;
ILibRemoteLogging_printf(ILibChainGetLogger(obj->ChainLink.ParentChain), ILibRemoteLogging_Modules_WebRTC_SCTP, ILibRemoteLogging_Flags_VerbosityLevel_3, "TSN Moved Forward to: %u", tsnx);
o->intsn = tsnx;

View File

@@ -831,11 +831,12 @@ void ILibWrapper_WebRTC_ConnectionFactory_RemoveFromChainSink(void *chain, void
while (node != NULL && finished == 0)
{
obj = (ILibChain_Link*)ILibLinkedList_GetDataFromNode(node);
if ((obj = (ILibChain_Link*)ILibLinkedList_GetDataFromNode(node)) != NULL)
{
if (obj == turnClient) { finished = 1; }
if (obj->DestroyHandler != NULL) { obj->DestroyHandler(obj); }
ILibChain_FreeLink(obj);
}
node = ILibLinkedList_Remove(node);
}
}