]> git.eshelyaron.com Git - emacs.git/commitdiff
New option -u / --suppress-output to emacsclient
authorPeder O. Klingenberg <peder@klingenberg.no>
Sat, 25 Feb 2017 08:30:46 +0000 (10:30 +0200)
committerEli Zaretskii <eliz@gnu.org>
Sat, 25 Feb 2017 08:30:46 +0000 (10:30 +0200)
* lib-src/emacsclient.c (print_help_and_exit, longopts)
(decode_options, main): Implement new option --suppress-output / -u to
suppress printing of eval-results.
* doc/emacs/misc.texi (emacsclient Options): Document the new
"--suppress-output/-u" options.
* etc/NEWS: Mention the new options.

doc/emacs/misc.texi
etc/NEWS
lib-src/emacsclient.c

index 091ead1bae706747df3ffa848872970bd1b342a9..bcc20a6db16185fba8cd741cd1d7611b450b6d6e 100644 (file)
@@ -1847,6 +1847,12 @@ option is mainly useful for developers.
 Do not let @command{emacsclient} display messages about waiting for
 Emacs or connecting to remote server sockets.
 
+@item -u
+@itemx --suppress-output
+Do not let @command{emacsclient} display results returned from the
+server.  Mostly useful in combination with @samp{-e} when the
+evaluation performed is for side-effect rather than result.
+
 @item -s @var{server-name}
 @itemx --socket-name=@var{server-name}
 Connect to the Emacs server named @var{server-name}.  The server name
index 9355dff7a08bdc1cef0119a14bb8afa32f9e3999..5d14e122a202859ae010207e7d1acd5ffec81177 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -321,6 +321,10 @@ substituted by a home directory by writing it as "/foo:/:/~/file".
 settings of 'scroll-margin' up to half the window size, instead of
 always restricting the margin to a quarter of the window.
 
++++
+** Emacsclient has a new option -u/--suppress-output.  The option
+suppresses display of return values from the server process.
+
 \f
 * Editing Changes in Emacs 26.1
 
index 70709ecec0423da96d36156dfcc41151acdf07a7..7b735dfb05dca303bf299b5d21f3e73ea571e022 100644 (file)
@@ -118,6 +118,9 @@ int nowait = 0;
 /* Nonzero means don't print messages for successful operations.  --quiet.  */
 int quiet = 0;
 
+/* Nonzero means don't print values returned from emacs. --suppress-output.  */
+int suppress_output = 0;
+
 /* Nonzero means args are expressions to be evaluated.  --eval.  */
 int eval = 0;
 
@@ -160,6 +163,7 @@ struct option longopts[] =
 {
   { "no-wait", no_argument,       NULL, 'n' },
   { "quiet",   no_argument,       NULL, 'q' },
+  { "suppress-output", no_argument, NULL, 'u' },
   { "eval",    no_argument,       NULL, 'e' },
   { "help",    no_argument,       NULL, 'H' },
   { "version", no_argument,       NULL, 'V' },
@@ -469,9 +473,9 @@ decode_options (int argc, char **argv)
     {
       int opt = getopt_long_only (argc, argv,
 #ifndef NO_SOCKETS_IN_FILE_SYSTEM
-                            "VHneqa:s:f:d:F:tc",
+                            "VHnequa:s:f:d:F:tc",
 #else
-                            "VHneqa:f:d:F:tc",
+                            "VHnequa:f:d:F:tc",
 #endif
                             longopts, 0);
 
@@ -519,6 +523,10 @@ decode_options (int argc, char **argv)
          quiet = 1;
          break;
 
+       case 'u':
+         suppress_output = 1;
+         break;
+
        case 'V':
          message (false, "emacsclient %s\n", VERSION);
          exit (EXIT_SUCCESS);
@@ -631,6 +639,7 @@ The following OPTIONS are accepted:\n\
 -e, --eval             Evaluate the FILE arguments as ELisp expressions\n\
 -n, --no-wait          Don't wait for the server to return\n\
 -q, --quiet            Don't display messages on success\n\
+-u, --suppress-output   Don't display return values from the server\n\
 -d DISPLAY, --display=DISPLAY\n\
                        Visit the file in the given display\n\
 ", "\
@@ -1860,19 +1869,25 @@ main (int argc, char **argv)
           else if (strprefix ("-print ", p))
             {
               /* -print STRING: Print STRING on the terminal. */
-              str = unquote_argument (p + strlen ("-print "));
-              if (needlf)
-                printf ("\n");
-              printf ("%s", str);
-              needlf = str[0] == '\0' ? needlf : str[strlen (str) - 1] != '\n';
-            }
+             if (!suppress_output)
+               {
+                 str = unquote_argument (p + strlen ("-print "));
+                 if (needlf)
+                   printf ("\n");
+                 printf ("%s", str);
+                 needlf = str[0] == '\0' ? needlf : str[strlen (str) - 1] != '\n';
+               }
+           }
           else if (strprefix ("-print-nonl ", p))
             {
               /* -print-nonl STRING: Print STRING on the terminal.
                  Used to continue a preceding -print command.  */
-              str = unquote_argument (p + strlen ("-print-nonl "));
-              printf ("%s", str);
-              needlf = str[0] == '\0' ? needlf : str[strlen (str) - 1] != '\n';
+             if (!suppress_output)
+               {
+                 str = unquote_argument (p + strlen ("-print-nonl "));
+                 printf ("%s", str);
+                 needlf = str[0] == '\0' ? needlf : str[strlen (str) - 1] != '\n';
+               }
             }
           else if (strprefix ("-error ", p))
             {