diff --git a/src/command/cmd_defs.c b/src/command/cmd_defs.c index c9faed96..c4d2df4a 100644 --- a/src/command/cmd_defs.c +++ b/src/command/cmd_defs.c @@ -2523,6 +2523,7 @@ static const struct cmd_t command_defs[] = { "/executable urlopen default", "/executable urlsave set ", "/executable urlsave default", + "/executable editor set ", "/executable vcard_photo set ", "/executable vcard_photo default") CMD_DESC( @@ -2545,7 +2546,7 @@ static const struct cmd_t command_defs[] = { "/executable urlsave set \"curl %u -o %p\"", "/executable urlsave default", "/executable vcard_photo set \"feh %p\"", - "/executable editor set vim") + "/executable editor set \"emacsclient -t\"") }, { CMD_PREAMBLE("/url", diff --git a/src/tools/editor.c b/src/tools/editor.c index 350fb5b1..0efb4d6b 100644 --- a/src/tools/editor.c +++ b/src/tools/editor.c @@ -88,11 +88,16 @@ get_message_from_editor(gchar* message, gchar** returned_message) } char* editor = prefs_get_string(PREF_COMPOSE_EDITOR); + gchar* editor_with_filename = g_strdup_printf("%s %s", editor, filename); + gchar** editor_argv = g_strsplit(editor_with_filename, " ", 0); + + g_free(editor_with_filename); // Fork / exec pid_t pid = fork(); if (pid == 0) { - int x = execlp(editor, editor, filename, (char*)NULL); + int x = execvp(editor_argv[0], editor_argv); + g_strfreev(editor_argv); if (x == -1) { log_error("[Editor] Failed to exec %s", editor); }