diff options
| author | Paul Eggert <eggert@cs.ucla.edu> | 2011-06-25 11:31:36 -0700 | 
|---|---|---|
| committer | Paul Eggert <eggert@cs.ucla.edu> | 2011-06-25 11:31:36 -0700 | 
| commit | 948b98fd3c17e56b5fa606eedbe6487091f2b66d (patch) | |
| tree | 470d98f5aa36d512902da3db4d9f35b3c0fe6f07 /lib-src | |
| parent | 7a7ef429182915745380c3074771d9f747dab964 (diff) | |
| parent | 11fdef7d0cf3ef1ce30d1cd09ca9ca9a2b099d20 (diff) | |
| download | emacs-948b98fd3c17e56b5fa606eedbe6487091f2b66d.tar.gz | |
Merge from trunk.
Diffstat (limited to 'lib-src')
| -rw-r--r-- | lib-src/ChangeLog | 9 | ||||
| -rw-r--r-- | lib-src/emacsclient.c | 21 | 
2 files changed, 28 insertions, 2 deletions
| diff --git a/lib-src/ChangeLog b/lib-src/ChangeLog index ec123e85036..b7a95fe8043 100644 --- a/lib-src/ChangeLog +++ b/lib-src/ChangeLog @@ -1,3 +1,12 @@ +2011-06-25  Glenn Morris  <rgm@gnu.org> + +	* emacsclient.c (decode_options) <opt>: Add `F:'. +	(print_help_and_exit): Mention --frame-parameters. + +2011-06-25  Andreas Rottmann  <a.rottmann@gmx.at> + +	* emacsclient.c (longopts, decode_options, main): Add frame-parameters. +  2011-06-10  Paul Eggert  <eggert@cs.ucla.edu>  	* movemail.c: Fix race condition and related bugs (Bug#8836). diff --git a/lib-src/emacsclient.c b/lib-src/emacsclient.c index c334fb6a196..2daed7eb9da 100644 --- a/lib-src/emacsclient.c +++ b/lib-src/emacsclient.c @@ -160,6 +160,10 @@ const char *server_file = NULL;  /* PID of the Emacs server process.  */  int emacs_pid = 0; +/* If non-NULL, a string that should form a frame parameter alist to +   be used for the new frame */ +const char *frame_parameters = NULL; +  static void print_help_and_exit (void) NO_RETURN;  static void fail (void) NO_RETURN; @@ -175,6 +179,7 @@ struct option longopts[] =    { "nw",	no_argument,       NULL, 't' },    { "create-frame", no_argument,   NULL, 'c' },    { "alternate-editor", required_argument, NULL, 'a' }, +  { "frame-parameters", required_argument, NULL, 'F' },  #ifndef NO_SOCKETS_IN_FILE_SYSTEM    { "socket-name",	required_argument, NULL, 's' },  #endif @@ -526,9 +531,9 @@ decode_options (int argc, char **argv)      {        int opt = getopt_long_only (argc, argv,  #ifndef NO_SOCKETS_IN_FILE_SYSTEM -			     "VHneqa:s:f:d:tc", +			     "VHneqa:s:f:d:F:tc",  #else -			     "VHneqa:f:d:tc", +			     "VHneqa:f:d:F:tc",  #endif  			     longopts, 0); @@ -599,6 +604,10 @@ decode_options (int argc, char **argv)  	  print_help_and_exit ();  	  break; +        case 'F': +          frame_parameters = optarg; +          break; +  	default:  	  message (TRUE, "Try `%s --help' for more information\n", progname);  	  exit (EXIT_FAILURE); @@ -665,6 +674,7 @@ The following OPTIONS are accepted:\n\  -nw, -t, --tty 		Open a new Emacs frame on the current terminal\n\  -c, --create-frame    	Create a new frame instead of trying to\n\  			use the current Emacs frame\n\ +-F, --frame-parameters	Set the parameters of a new frame\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\ @@ -1630,6 +1640,13 @@ main (int argc, char **argv)        send_to_emacs (emacs_socket, " ");      } +  if (frame_parameters && !current_frame) +    { +      send_to_emacs (emacs_socket, "-frame-parameters "); +      quote_argument (emacs_socket, frame_parameters); +      send_to_emacs (emacs_socket, " "); +    } +    /* If using the current frame, send tty information to Emacs anyway.       In daemon mode, Emacs may need to occupy this tty if no other       frame is available.  */ | 
