Flutter Engine
 
Loading...
Searching...
No Matches
fl_binary_messenger.h
Go to the documentation of this file.
1// Copyright 2013 The Flutter Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef FLUTTER_SHELL_PLATFORM_LINUX_PUBLIC_FLUTTER_LINUX_FL_BINARY_MESSENGER_H_
6#define FLUTTER_SHELL_PLATFORM_LINUX_PUBLIC_FLUTTER_LINUX_FL_BINARY_MESSENGER_H_
7
8#if !defined(__FLUTTER_LINUX_INSIDE__) && !defined(FLUTTER_LINUX_COMPILATION)
9#error "Only <flutter_linux/flutter_linux.h> can be included directly."
10#endif
11
12#include "fl_value.h"
13
14#include <gio/gio.h>
15#include <glib-object.h>
16#include <gmodule.h>
17
18G_BEGIN_DECLS
19
20/**
21 * FlBinaryMessengerError:
22 * @FL_BINARY_MESSENGER_ERROR_ALREADY_RESPONDED: unable to send response, this
23 * message has already been responded to.
24 *
25 * Errors for #FlBinaryMessenger objects to set on failures.
26 */
27#define FL_BINARY_MESSENGER_ERROR fl_binary_messenger_codec_error_quark()
28
29typedef enum {
30 // Part of the public API, so fixing the name is a breaking change.
33
34G_MODULE_EXPORT
35GQuark fl_binary_messenger_codec_error_quark(void) G_GNUC_CONST;
36
37G_MODULE_EXPORT
38G_DECLARE_INTERFACE(FlBinaryMessenger,
39 fl_binary_messenger,
40 FL,
41 BINARY_MESSENGER,
42 GObject)
43
44G_MODULE_EXPORT
45G_DECLARE_DERIVABLE_TYPE(FlBinaryMessengerResponseHandle,
49 GObject)
50
51/**
52 * FlBinaryMessengerMessageHandler:
53 * @messenger: an #FlBinaryMessenger.
54 * @channel: channel message received on.
55 * @message: message content received from Dart.
56 * @response_handle: a handle to respond to the message with.
57 * @user_data: (closure): data provided when registering this handler.
58 *
59 * Function called when platform messages are received. Call
60 * fl_binary_messenger_send_response() to respond to this message. If the
61 * response is not occurring in this callback take a reference to
62 * @response_handle and release that once it has been responded to. Failing to
63 * respond before the last reference to @response_handle is dropped is a
64 * programming error.
65 */
67 FlBinaryMessenger* messenger,
68 const gchar* channel,
69 GBytes* message,
70 FlBinaryMessengerResponseHandle* response_handle,
71 gpointer user_data);
72
74 GTypeInterface parent_iface;
75
77 FlBinaryMessenger* messenger,
78 const gchar* channel,
80 gpointer user_data,
81 GDestroyNotify destroy_notify);
82
83 gboolean (*send_response)(FlBinaryMessenger* messenger,
84 FlBinaryMessengerResponseHandle* response_handle,
85 GBytes* response,
86 GError** error);
87
88 void (*send_on_channel)(FlBinaryMessenger* messenger,
89 const gchar* channel,
90 GBytes* message,
91 GCancellable* cancellable,
92 GAsyncReadyCallback callback,
93 gpointer user_data);
94
95 GBytes* (*send_on_channel_finish)(FlBinaryMessenger* messenger,
96 GAsyncResult* result,
97 GError** error);
98
99 void (*resize_channel)(FlBinaryMessenger* messenger,
100 const gchar* channel,
101 int64_t new_size);
102
103 void (*set_warns_on_channel_overflow)(FlBinaryMessenger* messenger,
104 const gchar* channel,
105 bool warns);
106
107 void (*shutdown)(FlBinaryMessenger* messenger);
108};
109
113
114/**
115 * FlBinaryMessenger:
116 *
117 * #FlBinaryMessenger is an object that allows sending and receiving of platform
118 * messages with an #FlEngine.
119 */
120
121/**
122 * FlBinaryMessengerResponseHandle:
123 *
124 * #FlBinaryMessengerResponseHandle is an object used to send responses with.
125 */
126
127/**
128 * fl_binary_messenger_set_platform_message_handler:
129 * @binary_messenger: an #FlBinaryMessenger.
130 * @channel: channel to listen on.
131 * @handler: (allow-none): function to call when a message is received on this
132 * channel or %NULL to disable a handler
133 * @user_data: (closure): user data to pass to @handler.
134 * @destroy_notify: (allow-none): a function which gets called to free
135 * @user_data, or %NULL.
136 *
137 * Sets the function called when a platform message is received on the given
138 * channel. See #FlBinaryMessengerMessageHandler for details on how to respond
139 * to messages.
140 *
141 * The handler is removed if the channel is closed or is replaced by another
142 * handler, set @destroy_notify if you want to detect this.
143 */
145 FlBinaryMessenger* messenger,
146 const gchar* channel,
148 gpointer user_data,
149 GDestroyNotify destroy_notify);
150
151/**
152 * fl_binary_messenger_send_response:
153 * @binary_messenger: an #FlBinaryMessenger.
154 * @response_handle: handle that was provided in a
155 * #FlBinaryMessengerMessageHandler.
156 * @response: (allow-none): response to send or %NULL for an empty response.
157 * @error: (allow-none): #GError location to store the error occurring, or %NULL
158 * to ignore.
159 *
160 * Responds to a platform message. This function is thread-safe.
161 *
162 * Returns: %TRUE on success.
163 */
165 FlBinaryMessenger* messenger,
166 FlBinaryMessengerResponseHandle* response_handle,
167 GBytes* response,
168 GError** error);
169
170/**
171 * fl_binary_messenger_send_on_channel:
172 * @binary_messenger: an #FlBinaryMessenger.
173 * @channel: channel to send to.
174 * @message: (allow-none): message buffer to send or %NULL for an empty message.
175 * @cancellable: (allow-none): a #GCancellable or %NULL.
176 * @callback: (scope async): a #GAsyncReadyCallback to call when the request is
177 * satisfied.
178 * @user_data: (closure): user data to pass to @callback.
179 *
180 * Asynchronously sends a platform message.
181 */
182void fl_binary_messenger_send_on_channel(FlBinaryMessenger* messenger,
183 const gchar* channel,
184 GBytes* message,
185 GCancellable* cancellable,
186 GAsyncReadyCallback callback,
187 gpointer user_data);
188
189/**
190 * fl_binary_messenger_send_on_channel_finish:
191 * @messenger: an #FlBinaryMessenger.
192 * @result: a #GAsyncResult.
193 * @error: (allow-none): #GError location to store the error occurring, or %NULL
194 * to ignore.
195 *
196 * Completes request started with fl_binary_messenger_send_on_channel().
197 *
198 * Returns: (transfer full): message response on success or %NULL on error.
199 */
200GBytes* fl_binary_messenger_send_on_channel_finish(FlBinaryMessenger* messenger,
201 GAsyncResult* result,
202 GError** error);
203
204/**
205 * fl_binary_messenger_resize_channel:
206 * @binary_messenger: an #FlBinaryMessenger.
207 * @channel: channel to be resize.
208 * @new_size: the new size for the channel buffer.
209 *
210 * Sends a message to the control channel asking to resize a channel buffer.
211 */
212void fl_binary_messenger_resize_channel(FlBinaryMessenger* messenger,
213 const gchar* channel,
214 int64_t new_size);
215
216/**
217 * fl_binary_messenger_set_warns_on_channel_overflow:
218 * @messenger: an #FlBinaryMessenger.
219 * @channel: channel to be allowed to overflow silently.
220 * @warns: when false, the channel is expected to overflow and warning messages
221 * will not be shown.
222 *
223 * Sends a message to the control channel asking to allow or disallow a channel
224 * to overflow silently.
225 */
227 FlBinaryMessenger* messenger,
228 const gchar* channel,
229 bool warns);
230
231G_END_DECLS
232
233#endif // FLUTTER_SHELL_PLATFORM_LINUX_PUBLIC_FLUTTER_LINUX_FL_BINARY_MESSENGER_H_
G_BEGIN_DECLS G_DECLARE_DERIVABLE_TYPE(FlAccessibleNode, fl_accessible_node, FL, ACCESSIBLE_NODE, AtkObject)
static void resize_channel(FlBinaryMessenger *messenger, const gchar *channel, int64_t new_size)
static void send_on_channel(FlBinaryMessenger *messenger, const gchar *channel, GBytes *message, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data)
static void set_message_handler_on_channel(FlBinaryMessenger *messenger, const gchar *channel, FlBinaryMessengerMessageHandler handler, gpointer user_data, GDestroyNotify destroy_notify)
static gboolean send_response(FlBinaryMessenger *messenger, FlBinaryMessengerResponseHandle *response_handle_, GBytes *response, GError **error)
static void set_warns_on_channel_overflow(FlBinaryMessenger *messenger, const gchar *channel, bool warns)
static void shutdown(FlBinaryMessenger *messenger)
G_MODULE_EXPORT FL
G_MODULE_EXPORT G_DECLARE_INTERFACE(FlBinaryMessenger, fl_binary_messenger, FL, BINARY_MESSENGER, GObject) G_MODULE_EXPORT G_DECLARE_DERIVABLE_TYPE(FlBinaryMessengerResponseHandle
GBytes * fl_binary_messenger_send_on_channel_finish(FlBinaryMessenger *messenger, GAsyncResult *result, GError **error)
void fl_binary_messenger_set_warns_on_channel_overflow(FlBinaryMessenger *messenger, const gchar *channel, bool warns)
G_MODULE_EXPORT GQuark fl_binary_messenger_codec_error_quark(void) G_GNUC_CONST
void fl_binary_messenger_resize_channel(FlBinaryMessenger *messenger, const gchar *channel, int64_t new_size)
FlBinaryMessengerError
@ FL_BINARY_MESSENGER_ERROR_ALREADY_RESPONDED
G_MODULE_EXPORT GObject typedef void(* FlBinaryMessengerMessageHandler)(FlBinaryMessenger *messenger, const gchar *channel, GBytes *message, FlBinaryMessengerResponseHandle *response_handle, gpointer user_data)
void fl_binary_messenger_send_on_channel(FlBinaryMessenger *messenger, const gchar *channel, GBytes *message, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data)
gboolean fl_binary_messenger_send_response(FlBinaryMessenger *messenger, FlBinaryMessengerResponseHandle *response_handle, GBytes *response, GError **error)
G_MODULE_EXPORT BINARY_MESSENGER_RESPONSE_HANDLE
void fl_binary_messenger_set_message_handler_on_channel(FlBinaryMessenger *messenger, const gchar *channel, FlBinaryMessengerMessageHandler handler, gpointer user_data, GDestroyNotify destroy_notify)
G_MODULE_EXPORT fl_binary_messenger_response_handle
const gchar * channel
const gchar FlBinaryMessengerMessageHandler gpointer GDestroyNotify destroy_notify
const gchar FlBinaryMessengerMessageHandler handler
G_BEGIN_DECLS GBytes * message
const uint8_t uint32_t uint32_t GError ** error
FlutterDesktopBinaryReply callback