mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 14:12:34 +00:00 
			
		
		
		
	 d7b6cc6421
			
		
	
	
		d7b6cc6421
		
	
	
	
	
		
			
			Our existing implementation did not check the element type of the other pointer in the constructors and move assignment operators. This meant that some operations that would require explicit casting on raw pointers were done implicitly, such as: - downcasting a base class to a derived class (e.g. `Kernel::Inode` => `Kernel::ProcFSDirectoryInode` in Kernel/ProcFS.cpp), - casting to an unrelated type (e.g. `Promise<bool>` => `Promise<Empty>` in LibIMAP/Client.cpp) This, of course, allows gross violations of the type system, and makes the need to type-check less obvious before downcasting. Luckily, while adding the `static_ptr_cast`s, only two truly incorrect usages were found; in the other instances, our casts just needed to be made explicit.
		
			
				
	
	
		
			39 lines
		
	
	
	
		
			871 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
	
		
			871 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Jesse Buhagiar <jooster669@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <LibGL/GL/gl.h>
 | |
| #include <LibGL/Tex/TextureUnit.h>
 | |
| 
 | |
| namespace GL {
 | |
| 
 | |
| void TextureUnit::bind_texture_to_target(GLenum texture_target, const RefPtr<Texture>& texture)
 | |
| {
 | |
|     switch (texture_target) {
 | |
|     case GL_TEXTURE_2D:
 | |
|         m_texture_target_2d = static_ptr_cast<Texture2D>(texture);
 | |
|         m_currently_bound_texture = texture;
 | |
|         m_currently_bound_target = GL_TEXTURE_2D;
 | |
|         break;
 | |
|     default:
 | |
|         VERIFY_NOT_REACHED();
 | |
|     }
 | |
| }
 | |
| 
 | |
| void TextureUnit::unbind_texture(GLenum texture_target)
 | |
| {
 | |
|     switch (texture_target) {
 | |
|     case GL_TEXTURE_2D:
 | |
|         m_texture_target_2d = nullptr;
 | |
|         m_currently_bound_target = 0;
 | |
|         break;
 | |
|     default:
 | |
|         VERIFY_NOT_REACHED();
 | |
|     }
 | |
| 
 | |
|     m_currently_bound_texture = nullptr;
 | |
| }
 | |
| 
 | |
| }
 |