ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvtc.C
(Generate patch)

Comparing rxvt-unicode/src/rxvtc.C (file contents):
Revision 1.13 by root, Sun Aug 22 01:40:31 2004 UTC vs.
Revision 1.33 by root, Mon Feb 21 07:41:02 2011 UTC

1/*--------------------------------*-C-*---------------------------------* 1/*----------------------------------------------------------------------*
2 * File: rxvtc.C 2 * File: rxvtc.C
3 *----------------------------------------------------------------------* 3 *----------------------------------------------------------------------*
4 * 4 *
5 * All portions of code are copyright by their respective author/s. 5 * All portions of code are copyright by their respective author/s.
6 * Copyright (c) 2003-2004 Marc Lehmann <pcg@goof.com> 6 * Copyright (c) 2003-2006 Marc Lehmann <schmorp@schmorp.de>
7 * 7 *
8 * This program is free software; you can redistribute it and/or modify 8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by 9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or 10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version. 11 * (at your option) any later version.
19 * along with this program; if not, write to the Free Software 19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 *----------------------------------------------------------------------*/ 21 *----------------------------------------------------------------------*/
22 22
23#include "../config.h" 23#include "../config.h"
24#include <cstdio>
25#include <cstdlib>
26#include <cstring>
27#include <csignal>
28
29#include <unistd.h>
30#include <sys/socket.h>
31#include <sys/un.h>
32
24#include "rxvtdaemon.h" 33#include "rxvtdaemon.h"
34#include "libptytty.h"
25 35
26#include "rxvt.h" 36#include "rxvt.h"
27 37
28#include <cstdio> 38#define STATUS_SUCCESS 0
29#include <cstdlib> 39#define STATUS_FAILURE 1
30#include <cstring> 40#define STATUS_CONNECTION_FAILED 2
31 41
32#include <unistd.h>
33#include <signal.h>
34#include <sys/socket.h>
35#include <sys/un.h>
36
37struct client : rxvt_connection { 42struct client : rxvt_connection
43{
38 client (); 44 client ();
39}; 45};
40 46
41client::client () 47client::client ()
42{ 48{
49 sockaddr_un sa;
50 char *sockname = rxvt_connection::unix_sockname ();
51
52 if (strlen (sockname) >= sizeof (sa.sun_path))
53 {
54 fputs ("socket name too long, aborting.\n", stderr);
55 exit (STATUS_FAILURE);
56 }
57
43 if ((fd = socket (PF_UNIX, SOCK_STREAM, 0)) < 0) 58 if ((fd = socket (AF_UNIX, SOCK_STREAM, 0)) < 0)
44 { 59 {
45 perror ("unable to create communications socket"); 60 perror ("unable to create communications socket");
46 exit (EXIT_FAILURE); 61 exit (STATUS_FAILURE);
47 } 62 }
48 63
49 char *sockname = rxvt_connection::unix_sockname ();
50 sockaddr_un sa;
51 sa.sun_family = AF_UNIX; 64 sa.sun_family = AF_UNIX;
52 strcpy (sa.sun_path, sockname); 65 strcpy (sa.sun_path, sockname);
53 free (sockname); 66 free (sockname);
54 67
55 if (connect (fd, (sockaddr *)&sa, sizeof (sa))) 68 if (connect (fd, (sockaddr *)&sa, sizeof (sa)))
56 { 69 {
57 perror ("unable to connect to the rxvt-unicode daemon"); 70 perror ("unable to connect to the rxvt-unicode daemon");
58 exit (EXIT_FAILURE); 71 exit (STATUS_CONNECTION_FAILED);
59 } 72 }
60} 73}
61 74
62extern char **environ; 75extern char **environ;
63 76
64int 77int
65main (int argc, const char *const *argv) 78main (int argc, const char *const *argv)
66{ 79{
80 // instead of getcwd we could opendir (".") and pass the fd for fchdir *g*
81 char cwd[PATH_MAX];
82
83 if (!getcwd (cwd, sizeof (cwd)))
84 {
85 perror ("unable to determine current working directory");
86 exit (STATUS_FAILURE);
87 }
88
67 client c; 89 client c;
68 char buf[PATH_MAX];
69 90
70 { 91 {
71 sigset_t ss; 92 sigset_t ss;
72 93
73 sigemptyset (&ss); 94 sigemptyset (&ss);
74 sigaddset (&ss, SIGHUP); 95 sigaddset (&ss, SIGHUP);
96 sigaddset (&ss, SIGPIPE);
75 sigprocmask (SIG_BLOCK, &ss, 0); 97 sigprocmask (SIG_BLOCK, &ss, 0);
76 } 98 }
77 99
78 c.send ("NEW"); 100 c.send ("NEW");
79 // instead of getcwd we could opendir (".") and pass the fd for fchdir *g*
80 c.send ("CWD"), c.send (getcwd (buf, sizeof (buf)));
81 101
82 for (char **var = environ; *environ; environ++) 102 for (char **var = environ; *var; var++)
83 c.send ("ENV"), c.send (*environ); 103 c.send ("ENV"), c.send (*var);
84 104
85 const char *base = strrchr (argv[0], '/'); 105 const char *base = strrchr (argv[0], '/');
86 base = base ? base + 1 : argv[0]; 106 base = base ? base + 1 : argv[0];
87 c.send ("ARG"), c.send (strcmp (base, RXVTNAME "c") ? base : RXVTNAME); 107 c.send ("ARG"), c.send (strcmp (base, RXVTNAME "c") ? base : RXVTNAME);
108
109 c.send ("ARG"), c.send ("-cd");
110 c.send ("ARG"), c.send (cwd);
88 111
89 for (int i = 1; i < argc; i++) 112 for (int i = 1; i < argc; i++)
90 c.send ("ARG"), c.send (argv[i]); 113 c.send ("ARG"), c.send (argv[i]);
91 114
92 c.send ("END"); 115 c.send ("END");
93 116
94 auto_str tok; 117 auto_str tok;
118 int cint;
95 119
96 for (;;) 120 for (;;)
97 if (!c.recv (tok)) 121 if (!c.recv (tok))
98 { 122 {
99 fprintf (stderr, "protocol error: unexpected eof from server.\n"); 123 fprintf (stderr, "protocol error: unexpected eof from server.\n");
100 break; 124 break;
101 } 125 }
102 else if (!strcmp (tok, "MSG") && c.recv (tok)) 126 else if (!strcmp (tok, "MSG") && c.recv (tok))
103 fprintf (stderr, "%s", (const char *)tok); 127 fprintf (stderr, "%s", (const char *)tok);
128 else if (!strcmp (tok, "GETFD") && c.recv (cint))
129 {
130 if (!ptytty::send_fd (c.fd, cint))
131 {
132 fprintf (stderr, "unable to send fd %d: ", cint); perror (0);
133 exit (STATUS_FAILURE);
134 }
135 }
104 else if (!strcmp (tok, "END")) 136 else if (!strcmp (tok, "END"))
105 { 137 {
106 int success; 138 int success;
139
107 if (c.recv (success)) 140 if (c.recv (success))
108 exit (success ? EXIT_SUCCESS : EXIT_FAILURE); 141 exit (success ? STATUS_SUCCESS : STATUS_FAILURE);
109 } 142 }
110 else 143 else
111 { 144 {
112 fprintf (stderr, "protocol error: received illegal token '%s'.\n", (const char *)tok); 145 fprintf (stderr, "protocol error: received unsupported token '%s'.\n", (const char *)tok);
113 break; 146 break;
114 } 147 }
115 148
116 return EXIT_FAILURE; 149 return STATUS_FAILURE;
117} 150}
118 151

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines