|
|
|
|
@ -173,16 +173,26 @@ adb_create_argv(const char *serial, const char *const adb_cmd[], size_t len) {
|
|
|
|
|
|
|
|
|
|
static sc_pid
|
|
|
|
|
adb_execute_p(const char *serial, const char *const adb_cmd[], size_t len,
|
|
|
|
|
sc_pipe *pout) {
|
|
|
|
|
unsigned flags, sc_pipe *pout) {
|
|
|
|
|
const char **argv = adb_create_argv(serial, adb_cmd, len);
|
|
|
|
|
if (!argv) {
|
|
|
|
|
return SC_PROCESS_NONE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
unsigned process_flags = 0;
|
|
|
|
|
if (flags & SC_ADB_NO_STDOUT) {
|
|
|
|
|
process_flags |= SC_PROCESS_NO_STDOUT;
|
|
|
|
|
}
|
|
|
|
|
if (flags & SC_ADB_NO_STDERR) {
|
|
|
|
|
process_flags |= SC_PROCESS_NO_STDERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sc_pid pid;
|
|
|
|
|
enum sc_process_result r =
|
|
|
|
|
sc_process_execute_p(argv, &pid, 0, NULL, pout, NULL);
|
|
|
|
|
sc_process_execute_p(argv, &pid, process_flags, NULL, pout, NULL);
|
|
|
|
|
if (r != SC_PROCESS_SUCCESS) {
|
|
|
|
|
// If the execution itself failed (not the command exit code), log the
|
|
|
|
|
// error in all cases
|
|
|
|
|
show_adb_err_msg(r, argv);
|
|
|
|
|
pid = SC_PROCESS_NONE;
|
|
|
|
|
}
|
|
|
|
|
@ -192,61 +202,63 @@ adb_execute_p(const char *serial, const char *const adb_cmd[], size_t len,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sc_pid
|
|
|
|
|
adb_execute(const char *serial, const char *const adb_cmd[], size_t len) {
|
|
|
|
|
return adb_execute_p(serial, adb_cmd, len, NULL);
|
|
|
|
|
adb_execute(const char *serial, const char *const adb_cmd[], size_t len,
|
|
|
|
|
unsigned flags) {
|
|
|
|
|
return adb_execute_p(serial, adb_cmd, len, flags, NULL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
adb_forward(struct sc_intr *intr, const char *serial, uint16_t local_port,
|
|
|
|
|
const char *device_socket_name) {
|
|
|
|
|
const char *device_socket_name, unsigned flags) {
|
|
|
|
|
char local[4 + 5 + 1]; // tcp:PORT
|
|
|
|
|
char remote[108 + 14 + 1]; // localabstract:NAME
|
|
|
|
|
sprintf(local, "tcp:%" PRIu16, local_port);
|
|
|
|
|
snprintf(remote, sizeof(remote), "localabstract:%s", device_socket_name);
|
|
|
|
|
const char *const adb_cmd[] = {"forward", local, remote};
|
|
|
|
|
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd));
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd), flags);
|
|
|
|
|
return process_check_success_intr(intr, pid, "adb forward");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
adb_forward_remove(struct sc_intr *intr, const char *serial,
|
|
|
|
|
uint16_t local_port) {
|
|
|
|
|
uint16_t local_port, unsigned flags) {
|
|
|
|
|
char local[4 + 5 + 1]; // tcp:PORT
|
|
|
|
|
sprintf(local, "tcp:%" PRIu16, local_port);
|
|
|
|
|
const char *const adb_cmd[] = {"forward", "--remove", local};
|
|
|
|
|
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd));
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd), flags);
|
|
|
|
|
return process_check_success_intr(intr, pid, "adb forward --remove");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
adb_reverse(struct sc_intr *intr, const char *serial,
|
|
|
|
|
const char *device_socket_name, uint16_t local_port) {
|
|
|
|
|
const char *device_socket_name, uint16_t local_port,
|
|
|
|
|
unsigned flags) {
|
|
|
|
|
char local[4 + 5 + 1]; // tcp:PORT
|
|
|
|
|
char remote[108 + 14 + 1]; // localabstract:NAME
|
|
|
|
|
sprintf(local, "tcp:%" PRIu16, local_port);
|
|
|
|
|
snprintf(remote, sizeof(remote), "localabstract:%s", device_socket_name);
|
|
|
|
|
const char *const adb_cmd[] = {"reverse", remote, local};
|
|
|
|
|
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd));
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd), flags);
|
|
|
|
|
return process_check_success_intr(intr, pid, "adb reverse");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
adb_reverse_remove(struct sc_intr *intr, const char *serial,
|
|
|
|
|
const char *device_socket_name) {
|
|
|
|
|
const char *device_socket_name, unsigned flags) {
|
|
|
|
|
char remote[108 + 14 + 1]; // localabstract:NAME
|
|
|
|
|
snprintf(remote, sizeof(remote), "localabstract:%s", device_socket_name);
|
|
|
|
|
const char *const adb_cmd[] = {"reverse", "--remove", remote};
|
|
|
|
|
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd));
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd), flags);
|
|
|
|
|
return process_check_success_intr(intr, pid, "adb reverse --remove");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
adb_push(struct sc_intr *intr, const char *serial, const char *local,
|
|
|
|
|
const char *remote) {
|
|
|
|
|
const char *remote, unsigned flags) {
|
|
|
|
|
#ifdef __WINDOWS__
|
|
|
|
|
// Windows will parse the string, so the paths must be quoted
|
|
|
|
|
// (see sys/win/command.c)
|
|
|
|
|
@ -262,7 +274,7 @@ adb_push(struct sc_intr *intr, const char *serial, const char *local,
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
const char *const adb_cmd[] = {"push", local, remote};
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd));
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd), flags);
|
|
|
|
|
|
|
|
|
|
#ifdef __WINDOWS__
|
|
|
|
|
free((void *) remote);
|
|
|
|
|
@ -273,7 +285,8 @@ adb_push(struct sc_intr *intr, const char *serial, const char *local,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
adb_install(struct sc_intr *intr, const char *serial, const char *local) {
|
|
|
|
|
adb_install(struct sc_intr *intr, const char *serial, const char *local,
|
|
|
|
|
unsigned flags) {
|
|
|
|
|
#ifdef __WINDOWS__
|
|
|
|
|
// Windows will parse the string, so the local name must be quoted
|
|
|
|
|
// (see sys/win/command.c)
|
|
|
|
|
@ -284,7 +297,7 @@ adb_install(struct sc_intr *intr, const char *serial, const char *local) {
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
const char *const adb_cmd[] = {"install", "-r", local};
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd));
|
|
|
|
|
sc_pid pid = adb_execute(serial, adb_cmd, ARRAY_LEN(adb_cmd), flags);
|
|
|
|
|
|
|
|
|
|
#ifdef __WINDOWS__
|
|
|
|
|
free((void *) local);
|
|
|
|
|
@ -294,11 +307,11 @@ adb_install(struct sc_intr *intr, const char *serial, const char *local) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
char *
|
|
|
|
|
adb_get_serialno(struct sc_intr *intr) {
|
|
|
|
|
adb_get_serialno(struct sc_intr *intr, unsigned flags) {
|
|
|
|
|
const char *const adb_cmd[] = {"get-serialno"};
|
|
|
|
|
|
|
|
|
|
sc_pipe pout;
|
|
|
|
|
sc_pid pid = adb_execute_p(NULL, adb_cmd, ARRAY_LEN(adb_cmd), &pout);
|
|
|
|
|
sc_pid pid = adb_execute_p(NULL, adb_cmd, ARRAY_LEN(adb_cmd), flags, &pout);
|
|
|
|
|
if (pid == SC_PROCESS_NONE) {
|
|
|
|
|
LOGE("Could not execute \"adb get-serialno\"");
|
|
|
|
|
return NULL;
|
|
|
|
|
|