|
|
|
@ -76,8 +76,8 @@ int AMDeviceGetInterfaceType(struct am_device *device);
|
|
|
|
|
bool found_device = false, debug = false, verbose = false, unbuffered = false, nostart = false, detect_only = false, install = true, uninstall = false, no_wifi = false;
|
|
|
|
|
bool command_only = false;
|
|
|
|
|
char *command = NULL;
|
|
|
|
|
char *target_filename = NULL;
|
|
|
|
|
char *upload_pathname = NULL;
|
|
|
|
|
char const*target_filename = NULL;
|
|
|
|
|
char const*upload_pathname = NULL;
|
|
|
|
|
char *bundle_id = NULL;
|
|
|
|
|
bool interactive = true;
|
|
|
|
|
bool justlaunch = false;
|
|
|
|
@ -86,7 +86,7 @@ char *device_id = NULL;
|
|
|
|
|
char *args = NULL;
|
|
|
|
|
char *list_root = NULL;
|
|
|
|
|
int _timeout = 0;
|
|
|
|
|
int port = 0; // 0 means "dynamically assigned"
|
|
|
|
|
int port = 0; // 0 means "dynamically assigned"
|
|
|
|
|
CFStringRef last_path = NULL;
|
|
|
|
|
service_conn_t gdbfd;
|
|
|
|
|
pid_t parent = 0;
|
|
|
|
@ -122,8 +122,8 @@ void on_error(NSString* format, ...)
|
|
|
|
|
NSString* str = [[[NSString alloc] initWithFormat:format arguments:valist] autorelease];
|
|
|
|
|
va_end(valist);
|
|
|
|
|
|
|
|
|
|
NSLog(@"[ !! ] %@", str);
|
|
|
|
|
|
|
|
|
|
NSLog(@"[ !! ] %@", str);
|
|
|
|
|
|
|
|
|
|
exit(exitcode_error);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -135,7 +135,7 @@ void on_sys_error(NSString* format, ...) {
|
|
|
|
|
va_start(valist, format);
|
|
|
|
|
NSString* str = [[[NSString alloc] initWithFormat:format arguments:valist] autorelease];
|
|
|
|
|
va_end(valist);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
on_error(@"%@ : %@", str, [NSString stringWithUTF8String:errstr]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -147,25 +147,25 @@ void __NSLogOut(NSString* format, va_list valist) {
|
|
|
|
|
void NSLogOut(NSString* format, ...) {
|
|
|
|
|
va_list valist;
|
|
|
|
|
va_start(valist, format);
|
|
|
|
|
__NSLogOut(format, valist);
|
|
|
|
|
__NSLogOut(format, valist);
|
|
|
|
|
va_end(valist);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void NSLogVerbose(NSString* format, ...) {
|
|
|
|
|
if (verbose) {
|
|
|
|
|
va_list valist;
|
|
|
|
|
va_start(valist, format);
|
|
|
|
|
__NSLogOut(format, valist);
|
|
|
|
|
va_end(valist);
|
|
|
|
|
}
|
|
|
|
|
if (verbose) {
|
|
|
|
|
va_list valist;
|
|
|
|
|
va_start(valist, format);
|
|
|
|
|
__NSLogOut(format, valist);
|
|
|
|
|
va_end(valist);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOL mkdirp(NSString* path) {
|
|
|
|
|
NSError* error = nil;
|
|
|
|
|
BOOL success = [[NSFileManager defaultManager] createDirectoryAtPath:path
|
|
|
|
|
withIntermediateDirectories:YES
|
|
|
|
|
attributes:nil
|
|
|
|
|
BOOL success = [[NSFileManager defaultManager] createDirectoryAtPath:path
|
|
|
|
|
withIntermediateDirectories:YES
|
|
|
|
|
attributes:nil
|
|
|
|
|
error:&error];
|
|
|
|
|
return success;
|
|
|
|
|
}
|
|
|
|
@ -185,23 +185,14 @@ Boolean path_exists(CFTypeRef path) {
|
|
|
|
|
|
|
|
|
|
CFStringRef find_path(CFStringRef rootPath, CFStringRef namePattern, CFStringRef expression) {
|
|
|
|
|
FILE *fpipe = NULL;
|
|
|
|
|
CFStringRef quotedRootPath = rootPath;
|
|
|
|
|
CFStringRef cf_command;
|
|
|
|
|
CFRange slashLocation;
|
|
|
|
|
|
|
|
|
|
if (CFStringGetCharacterAtIndex(rootPath, 0) != '`') {
|
|
|
|
|
quotedRootPath = CFStringCreateWithFormat(NULL, NULL, CFSTR("'%@'"), rootPath);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
slashLocation = CFStringFind(namePattern, CFSTR("/"), 0);
|
|
|
|
|
if (slashLocation.location == kCFNotFound) {
|
|
|
|
|
cf_command = CFStringCreateWithFormat(NULL, NULL, CFSTR("find %@ -name '%@' %@ 2>/dev/null | sort | tail -n 1"), quotedRootPath, namePattern, expression);
|
|
|
|
|
cf_command = CFStringCreateWithFormat(NULL, NULL, CFSTR("find %@ -name '%@' %@ 2>/dev/null | sort | tail -n 1"), rootPath, namePattern, expression);
|
|
|
|
|
} else {
|
|
|
|
|
cf_command = CFStringCreateWithFormat(NULL, NULL, CFSTR("find %@ -path '%@' %@ 2>/dev/null | sort | tail -n 1"), quotedRootPath, namePattern, expression);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (quotedRootPath != rootPath) {
|
|
|
|
|
CFRelease(quotedRootPath);
|
|
|
|
|
cf_command = CFStringCreateWithFormat(NULL, NULL, CFSTR("find %@ -path '%@' %@ 2>/dev/null | sort | tail -n 1"), rootPath, namePattern, expression);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
char command[1024] = { '\0' };
|
|
|
|
@ -331,6 +322,13 @@ const CFStringRef get_device_hardware_name(const AMDeviceRef device) {
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "P102AP", "iPad 4 (GSM)")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "P103AP", "iPad 4 (CDMA)")
|
|
|
|
|
|
|
|
|
|
// iPad Pro
|
|
|
|
|
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J98aAP", "iPad Pro (12.9\")")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J98aAP", "iPad Pro (12.9\")")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J127AP", "iPad Pro (9.7\")")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J128AP", "iPad Pro (9.7\")")
|
|
|
|
|
|
|
|
|
|
// iPad Mini
|
|
|
|
|
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "P105AP", "iPad mini")
|
|
|
|
@ -342,6 +340,7 @@ const CFStringRef get_device_hardware_name(const AMDeviceRef device) {
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "K66AP", "Apple TV 2G")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J33AP", "Apple TV 3G")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J33IAP", "Apple TV 3.1G")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "J42dAP", "Apple TV 4G")
|
|
|
|
|
|
|
|
|
|
// iPhone
|
|
|
|
|
|
|
|
|
@ -360,11 +359,18 @@ const CFStringRef get_device_hardware_name(const AMDeviceRef device) {
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N53AP", "iPhone 5s (Global/CDMA)")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N61AP", "iPhone 6 (GSM)")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N56AP", "iPhone 6 Plus")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N71mAP", "iPhone 6s")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N71AP", "iPhone 6s")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N66AP", "iPhone 6s Plus")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N66mAP", "iPhone 6s Plus")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N69AP", "iPhone SE")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N69uAP", "iPhone SE")
|
|
|
|
|
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N71mAP", "iPhone 6s")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N71AP", "iPhone 6s")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N66AP", "iPhone 6s Plus")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "N66mAP", "iPhone 6s Plus")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "D10AP", "iPhone 7")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "D101AP", "iPhone 7")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "D11AP", "iPhone 7 Plus")
|
|
|
|
|
GET_FRIENDLY_MODEL_NAME(model, "D111AP", "iPhone 7 Plus")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return model;
|
|
|
|
|
}
|
|
|
|
@ -397,8 +403,8 @@ CFStringRef get_device_full_name(const AMDeviceRef device) {
|
|
|
|
|
device_name = AMDeviceCopyValue(device, 0, CFSTR("DeviceName")),
|
|
|
|
|
model_name = get_device_hardware_name(device);
|
|
|
|
|
|
|
|
|
|
NSLogVerbose(@"Device Name: %@", device_name);
|
|
|
|
|
NSLogVerbose(@"Model Name: %@", model_name);
|
|
|
|
|
NSLogVerbose(@"Device Name: %@", device_name);
|
|
|
|
|
NSLogVerbose(@"Model Name: %@", model_name);
|
|
|
|
|
|
|
|
|
|
if(device_name != NULL && model_name != NULL)
|
|
|
|
|
{
|
|
|
|
@ -445,25 +451,39 @@ CFMutableArrayRef get_device_product_version_parts(AMDeviceRef device) {
|
|
|
|
|
CFStringRef copy_device_support_path(AMDeviceRef device) {
|
|
|
|
|
CFStringRef version = NULL;
|
|
|
|
|
CFStringRef build = AMDeviceCopyValue(device, 0, CFSTR("BuildVersion"));
|
|
|
|
|
CFStringRef deviceClass = AMDeviceCopyValue(device, 0, CFSTR("DeviceClass"));
|
|
|
|
|
CFStringRef path = NULL;
|
|
|
|
|
CFMutableArrayRef version_parts = get_device_product_version_parts(device);
|
|
|
|
|
|
|
|
|
|
NSLogVerbose(@"Device Class: %@", deviceClass);
|
|
|
|
|
NSLogVerbose(@"build: %@", build);
|
|
|
|
|
|
|
|
|
|
CFStringRef deviceClassPath_platform;
|
|
|
|
|
CFStringRef deviceClassPath_alt;
|
|
|
|
|
if (CFStringCompare(CFSTR("AppleTV"), deviceClass, 0) == kCFCompareEqualTo) {
|
|
|
|
|
deviceClassPath_platform = CFSTR("Platforms/AppleTVOS.platform/DeviceSupport");
|
|
|
|
|
deviceClassPath_alt = CFSTR("tvOS\\ DeviceSupport");
|
|
|
|
|
} else {
|
|
|
|
|
deviceClassPath_platform = CFSTR("Platforms/iPhoneOS.platform/DeviceSupport");
|
|
|
|
|
deviceClassPath_alt = CFSTR("iOS\\ DeviceSupport");
|
|
|
|
|
}
|
|
|
|
|
while (CFArrayGetCount(version_parts) > 0) {
|
|
|
|
|
version = CFStringCreateByCombiningStrings(NULL, version_parts, CFSTR("."));
|
|
|
|
|
NSLogVerbose(@"version: %@", version);
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("iOS DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("%@ (%@)"), version, build));
|
|
|
|
|
path = copy_xcode_path_for(deviceClassPath_alt, CFStringCreateWithFormat(NULL, NULL, CFSTR("%@\\ \\(%@\\)"), version, build));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("%@ (%@)"), version, build));
|
|
|
|
|
path = copy_xcode_path_for(deviceClassPath_platform, CFStringCreateWithFormat(NULL, NULL, CFSTR("%@\\ \\(%@\\)"), version, build));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("%@ (*)"), version));
|
|
|
|
|
path = copy_xcode_path_for(deviceClassPath_platform, CFStringCreateWithFormat(NULL, NULL, CFSTR("%@\\ \\(*\\)"), version));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport"), version);
|
|
|
|
|
path = copy_xcode_path_for(deviceClassPath_platform, version);
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport/Latest"), CFSTR(""));
|
|
|
|
|
path = copy_xcode_path_for(CFStringCreateWithFormat(NULL, NULL, CFSTR("%@%@"), deviceClassPath_platform, CFSTR("/Latest")), CFSTR(""));
|
|
|
|
|
}
|
|
|
|
|
CFRelease(version);
|
|
|
|
|
if (path != NULL) {
|
|
|
|
@ -474,7 +494,7 @@ CFStringRef copy_device_support_path(AMDeviceRef device) {
|
|
|
|
|
|
|
|
|
|
CFRelease(version_parts);
|
|
|
|
|
CFRelease(build);
|
|
|
|
|
|
|
|
|
|
CFRelease(deviceClass);
|
|
|
|
|
if (path == NULL)
|
|
|
|
|
on_error(@"Unable to locate DeviceSupport directory. This probably means you don't have Xcode installed, you will need to launch the app manually and logging output will not be shown!");
|
|
|
|
|
|
|
|
|
@ -484,25 +504,40 @@ CFStringRef copy_device_support_path(AMDeviceRef device) {
|
|
|
|
|
CFStringRef copy_developer_disk_image_path(AMDeviceRef device) {
|
|
|
|
|
CFStringRef version = NULL;
|
|
|
|
|
CFStringRef build = AMDeviceCopyValue(device, 0, CFSTR("BuildVersion"));
|
|
|
|
|
CFStringRef deviceClass = AMDeviceCopyValue(device, 0, CFSTR("DeviceClass"));
|
|
|
|
|
CFStringRef path = NULL;
|
|
|
|
|
CFMutableArrayRef version_parts = get_device_product_version_parts(device);
|
|
|
|
|
|
|
|
|
|
NSLogVerbose(@"Device Class: %@", deviceClass);
|
|
|
|
|
NSLogVerbose(@"build: %@", build);
|
|
|
|
|
CFStringRef deviceClassPath_platform;
|
|
|
|
|
CFStringRef deviceClassPath_alt;
|
|
|
|
|
if (CFStringCompare(CFSTR("AppleTV"), deviceClass, 0) == kCFCompareEqualTo) {
|
|
|
|
|
deviceClassPath_platform = CFSTR("Platforms/AppleTVOS.platform/DeviceSupport");
|
|
|
|
|
deviceClassPath_alt = CFSTR("tvOS\\ DeviceSupport");
|
|
|
|
|
} else {
|
|
|
|
|
deviceClassPath_platform = CFSTR("Platforms/iPhoneOS.platform/DeviceSupport");
|
|
|
|
|
deviceClassPath_alt = CFSTR("iOS\\ DeviceSupport");
|
|
|
|
|
}
|
|
|
|
|
// path = getPathForTVOS(device);
|
|
|
|
|
while (CFArrayGetCount(version_parts) > 0) {
|
|
|
|
|
version = CFStringCreateByCombiningStrings(NULL, version_parts, CFSTR("."));
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("iOS DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("%@ (%@)/DeveloperDiskImage.dmg"), version, build));
|
|
|
|
|
NSLogVerbose(@"version: %@", version);
|
|
|
|
|
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFStringCreateWithFormat(NULL, NULL, CFSTR("%@/%@\\ \\(%@\\)"), deviceClassPath_alt, version, build), CFSTR("DeveloperDiskImage.dmg"));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("%@ (%@)/DeveloperDiskImage.dmg"), version, build));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("*/%@ (*)/DeveloperDiskImage.dmg"), version));
|
|
|
|
|
path = copy_xcode_path_for(deviceClassPath_platform, CFStringCreateWithFormat(NULL, NULL, CFSTR("%@ (%@)/DeveloperDiskImage.dmg"), version, build));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport"), CFStringCreateWithFormat(NULL, NULL, CFSTR("%@/DeveloperDiskImage.dmg"), version));
|
|
|
|
|
path = copy_xcode_path_for(CFStringCreateWithFormat(NULL, NULL, CFSTR("%@/%@\\ \\(*\\)"), deviceClassPath_platform, version), CFSTR("DeveloperDiskImage.dmg"));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFSTR("Platforms/iPhoneOS.platform/DeviceSupport/Latest"), CFSTR("DeveloperDiskImage.dmg"));
|
|
|
|
|
path = copy_xcode_path_for(deviceClassPath_platform, CFStringCreateWithFormat(NULL, NULL, CFSTR("%@/DeveloperDiskImage.dmg"), version));
|
|
|
|
|
}
|
|
|
|
|
if (path == NULL) {
|
|
|
|
|
path = copy_xcode_path_for(CFStringCreateWithFormat(NULL, NULL, CFSTR("%@/Latest"), deviceClassPath_platform), CFSTR("/DeveloperDiskImage.dmg"));
|
|
|
|
|
}
|
|
|
|
|
CFRelease(version);
|
|
|
|
|
if (path != NULL) {
|
|
|
|
@ -513,6 +548,7 @@ CFStringRef copy_developer_disk_image_path(AMDeviceRef device) {
|
|
|
|
|
|
|
|
|
|
CFRelease(version_parts);
|
|
|
|
|
CFRelease(build);
|
|
|
|
|
CFRelease(deviceClass);
|
|
|
|
|
if (path == NULL)
|
|
|
|
|
on_error(@"Unable to locate DeveloperDiskImage.dmg. This probably means you don't have Xcode installed, you will need to launch the app manually and logging output will not be shown!");
|
|
|
|
|
|
|
|
|
@ -536,9 +572,9 @@ void mount_developer_image(AMDeviceRef device) {
|
|
|
|
|
CFStringRef image_path = copy_developer_disk_image_path(device);
|
|
|
|
|
CFStringRef sig_path = CFStringCreateWithFormat(NULL, NULL, CFSTR("%@.signature"), image_path);
|
|
|
|
|
|
|
|
|
|
NSLogVerbose(@"Device support path: %@", ds_path);
|
|
|
|
|
NSLogVerbose(@"Developer disk image: %@", image_path);
|
|
|
|
|
CFRelease(ds_path);
|
|
|
|
|
NSLogVerbose(@"Device support path: %@", ds_path);
|
|
|
|
|
NSLogVerbose(@"Developer disk image: %@", image_path);
|
|
|
|
|
CFRelease(ds_path);
|
|
|
|
|
|
|
|
|
|
FILE* sig = fopen(CFStringGetCStringPtr(sig_path, kCFStringEncodingMacRoman), "rb");
|
|
|
|
|
void *sig_buf = malloc(128);
|
|
|
|
@ -599,7 +635,7 @@ CFURLRef copy_device_app_url(AMDeviceRef device, CFStringRef identifier) {
|
|
|
|
|
CFDictionaryRef result = nil;
|
|
|
|
|
|
|
|
|
|
NSArray *a = [NSArray arrayWithObjects:
|
|
|
|
|
@"CFBundleIdentifier", // absolute must
|
|
|
|
|
@"CFBundleIdentifier", // absolute must
|
|
|
|
|
@"ApplicationDSID",
|
|
|
|
|
@"ApplicationType",
|
|
|
|
|
@"CFBundleExecutable",
|
|
|
|
@ -624,7 +660,7 @@ CFURLRef copy_device_app_url(AMDeviceRef device, CFStringRef identifier) {
|
|
|
|
|
nil];
|
|
|
|
|
|
|
|
|
|
NSDictionary *optionsDict = [NSDictionary dictionaryWithObject:a forKey:@"ReturnAttributes"];
|
|
|
|
|
CFDictionaryRef options = (CFDictionaryRef)optionsDict;
|
|
|
|
|
CFDictionaryRef options = (CFDictionaryRef)optionsDict;
|
|
|
|
|
|
|
|
|
|
check_error(AMDeviceLookupApplications(device, options, &result));
|
|
|
|
|
|
|
|
|
@ -643,9 +679,9 @@ CFStringRef copy_disk_app_identifier(CFURLRef disk_app_url) {
|
|
|
|
|
CFURLRef plist_url = CFURLCreateCopyAppendingPathComponent(NULL, disk_app_url, CFSTR("Info.plist"), false);
|
|
|
|
|
CFReadStreamRef plist_stream = CFReadStreamCreateWithFile(NULL, plist_url);
|
|
|
|
|
if (!CFReadStreamOpen(plist_stream)) {
|
|
|
|
|
on_error(@"Cannot read Info.plist file: %@", plist_url);
|
|
|
|
|
on_error(@"Cannot read Info.plist file: %@", plist_url);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CFPropertyListRef plist = CFPropertyListCreateWithStream(NULL, plist_stream, 0, kCFPropertyListImmutable, NULL, NULL);
|
|
|
|
|
CFStringRef bundle_identifier = CFRetain(CFDictionaryGetValue(plist, CFSTR("CFBundleIdentifier")));
|
|
|
|
|
CFReadStreamClose(plist_stream);
|
|
|
|
@ -722,14 +758,14 @@ void write_lldb_prep_cmds(AMDeviceRef device, CFURLRef disk_app_url) {
|
|
|
|
|
CFStringFindAndReplace(cmds, CFSTR("{disk_container}"), disk_container_path, range, 0);
|
|
|
|
|
|
|
|
|
|
NSString* python_file_path = [NSString stringWithFormat:@"/tmp/%@/fruitstrap_", tmpUUID];
|
|
|
|
|
mkdirp(python_file_path);
|
|
|
|
|
|
|
|
|
|
mkdirp(python_file_path);
|
|
|
|
|
|
|
|
|
|
NSString* python_command = @"fruitstrap_";
|
|
|
|
|
if(device_id != NULL) {
|
|
|
|
|
python_file_path = [python_file_path stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
python_command = [python_command stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
python_file_path = [python_file_path stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
python_command = [python_command stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
}
|
|
|
|
|
python_file_path = [python_file_path stringByAppendingString:@".py"];
|
|
|
|
|
python_file_path = [python_file_path stringByAppendingString:@".py"];
|
|
|
|
|
|
|
|
|
|
CFStringFindAndReplace(cmds, CFSTR("{python_command}"), (CFStringRef)python_command, range, 0);
|
|
|
|
|
range.length = CFStringGetLength(cmds);
|
|
|
|
@ -740,7 +776,7 @@ void write_lldb_prep_cmds(AMDeviceRef device, CFURLRef disk_app_url) {
|
|
|
|
|
NSString* prep_cmds_path = [NSString stringWithFormat:PREP_CMDS_PATH, tmpUUID];
|
|
|
|
|
if(device_id != NULL) {
|
|
|
|
|
prep_cmds_path = [prep_cmds_path stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
FILE *out = fopen([prep_cmds_path UTF8String], "w");
|
|
|
|
|
fwrite(CFDataGetBytePtr(cmds_data), CFDataGetLength(cmds_data), 1, out);
|
|
|
|
|
// Write additional commands based on mode we're running in
|
|
|
|
@ -993,12 +1029,12 @@ void launch_debugger(AMDeviceRef device, CFURLRef url) {
|
|
|
|
|
setup_dummy_pipe_on_stdin(pfd);
|
|
|
|
|
|
|
|
|
|
NSString* lldb_shell;
|
|
|
|
|
NSString* prep_cmds = [NSString stringWithFormat:PREP_CMDS_PATH, tmpUUID];
|
|
|
|
|
lldb_shell = [NSString stringWithFormat:LLDB_SHELL, prep_cmds];
|
|
|
|
|
|
|
|
|
|
NSString* prep_cmds = [NSString stringWithFormat:PREP_CMDS_PATH, tmpUUID];
|
|
|
|
|
lldb_shell = [NSString stringWithFormat:LLDB_SHELL, prep_cmds];
|
|
|
|
|
|
|
|
|
|
if(device_id != NULL) {
|
|
|
|
|
lldb_shell = [lldb_shell stringByAppendingString: [NSString stringWithUTF8String:device_id]];
|
|
|
|
|
}
|
|
|
|
|
lldb_shell = [lldb_shell stringByAppendingString: [NSString stringWithUTF8String:device_id]];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int status = system([lldb_shell UTF8String]); // launch lldb
|
|
|
|
|
if (status == -1)
|
|
|
|
@ -1034,10 +1070,10 @@ void launch_debugger_and_exit(AMDeviceRef device, CFURLRef url) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
NSString* prep_cmds = [NSString stringWithFormat:PREP_CMDS_PATH, tmpUUID];
|
|
|
|
|
NSString* lldb_shell = [NSString stringWithFormat:LLDB_SHELL, prep_cmds];
|
|
|
|
|
NSString* lldb_shell = [NSString stringWithFormat:LLDB_SHELL, prep_cmds];
|
|
|
|
|
if(device_id != NULL) {
|
|
|
|
|
lldb_shell = [lldb_shell stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
}
|
|
|
|
|
lldb_shell = [lldb_shell stringByAppendingString:[NSString stringWithUTF8String:device_id]];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int status = system([lldb_shell UTF8String]); // launch lldb
|
|
|
|
|
if (status == -1)
|
|
|
|
@ -1122,15 +1158,15 @@ void read_dir(service_conn_t afcFd, afc_connection* afc_conn_p, const char* dir,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
AFCKeyValueClose(afc_dict_p);
|
|
|
|
|
|
|
|
|
|
if (not_dir) {
|
|
|
|
|
NSLogOut(@"%@", [NSString stringWithUTF8String:dir]);
|
|
|
|
|
} else {
|
|
|
|
|
NSLogOut(@"%@/", [NSString stringWithUTF8String:dir]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (not_dir) {
|
|
|
|
|
if (callback) (*callback)(afc_conn_p, dir, not_dir);
|
|
|
|
|
NSLogOut(@"%@", [NSString stringWithUTF8String:dir]);
|
|
|
|
|
} else {
|
|
|
|
|
NSLogOut(@"%@/", [NSString stringWithUTF8String:dir]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (not_dir) {
|
|
|
|
|
if (callback) (*callback)(afc_conn_p, dir, not_dir);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -1192,9 +1228,9 @@ service_conn_t start_house_arrest_service(AMDeviceRef device) {
|
|
|
|
|
return houseFd;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
char* get_filename_from_path(char* path)
|
|
|
|
|
char const* get_filename_from_path(char const* path)
|
|
|
|
|
{
|
|
|
|
|
char *ptr = path + strlen(path);
|
|
|
|
|
char const*ptr = path + strlen(path);
|
|
|
|
|
while (ptr > path)
|
|
|
|
|
{
|
|
|
|
|
if (*ptr == '/')
|
|
|
|
@ -1208,7 +1244,7 @@ char* get_filename_from_path(char* path)
|
|
|
|
|
return ptr+1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void* read_file_to_memory(char * path, size_t* file_size)
|
|
|
|
|
void* read_file_to_memory(char const * path, size_t* file_size)
|
|
|
|
|
{
|
|
|
|
|
struct stat buf;
|
|
|
|
|
int err = stat(path, &buf);
|
|
|
|
@ -1266,7 +1302,7 @@ int app_exists(AMDeviceRef device)
|
|
|
|
|
check_error(AMDeviceStopSession(device));
|
|
|
|
|
check_error(AMDeviceDisconnect(device));
|
|
|
|
|
if (appExists)
|
|
|
|
|
return 0;
|
|
|
|
|
return 0;
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -1276,13 +1312,13 @@ void list_bundle_id(AMDeviceRef device)
|
|
|
|
|
assert(AMDeviceIsPaired(device));
|
|
|
|
|
check_error(AMDeviceValidatePairing(device));
|
|
|
|
|
check_error(AMDeviceStartSession(device));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
NSArray *a = [NSArray arrayWithObjects:@"CFBundleIdentifier", nil];
|
|
|
|
|
NSDictionary *optionsDict = [NSDictionary dictionaryWithObject:a forKey:@"ReturnAttributes"];
|
|
|
|
|
CFDictionaryRef options = (CFDictionaryRef)optionsDict;
|
|
|
|
|
CFDictionaryRef result = nil;
|
|
|
|
|
check_error(AMDeviceLookupApplications(device, options, &result));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CFIndex count;
|
|
|
|
|
count = CFDictionaryGetCount(result);
|
|
|
|
|
const void *keys[count];
|
|
|
|
@ -1290,7 +1326,7 @@ void list_bundle_id(AMDeviceRef device)
|
|
|
|
|
for(int i = 0; i < count; ++i) {
|
|
|
|
|
NSLogOut(@"%@", (CFStringRef)keys[i]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
check_error(AMDeviceStopSession(device));
|
|
|
|
|
check_error(AMDeviceDisconnect(device));
|
|
|
|
|
}
|
|
|
|
@ -1304,35 +1340,35 @@ void copy_file_callback(afc_connection* afc_conn_p, const char *name,int file)
|
|
|
|
|
if (*local_name=='\0') return;
|
|
|
|
|
|
|
|
|
|
if (file) {
|
|
|
|
|
afc_file_ref fref;
|
|
|
|
|
int err = AFCFileRefOpen(afc_conn_p,name,1,&fref);
|
|
|
|
|
afc_file_ref fref;
|
|
|
|
|
int err = AFCFileRefOpen(afc_conn_p,name,1,&fref);
|
|
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
|
fprintf(stderr,"AFCFileRefOpen(\"%s\") failed: %d\n",name,err);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (err) {
|
|
|
|
|
fprintf(stderr,"AFCFileRefOpen(\"%s\") failed: %d\n",name,err);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FILE *fp = fopen(local_name,"w");
|
|
|
|
|
FILE *fp = fopen(local_name,"w");
|
|
|
|
|
|
|
|
|
|
if (fp==NULL) {
|
|
|
|
|
fprintf(stderr,"fopen(\"%s\",\"w\") failer: %s\n",local_name,strerror(errno));
|
|
|
|
|
AFCFileRefClose(afc_conn_p,fref);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (fp==NULL) {
|
|
|
|
|
fprintf(stderr,"fopen(\"%s\",\"w\") failer: %s\n",local_name,strerror(errno));
|
|
|
|
|
AFCFileRefClose(afc_conn_p,fref);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
char buf[4096];
|
|
|
|
|
size_t sz=sizeof(buf);
|
|
|
|
|
char buf[4096];
|
|
|
|
|
size_t sz=sizeof(buf);
|
|
|
|
|
|
|
|
|
|
while (AFCFileRefRead(afc_conn_p,fref,buf,&sz)==0 && sz) {
|
|
|
|
|
fwrite(buf,sz,1,fp);
|
|
|
|
|
sz = sizeof(buf);
|
|
|
|
|
}
|
|
|
|
|
while (AFCFileRefRead(afc_conn_p,fref,buf,&sz)==0 && sz) {
|
|
|
|
|
fwrite(buf,sz,1,fp);
|
|
|
|
|
sz = sizeof(buf);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
AFCFileRefClose(afc_conn_p,fref);
|
|
|
|
|
fclose(fp);
|
|
|
|
|
AFCFileRefClose(afc_conn_p,fref);
|
|
|
|
|
fclose(fp);
|
|
|
|
|
} else {
|
|
|
|
|
if (mkdir(local_name,0777) && errno!=EEXIST)
|
|
|
|
|
fprintf(stderr,"mkdir(\"%s\") failed: %s\n",local_name,strerror(errno));
|
|
|
|
|
if (mkdir(local_name,0777) && errno!=EEXIST)
|
|
|
|
|
fprintf(stderr,"mkdir(\"%s\") failed: %s\n",local_name,strerror(errno));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -1341,29 +1377,29 @@ void download_tree(AMDeviceRef device)
|
|
|
|
|
service_conn_t houseFd = start_house_arrest_service(device);
|
|
|
|
|
afc_connection* afc_conn_p = NULL;
|
|
|
|
|
char *dirname = NULL;
|
|
|
|
|
|
|
|
|
|
list_root = list_root? list_root : "/";
|
|
|
|
|
target_filename = target_filename? target_filename : ".";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list_root = list_root? list_root : "/";
|
|
|
|
|
target_filename = target_filename? target_filename : ".";
|
|
|
|
|
|
|
|
|
|
NSString* targetPath = [NSString pathWithComponents:@[ @(target_filename), @(list_root)] ];
|
|
|
|
|
mkdirp([targetPath stringByDeletingLastPathComponent]);
|
|
|
|
|
|
|
|
|
|
if (AFCConnectionOpen(houseFd, 0, &afc_conn_p) == 0) do {
|
|
|
|
|
|
|
|
|
|
if (target_filename) {
|
|
|
|
|
dirname = strdup(target_filename);
|
|
|
|
|
mkdirp(@(dirname));
|
|
|
|
|
if (mkdir(dirname,0777) && errno!=EEXIST) {
|
|
|
|
|
fprintf(stderr,"mkdir(\"%s\") failed: %s\n",dirname,strerror(errno));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (chdir(dirname)) {
|
|
|
|
|
fprintf(stderr,"chdir(\"%s\") failed: %s\n",dirname,strerror(errno));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (target_filename) {
|
|
|
|
|
dirname = strdup(target_filename);
|
|
|
|
|
mkdirp(@(dirname));
|
|
|
|
|
if (mkdir(dirname,0777) && errno!=EEXIST) {
|
|
|
|
|
fprintf(stderr,"mkdir(\"%s\") failed: %s\n",dirname,strerror(errno));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (chdir(dirname)) {
|
|
|
|
|
fprintf(stderr,"chdir(\"%s\") failed: %s\n",dirname,strerror(errno));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
read_dir(houseFd, afc_conn_p, list_root, copy_file_callback);
|
|
|
|
|
read_dir(houseFd, afc_conn_p, list_root, copy_file_callback);
|
|
|
|
|
|
|
|
|
|
} while(0);
|
|
|
|
|
|
|
|
|
@ -1371,10 +1407,12 @@ void download_tree(AMDeviceRef device)
|
|
|
|
|
if (afc_conn_p) AFCConnectionClose(afc_conn_p);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void upload_file(AMDeviceRef device) {
|
|
|
|
|
service_conn_t houseFd = start_house_arrest_service(device);
|
|
|
|
|
void upload_dir(AMDeviceRef device, afc_connection* afc_conn_p, NSString* source, NSString* destination);
|
|
|
|
|
void upload_single_file(AMDeviceRef device, afc_connection* afc_conn_p, NSString* sourcePath, NSString* destinationPath);
|
|
|
|
|
|
|
|
|
|
afc_file_ref file_ref;
|
|
|
|
|
void upload_file(AMDeviceRef device)
|
|
|
|
|
{
|
|
|
|
|
service_conn_t houseFd = start_house_arrest_service(device);
|
|
|
|
|
|
|
|
|
|
afc_connection afc_conn;
|
|
|
|
|
afc_connection* afc_conn_p = &afc_conn;
|
|
|
|
@ -1387,44 +1425,82 @@ void upload_file(AMDeviceRef device) {
|
|
|
|
|
target_filename = get_filename_from_path(upload_pathname);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
NSString* sourcePath = [NSString stringWithUTF8String: upload_pathname];
|
|
|
|
|
NSString* destinationPath = [NSString stringWithUTF8String: target_filename];
|
|
|
|
|
|
|
|
|
|
BOOL isDir;
|
|
|
|
|
bool exists = [[NSFileManager defaultManager] fileExistsAtPath: sourcePath isDirectory: &isDir];
|
|
|
|
|
if (!exists)
|
|
|
|
|
{
|
|
|
|
|
on_error(@"Could not find file: %s", upload_pathname);
|
|
|
|
|
}
|
|
|
|
|
else if (isDir)
|
|
|
|
|
{
|
|
|
|
|
upload_dir(device, afc_conn_p, sourcePath, destinationPath);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
upload_single_file(device, afc_conn_p, sourcePath, destinationPath);
|
|
|
|
|
}
|
|
|
|
|
assert(AFCConnectionClose(afc_conn_p) == 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void upload_single_file(AMDeviceRef device, afc_connection* afc_conn_p, NSString* sourcePath, NSString* destinationPath) {
|
|
|
|
|
|
|
|
|
|
afc_file_ref file_ref;
|
|
|
|
|
|
|
|
|
|
// read_dir(houseFd, NULL, "/", NULL);
|
|
|
|
|
|
|
|
|
|
size_t file_size;
|
|
|
|
|
void* file_content = read_file_to_memory(upload_pathname, &file_size);
|
|
|
|
|
void* file_content = read_file_to_memory([sourcePath fileSystemRepresentation], &file_size);
|
|
|
|
|
|
|
|
|
|
if (!file_content)
|
|
|
|
|
{
|
|
|
|
|
on_error(@"Could not open file: %@", [NSString stringWithUTF8String:upload_pathname]);
|
|
|
|
|
on_error(@"Could not open file: %@", sourcePath);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Make sure the directory was created
|
|
|
|
|
{
|
|
|
|
|
char *dirpath = strdup(target_filename);
|
|
|
|
|
char *c = dirpath, *lastSlash = dirpath;
|
|
|
|
|
while(*c) {
|
|
|
|
|
if(*c == '/') {
|
|
|
|
|
lastSlash = c;
|
|
|
|
|
}
|
|
|
|
|
c++;
|
|
|
|
|
}
|
|
|
|
|
*lastSlash = '\0';
|
|
|
|
|
check_error(AFCDirectoryCreate(afc_conn_p, dirpath));
|
|
|
|
|
NSString *dirpath = [destinationPath stringByDeletingLastPathComponent];
|
|
|
|
|
check_error(AFCDirectoryCreate(afc_conn_p, [dirpath fileSystemRepresentation]));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int ret = AFCFileRefOpen(afc_conn_p, target_filename, 3, &file_ref);
|
|
|
|
|
int ret = AFCFileRefOpen(afc_conn_p, [destinationPath fileSystemRepresentation], 3, &file_ref);
|
|
|
|
|
if (ret == 0x000a) {
|
|
|
|
|
on_error(@"Cannot write to %@. Permission error.", [NSString stringWithUTF8String:target_filename]);
|
|
|
|
|
on_error(@"Cannot write to %@. Permission error.", destinationPath);
|
|
|
|
|
}
|
|
|
|
|
if (ret == 0x0009) {
|
|
|
|
|
on_error(@"Target %@ is a directory.", [NSString stringWithUTF8String:target_filename]);
|
|
|
|
|
on_error(@"Target %@ is a directory.", destinationPath);
|
|
|
|
|
}
|
|
|
|
|
assert(ret == 0);
|
|
|
|
|
assert(AFCFileRefWrite(afc_conn_p, file_ref, file_content, file_size) == 0);
|
|
|
|
|
assert(AFCFileRefClose(afc_conn_p, file_ref) == 0);
|
|
|
|
|
assert(AFCConnectionClose(afc_conn_p) == 0);
|
|
|
|
|
|
|
|
|
|
free(file_content);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void upload_dir(AMDeviceRef device, afc_connection* afc_conn_p, NSString* source, NSString* destination)
|
|
|
|
|
{
|
|
|
|
|
check_error(AFCDirectoryCreate(afc_conn_p, [destination fileSystemRepresentation]));
|
|
|
|
|
destination = [destination copy];
|
|
|
|
|
for (NSString* item in [[NSFileManager defaultManager] contentsOfDirectoryAtPath: source error: nil])
|
|
|
|
|
{
|
|
|
|
|
NSString* sourcePath = [source stringByAppendingPathComponent: item];
|
|
|
|
|
NSString* destinationPath = [destination stringByAppendingPathComponent: item];
|
|
|
|
|
BOOL isDir;
|
|
|
|
|
[[NSFileManager defaultManager] fileExistsAtPath: sourcePath isDirectory: &isDir];
|
|
|
|
|
if (isDir)
|
|
|
|
|
{
|
|
|
|
|
upload_dir(device, afc_conn_p, sourcePath, destinationPath);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
upload_single_file(device, afc_conn_p, sourcePath, destinationPath);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void make_directory(AMDeviceRef device) {
|
|
|
|
|
service_conn_t houseFd = start_house_arrest_service(device);
|
|
|
|
|
|
|
|
|
@ -1482,12 +1558,12 @@ void uninstall_app(AMDeviceRef device) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void handle_device(AMDeviceRef device) {
|
|
|
|
|
NSLogVerbose(@"Already found device? %d", found_device);
|
|
|
|
|
NSLogVerbose(@"Already found device? %d", found_device);
|
|
|
|
|
|
|
|
|
|
CFStringRef found_device_id = AMDeviceCopyDeviceIdentifier(device),
|
|
|
|
|
device_full_name = get_device_full_name(device),
|
|
|
|
|
device_interface_name = get_device_interface_name(device);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (detect_only) {
|
|
|
|
|
NSLogOut(@"[....] Found %@ connected through %@.", device_full_name, device_interface_name);
|
|
|
|
|
found_device = true;
|
|
|
|
@ -1515,7 +1591,7 @@ void handle_device(AMDeviceRef device) {
|
|
|
|
|
} else if (strcmp("upload", command) == 0) {
|
|
|
|
|
upload_file(device);
|
|
|
|
|
} else if (strcmp("download", command) == 0) {
|
|
|
|
|
download_tree(device);
|
|
|
|
|
download_tree(device);
|
|
|
|
|
} else if (strcmp("mkdir", command) == 0) {
|
|
|
|
|
make_directory(device);
|
|
|
|
|
} else if (strcmp("rm", command) == 0) {
|
|
|
|
@ -1636,17 +1712,17 @@ void device_callback(struct am_device_notification_callback_info *info, void *ar
|
|
|
|
|
switch (info->msg) {
|
|
|
|
|
case ADNCI_MSG_CONNECTED:
|
|
|
|
|
if(device_id != NULL || !debug || AMDeviceGetInterfaceType(info->dev) != 2) {
|
|
|
|
|
if (no_wifi && AMDeviceGetInterfaceType(info->dev) == 2)
|
|
|
|
|
{
|
|
|
|
|
NSLogVerbose(@"Skipping wifi device (type: %d)", AMDeviceGetInterfaceType(info->dev));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
NSLogVerbose(@"Handling device type: %d", AMDeviceGetInterfaceType(info->dev));
|
|
|
|
|
handle_device(info->dev);
|
|
|
|
|
}
|
|
|
|
|
if (no_wifi && AMDeviceGetInterfaceType(info->dev) == 2)
|
|
|
|
|
{
|
|
|
|
|
NSLogVerbose(@"Skipping wifi device (type: %d)", AMDeviceGetInterfaceType(info->dev));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
NSLogVerbose(@"Handling device type: %d", AMDeviceGetInterfaceType(info->dev));
|
|
|
|
|
handle_device(info->dev);
|
|
|
|
|
}
|
|
|
|
|
} else if(best_device_match == NULL) {
|
|
|
|
|
NSLogVerbose(@"Best device match: %d", AMDeviceGetInterfaceType(info->dev));
|
|
|
|
|
NSLogVerbose(@"Best device match: %d", AMDeviceGetInterfaceType(info->dev));
|
|
|
|
|
best_device_match = info->dev;
|
|
|
|
|
CFRetain(best_device_match);
|
|
|
|
|
}
|
|
|
|
@ -1658,7 +1734,7 @@ void device_callback(struct am_device_notification_callback_info *info, void *ar
|
|
|
|
|
void timeout_callback(CFRunLoopTimerRef timer, void *info) {
|
|
|
|
|
if ((!found_device) && (!detect_only)) {
|
|
|
|
|
if(best_device_match != NULL) {
|
|
|
|
|
NSLogVerbose(@"Handling best device match.");
|
|
|
|
|
NSLogVerbose(@"Handling best device match.");
|
|
|
|
|
handle_device(best_device_match);
|
|
|
|
|
|
|
|
|
|
CFRelease(best_device_match);
|
|
|
|
@ -1681,8 +1757,8 @@ void timeout_callback(CFRunLoopTimerRef timer, void *info) {
|
|
|
|
|
int mypid = getpid();
|
|
|
|
|
if ((parent != 0) && (parent == mypid) && (child != 0))
|
|
|
|
|
{
|
|
|
|
|
NSLogVerbose(@"Timeout. Killing child (%d) tree.", child);
|
|
|
|
|
kill_ptree(child, SIGHUP);
|
|
|
|
|
NSLogVerbose(@"Timeout. Killing child (%d) tree.", child);
|
|
|
|
|
kill_ptree(child, SIGHUP);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
exit(0);
|
|
|
|
@ -1729,12 +1805,12 @@ void show_version() {
|
|
|
|
|
|
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
|
|
|
|
|
|
// create a UUID for tmp purposes
|
|
|
|
|
// create a UUID for tmp purposes
|
|
|
|
|
CFUUIDRef uuid = CFUUIDCreate(NULL);
|
|
|
|
|
CFStringRef str = CFUUIDCreateString(NULL, uuid);
|
|
|
|
|
CFRelease(uuid);
|
|
|
|
|
tmpUUID = [(NSString*)str autorelease];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static struct option longopts[] = {
|
|
|
|
|
{ "debug", no_argument, NULL, 'd' },
|
|
|
|
|
{ "id", required_argument, NULL, 'i' },
|
|
|
|
|