dropping a feature: remove the ability to use the 'formatter' command

Since the last version, the user can filter an entire buffer through
an external command.  This external command can also be a formatting
program, so there is no longer any need for this specific and special
formatter command.
master
Benno Schulenberg 2018-07-10 16:24:22 +02:00
parent 94b4f07281
commit 975b491235
8 changed files with 14 additions and 164 deletions

View File

@ -986,11 +986,6 @@ on the system and will be silently ignored otherwise.)
Use the given @var{program} to do a syntax check on the current buffer. Use the given @var{program} to do a syntax check on the current buffer.
(This overrides the speller function.) (This overrides the speller function.)
@item formatter @var{program} [@var{arg} @dots{}]
Use the given @var{program} to automatically reformat the text in
the current buffer --- useful for a programming language like Go.
(This overrides the speller and linter functions.)
@item comment "@var{string}" @item comment "@var{string}"
Use the given string for commenting and uncommenting lines. Use the given string for commenting and uncommenting lines.
If the string contains a vertical bar or pipe character (@t{|}), If the string contains a vertical bar or pipe character (@t{|}),
@ -1034,8 +1029,7 @@ to @code{icolor}.
@item extendsyntax @var{name} @var{command} [@var{arg} @dots{}] @item extendsyntax @var{name} @var{command} [@var{arg} @dots{}]
Extend the syntax previously defined as "@var{name}" with another @var{command}. Extend the syntax previously defined as "@var{name}" with another @var{command}.
This allows you to add a new @code{color}, @code{icolor}, @code{header}, This allows you to add a new @code{color}, @code{icolor}, @code{header},
@code{magic}, @code{comment}, @code{linter}, or @code{formatter} command @code{magic}, @code{comment}, or @code{linter} command to an already
to an already
defined syntax --- useful when you want to slightly improve a syntax defined defined syntax --- useful when you want to slightly improve a syntax defined
in one of the system-installed files (which normally are not writable). in one of the system-installed files (which normally are not writable).
@ -1164,7 +1158,7 @@ Shows the current cursor position: the line, column, and character positions.
Counts the number of words, lines and characters in the current buffer. Counts the number of words, lines and characters in the current buffer.
@item speller @item speller
Invokes a spell-checking program (or linting program, or formatter program, Invokes a spell-checking program (or linting program,
if the active syntax defines such a thing). if the active syntax defines such a thing).
@item justify @item justify

View File

@ -341,11 +341,6 @@ system and will be silently ignored otherwise.)
Use the given \fIprogram\fR to run a syntax check on the current buffer. Use the given \fIprogram\fR to run a syntax check on the current buffer.
(This overrides the speller function.) (This overrides the speller function.)
.TP .TP
.BI formatter " program " \fR[ "arg " \fR...]
Use the given \fIprogram\fR to automatically reformat the text in
the current buffer -- useful in a programming language like Go.
(This overrides the speller and linter functions.)
.TP
.BI "comment """ string """ .BI "comment """ string """
Use the given \fIstring\fR for commenting and uncommenting lines. Use the given \fIstring\fR for commenting and uncommenting lines.
If the string contains a vertical bar or pipe character (\fB|\fR), If the string contains a vertical bar or pipe character (\fB|\fR),
@ -391,7 +386,7 @@ to \fBicolor\fP.
.BI extendsyntax " name command " \fR[ "arg " \fR...] .BI extendsyntax " name command " \fR[ "arg " \fR...]
Extend the syntax previously defined as \fIname\fR with another Extend the syntax previously defined as \fIname\fR with another
\fIcommand\fR. This allows adding a new \fBcolor\fP, \fBicolor\fP, \fIcommand\fR. This allows adding a new \fBcolor\fP, \fBicolor\fP,
\fBheader\fP, \fBmagic\fP, \fBcomment\fP, \fBlinter\fP, or \fBformatter\fP \fBheader\fP, \fBmagic\fP, \fBcomment\fP, or \fBlinter\fP
command to an already defined syntax -- useful when you want to command to an already defined syntax -- useful when you want to
slightly improve a syntax defined in one of the system-installed slightly improve a syntax defined in one of the system-installed
files (which normally are not writable). files (which normally are not writable).
@ -514,7 +509,7 @@ Shows the current cursor position: the line, column, and character positions.
Counts the number of words, lines and characters in the current buffer. Counts the number of words, lines and characters in the current buffer.
.TP .TP
.B speller .B speller
Invokes a spell-checking program (or linting program, or formatter program, Invokes a spell-checking program (or linting program,
if the active syntax defines such a thing). if the active syntax defines such a thing).
.TP .TP
.B linter .B linter

View File

@ -655,9 +655,6 @@ void shortcut_init(void)
const char *lint_gist = N_("Invoke the linter, if available"); const char *lint_gist = N_("Invoke the linter, if available");
const char *prevlint_gist = N_("Go to previous linter msg"); const char *prevlint_gist = N_("Go to previous linter msg");
const char *nextlint_gist = N_("Go to next linter msg"); const char *nextlint_gist = N_("Go to next linter msg");
#ifdef ENABLE_SPELLER
const char *formatter_gist = N_("Invoke formatter, if available");
#endif
#endif #endif
#endif /* ENABLE_HELP */ #endif /* ENABLE_HELP */
@ -754,10 +751,6 @@ void shortcut_init(void)
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
add_to_funcs(do_linter, MMAIN, add_to_funcs(do_linter, MMAIN,
N_("To Linter"), WITHORSANS(lint_gist), TOGETHER, NOVIEW); N_("To Linter"), WITHORSANS(lint_gist), TOGETHER, NOVIEW);
#ifdef ENABLE_SPELLER
add_to_funcs(do_formatter, MMAIN,
N_("Formatter"), WITHORSANS(formatter_gist), BLANKAFTER, NOVIEW);
#endif
#endif #endif
} }
@ -1349,20 +1342,13 @@ void replace_scs_for(void (*oldfunc)(void), void (*newfunc)(void))
s->func = newfunc; s->func = newfunc;
} }
void set_lint_or_format_shortcuts(void) void set_linter_shortcut(void)
{ {
if (openfile->syntax->formatter) {
replace_scs_for(do_spell, do_formatter);
replace_scs_for(do_linter, do_formatter);
} else {
replace_scs_for(do_spell, do_linter); replace_scs_for(do_spell, do_linter);
replace_scs_for(do_formatter, do_linter);
}
} }
void set_spell_shortcuts(void) void set_speller_shortcut(void)
{ {
replace_scs_for(do_formatter, do_spell);
replace_scs_for(do_linter, do_spell); replace_scs_for(do_linter, do_spell);
} }
#endif /* ENABLE_COLOR && ENABLE_SPELLER */ #endif /* ENABLE_COLOR && ENABLE_SPELLER */
@ -1795,7 +1781,6 @@ void thanks_for_all_the_fish(void)
free(sint->name); free(sint->name);
free(sint->linter); free(sint->linter);
free(sint->formatter);
while (sint->extensions != NULL) { while (sint->extensions != NULL) {
regexlisttype *item = sint->extensions; regexlisttype *item = sint->extensions;

View File

@ -229,8 +229,6 @@ typedef struct syntaxtype {
/* The list of libmagic results that this syntax applies to. */ /* The list of libmagic results that this syntax applies to. */
char *linter; char *linter;
/* The command with which to lint this type of file. */ /* The command with which to lint this type of file. */
char *formatter;
/* The formatting command (for programming languages mainly). */
#ifdef ENABLE_COMMENT #ifdef ENABLE_COMMENT
char *comment; char *comment;
/* The line comment prefix (and postfix) for this type of file. */ /* The line comment prefix (and postfix) for this type of file. */

View File

@ -323,8 +323,8 @@ void assign_keyinfo(sc *s, const char *keystring, const int keycode);
void print_sclist(void); void print_sclist(void);
void shortcut_init(void); void shortcut_init(void);
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
void set_lint_or_format_shortcuts(void); void set_linter_shortcut(void);
void set_spell_shortcuts(void); void set_speller_shortcut(void);
#endif #endif
const subnfunc *sctofunc(const sc *s); const subnfunc *sctofunc(const sc *s);
const char *flagtostr(int flag); const char *flagtostr(int flag);
@ -555,7 +555,6 @@ void do_spell(void);
#endif #endif
#ifdef ENABLE_COLOR #ifdef ENABLE_COLOR
void do_linter(void); void do_linter(void);
void do_formatter(void);
#endif #endif
#ifndef NANO_TINY #ifndef NANO_TINY
void do_wordlinechar_count(void); void do_wordlinechar_count(void);

View File

@ -300,7 +300,6 @@ void parse_syntax(char *ptr)
live_syntax->headers = NULL; live_syntax->headers = NULL;
live_syntax->magics = NULL; live_syntax->magics = NULL;
live_syntax->linter = NULL; live_syntax->linter = NULL;
live_syntax->formatter = NULL;
#ifdef ENABLE_COMMENT #ifdef ENABLE_COMMENT
live_syntax->comment = mallocstrcpy(NULL, GENERAL_COMMENT_CHARACTER); live_syntax->comment = mallocstrcpy(NULL, GENERAL_COMMENT_CHARACTER);
#endif #endif
@ -834,7 +833,7 @@ void grab_and_store(const char *kind, char *ptr, regexlisttype **storage)
} }
} }
/* Gather and store the string after a comment/linter/formatter command. */ /* Gather and store the string after a comment/linter command. */
void pick_up_name(const char *kind, char *ptr, char **storage) void pick_up_name(const char *kind, char *ptr, char **storage)
{ {
if (!opensyntax) { if (!opensyntax) {
@ -985,12 +984,6 @@ void parse_rcfile(FILE *rcstream, bool syntax_only)
parse_colors(ptr, NANO_REG_EXTENDED | REG_ICASE); parse_colors(ptr, NANO_REG_EXTENDED | REG_ICASE);
else if (strcasecmp(keyword, "linter") == 0) else if (strcasecmp(keyword, "linter") == 0)
pick_up_name("linter", ptr, &live_syntax->linter); pick_up_name("linter", ptr, &live_syntax->linter);
else if (strcasecmp(keyword, "formatter") == 0)
#ifdef ENABLE_SPELLER
pick_up_name("formatter", ptr, &live_syntax->formatter);
#else
;
#endif
else if (syntax_only && (strcasecmp(keyword, "set") == 0 || else if (syntax_only && (strcasecmp(keyword, "set") == 0 ||
strcasecmp(keyword, "unset") == 0 || strcasecmp(keyword, "unset") == 0 ||
strcasecmp(keyword, "bind") == 0 || strcasecmp(keyword, "bind") == 0 ||

View File

@ -3303,119 +3303,6 @@ void do_linter(void)
free(tmplint); free(tmplint);
} }
} }
#ifdef ENABLE_SPELLER
/* Run a formatter for the current syntax. This expects the formatter
* to be non-interactive and operate on a file in-place, which we'll
* pass it on the command line. */
void do_formatter(void)
{
bool status;
FILE *temp_file;
int format_status;
ssize_t lineno_save = openfile->current->lineno;
size_t current_x_save = openfile->current_x;
size_t pww_save = openfile->placewewant;
bool was_at_eol = (openfile->current->data[openfile->current_x] == '\0');
pid_t pid_format;
static char **formatargs = NULL;
char *temp, *finalstatus = NULL;
if (openfile->totsize == 0) {
statusbar(_("Finished"));
return;
}
temp = safe_tempfile(&temp_file);
if (temp == NULL) {
statusline(ALERT, _("Error writing temp file: %s"), strerror(errno));
return;
}
#ifndef NANO_TINY
/* We're not supporting partial formatting, oi vey. */
openfile->mark = NULL;
#endif
status = write_file(temp, temp_file, TRUE, OVERWRITE, TRUE);
if (!status) {
statusline(ALERT, _("Error writing temp file: %s"), strerror(errno));
free(temp);
return;
}
blank_bottombars();
statusbar(_("Invoking formatter, please wait"));
construct_argument_list(&formatargs, openfile->syntax->formatter, temp);
/* Start a new process for the formatter. */
if ((pid_format = fork()) == 0) {
/* Start the formatting program; we are using $PATH. */
execvp(formatargs[0], formatargs);
/* Should not be reached, if the formatter is found! */
exit(1);
}
/* If we couldn't fork, get out. */
if (pid_format < 0) {
statusbar(_("Could not fork"));
unlink(temp);
free(temp);
return;
}
#ifndef NANO_TINY
/* Block SIGWINCHes so the formatter doesn't get any. */
allow_sigwinch(FALSE);
#endif
/* Wait for the formatter to finish. */
wait(&format_status);
if (!WIFEXITED(format_status) || WEXITSTATUS(format_status) != 0)
finalstatus = invocation_error(openfile->syntax->formatter);
else {
/* Replace the text of the current buffer with the formatted text. */
replace_buffer(temp);
/* Restore the cursor position. */
goto_line_posx(lineno_save, current_x_save);
if (was_at_eol || openfile->current_x > strlen(openfile->current->data))
openfile->current_x = strlen(openfile->current->data);
openfile->placewewant = pww_save;
adjust_viewport(STATIONARY);
set_modified();
#ifndef NANO_TINY
/* Flush the undo stack, to avoid a mess or crash when
* the user tries to undo things in reformatted lines. */
discard_until(NULL, openfile, FALSE);
#endif
finalstatus = _("Finished formatting");
}
unlink(temp);
free(temp);
#ifndef NANO_TINY
/* Unblock SIGWINCHes again. */
allow_sigwinch(TRUE);
#endif
statusbar(finalstatus);
/* If there were error messages, allow the user some time to read them. */
if (WIFEXITED(format_status) && WEXITSTATUS(format_status) == 2)
sleep(4);
/* If there were any messages, clear them off. */
total_refresh();
}
#endif /* ENABLE_SPELLER */
#endif /* ENABLE_COLOR */ #endif /* ENABLE_COLOR */
#ifndef NANO_TINY #ifndef NANO_TINY

View File

@ -3334,11 +3334,10 @@ void total_refresh(void)
void display_main_list(void) void display_main_list(void)
{ {
#if defined(ENABLE_COLOR) && defined(ENABLE_SPELLER) #if defined(ENABLE_COLOR) && defined(ENABLE_SPELLER)
if (openfile->syntax && if (openfile->syntax && openfile->syntax->linter)
(openfile->syntax->formatter || openfile->syntax->linter)) set_linter_shortcut();
set_lint_or_format_shortcuts();
else else
set_spell_shortcuts(); set_speller_shortcut();
#endif #endif
bottombars(MMAIN); bottombars(MMAIN);