123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- #include <LibC/SharedBuffer.h>
- #include <LibGUI/GClipboard.h>
- #include <LibGUI/GWindowServerConnection.h>
- GClipboard& GClipboard::the()
- {
- static GClipboard* s_the;
- if (!s_the)
- s_the = new GClipboard;
- return *s_the;
- }
- GClipboard::GClipboard()
- {
- }
- GClipboard::DataAndType GClipboard::data_and_type() const
- {
- auto response = GWindowServerConnection::the().send_sync<WindowServer::GetClipboardContents>();
- if (response->shared_buffer_id() < 0)
- return {};
- auto shared_buffer = SharedBuffer::create_from_shared_buffer_id(response->shared_buffer_id());
- if (!shared_buffer) {
- dbgprintf("GClipboard::data() failed to attach to the shared buffer\n");
- return {};
- }
- if (response->content_size() > shared_buffer->size()) {
- dbgprintf("GClipboard::data() clipping contents size is greater than shared buffer size\n");
- return {};
- }
- auto data = String((const char*)shared_buffer->data(), response->content_size());
- auto type = response->content_type();
- return { data, type };
- }
- void GClipboard::set_data(const StringView& data, const String& type)
- {
- auto shared_buffer = SharedBuffer::create_with_size(data.length() + 1);
- if (!shared_buffer) {
- dbgprintf("GClipboard::set_data() failed to create a shared buffer\n");
- return;
- }
- if (!data.is_empty())
- memcpy(shared_buffer->data(), data.characters_without_null_termination(), data.length() + 1);
- else
- ((u8*)shared_buffer->data())[0] = '\0';
- shared_buffer->seal();
- shared_buffer->share_with(GWindowServerConnection::the().server_pid());
- GWindowServerConnection::the().send_sync<WindowServer::SetClipboardContents>(shared_buffer->shared_buffer_id(), data.length(), type);
- }
- void GClipboard::did_receive_clipboard_contents_changed(Badge<GWindowServerConnection>, const String& data_type)
- {
- if (on_content_change)
- on_content_change(data_type);
- }
|