ladybird/Userland/Libraries/LibGfx/Rect.cpp
Timothy Flynn 05f41382bb Userland: Properly define IPC::encode and IPC::decode specializations
In order to avoid the base encode/decode methods from being used (and
failing a static assertion), we must be sure to declare/define the
custom type implementations as template specializations.

After this, LibIPC is no longer sensitive to include order.
2022-11-15 13:25:51 -05:00

54 lines
1,022 B
C++

/*
* Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <AK/StdLibExtras.h>
#include <AK/String.h>
#include <AK/Vector.h>
#include <LibGfx/Line.h>
#include <LibGfx/Rect.h>
#include <LibIPC/Decoder.h>
#include <LibIPC/Encoder.h>
namespace Gfx {
template<>
String IntRect::to_string() const
{
return String::formatted("[{},{} {}x{}]", x(), y(), width(), height());
}
template<>
String FloatRect::to_string() const
{
return String::formatted("[{},{} {}x{}]", x(), y(), width(), height());
}
}
namespace IPC {
template<>
bool encode(Encoder& encoder, Gfx::IntRect const& rect)
{
encoder << rect.location() << rect.size();
return true;
}
template<>
ErrorOr<void> decode(Decoder& decoder, Gfx::IntRect& rect)
{
Gfx::IntPoint point;
Gfx::IntSize size;
TRY(decoder.decode(point));
TRY(decoder.decode(size));
rect = { point, size };
return {};
}
}
template class Gfx::Rect<int>;
template class Gfx::Rect<float>;