Client.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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. handshake();
  13. }
  14. void Client::die()
  15. {
  16. if (on_death)
  17. on_death();
  18. }
  19. void Client::handshake()
  20. {
  21. greet();
  22. }
  23. void Client::dummy()
  24. {
  25. }
  26. Optional<DecodedImage> Client::decode_image(const ByteBuffer& encoded_data)
  27. {
  28. if (encoded_data.is_empty())
  29. return {};
  30. auto encoded_buffer = Core::AnonymousBuffer::create_with_size(encoded_data.size());
  31. if (!encoded_buffer.is_valid()) {
  32. dbgln("Could not allocate encoded buffer");
  33. return {};
  34. }
  35. memcpy(encoded_buffer.data<void>(), encoded_data.data(), encoded_data.size());
  36. auto response_or_error = try_decode_image(move(encoded_buffer));
  37. if (response_or_error.is_error()) {
  38. dbgln("ImageDecoder died heroically");
  39. return {};
  40. }
  41. auto& response = response_or_error.value();
  42. if (response.bitmaps().is_empty())
  43. return {};
  44. DecodedImage image;
  45. image.is_animated = response.is_animated();
  46. image.loop_count = response.loop_count();
  47. image.frames.resize(response.bitmaps().size());
  48. for (size_t i = 0; i < image.frames.size(); ++i) {
  49. auto& frame = image.frames[i];
  50. frame.bitmap = response.bitmaps()[i].bitmap();
  51. frame.duration = response.durations()[i];
  52. }
  53. return image;
  54. }
  55. }