Client.cpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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(NonnullOwnPtr<Core::LocalSocket> socket)
  10. : IPC::ConnectionToServer<ImageDecoderClientEndpoint, ImageDecoderServerEndpoint>(*this, move(socket))
  11. {
  12. }
  13. void Client::die()
  14. {
  15. if (on_death)
  16. on_death();
  17. }
  18. Optional<DecodedImage> Client::decode_image(ReadonlyBytes encoded_data, Optional<DeprecatedString> mime_type)
  19. {
  20. if (encoded_data.is_empty())
  21. return {};
  22. auto encoded_buffer_or_error = Core::AnonymousBuffer::create_with_size(encoded_data.size());
  23. if (encoded_buffer_or_error.is_error()) {
  24. dbgln("Could not allocate encoded buffer");
  25. return {};
  26. }
  27. auto encoded_buffer = encoded_buffer_or_error.release_value();
  28. memcpy(encoded_buffer.data<void>(), encoded_data.data(), encoded_data.size());
  29. auto response_or_error = try_decode_image(move(encoded_buffer), mime_type);
  30. if (response_or_error.is_error()) {
  31. dbgln("ImageDecoder died heroically");
  32. return {};
  33. }
  34. auto& response = response_or_error.value();
  35. if (response.bitmaps().is_empty())
  36. return {};
  37. DecodedImage image;
  38. image.is_animated = response.is_animated();
  39. image.loop_count = response.loop_count();
  40. image.frames.ensure_capacity(response.bitmaps().size());
  41. auto bitmaps = response.take_bitmaps();
  42. for (size_t i = 0; i < bitmaps.size(); ++i) {
  43. if (!bitmaps[i].is_valid())
  44. return {};
  45. image.frames.empend(*bitmaps[i].bitmap(), response.durations()[i]);
  46. }
  47. return image;
  48. }
  49. }