Client.cpp 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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.resize(response.bitmaps().size());
  41. auto bitmaps = response.take_bitmaps();
  42. for (size_t i = 0; i < image.frames.size(); ++i) {
  43. auto& frame = image.frames[i];
  44. frame.bitmap = bitmaps[i].bitmap();
  45. frame.duration = response.durations()[i];
  46. }
  47. return image;
  48. }
  49. }