forked from eden-emu/eden
		
	common: tree: Avoid a crash on nullptr dereference.
This commit is contained in:
		
					parent
					
						
							
								6e3c9d2b06
							
						
					
				
			
			
				commit
				
					
						d77adad0c4
					
				
			
		
					 1 changed files with 11 additions and 0 deletions
				
			
		|  | @ -43,6 +43,8 @@ | |||
|  * The maximum height of a red-black tree is 2lg (n+1). | ||||
|  */ | ||||
| 
 | ||||
| #include "common/assert.h" | ||||
| 
 | ||||
| namespace Common { | ||||
| template <typename T> | ||||
| class RBHead { | ||||
|  | @ -325,6 +327,10 @@ void RB_REMOVE_COLOR(RBHead<Node>* head, Node* parent, Node* elm) { | |||
|     while ((elm == nullptr || RB_IS_BLACK(elm)) && elm != head->Root() && parent != nullptr) { | ||||
|         if (RB_LEFT(parent) == elm) { | ||||
|             tmp = RB_RIGHT(parent); | ||||
|             if (!tmp) { | ||||
|                 ASSERT_MSG(false, "tmp is invalid!"); | ||||
|                 break; | ||||
|             } | ||||
|             if (RB_IS_RED(tmp)) { | ||||
|                 RB_SET_BLACKRED(tmp, parent); | ||||
|                 RB_ROTATE_LEFT(head, parent, tmp); | ||||
|  | @ -366,6 +372,11 @@ void RB_REMOVE_COLOR(RBHead<Node>* head, Node* parent, Node* elm) { | |||
|                 tmp = RB_LEFT(parent); | ||||
|             } | ||||
| 
 | ||||
|             if (!tmp) { | ||||
|                 ASSERT_MSG(false, "tmp is invalid!"); | ||||
|                 break; | ||||
|             } | ||||
| 
 | ||||
|             if ((RB_LEFT(tmp) == nullptr || RB_IS_BLACK(RB_LEFT(tmp))) && | ||||
|                 (RB_RIGHT(tmp) == nullptr || RB_IS_BLACK(RB_RIGHT(tmp)))) { | ||||
|                 RB_SET_COLOR(tmp, EntryColor::Red); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
				bunnei