source: trunk/tools/neercs/old/main.c @ 2183

Last change on this file since 2183 was 2183, checked in by sam, 7 years ago

build: fix the WTFPL site URL in all code comments.

  • Property svn:keywords set to Id
File size: 9.5 KB
Line 
1/*
2 *  neercs        console-based window manager
3 *  Copyright (c) 2006-2010 Sam Hocevar <sam@hocevar.net>
4 *                2008-2010 Jean-Yves Lamoureux <jylam@lnxscene.org>
5 *                2008-2010 Pascal Terjan <pterjan@linuxfr.org>
6 *                All Rights Reserved
7 *
8 *  This program is free software. It comes without any warranty, to
9 *  the extent permitted by applicable law. You can redistribute it
10 *  and/or modify it under the terms of the Do What The Fuck You Want
11 *  To Public License, Version 2, as published by Sam Hocevar. See
12 *  http://www.wtfpl.net/ for more details.
13 */
14
15#if defined HAVE_CONFIG_H
16#   include "config.h"
17#endif
18
19#if !defined _WIN32
20
21#include <stdio.h>
22#include <string.h>
23#include <stdlib.h>
24#include <unistd.h>
25#include <fcntl.h>
26#include <signal.h>
27#include <sys/ioctl.h>
28#include <sys/types.h>
29#include <sys/wait.h>
30#include <sys/time.h>
31#include <time.h>
32
33#if !defined HAVE_GETOPT_LONG
34#   include "mygetopt.h"
35#elif defined HAVE_GETOPT_H
36#   include <getopt.h>
37#endif
38#if defined HAVE_GETOPT_LONG
39#   define mygetopt getopt_long
40#   define myoptind optind
41#   define myoptarg optarg
42#   define myoption option
43#endif
44#include <errno.h>
45#include <caca.h>
46
47#include "neercs.h"
48
49
50void version(void)
51{
52    printf("%s\n", PACKAGE_STRING);
53    printf("Copyright (C) 2006, 2008 Sam Hocevar <sam@zoy.org>\n");
54    printf
55        ("                         Jean-Yves Lamoureux <jylam@lnxscene.org>\n\n");
56    printf
57        ("This is free software.  You may redistribute copies of it under the\n");
58    printf
59        ("terms of the Do What The Fuck You Want To Public License, Version 2\n");
60    printf("<http://www.wtfpl.net/>.\n");
61    printf("There is NO WARRANTY, to the extent permitted by law.\n");
62    printf("\n");
63    printf
64        ("For more informations, visit http://libcaca.zoy.org/wiki/neercs\n");
65}
66
67void usage(int argc, char **argv)
68{
69    printf("%s\n", PACKAGE_STRING);
70    printf("Usage : %s [command1] [command2] ... [commandN]\n", argv[0]);
71    printf("Example : %s zsh top \n\n", argv[0]);
72    printf("Options :\n");
73    printf("\t--config\t-c <file>\t\tuse given config file\n");
74    printf("\t--pid\t\t-P [pid]\t\tgrab process\n");
75    printf("\t\t\t-r [session]\t\treattach to a detached neercs\n");
76    printf
77        ("\t\t\t-R [session]\t\treattach if possible, otherwise start a new session\n");
78    printf("\t\t\t-S <name>\t\tname this session <name> instead of <pid>\n");
79    printf("\t--lock-after\t-l [n]\t\t\tlock screen after n seconds\n");
80    printf("\t--version\t-v \t\t\tdisplay version and exit\n");
81    printf("\t--help\t\t-h \t\t\tthis help\n");
82}
83
84struct screen_list *init_neercs(int argc, char **argv)
85{
86    struct screen_list *screen_list = NULL;
87    int args;
88
89    int mainret = -1;
90
91    screen_list = create_screen_list();
92    screen_list->sys.default_shell = getenv("SHELL");
93
94    args = argc - 1;
95    if (screen_list->sys.default_shell == NULL && args <= 0)
96    {
97        fprintf(stderr,
98                "Environment variable SHELL not set and no arguments given. kthxbye.\n");
99        free_screen_list(screen_list);
100        return NULL;
101    }
102
103    if (handle_command_line(argc, argv, screen_list) < 0)
104    {
105        free_screen_list(screen_list);
106        return NULL;
107    }
108
109    /* Read global configuration first */
110    read_configuration_file("/etc/neercsrc", screen_list);
111
112    /* Then local one */
113    if (screen_list->sys.user_path)
114    {
115        read_configuration_file(screen_list->sys.user_path, screen_list);
116        free(screen_list->sys.user_path);
117    }
118
119    if (screen_list->sys.attach)
120    {
121        if (screen_list->sys.nb_to_grab || screen_list->sys.to_start)
122        {
123            fprintf(stderr,
124                    "-R can not be associated with commands or pids!\n");
125            free_screen_list(screen_list);
126            return NULL;
127        }
128
129        attach(screen_list);
130
131        if (screen_list->sys.forceattach && !screen_list->sys.attach)
132        {
133            free_screen_list(screen_list);
134            return NULL;
135        }
136    }
137
138    /* Build default session name */
139    if (!screen_list->comm.session_name)
140    {
141        char mypid[32];         /* FIXME Compute the length of PID_MAX ? */
142        snprintf(mypid, 31, "%d", getpid());
143        mypid[31] = '\0';
144        screen_list->comm.session_name = strdup(mypid);
145        if (!screen_list->comm.session_name)
146        {
147            fprintf(stderr, "Can't allocate memory at %s:%d\n", __FUNCTION__,
148                    __LINE__);
149            free_screen_list(screen_list);
150            return NULL;
151        }
152    }
153    if (!screen_list->comm.socket_path[SOCK_CLIENT])
154        screen_list->comm.socket_path[SOCK_CLIENT] =
155            build_socket_path(screen_list->comm.socket_dir,
156                              screen_list->comm.session_name, SOCK_CLIENT);
157
158    if (!screen_list->comm.socket_path[SOCK_SERVER])
159        screen_list->comm.socket_path[SOCK_SERVER] =
160            build_socket_path(screen_list->comm.socket_dir,
161                              screen_list->comm.session_name, SOCK_SERVER);
162
163    /* Fork the server if needed */
164    if (!screen_list->sys.attach)
165    {
166        debug("Spawning a new server");
167        if (start_server(screen_list))
168        {
169            free_screen_list(screen_list);
170            return NULL;
171        }
172        if (start_client(screen_list))
173        {
174            free_screen_list(screen_list);
175            return NULL;
176        }
177    }
178
179    return screen_list;
180}
181
182int handle_command_line(int argc, char *argv[],
183                        struct screen_list *screen_list)
184{
185    int s = 0, i;
186    for (;;)
187    {
188        int option_index = 0;
189        int pidopt;
190        static struct myoption long_options[] = {
191            {"config", 1, NULL, 'c'},
192#if defined USE_GRAB
193            {"pid", 0, NULL, 'P'},
194#endif
195            {"lock-after", 1, NULL, 'l'},
196            {"help", 0, NULL, 'h'},
197            {"version", 0, NULL, 'v'},
198            {NULL, 0, NULL, 0},
199        };
200#if defined USE_GRAB
201        int c =
202            mygetopt(argc, argv, "c:S:R::l::r::P::hv", long_options,
203                     &option_index);
204#else
205        int c =
206            mygetopt(argc, argv, "c:S:R::l::r::hv", long_options,
207                     &option_index);
208#endif
209        if (c == -1)
210            break;
211
212        switch (c)
213        {
214        case 'c':              /* --config */
215            if (screen_list->sys.user_path)
216                free(screen_list->sys.user_path);
217            screen_list->sys.user_path = strdup(myoptarg);
218            s += 2;
219            break;
220        case 'S':
221            if (!screen_list->comm.session_name)
222                screen_list->comm.session_name = strdup(myoptarg);
223            s += 2;
224            break;
225        case 'P':              /* --pid */
226            if (myoptarg)
227            {
228                pidopt = atoi(myoptarg);
229                if (pidopt <= 0)
230                {
231                    fprintf(stderr, "Invalid pid %d\n", pidopt);
232                    if (screen_list->sys.to_grab)
233                        free(screen_list->sys.to_grab);
234                    return -1;
235                }
236            }
237            else
238                pidopt = select_process(screen_list);
239            if (pidopt <= 0)
240            {
241                s += 1;
242                break;
243            }
244            if (!screen_list->sys.to_grab)
245            {
246                /* At most argc-1-s times -P <pid> + final 0 */
247                screen_list->sys.to_grab =
248                    (int *)malloc(((argc - 1 - s) / 2 + 1) * sizeof(int));
249                if (!screen_list->sys.to_grab)
250                {
251                    fprintf(stderr, "Can't allocate memory at %s:%d\n",
252                            __FUNCTION__, __LINE__);
253                    return -1;
254                }
255            }
256            screen_list->sys.to_grab[screen_list->sys.nb_to_grab++] = pidopt;
257            screen_list->sys.to_grab[screen_list->sys.nb_to_grab] = 0;
258            s += 2;
259            break;
260        case 'l':
261            screen_list->lock.autolock_timeout = atoi(myoptarg) * 1000000;
262            if (screen_list->lock.autolock_timeout == 0)
263                screen_list->lock.autolock_timeout -= 1;
264            break;
265        case 'r':
266            screen_list->sys.forceattach = 1;
267        case 'R':
268            if (screen_list->sys.attach)
269            {
270                fprintf(stderr, "Attaching can only be requested once\n");
271                return -1;
272            }
273            if (myoptarg)
274            {
275                if (screen_list->comm.session_name)
276                    free(screen_list->comm.session_name);
277                screen_list->comm.session_name = strdup(myoptarg);
278                s += 1;
279            }
280            screen_list->sys.attach = 1;
281            s += 1;
282            break;
283        case 'h':              /* --help */
284            usage(argc, argv);
285            return -1;
286            break;
287        case 'v':              /* --version */
288            version();
289            return -1;
290            break;
291        case -2:
292            return -1;
293        default:
294            fprintf(stderr, "Unknown argument #%d\n", myoptind);
295            return -1;
296            break;
297        }
298    }
299    if (s >= 0 && s < argc - 1)
300    {
301        screen_list->sys.to_start = (char **)malloc((argc - s) * sizeof(char *));
302        if (!screen_list->sys.to_start)
303        {
304            fprintf(stderr, "Can't allocate memory at %s:%d\n", __FUNCTION__,
305                    __LINE__);
306            return -1;
307        }
308        for (i = 0; i < (argc - 1) - s; i++)
309        {
310            screen_list->sys.to_start[i] = strdup(argv[i + s + 1]);
311        }
312        screen_list->sys.to_start[argc - 1 - s] = NULL;
313    }
314    return s;
315}
316
317#endif
318
Note: See TracBrowser for help on using the repository browser.