merged with phonegap

This commit is contained in:
Manickavasagam Senthil
2015-04-30 16:42:01 -04:00
3 changed files with 68 additions and 8 deletions

View File

@@ -34,16 +34,19 @@ $ npm install -g ios-deploy
-L, --justlaunch just launch the app and exit lldb -L, --justlaunch just launch the app and exit lldb
-v, --verbose enable verbose output -v, --verbose enable verbose output
-m, --noinstall directly start debugging without app install (-d not required) -m, --noinstall directly start debugging without app install (-d not required)
-p, --port <number> port used for device, default: 12345 -p, --port <number> port used for device, default: 12345
-r, --uninstall uninstall the app before install (do not use with -m; app cache and data are cleared) -r, --uninstall uninstall the app before install (do not use with -m; app cache and data are cleared)
-1, --bundle_id <bundle id> specify bundle id for list and upload -1, --bundle_id <bundle id> specify bundle id for list and upload
-l, --list list files -l, --list list files
-o, --upload <file> upload file -o, --upload <file> upload file
-w, --download download app tree -w, --download download app tree
-2, --to <target pathname> use together with up/download file/tree. specify target -2, --to <target pathname> use together with up/download file/tree. specify target
-V, --version print the executable version -D, --mkdir <dir> make directory on device
-R, --rm <path> remove file or directory on device (directories must be empty)
-V, --version print the executable version
-e, --exists check if the app with given bundle_id is installed or not -e, --exists check if the app with given bundle_id is installed or not
## Examples ## Examples
The commands below assume that you have an app called `my.app` with bundle id `bundle.id`. Substitute where necessary. The commands below assume that you have an app called `my.app` with bundle id `bundle.id`. Substitute where necessary.
@@ -59,7 +62,7 @@ The commands below assume that you have an app called `my.app` with bundle id `b
// Upload a file to your app's Documents folder // Upload a file to your app's Documents folder
ios-deploy --bundle_id 'bundle.id' --upload test.txt --to Documents/test.txt ios-deploy --bundle_id 'bundle.id' --upload test.txt --to Documents/test.txt
// Download your app's Documents, Library and tmp folders // Download your app's Documents, Library and tmp folders
ios-deploy --bundle_id 'bundle.id' --download --to MyDestinationFolder ios-deploy --bundle_id 'bundle.id' --download --to MyDestinationFolder
@@ -68,7 +71,7 @@ The commands below assume that you have an app called `my.app` with bundle id `b
// deploy and debug your app to a connected device, uninstall the app first // deploy and debug your app to a connected device, uninstall the app first
ios-deploy --uninstall --debug --bundle my.app ios-deploy --uninstall --debug --bundle my.app
// check whether an app by bundle id exists on the device (check return code `echo $?`) // check whether an app by bundle id exists on the device (check return code `echo $?`)
ios-deploy --exists --bundle_id com.apple.mobilemail ios-deploy --exists --bundle_id com.apple.mobilemail

View File

@@ -16,7 +16,7 @@
#include <netinet/tcp.h> #include <netinet/tcp.h>
#include "MobileDevice.h" #include "MobileDevice.h"
#define APP_VERSION "1.5.1" #define APP_VERSION "1.5.2"
#define PREP_CMDS_PATH "/tmp/fruitstrap-lldb-prep-cmds-" #define PREP_CMDS_PATH "/tmp/fruitstrap-lldb-prep-cmds-"
#define LLDB_SHELL "lldb -s " PREP_CMDS_PATH #define LLDB_SHELL "lldb -s " PREP_CMDS_PATH
/* /*
@@ -435,6 +435,18 @@ CFStringRef get_device_full_name(const AMDeviceRef device) {
fprintCFSTR(stdout, CFSTR("Device Name:[%@]\n"), device_name); fprintCFSTR(stdout, CFSTR("Device Name:[%@]\n"), device_name);
if (model_name != NULL) if (model_name != NULL)
fprintCFSTR(stdout, CFSTR("Model Name:[%@]\n"), model_name); fprintCFSTR(stdout, CFSTR("Model Name:[%@]\n"), model_name);
char *devName = MYCFStringCopyUTF8String(device_name);
printf("Device Name:[%s]\n",devName);
CFShow(device_name);
printf("\n");
free(devName);
char *mdlName = MYCFStringCopyUTF8String(model_name);
printf("Model Name:[%s]\n",mdlName);
printf("MM: [%s]\n",CFStringGetCStringPtr(model_name, kCFStringEncodingUTF8));
CFShow(model_name);
printf("\n");
free(mdlName);
} }
if(device_name != NULL && model_name != NULL) if(device_name != NULL && model_name != NULL)
@@ -1464,6 +1476,33 @@ void upload_file(AMDeviceRef device) {
free(file_content); free(file_content);
} }
void make_directory(AMDeviceRef device) {
service_conn_t houseFd = start_house_arrest_service(device);
afc_file_ref file_ref;
afc_connection afc_conn;
afc_connection* afc_conn_p = &afc_conn;
AFCConnectionOpen(houseFd, 0, &afc_conn_p);
assert(AFCDirectoryCreate(afc_conn_p, target_filename) == 0);
assert(AFCConnectionClose(afc_conn_p) == 0);
}
void remove_path(AMDeviceRef device) {
service_conn_t houseFd = start_house_arrest_service(device);
afc_file_ref file_ref;
afc_connection afc_conn;
afc_connection* afc_conn_p = &afc_conn;
AFCConnectionOpen(houseFd, 0, &afc_conn_p);
assert(AFCRemovePath(afc_conn_p, target_filename) == 0);
assert(AFCConnectionClose(afc_conn_p) == 0);
}
void handle_device(AMDeviceRef device) { void handle_device(AMDeviceRef device) {
//if (found_device) //if (found_device)
// return; // handle one device only // return; // handle one device only
@@ -1498,7 +1537,11 @@ void handle_device(AMDeviceRef device) {
} else if (strcmp("upload", command) == 0) { } else if (strcmp("upload", command) == 0) {
upload_file(device); upload_file(device);
} else if (strcmp("download", command) == 0) { } 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) {
remove_path(device);
} else if (strcmp("exists", command) == 0) { } else if (strcmp("exists", command) == 0) {
exit(app_exists(device)); exit(app_exists(device));
} }
@@ -1681,6 +1724,8 @@ void usage(const char* app) {
" -o, --upload <file> upload file\n" " -o, --upload <file> upload file\n"
" -w, --download download app tree\n" " -w, --download download app tree\n"
" -2, --to <target pathname> use together with up/download file/tree. specify target\n" " -2, --to <target pathname> use together with up/download file/tree. specify target\n"
" -D, --mkdir <dir> make directory on device\n"
" -R, --rm <path> remove file or directory on device (directories must be empty)\n"
" -V, --version print the executable version \n" " -V, --version print the executable version \n"
" -e, --exists check if the app with given bundle_id is installed or not \n", " -e, --exists check if the app with given bundle_id is installed or not \n",
app); app);
@@ -1712,6 +1757,8 @@ int main(int argc, char *argv[]) {
{ "upload", required_argument, NULL, 'o'}, { "upload", required_argument, NULL, 'o'},
{ "download", optional_argument, NULL, 'w'}, { "download", optional_argument, NULL, 'w'},
{ "to", required_argument, NULL, '2'}, { "to", required_argument, NULL, '2'},
{ "mkdir", required_argument, NULL, 'D'},
{ "rm", required_argument, NULL, 'R'},
{ "exists", no_argument, NULL, 'e'}, { "exists", no_argument, NULL, 'e'},
{ NULL, 0, NULL, 0 }, { NULL, 0, NULL, 0 },
}; };
@@ -1789,6 +1836,16 @@ int main(int argc, char *argv[]) {
command = "download"; command = "download";
list_root = optarg; list_root = optarg;
break; break;
case 'D':
command_only = true;
target_filename = optarg;
command = "mkdir";
break;
case 'R':
command_only = true;
target_filename = optarg;
command = "rm";
break;
case 'e': case 'e':
command_only = true; command_only = true;
command = "exists"; command = "exists";

View File

@@ -1,6 +1,6 @@
{ {
"name": "ios-deploy", "name": "ios-deploy",
"version": "1.5.1", "version": "1.5.2",
"description": "launch iOS apps iOS devices from the command line (Xcode 6)", "description": "launch iOS apps iOS devices from the command line (Xcode 6)",
"main": "ios-deploy", "main": "ios-deploy",
"scripts": { "scripts": {