diff --git a/commands/CmdFI.c b/commands/CmdFI.c index cfd4066b..314dd20e 100644 --- a/commands/CmdFI.c +++ b/commands/CmdFI.c @@ -943,6 +943,7 @@ CmdFlush(w, cmd) static char *actionNames[] = { "no", "yes", 0 }; char *prompt; bool dereference = FALSE; + bool noprompt = FALSE; /* no interactive confirm when changed */ if (!strncmp(cmd->tx_argv[cmd->tx_argc - 1], "-deref", 6)) { @@ -950,9 +951,15 @@ CmdFlush(w, cmd) cmd->tx_argc--; } + if (!strcmp(cmd->tx_argv[cmd->tx_argc - 1], "-noprompt")) + { + noprompt = TRUE; + cmd->tx_argc--; + } + if (cmd->tx_argc > 2) { - TxError("Usage: flush [cellname] [dereference]\n"); + TxError("Usage: flush [cellname] [-noprompt] [-dereference]\n"); return; } @@ -973,7 +980,9 @@ CmdFlush(w, cmd) } } - if (def->cd_flags & (CDMODIFIED|CDSTAMPSCHANGED|CDBOXESCHANGED)) + bool has_changes = (def->cd_flags & (CDMODIFIED|CDSTAMPSCHANGED|CDBOXESCHANGED)) != 0; + + if (!noprompt && has_changes) { prompt = TxPrintString("Really throw away all changes made" " to cell %s? ", def->cd_name); @@ -984,7 +993,7 @@ CmdFlush(w, cmd) cmdFlushCell(def, dereference); SelectClear(); - TxPrintf("[Flushed]\n"); + TxPrintf("[Flushed%s]\n", has_changes ? " Modifications were Discarded" : ""); } diff --git a/doc/html/flush.html b/doc/html/flush.html index 6ee7be30..8ae2b68f 100644 --- a/doc/html/flush.html +++ b/doc/html/flush.html @@ -26,7 +26,7 @@
- flush [cellname] [-dereference]
+ flush [cellname] [-noprompt] [-dereference]
where cellname is the name of a cell definition to be flushed. @@ -43,6 +43,10 @@Summary:
The effects of the flush command are irrevocable; the command cannot be undone with an undo command.+ With the -noprompt option, no interactive confirmation is + presented if there are unsaved changes. Those changes will be + flushed. + With the -dereference option, any file path that has been associated with the cell is discarded, and the cell is reloaded from the first location found in the search path. With search diff --git a/doc/html/quit.html b/doc/html/quit.html index 2bff2e41..e428ca30 100644 --- a/doc/html/quit.html +++ b/doc/html/quit.html @@ -31,7 +31,7 @@
Shortcuts:
Usage:
- quit
+ quit [exit_status] [-noprompt]
Summary:
@@ -45,6 +45,13 @@Summary:
and the Tcl exit command is required to quit the program. The Tcl exit command will always exit magic immediately, without prompting or cleanup or any other niceties.+ + The exit_status option allows an exit status number in + the range 0 to 255 to be indicated to the parent process. The + default exit_status is 0 indicating success.
+ + With the -noprompt option, the interactive confirm prompt + does not occur so any changes will be discarded.
Implementation Notes:
diff --git a/windows/windCmdNR.c b/windows/windCmdNR.c index b550bd2e..9c50a565 100644 --- a/windows/windCmdNR.c +++ b/windows/windCmdNR.c @@ -263,19 +263,47 @@ windQuitCmd(w, cmd) { clientRec *cr; bool checkfirst = TRUE; + int exit_status = 0; - if (cmd->tx_argc == 2) - if (!strcmp(cmd->tx_argv[1], "-noprompt")) + if (cmd->tx_argc > 1) + { + if (!strcmp(cmd->tx_argv[cmd->tx_argc - 1], "-noprompt")) + { checkfirst = FALSE; + cmd->tx_argc--; + } + } + + if (cmd->tx_argc > 1) + { + int tmp; + if (sscanf(cmd->tx_argv[cmd->tx_argc - 1], "%d", &tmp) == 1 && exit_status >= 0 && exit_status <= 255) + { + exit_status = tmp; + cmd->tx_argc--; + } + else + { + TxError("Invalid exit_status: %s\n", cmd->tx_argv[cmd->tx_argc - 1]); + } + } + + if (cmd->tx_argc > 1) + { + TxError("Usage: quit [exit_status] [-noprompt]\n"); + return; + } if (checkfirst) + { for (cr = windFirstClientRec; cr != (clientRec *) NULL; cr = cr->w_nextClient) if (cr->w_exit != NULL) if (!(*(cr->w_exit))()) return; + } - MainExit(0); + MainExit(exit_status); }