summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibWeb/WebDriver/Response.h
blob: 09c76458f822d3247e77ac5c9a0e6e57bb0364d6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
 * Copyright (c) 2022, Tim Flynn <trflynn89@serenityos.org>
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#pragma once

#include <AK/JsonValue.h>
#include <AK/Variant.h>
#include <LibIPC/Forward.h>
#include <LibWeb/WebDriver/Error.h>

namespace Web::WebDriver {

// FIXME: Ideally, this could be `using Response = ErrorOr<JsonValue, Error>`, but that won't be
//        default-constructible, which is a requirement for the generated IPC.
struct Response {
    Response() = default;
    Response(JsonValue&&);
    Response(Error&&);

    JsonValue& value() { return m_value_or_error.template get<JsonValue>(); }
    JsonValue const& value() const { return m_value_or_error.template get<JsonValue>(); }

    Error& error() { return m_value_or_error.template get<Error>(); }
    Error const& error() const { return m_value_or_error.template get<Error>(); }

    bool is_error() const { return m_value_or_error.template has<Error>(); }

    JsonValue release_value() { return move(value()); }
    Error release_error() { return move(error()); }

    template<typename... Visitors>
    decltype(auto) visit(Visitors&&... visitors) const
    {
        return m_value_or_error.visit(forward<Visitors>(visitors)...);
    }

private:
    // Note: Empty is only a possible state until the Response has been decoded by IPC.
    Variant<Empty, JsonValue, Error> m_value_or_error;
};

}

namespace IPC {

template<>
ErrorOr<void> encode(Encoder&, Web::WebDriver::Response const&);

template<>
ErrorOr<Web::WebDriver::Response> decode(Decoder&);

}