Client.cpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright (c) 2020-2021, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibCore/AnonymousBuffer.h>
  7. #include <LibImageDecoderClient/Client.h>
  8. namespace ImageDecoderClient {
  9. Client::Client()
  10. : IPC::ServerConnection<ImageDecoderClientEndpoint, ImageDecoderServerEndpoint>(*this, "/tmp/portal/image")
  11. {
  12. }
  13. void Client::die()
  14. {
  15. if (on_death)
  16. on_death();
  17. }
  18. Optional<DecodedImage> Client::decode_image(const ReadonlyBytes& encoded_data)
  19. {
  20. if (encoded_data.is_empty())
  21. return {};
  22. auto encoded_buffer = Core::AnonymousBuffer::create_with_size(encoded_data.size());
  23. if (!encoded_buffer.is_valid()) {
  24. dbgln("Could not allocate encoded buffer");
  25. return {};
  26. }
  27. memcpy(encoded_buffer.data<void>(), encoded_data.data(), encoded_data.size());
  28. auto response_or_error = try_decode_image(move(encoded_buffer));
  29. if (response_or_error.is_error()) {
  30. dbgln("ImageDecoder died heroically");
  31. return {};
  32. }
  33. auto& response = response_or_error.value();
  34. if (response.bitmaps().is_empty())
  35. return {};
  36. DecodedImage image;
  37. image.is_animated = response.is_animated();
  38. image.loop_count = response.loop_count();
  39. image.frames.resize(response.bitmaps().size());
  40. for (size_t i = 0; i < image.frames.size(); ++i) {
  41. auto& frame = image.frames[i];
  42. frame.bitmap = response.bitmaps()[i].bitmap();
  43. frame.duration = response.durations()[i];
  44. }
  45. return image;
  46. }
  47. }