mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 17:52:35 +00:00 
			
		
		
		
	 05f41382bb
			
		
	
	
		05f41382bb
		
	
	
	
	
		
			
			In order to avoid the base encode/decode methods from being used (and failing a static assertion), we must be sure to declare/define the custom type implementations as template specializations. After this, LibIPC is no longer sensitive to include order.
		
			
				
	
	
		
			83 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
 | |
|  * Copyright (c) 2022, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Error.h>
 | |
| #include <AK/Noncopyable.h>
 | |
| #include <AK/RefCounted.h>
 | |
| #include <AK/RefPtr.h>
 | |
| #include <AK/Types.h>
 | |
| #include <LibIPC/Forward.h>
 | |
| 
 | |
| namespace Core {
 | |
| 
 | |
| class AnonymousBufferImpl final : public RefCounted<AnonymousBufferImpl> {
 | |
| public:
 | |
|     static ErrorOr<NonnullRefPtr<AnonymousBufferImpl>> create(int fd, size_t);
 | |
|     ~AnonymousBufferImpl();
 | |
| 
 | |
|     int fd() const { return m_fd; }
 | |
|     size_t size() const { return m_size; }
 | |
|     void* data() { return m_data; }
 | |
|     void const* data() const { return m_data; }
 | |
| 
 | |
| private:
 | |
|     AnonymousBufferImpl(int fd, size_t, void*);
 | |
| 
 | |
|     int m_fd { -1 };
 | |
|     size_t m_size { 0 };
 | |
|     void* m_data { nullptr };
 | |
| };
 | |
| 
 | |
| class AnonymousBuffer {
 | |
| public:
 | |
|     static ErrorOr<AnonymousBuffer> create_with_size(size_t);
 | |
|     static ErrorOr<AnonymousBuffer> create_from_anon_fd(int fd, size_t);
 | |
| 
 | |
|     AnonymousBuffer() = default;
 | |
| 
 | |
|     bool is_valid() const { return m_impl; }
 | |
| 
 | |
|     int fd() const { return m_impl ? m_impl->fd() : -1; }
 | |
|     size_t size() const { return m_impl ? m_impl->size() : 0; }
 | |
| 
 | |
|     template<typename T>
 | |
|     T* data()
 | |
|     {
 | |
|         static_assert(IsVoid<T> || IsTrivial<T>);
 | |
|         if (!m_impl)
 | |
|             return nullptr;
 | |
|         return (T*)m_impl->data();
 | |
|     }
 | |
| 
 | |
|     template<typename T>
 | |
|     const T* data() const
 | |
|     {
 | |
|         static_assert(IsVoid<T> || IsTrivial<T>);
 | |
|         if (!m_impl)
 | |
|             return nullptr;
 | |
|         return (const T*)m_impl->data();
 | |
|     }
 | |
| 
 | |
| private:
 | |
|     explicit AnonymousBuffer(NonnullRefPtr<AnonymousBufferImpl>);
 | |
| 
 | |
|     RefPtr<AnonymousBufferImpl> m_impl;
 | |
| };
 | |
| 
 | |
| }
 | |
| 
 | |
| namespace IPC {
 | |
| 
 | |
| template<>
 | |
| bool encode(Encoder&, Core::AnonymousBuffer const&);
 | |
| 
 | |
| template<>
 | |
| ErrorOr<void> decode(Decoder&, Core::AnonymousBuffer&);
 | |
| 
 | |
| }
 |