changeset 98290:90bc7e356363

* emacs.c (standard_args): Add --daemon. (main): Disconnect from the terminal when --daemon is passed. (is_daemon): New variable. (Fdaemonp): New function. (syms_of_emacs): Defsubr it. * startup.el (command-line): Start the server when in daemon mode. * cmdargs.texi (Initial Options): Document --daemon.
author Dan Nicolaescu <dann@ics.uci.edu>
date Sun, 21 Sep 2008 23:31:40 +0000
parents a923103ca68c
children bea14960a539
files doc/emacs/ChangeLog doc/emacs/cmdargs.texi etc/NEWS lisp/ChangeLog lisp/startup.el src/ChangeLog src/emacs.c
diffstat 7 files changed, 77 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/doc/emacs/ChangeLog	Sun Sep 21 22:58:41 2008 +0000
+++ b/doc/emacs/ChangeLog	Sun Sep 21 23:31:40 2008 +0000
@@ -1,3 +1,7 @@
+2008-09-21  Dan Nicolaescu  <dann@ics.uci.edu>
+
+	* cmdargs.texi (Initial Options): Document --daemon.
+
 2008-09-20  Glenn Morris  <rgm@gnu.org>
 
 	* files.texi (Numbered Backups): Mention that some modes set
--- a/doc/emacs/cmdargs.texi	Sun Sep 21 22:58:41 2008 +0000
+++ b/doc/emacs/cmdargs.texi	Sun Sep 21 23:31:40 2008 +0000
@@ -277,6 +277,15 @@
 Start emacs with minimum customizations.  This is like using @samp{-q}
 and @samp{--no-site-file}, but also disables the startup screen.
 
+@item -daemon
+@opindex -daemon
+@itemx --daemon
+@opindex --daemon
+Start emacs in background as a daemon (i.e. it will disconnect from the
+terminal), do not open any frames and start the server.  Clients can
+connect and create graphical or terminal frames using
+@code{emacsclient}.
+
 @item --no-splash
 @opindex --no-splash
 @vindex inhibit-splash-screen
--- a/etc/NEWS	Sun Sep 21 22:58:41 2008 +0000
+++ b/etc/NEWS	Sun Sep 21 23:31:40 2008 +0000
@@ -130,6 +130,11 @@
 Use the -c option to get the old behavior of opening files in the
 currently selected Emacs frame.
 
+*** Emacs can now start in background, as a daemon when using the
+--daemon command line argument.  It disconnects from the terminal and
+starts the server.  Clients can connect and create graphical or
+terminal frames using emacsclient.
+
 *** The new command close-display-connection closes a connection to a
 remote display.
 
--- a/lisp/ChangeLog	Sun Sep 21 22:58:41 2008 +0000
+++ b/lisp/ChangeLog	Sun Sep 21 23:31:40 2008 +0000
@@ -1,5 +1,7 @@
 2008-09-21  Dan Nicolaescu  <dann@ics.uci.edu>
 
+	* startup.el (command-line): Start the server when in daemon mode.
+
 	* frame.el (frame-initialize): Remove spurious setting of
 	special-display-function with the default value.
 
--- a/lisp/startup.el	Sun Sep 21 22:58:41 2008 +0000
+++ b/lisp/startup.el	Sun Sep 21 23:31:40 2008 +0000
@@ -881,9 +881,15 @@
 
   (run-hooks 'before-init-hook)
 
-  ;; Under X Window, this creates the X frame and deletes the terminal frame.
-  (when (fboundp 'frame-initialize)
-    (frame-initialize))
+  (if (daemonp)
+      ;; Just start the server here, no need to run
+      ;; `frame-initialize', it deals with creating a frame and
+      ;; setting the parameters for the initial frame, we don't need
+      ;; any oxof those.
+      (server-start)
+    ;; Under X Window, this creates the X frame and deletes the terminal frame.
+    (when (fboundp 'frame-initialize)
+      (frame-initialize)))
 
   ;; Turn off blinking cursor if so specified in X resources.  This is here
   ;; only because all other settings of no-blinking-cursor are here.
--- a/src/ChangeLog	Sun Sep 21 22:58:41 2008 +0000
+++ b/src/ChangeLog	Sun Sep 21 23:31:40 2008 +0000
@@ -1,3 +1,11 @@
+2008-09-21  Dan Nicolaescu  <dann@ics.uci.edu>
+
+	* emacs.c (standard_args): Add --daemon.
+	(main): Disconnect from the terminal when --daemon is passed.
+	(is_daemon): New variable.
+	(Fdaemonp): New function.
+	(syms_of_emacs): Defsubr it.
+
 2008-09-20  Chong Yidong  <cyd@stupidchicken.com>
 
 	* xdisp.c (get_next_display_element): Handle string display
--- a/src/emacs.c	Sun Sep 21 22:58:41 2008 +0000
+++ b/src/emacs.c	Sun Sep 21 23:31:40 2008 +0000
@@ -232,6 +232,9 @@
 
 int noninteractive1;
 
+/* Nonzero means Emacs was started as a daemon.  */
+int is_daemon = 0;
+
 /* Save argv and argc.  */
 char **initial_argv;
 int initial_argc;
@@ -1068,6 +1071,34 @@
       exit (0);
     }
 
+#ifndef DOS_NT
+  if (argmatch (argv, argc, "-daemon", "--daemon", 5, NULL, &skip_args))
+    {
+      pid_t f = fork();
+      int nfd;
+      if (f > 0)
+	exit(0);
+      if (f < 0)
+	{
+	  fprintf (stderr, "Cannot fork!\n");
+	  exit(1);
+	}
+
+      nfd = open("/dev/null", O_RDWR);
+      dup2(nfd, 0);
+      dup2(nfd, 1);
+      dup2(nfd, 2);
+      close (nfd);
+      is_daemon = 1;
+#ifdef HAVE_SETSID
+      setsid();
+#endif
+    }
+#else /* DOS_NT */
+  fprintf (stderr, "This platform does not support the -daemon flag.\n");
+  exit (1);
+#endif /* DOS_NT */
+
   if (! noninteractive)
     {
 #ifdef BSD_PGRPS
@@ -1719,6 +1750,7 @@
   { "-nw", "--no-windows", 110, 0 },
   { "-batch", "--batch", 100, 0 },
   { "-script", "--script", 100, 1 },
+  { "-daemon", "--daemon", 99, 0 },
   { "-help", "--help", 90, 0 },
   { "-no-unibyte", "--no-unibyte", 83, 0 },
   { "-multibyte", "--multibyte", 82, 0 },
@@ -2350,6 +2382,13 @@
   return Fnreverse (lpath);
 }
 
+DEFUN ("daemonp", Fdaemonp, Sdaemonp, 0, 0, 0,
+       doc: /* Make the current emacs process a daemon.*/)
+  (void)
+{
+  return is_daemon ? Qt : Qnil;
+}
+
 void
 syms_of_emacs ()
 {
@@ -2368,6 +2407,7 @@
 
   defsubr (&Sinvocation_name);
   defsubr (&Sinvocation_directory);
+  defsubr (&Sdaemonp);
 
   DEFVAR_LISP ("command-line-args", &Vcommand_line_args,
 	       doc: /* Args passed by shell to Emacs, as a list of strings.