b419eef55e
A device disconnection (when the adb connection is closed) makes the read() on the "receiver" socket fail. Since commit 063a8339ed27b94a8fe1e53a284507eb2d044e15, this is reported as an error. As a consequence, scrcpy fails with: ERROR: Controller error instead of: WARN: Device disconnected To fix the issue, report a device disconnection in that case. PR #5044 <https://github.com/Genymobile/scrcpy/pull/5044>
47 lines
1.0 KiB
C
47 lines
1.0 KiB
C
#ifndef SC_RECEIVER_H
|
|
#define SC_RECEIVER_H
|
|
|
|
#include "common.h"
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "uhid/uhid_output.h"
|
|
#include "util/acksync.h"
|
|
#include "util/net.h"
|
|
#include "util/thread.h"
|
|
|
|
// receive events from the device
|
|
// managed by the controller
|
|
struct sc_receiver {
|
|
sc_socket control_socket;
|
|
sc_thread thread;
|
|
sc_mutex mutex;
|
|
|
|
struct sc_acksync *acksync;
|
|
struct sc_uhid_devices *uhid_devices;
|
|
|
|
const struct sc_receiver_callbacks *cbs;
|
|
void *cbs_userdata;
|
|
};
|
|
|
|
struct sc_receiver_callbacks {
|
|
void (*on_ended)(struct sc_receiver *receiver, bool error, void *userdata);
|
|
};
|
|
|
|
bool
|
|
sc_receiver_init(struct sc_receiver *receiver, sc_socket control_socket,
|
|
const struct sc_receiver_callbacks *cbs, void *cbs_userdata);
|
|
|
|
void
|
|
sc_receiver_destroy(struct sc_receiver *receiver);
|
|
|
|
bool
|
|
sc_receiver_start(struct sc_receiver *receiver);
|
|
|
|
// no sc_receiver_stop(), it will automatically stop on control_socket shutdown
|
|
|
|
void
|
|
sc_receiver_join(struct sc_receiver *receiver);
|
|
|
|
#endif
|