Modified MAX_PATH usage to use more appropriate MAX_COMMAND_LENGTH

This commit is contained in:
Christian Murphy 2017-02-15 23:10:04 +00:00
parent b552231c1d
commit c3ea18f490
2 changed files with 26 additions and 22 deletions

View File

@ -320,16 +320,16 @@ static dialog_type get_dialog_app(char *cmd, size_t *cmd_size) {
bool platform_open_common_file_dialog(utf8 *outFilename, file_dialog_desc *desc, size_t outSize) { bool platform_open_common_file_dialog(utf8 *outFilename, file_dialog_desc *desc, size_t outSize) {
sint32 exit_value; sint32 exit_value;
char executable[MAX_PATH]; char executable[MAX_PATH];
char cmd[MAX_PATH]; char cmd[MAX_COMMAND_LENGTH];
char result[MAX_PATH]; char result[MAX_COMMAND_LENGTH];
size_t size; size_t size;
dialog_type dtype; dialog_type dtype;
char *action = NULL; char *action = NULL;
char *flags = NULL; char *flags = NULL;
char filter[MAX_PATH] = { 0 }; char filter[MAX_COMMAND_LENGTH] = { 0 };
char filterPatternRegex[64]; char filterPatternRegex[64];
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
dtype = get_dialog_app(executable, &size); dtype = get_dialog_app(executable, &size);
switch (dtype) { switch (dtype) {
@ -376,7 +376,7 @@ bool platform_open_common_file_dialog(utf8 *outFilename, file_dialog_desc *desc,
} }
} }
snprintf(cmd, MAX_PATH, "%s --title '%s' %s '%s/' ~ '%s'", executable, desc->title, action, desc->initial_directory, filter); snprintf(cmd, MAX_COMMAND_LENGTH, "%s --title '%s' %s '%s/' ~ '%s'", executable, desc->title, action, desc->initial_directory, filter);
break; break;
case DT_ZENITY: case DT_ZENITY:
action = "--file-selection"; action = "--file-selection";
@ -420,12 +420,12 @@ bool platform_open_common_file_dialog(utf8 *outFilename, file_dialog_desc *desc,
snprintf(filterTemp, countof(filterTemp), " --file-filter='%s | *'", (char *)language_get_string(STR_ALL_FILES)); snprintf(filterTemp, countof(filterTemp), " --file-filter='%s | *'", (char *)language_get_string(STR_ALL_FILES));
safe_strcat(filter, filterTemp, countof(filter)); safe_strcat(filter, filterTemp, countof(filter));
snprintf(cmd, MAX_PATH, "%s %s --filename='%s/' %s --title='%s' / %s", executable, action, desc->initial_directory, flags, desc->title, filter); snprintf(cmd, MAX_COMMAND_LENGTH, "%s %s --filename='%s/' %s --title='%s' / %s", executable, action, desc->initial_directory, flags, desc->title, filter);
break; break;
default: return 0; default: return 0;
} }
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
execute_cmd(cmd, &exit_value, result, &size); execute_cmd(cmd, &exit_value, result, &size);
if (exit_value != 0) { if (exit_value != 0) {
@ -436,17 +436,17 @@ bool platform_open_common_file_dialog(utf8 *outFilename, file_dialog_desc *desc,
log_verbose("filename = %s", result); log_verbose("filename = %s", result);
if (desc->type == FD_OPEN && access(result, F_OK) == -1) { if (desc->type == FD_OPEN && access(result, F_OK) == -1) {
char msg[MAX_PATH]; char msg[MAX_COMMAND_LENGTH];
snprintf(msg, MAX_PATH, "\"%s\" not found: %s, please choose another file\n", result, strerror(errno)); snprintf(msg, MAX_COMMAND_LENGTH, "\"%s\" not found: %s, please choose another file\n", result, strerror(errno));
platform_show_messagebox(msg); platform_show_messagebox(msg);
return platform_open_common_file_dialog(outFilename, desc, outSize); return platform_open_common_file_dialog(outFilename, desc, outSize);
} else } else
if (desc->type == FD_SAVE && access(result, F_OK) != -1 && dtype == DT_KDIALOG) { if (desc->type == FD_SAVE && access(result, F_OK) != -1 && dtype == DT_KDIALOG) {
snprintf(cmd, MAX_PATH, "%s --yesno \"Overwrite %s?\"", executable, result); snprintf(cmd, MAX_COMMAND_LENGTH, "%s --yesno \"Overwrite %s?\"", executable, result);
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
execute_cmd(cmd, &exit_value, 0, 0); execute_cmd(cmd, &exit_value, 0, 0);
if (exit_value != 0) { if (exit_value != 0) {
@ -463,25 +463,25 @@ utf8 *platform_open_directory_browser(utf8 *title) {
size_t size; size_t size;
dialog_type dtype; dialog_type dtype;
sint32 exit_value; sint32 exit_value;
char cmd[MAX_PATH]; char cmd[MAX_COMMAND_LENGTH];
char executable[MAX_PATH]; char executable[MAX_PATH];
char result[MAX_PATH]; char result[MAX_COMMAND_LENGTH];
char *return_value; char *return_value;
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
dtype = get_dialog_app(executable, &size); dtype = get_dialog_app(executable, &size);
switch (dtype) { switch (dtype) {
case DT_KDIALOG: case DT_KDIALOG:
snprintf(cmd, MAX_PATH, "%s --title '%s' --getexistingdirectory /", executable, title); snprintf(cmd, MAX_COMMAND_LENGTH, "%s --title '%s' --getexistingdirectory /", executable, title);
break; break;
case DT_ZENITY: case DT_ZENITY:
snprintf(cmd, MAX_PATH, "%s --title='%s' --file-selection --directory /", executable, title); snprintf(cmd, MAX_COMMAND_LENGTH, "%s --title='%s' --file-selection --directory /", executable, title);
break; break;
default: return 0; default: return 0;
} }
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
execute_cmd(cmd, &exit_value, result, &size); execute_cmd(cmd, &exit_value, result, &size);
if (exit_value != 0) { if (exit_value != 0) {
@ -498,27 +498,27 @@ utf8 *platform_open_directory_browser(utf8 *title) {
void platform_show_messagebox(const char * message) { void platform_show_messagebox(const char * message) {
size_t size; size_t size;
dialog_type dtype; dialog_type dtype;
char cmd[MAX_PATH]; char cmd[MAX_COMMAND_LENGTH];
char executable[MAX_PATH]; char executable[MAX_PATH];
log_verbose(message); log_verbose(message);
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
dtype = get_dialog_app(executable, &size); dtype = get_dialog_app(executable, &size);
switch (dtype) { switch (dtype) {
case DT_KDIALOG: case DT_KDIALOG:
snprintf(cmd, MAX_PATH, "%s --title \"OpenRCT2\" --msgbox \"%s\"", executable, message); snprintf(cmd, MAX_COMMAND_LENGTH, "%s --title \"OpenRCT2\" --msgbox \"%s\"", executable, message);
break; break;
case DT_ZENITY: case DT_ZENITY:
snprintf(cmd, MAX_PATH, "%s --title=\"OpenRCT2\" --info --text=\"%s\"", executable, message); snprintf(cmd, MAX_COMMAND_LENGTH, "%s --title=\"OpenRCT2\" --info --text=\"%s\"", executable, message);
break; break;
default: default:
SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_WARNING, "OpenRCT2", message, gWindow); SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_WARNING, "OpenRCT2", message, gWindow);
return; return;
} }
size = MAX_PATH; size = MAX_COMMAND_LENGTH;
execute_cmd(cmd, 0, 0, 0); execute_cmd(cmd, 0, 0, 0);
} }

View File

@ -35,6 +35,10 @@
#define MAX_PATH 260 #define MAX_PATH 260
#endif #endif
#ifndef MAX_COMMAND_LENGTH
#define MAX_COMMAND_LENGTH 512
#endif
#ifdef __MACOSX__ #ifdef __MACOSX__
#define KEYBOARD_PRIMARY_MODIFIER KMOD_GUI #define KEYBOARD_PRIMARY_MODIFIER KMOD_GUI
#else #else