diff options
| -rw-r--r-- | src/restore.c | 48 | 
1 files changed, 20 insertions, 28 deletions
| diff --git a/src/restore.c b/src/restore.c index 676d449..e7a9930 100644 --- a/src/restore.c +++ b/src/restore.c @@ -299,10 +299,21 @@ static int restore_is_current_device(struct idevicerestore_client_t* client, con  	return (strcasecmp(this_srnm, client->srnm) == 0);  } +static void restore_device_event_cb(const idevice_event_t *event, void *user_data) +{ +	if (event->event == IDEVICE_DEVICE_ADD) { +		struct idevicerestore_client_t* client = (struct idevicerestore_client_t*)user_data; +		if (restore_is_current_device(client, event->udid)) { +			restore_device_connected = 1; +			client->udid = strdup(event->udid); +		} +	} +} +  int restore_open_with_timeout(struct idevicerestore_client_t* client) {  	int i = 0;  	int j = 0; -	int attempts = 20; +	int attempts = 180;  	char *type = NULL;  	uint64_t version = 0;  	idevice_t device = NULL; @@ -332,38 +343,19 @@ int restore_open_with_timeout(struct idevicerestore_client_t* client) {  	restore_device_connected = 0; -	info("trying to connect...\n"); -	for (i = 0; i < attempts; i++) { -		int num_devices = 0; -		char **devices = NULL; -		idevice_get_device_list(&devices, &num_devices); -		if (num_devices == 0) { -			sleep(2); -			continue; -		} -		for (j = 0; j < num_devices; j++) { -			if (restore_is_current_device(client, devices[j])) { -				restore_device_connected = 1; -				client->udid = strdup(devices[j]); -				break; -			} -		} -		idevice_device_list_free(devices); - -		if (restore_device_connected == 1) { +	info("Waiting for device...\n"); +	idevice_event_subscribe(restore_device_event_cb, client); +	i = 0; +	while (i++ < attempts) { +		if (restore_device_connected) {  			break;  		} - -		if (i == attempts) { -			error("ERROR: Unable to connect to device in restore mode\n"); -			return -1; -		} - -		sleep(2); +		sleep(1);  	} +	idevice_event_unsubscribe();  	if (!restore_device_connected) { -		error("hm... could not connect\n"); +		error("ERROR: Unable to connect to device in restore mode\n");  		return -1;  	} | 
