forked from libimobiledevice-win32/ios-webkit-debug-proxy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdl_client.c
102 lines (88 loc) · 1.99 KB
/
dl_client.c
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// Google BSD license https://developers.google.com/google-bsd-license
// Copyright 2012 Google Inc. wrightt@google.com
//
// An example device_listener client
//
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#ifdef WIN32
#include <winsock2.h>
#else
#include <sys/socket.h>
#endif
#include "ios-webkit-debug-proxy/device_listener.h"
#define BUF_LEN 1024
struct my_struct {
int fd;
};
typedef struct my_struct *my_t;
// callbacks:
dl_status my_send_packet(dl_t dl, const char *buf, size_t length) {
int fd = ((my_t)dl->state)->fd;
ssize_t send_bytes = send(fd, buf, length, 0);
return (send_bytes == length ? DL_SUCCESS : DL_ERROR);
}
dl_status my_on_attach(dl_t dl, const char *device_id, int device_num) {
printf("on_attach %s %d\n", device_id, device_num);
return DL_SUCCESS;
}
dl_status my_on_detach(dl_t dl, const char *device_id, int device_num) {
printf("on_detach %s %d\n", device_id, device_num);
return DL_SUCCESS;
}
int main(int argc, char** argv) {
#ifdef WIN32
WSADATA wsa_data;
int res = WSAStartup(MAKEWORD(2,2), &wsa_data);
if (res) {
fprintf(stderr, "WSAStartup failed with error: %d\n", res);
exit(1);
}
#endif
int fd = dl_connect(3000);
if (fd < 0) {
return -1;
}
dl_t dl = dl_new();
dl->send_packet = my_send_packet;
dl->on_attach = my_on_attach;
dl->on_detach = my_on_detach;
my_t my = (my_t)malloc(sizeof(struct my_struct));
my->fd = fd;
dl->state = my;
if (dl->start(dl)) {
return -1;
}
char buf[BUF_LEN];
while (1) {
ssize_t read_bytes = recv(fd, buf, BUF_LEN, 0);
if (read_bytes < 0) {
#ifdef WIN32
if (WSAGetLastError() == WSAETIMEDOUT) {
#else
if (errno == EAGAIN) {
#endif
continue;
}
break;
}
if (dl->on_recv(dl, buf, read_bytes)) {
break;
}
}
free(dl->state);
dl_free(dl);
#ifdef WIN32
closesocket(fd);
WSACleanup();
#else
close(fd);
#endif
return 0;
}