mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Use fallback method when /executable urlsave is unset
This commit is contained in:
parent
4711fc62a3
commit
fb002a59b6
@ -9212,6 +9212,8 @@ _make_unique_filename(const char* filename)
|
|||||||
if (asprintf(&unique, "%s.%u", filename, i) < 0) {
|
if (asprintf(&unique, "%s.%u", filename, i) < 0) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return unique;
|
return unique;
|
||||||
@ -9295,11 +9297,14 @@ cmd_url_save(ProfWin* window, const char* const command, gchar** args)
|
|||||||
gboolean
|
gboolean
|
||||||
cmd_executable(ProfWin* window, const char* const command, gchar** args)
|
cmd_executable(ProfWin* window, const char* const command, gchar** args)
|
||||||
{
|
{
|
||||||
|
guint num_args = g_strv_length(args);
|
||||||
|
|
||||||
if (g_strcmp0(args[0], "avatar") == 0) {
|
if (g_strcmp0(args[0], "avatar") == 0) {
|
||||||
prefs_set_string(PREF_AVATAR_CMD, args[1]);
|
prefs_set_string(PREF_AVATAR_CMD, args[1]);
|
||||||
cons_show("Avatar command set to: %s", args[1]);
|
cons_show("Avatar command set to: %s", args[1]);
|
||||||
|
|
||||||
} else if (g_strcmp0(args[0], "urlopen") == 0) {
|
} else if (g_strcmp0(args[0], "urlopen") == 0) {
|
||||||
if (g_strv_length(args) < 4) {
|
if (num_args < 4) {
|
||||||
cons_bad_cmd_usage(command);
|
cons_bad_cmd_usage(command);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -9309,16 +9314,29 @@ cmd_executable(ProfWin* window, const char* const command, gchar** args)
|
|||||||
prefs_set_string_list_with_option(PREF_URL_OPEN_CMD, args[1], list);
|
prefs_set_string_list_with_option(PREF_URL_OPEN_CMD, args[1], list);
|
||||||
cons_show("`url open` command set to: %s for %s files", str, args[1]);
|
cons_show("`url open` command set to: %s for %s files", str, args[1]);
|
||||||
g_free(str);
|
g_free(str);
|
||||||
|
|
||||||
} else if (g_strcmp0(args[0], "urlsave") == 0) {
|
} else if (g_strcmp0(args[0], "urlsave") == 0) {
|
||||||
if (g_strv_length(args) < 3) {
|
|
||||||
|
if (num_args < 3) {
|
||||||
cons_bad_cmd_usage(command);
|
cons_bad_cmd_usage(command);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
gchar* str = g_strjoinv(" ", &args[2]);
|
if (g_strcmp0(args[1], "set") == 0 && num_args >= 4) {
|
||||||
prefs_set_string_with_option(PREF_URL_SAVE_CMD, args[1], str);
|
gchar* str = g_strjoinv(" ", &args[3]);
|
||||||
cons_show("`url save` command set to: %s for scheme %s", str, args[1]);
|
prefs_set_string_with_option(PREF_URL_SAVE_CMD, args[2], str);
|
||||||
|
cons_show("`url save` command set to: %s for scheme %s", str, args[2]);
|
||||||
g_free(str);
|
g_free(str);
|
||||||
|
|
||||||
|
} else if (g_strcmp0(args[1], "clear") == 0) {
|
||||||
|
prefs_set_string_with_option(PREF_URL_SAVE_CMD, args[2], NULL);
|
||||||
|
cons_show("`url save` will use internal download method for scheme %s", args[2]);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
cons_bad_cmd_usage(command);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
cons_bad_cmd_usage(command);
|
cons_bad_cmd_usage(command);
|
||||||
}
|
}
|
||||||
|
@ -2318,8 +2318,6 @@ _get_default_string(preference_t pref)
|
|||||||
return "false";
|
return "false";
|
||||||
case PREF_AVATAR_CMD:
|
case PREF_AVATAR_CMD:
|
||||||
return "xdg-open";
|
return "xdg-open";
|
||||||
case PREF_URL_SAVE_CMD:
|
|
||||||
return "curl -o %p %u";
|
|
||||||
default:
|
default:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user