annotate lib-src/fakemail.c @ 72863:526dc1f36b09

(produce_image_glyph): Automatically crop wide images at right window edge so we can draw the cursor on the same row to avoid confusing redisplay by placing the cursor outside the visible window area.
author Kim F. Storm <storm@cua.dk>
date Thu, 14 Sep 2006 09:37:44 +0000
parents ca1a855f01ae
children 6d19c76d81c5 858cb33ae39d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 /* sendmail-like interface to /bin/mail for system V,
64769
6358e3c6075c Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64083
diff changeset
2 Copyright (C) 1985, 1994, 1999, 2002, 2003, 2004,
68647
3661e9b3c48f Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64769
diff changeset
3 2005, 2006 Free Software Foundation, Inc.
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
4
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5 This file is part of GNU Emacs.
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6
37
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
7 GNU Emacs is free software; you can redistribute it and/or modify
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
8 it under the terms of the GNU General Public License as published by
6109
e52619114580 Update GPL.
David J. MacKenzie <djm@gnu.org>
parents: 5959
diff changeset
9 the Free Software Foundation; either version 2, or (at your option)
37
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
10 any later version.
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11
37
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
15 GNU General Public License for more details.
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
16
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
17 You should have received a copy of the GNU General Public License
e48c0f5e6696 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 20
diff changeset
18 along with GNU Emacs; see the file COPYING. If not, write to
64083
23a17af379b1 Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 55442
diff changeset
19 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
23a17af379b1 Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 55442
diff changeset
20 Boston, MA 02110-1301, USA. */
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22 #define NO_SHORTNAMES
42134
de525d9743c9 Include "config.h", not <../src/config.h>.
Dave Love <fx@gnu.org>
parents: 34951
diff changeset
23 #define _XOPEN_SOURCE 500 /* for cuserid */
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
24
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
25 #ifdef HAVE_CONFIG_H
42469
64341c22fb4c Include <config.h>.
Pavel Janík <Pavel@Janik.cz>
parents: 42181
diff changeset
26 #include <config.h>
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
27 #endif
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28
16218
32f82ca8b41f Replaced all BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16121
diff changeset
29 #if defined (BSD_SYSTEM) && !defined (BSD4_1) && !defined (USE_FAKEMAIL)
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30 /* This program isnot used in BSD, so just avoid loader complaints. */
15683
5f9426e991a3 Declare main as int, not void.
Karl Heuer <kwzh@gnu.org>
parents: 15099
diff changeset
31 int
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32 main ()
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 {
16121
6e026dc3f1b1 Whitespace fix.
Richard M. Stallman <rms@gnu.org>
parents: 15683
diff changeset
34 return 0;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36 #else /* not BSD 4.2 (or newer) */
5447
6f0905b05218 (main) [MSDOS]: Dummy stub just to make the file compile.
Richard M. Stallman <rms@gnu.org>
parents: 4696
diff changeset
37 #ifdef MSDOS
15683
5f9426e991a3 Declare main as int, not void.
Karl Heuer <kwzh@gnu.org>
parents: 15099
diff changeset
38 int
5447
6f0905b05218 (main) [MSDOS]: Dummy stub just to make the file compile.
Richard M. Stallman <rms@gnu.org>
parents: 4696
diff changeset
39 main ()
6f0905b05218 (main) [MSDOS]: Dummy stub just to make the file compile.
Richard M. Stallman <rms@gnu.org>
parents: 4696
diff changeset
40 {
16121
6e026dc3f1b1 Whitespace fix.
Richard M. Stallman <rms@gnu.org>
parents: 15683
diff changeset
41 return 0;
5447
6f0905b05218 (main) [MSDOS]: Dummy stub just to make the file compile.
Richard M. Stallman <rms@gnu.org>
parents: 4696
diff changeset
42 }
6f0905b05218 (main) [MSDOS]: Dummy stub just to make the file compile.
Richard M. Stallman <rms@gnu.org>
parents: 4696
diff changeset
43 #else /* not MSDOS */
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 /* This conditional contains all the rest of the file. */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46 /* These are defined in config in some versions. */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 #ifdef static
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49 #undef static
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 #endif
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51
15099
857388330750 [WINDOWSNT]: Include ntlib.h.
Richard M. Stallman <rms@gnu.org>
parents: 14186
diff changeset
52 #ifdef WINDOWSNT
857388330750 [WINDOWSNT]: Include ntlib.h.
Richard M. Stallman <rms@gnu.org>
parents: 14186
diff changeset
53 #include "ntlib.h"
857388330750 [WINDOWSNT]: Include ntlib.h.
Richard M. Stallman <rms@gnu.org>
parents: 14186
diff changeset
54 #endif
857388330750 [WINDOWSNT]: Include ntlib.h.
Richard M. Stallman <rms@gnu.org>
parents: 14186
diff changeset
55
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
56 #include <stdio.h>
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
57 #include <string.h>
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
58 #include <ctype.h>
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
59 #include <time.h>
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
60 #include <pwd.h>
18841
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
61
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
62 /* This is to declare cuserid. */
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
63 #ifdef HAVE_UNISTD_H
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
64 #include <unistd.h>
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
65 #endif
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
66
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67 /* Type definitions */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
68
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
69 #define boolean int
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
70 #define true 1
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71 #define false 0
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72
69790
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
73 #define TM_YEAR_BASE 1900
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
74
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
75 /* Nonzero if TM_YEAR is a struct tm's tm_year value that causes
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
76 asctime to have well-defined behavior. */
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
77 #ifndef TM_YEAR_IN_ASCTIME_RANGE
69697
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
78 # define TM_YEAR_IN_ASCTIME_RANGE(tm_year) \
69790
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
79 (1000 - TM_YEAR_BASE <= (tm_year) && (tm_year) <= 9999 - TM_YEAR_BASE)
69697
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
80 #endif
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
81
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82 /* Various lists */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84 struct line_record
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
85 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
86 char *string;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
87 struct line_record *continuation;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
88 };
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
89 typedef struct line_record *line_list;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
90
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
91 struct header_record
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
92 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
93 line_list text;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94 struct header_record *next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
95 struct header_record *previous;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
96 };
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
97 typedef struct header_record *header;
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
98
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99 struct stream_record
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101 FILE *handle;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
102 int (*action)();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
103 struct stream_record *rest_streams;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104 };
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
105 typedef struct stream_record *stream_list;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
106
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107 /* A `struct linebuffer' is a structure which holds a line of text.
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
108 * `readline' reads a line from a stream into a linebuffer
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
109 * and works regardless of the length of the line.
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
110 */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
111
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
112 struct linebuffer
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
113 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
114 long size;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
115 char *buffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
116 };
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
117
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
118 struct linebuffer lb;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
119
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
120 #define new_list() \
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
121 ((line_list) xmalloc (sizeof (struct line_record)))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
122 #define new_header() \
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
123 ((header) xmalloc (sizeof (struct header_record)))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
124 #define new_stream() \
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
125 ((stream_list) xmalloc (sizeof (struct stream_record)))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
126 #define alloc_string(nchars) \
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
127 ((char *) xmalloc ((nchars) + 1))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
128
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
129 /* Global declarations */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
130
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
131 #define BUFLEN 1024
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
132 #define KEYWORD_SIZE 256
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
133 #define FROM_PREFIX "From"
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
134 #define MY_NAME "fakemail"
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
135 #define NIL ((line_list) NULL)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
136 #define INITIAL_LINE_SIZE 200
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
137
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
138 #ifndef MAIL_PROGRAM_NAME
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
139 #define MAIL_PROGRAM_NAME "/bin/mail"
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
140 #endif
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
141
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
142 static char *my_name;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
143 static char *the_date;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144 static char *the_user;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
145 static line_list file_preface;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
146 static stream_list the_streams;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
147 static boolean no_problems = true;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
148
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
149 extern FILE *popen ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
150 extern int fclose (), pclose ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
151
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
152 #ifdef CURRENT_USER
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
153 extern struct passwd *getpwuid ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
154 extern unsigned short geteuid ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
155 static struct passwd *my_entry;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
156 #define cuserid(s) \
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
157 (my_entry = getpwuid (((int) geteuid ())), \
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
158 my_entry->pw_name)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
159 #endif
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
160
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
161 /* Utilities */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
162
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
163 /* Print error message. `s1' is printf control string, `s2' is arg for it. */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
164
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
165 static void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
166 error (s1, s2)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
167 char *s1, *s2;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
168 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
169 printf ("%s: ", my_name);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
170 printf (s1, s2);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
171 printf ("\n");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
172 no_problems = false;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
173 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
174
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
175 /* Print error message and exit. */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
176
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
177 static void
72034
ca1a855f01ae (fatal): Drop second parameter and treat first
Andreas Schwab <schwab@suse.de>
parents: 70278
diff changeset
178 fatal (s1)
ca1a855f01ae (fatal): Drop second parameter and treat first
Andreas Schwab <schwab@suse.de>
parents: 70278
diff changeset
179 char *s1;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
180 {
72034
ca1a855f01ae (fatal): Drop second parameter and treat first
Andreas Schwab <schwab@suse.de>
parents: 70278
diff changeset
181 error ("%s", s1);
55442
a47704955f8d Throughout, replace 0 destined for `exit' arg with `EXIT_SUCCESS'.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 52401
diff changeset
182 exit (EXIT_FAILURE);
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
183 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
184
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
185 /* Like malloc but get fatal error if memory is exhausted. */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
186
12833
25464bf61eb1 (xmalloc, xrealloc): Use return-type long *.
Richard M. Stallman <rms@gnu.org>
parents: 10265
diff changeset
187 static long *
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
188 xmalloc (size)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
189 int size;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
190 {
12833
25464bf61eb1 (xmalloc, xrealloc): Use return-type long *.
Richard M. Stallman <rms@gnu.org>
parents: 10265
diff changeset
191 long *result = (long *) malloc (((unsigned) size));
25464bf61eb1 (xmalloc, xrealloc): Use return-type long *.
Richard M. Stallman <rms@gnu.org>
parents: 10265
diff changeset
192 if (result == ((long *) NULL))
72034
ca1a855f01ae (fatal): Drop second parameter and treat first
Andreas Schwab <schwab@suse.de>
parents: 70278
diff changeset
193 fatal ("virtual memory exhausted");
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
194 return result;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
195 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
196
12833
25464bf61eb1 (xmalloc, xrealloc): Use return-type long *.
Richard M. Stallman <rms@gnu.org>
parents: 10265
diff changeset
197 static long *
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
198 xrealloc (ptr, size)
12833
25464bf61eb1 (xmalloc, xrealloc): Use return-type long *.
Richard M. Stallman <rms@gnu.org>
parents: 10265
diff changeset
199 long *ptr;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
200 int size;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
201 {
12833
25464bf61eb1 (xmalloc, xrealloc): Use return-type long *.
Richard M. Stallman <rms@gnu.org>
parents: 10265
diff changeset
202 long *result = (long *) realloc (ptr, ((unsigned) size));
12840
4e9a14304b8b (xrealloc): Change cast to match return type.
Karl Heuer <kwzh@gnu.org>
parents: 12833
diff changeset
203 if (result == ((long *) NULL))
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
204 fatal ("virtual memory exhausted");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
205 return result;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
206 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
207
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
208 /* Initialize a linebuffer for use */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
209
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
210 void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
211 init_linebuffer (linebuffer)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
212 struct linebuffer *linebuffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
213 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
214 linebuffer->size = INITIAL_LINE_SIZE;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
215 linebuffer->buffer = ((char *) xmalloc (INITIAL_LINE_SIZE));
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
216 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
217
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
218 /* Read a line of text from `stream' into `linebuffer'.
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
219 Return the length of the line. */
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
220
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
221 long
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
222 readline (linebuffer, stream)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
223 struct linebuffer *linebuffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
224 FILE *stream;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
225 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
226 char *buffer = linebuffer->buffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
227 char *p = linebuffer->buffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
228 char *end = p + linebuffer->size;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
229
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
230 while (true)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
231 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
232 int c = getc (stream);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
233 if (p == end)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
234 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
235 linebuffer->size *= 2;
34951
1efc40541908 (readline): Cast buffer to "long *" to pacify
Eli Zaretskii <eliz@gnu.org>
parents: 34609
diff changeset
236 buffer = ((char *) xrealloc ((long *)buffer, linebuffer->size));
6992
ed57331fb222 (readline): Fix updating of p when buffer grows.
Richard M. Stallman <rms@gnu.org>
parents: 6954
diff changeset
237 p = buffer + (p - linebuffer->buffer);
6954
774fdc20d115 (readline): When extending the buffer,
Richard M. Stallman <rms@gnu.org>
parents: 6109
diff changeset
238 end = buffer + linebuffer->size;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
239 linebuffer->buffer = buffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
240 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
241 if (c < 0 || c == '\n')
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
242 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
243 *p = 0;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
244 break;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
245 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
246 *p++ = c;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
247 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
248
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
249 return p - buffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
250 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
251
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
252 /* Extract a colon-terminated keyword from the string FIELD.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
253 Return that keyword as a string stored in a static buffer.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
254 Store the address of the rest of the string into *REST.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
255
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
256 If there is no keyword, return NULL and don't alter *REST. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
257
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
258 char *
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
259 get_keyword (field, rest)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
260 register char *field;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
261 char **rest;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
262 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
263 static char keyword[KEYWORD_SIZE];
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
264 register char *ptr;
34609
cb2667416fa5 (get_keyword): Make sure that isspace and
Gerd Moellmann <gerd@gnu.org>
parents: 26083
diff changeset
265 register int c;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
266
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
267 ptr = &keyword[0];
34609
cb2667416fa5 (get_keyword): Make sure that isspace and
Gerd Moellmann <gerd@gnu.org>
parents: 26083
diff changeset
268 c = (unsigned char) *field++;
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
269 if (isspace (c) || c == ':')
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
270 return ((char *) NULL);
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
271 *ptr++ = (islower (c) ? toupper (c) : c);
34609
cb2667416fa5 (get_keyword): Make sure that isspace and
Gerd Moellmann <gerd@gnu.org>
parents: 26083
diff changeset
272 while (((c = (unsigned char) *field++) != ':') && ! isspace (c))
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
273 *ptr++ = (islower (c) ? toupper (c) : c);
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
274 *ptr++ = '\0';
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
275 while (isspace (c))
34609
cb2667416fa5 (get_keyword): Make sure that isspace and
Gerd Moellmann <gerd@gnu.org>
parents: 26083
diff changeset
276 c = (unsigned char) *field++;
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
277 if (c != ':')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
278 return ((char *) NULL);
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
279 *rest = field;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
280 return &keyword[0];
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
281 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
282
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
283 /* Nonzero if the string FIELD starts with a colon-terminated keyword. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
284
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
285 boolean
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
286 has_keyword (field)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
287 char *field;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
288 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
289 char *ignored;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
290 return (get_keyword (field, &ignored) != ((char *) NULL));
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
291 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
292
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
293 /* Store the string FIELD, followed by any lines in THE_LIST,
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
294 into the buffer WHERE.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
295 Concatenate lines, putting just a space between them.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
296 Delete everything contained in parentheses.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
297 When a recipient name contains <...>, we discard
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
298 everything except what is inside the <...>.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
299
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
300 We don't pay attention to overflowing WHERE;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
301 the caller has to make it big enough. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
302
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
303 char *
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
304 add_field (the_list, field, where)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
305 line_list the_list;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
306 register char *field, *where;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
307 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
308 register char c;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
309 while (true)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
310 {
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
311 char *this_recipient_where;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
312 int in_quotes = 0;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
313
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
314 *where++ = ' ';
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
315 this_recipient_where = where;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
316
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
317 while ((c = *field++) != '\0')
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
318 {
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
319 if (c == '\\')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
320 *where++ = c;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
321 else if (c == '"')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
322 {
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
323 in_quotes = ! in_quotes;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
324 *where++ = c;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
325 }
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
326 else if (in_quotes)
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
327 *where++ = c;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
328 else if (c == '(')
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
329 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
330 while (*field && *field != ')') ++field;
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
331 if (! (*field++)) break; /* no close */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
332 continue;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
333 }
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
334 else if (c == ',')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
335 {
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
336 *where++ = ' ';
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
337 /* When we get to the end of one recipient,
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
338 don't discard it if the next one has <...>. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
339 this_recipient_where = where;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
340 }
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
341 else if (c == '<')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
342 /* Discard everything we got before the `<'. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
343 where = this_recipient_where;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
344 else if (c == '>')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
345 /* Discard the rest of this name that follows the `>'. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
346 {
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
347 while (*field && *field != ',') ++field;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
348 if (! (*field++)) break; /* no comma */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
349 continue;
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
350 }
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
351 else
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
352 *where++ = c;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
353 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
354 if (the_list == NIL) break;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
355 field = the_list->string;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
356 the_list = the_list->continuation;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
357 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
358 return where;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
359 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
360
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
361 line_list
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
362 make_file_preface ()
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
363 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
364 char *the_string, *temp;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
365 long idiotic_interface;
69697
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
366 struct tm *tm;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
367 long prefix_length;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
368 long user_length;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
369 long date_length;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
370 line_list result;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
371
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
372 prefix_length = strlen (FROM_PREFIX);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
373 time (&idiotic_interface);
69697
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
374 /* Convert to a string, checking for out-of-range time stamps.
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
375 Don't use 'ctime', as that might dump core if the hardware clock
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
376 is set to a bizarre value. */
e112ec9aa49b * b2m.c: Include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 68647
diff changeset
377 tm = localtime (&idiotic_interface);
69790
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
378 if (! (tm && TM_YEAR_IN_ASCTIME_RANGE (tm->tm_year)
1e68e7f3b824 * lib-src/b2m.c (main): Don't include <limits.h>.
Paul Eggert <eggert@twinsun.com>
parents: 69697
diff changeset
379 && (the_date = asctime (tm))))
72034
ca1a855f01ae (fatal): Drop second parameter and treat first
Andreas Schwab <schwab@suse.de>
parents: 70278
diff changeset
380 fatal ("current time is out of range");
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
381 /* the_date has an unwanted newline at the end */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
382 date_length = strlen (the_date) - 1;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
383 the_date[date_length] = '\0';
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
384 temp = cuserid ((char *) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
385 user_length = strlen (temp);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
386 the_user = alloc_string (user_length + 1);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
387 strcpy (the_user, temp);
18841
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
388 the_string = alloc_string (3 + prefix_length
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
389 + user_length
36704f455f32 [HAVE_UNISTD_H]: Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 16218
diff changeset
390 + date_length);
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
391 temp = the_string;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
392 strcpy (temp, FROM_PREFIX);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
393 temp = &temp[prefix_length];
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
394 *temp++ = ' ';
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
395 strcpy (temp, the_user);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
396 temp = &temp[user_length];
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
397 *temp++ = ' ';
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
398 strcpy (temp, the_date);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
399 result = new_list ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
400 result->string = the_string;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
401 result->continuation = ((line_list) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
402 return result;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
403 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
404
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
405 void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
406 write_line_list (the_list, the_stream)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
407 register line_list the_list;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
408 FILE *the_stream;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
409 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
410 for ( ;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
411 the_list != ((line_list) NULL) ;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
412 the_list = the_list->continuation)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
413 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
414 fputs (the_list->string, the_stream);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
415 putc ('\n', the_stream);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
416 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
417 return;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
418 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
419
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
420 int
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
421 close_the_streams ()
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
422 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
423 register stream_list rem;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
424 for (rem = the_streams;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
425 rem != ((stream_list) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
426 rem = rem->rest_streams)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
427 no_problems = (no_problems &&
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
428 ((*rem->action) (rem->handle) == 0));
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
429 the_streams = ((stream_list) NULL);
55442
a47704955f8d Throughout, replace 0 destined for `exit' arg with `EXIT_SUCCESS'.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 52401
diff changeset
430 return (no_problems ? EXIT_SUCCESS : EXIT_FAILURE);
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
431 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
432
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
433 void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
434 add_a_stream (the_stream, closing_action)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
435 FILE *the_stream;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
436 int (*closing_action)();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
437 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
438 stream_list old = the_streams;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
439 the_streams = new_stream ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
440 the_streams->handle = the_stream;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
441 the_streams->action = closing_action;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
442 the_streams->rest_streams = old;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
443 return;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
444 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
445
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
446 int
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
447 my_fclose (the_file)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
448 FILE *the_file;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
449 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
450 putc ('\n', the_file);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
451 fflush (the_file);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
452 return fclose (the_file);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
453 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
454
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
455 boolean
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
456 open_a_file (name)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
457 char *name;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
458 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
459 FILE *the_stream = fopen (name, "a");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
460 if (the_stream != ((FILE *) NULL))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
461 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
462 add_a_stream (the_stream, my_fclose);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
463 if (the_user == ((char *) NULL))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
464 file_preface = make_file_preface ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
465 write_line_list (file_preface, the_stream);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
466 return true;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
467 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
468 return false;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
469 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
470
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
471 void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
472 put_string (s)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
473 char *s;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
474 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
475 register stream_list rem;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
476 for (rem = the_streams;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
477 rem != ((stream_list) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
478 rem = rem->rest_streams)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
479 fputs (s, rem->handle);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
480 return;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
481 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
482
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
483 void
20
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
484 put_line (string)
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
485 char *string;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
486 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
487 register stream_list rem;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
488 for (rem = the_streams;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
489 rem != ((stream_list) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
490 rem = rem->rest_streams)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
491 {
20
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
492 char *s = string;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
493 int column = 0;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
494
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
495 /* Divide STRING into lines. */
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
496 while (*s != 0)
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
497 {
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
498 char *breakpos;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
499
5959
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
500 /* Find the last char that fits. */
20
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
501 for (breakpos = s; *breakpos && column < 78; ++breakpos)
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
502 {
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
503 if (*breakpos == '\t')
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
504 column += 8;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
505 else
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
506 column++;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
507 }
5959
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
508 /* If we didn't reach end of line, break the line. */
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
509 if (*breakpos)
20
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
510 {
5959
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
511 /* Back up to just after the last comma that fits. */
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
512 while (breakpos != s && breakpos[-1] != ',') --breakpos;
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
513
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
514 if (breakpos == s)
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
515 {
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
516 /* If no comma fits, move past the first address anyway. */
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
517 while (*breakpos != 0 && *breakpos != ',') ++breakpos;
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
518 if (*breakpos != 0)
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
519 /* Include the comma after it. */
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
520 ++breakpos;
e4337a7bbe32 (put_line): Don't break the line if it all fits.
Richard M. Stallman <rms@gnu.org>
parents: 5447
diff changeset
521 }
20
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
522 }
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
523 /* Output that much, then break the line. */
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
524 fwrite (s, 1, breakpos - s, rem->handle);
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
525 column = 8;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
526
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
527 /* Skip whitespace and prepare to print more addresses. */
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
528 s = breakpos;
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
529 while (*s == ' ' || *s == '\t') ++s;
3219
1aa8fa0a569e (put_line): Don't output \n\t unless more text follows.
Richard M. Stallman <rms@gnu.org>
parents: 37
diff changeset
530 if (*s != 0)
1aa8fa0a569e (put_line): Don't output \n\t unless more text follows.
Richard M. Stallman <rms@gnu.org>
parents: 37
diff changeset
531 fputs ("\n\t", rem->handle);
20
34d646609216 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 18
diff changeset
532 }
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
533 putc ('\n', rem->handle);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
534 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
535 return;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
536 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
537
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
538 #define mail_error error
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
539
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
540 /* Handle an FCC field. FIELD is the text of the first line (after
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
541 the header name), and THE_LIST holds the continuation lines if any.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
542 Call open_a_file for each file. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
543
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
544 void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
545 setup_files (the_list, field)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
546 register line_list the_list;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
547 register char *field;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
548 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
549 register char *start;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
550 register char c;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
551 while (true)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
552 {
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
553 while (((c = *field) != '\0')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
554 && (c == ' '
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
555 || c == '\t'
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
556 || c == ','))
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
557 field += 1;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
558 if (c != '\0')
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
559 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
560 start = field;
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
561 while (((c = *field) != '\0')
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
562 && c != ' '
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
563 && c != '\t'
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
564 && c != ',')
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
565 field += 1;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
566 *field = '\0';
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
567 if (!open_a_file (start))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
568 mail_error ("Could not open file %s", start);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
569 *field = c;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
570 if (c != '\0') continue;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
571 }
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
572 if (the_list == ((line_list) NULL))
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
573 return;
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
574 field = the_list->string;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
575 the_list = the_list->continuation;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
576 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
577 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
578
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
579 /* Compute the total size of all recipient names stored in THE_HEADER.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
580 The result says how big to make the buffer to pass to parse_header. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
581
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
582 int
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
583 args_size (the_header)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
584 header the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
585 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
586 register header old = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
587 register line_list rem;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
588 register int size = 0;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
589 do
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
590 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
591 char *field;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
592 register char *keyword = get_keyword (the_header->text->string, &field);
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
593 if ((strcmp (keyword, "TO") == 0)
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
594 || (strcmp (keyword, "CC") == 0)
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
595 || (strcmp (keyword, "BCC") == 0))
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
596 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
597 size += 1 + strlen (field);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
598 for (rem = the_header->text->continuation;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
599 rem != NIL;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
600 rem = rem->continuation)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
601 size += 1 + strlen (rem->string);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
602 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
603 the_header = the_header->next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
604 } while (the_header != old);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
605 return size;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
606 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
607
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
608 /* Scan the header described by the lists THE_HEADER,
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
609 and put all recipient names into the buffer WHERE.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
610 Precede each recipient name with a space.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
611
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
612 Also, if the header has any FCC fields, call setup_files for each one. */
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
613
21389
48690fd8d40a (_XOPEN_SOURCE): Define for declaration of cuserid.
Andreas Schwab <schwab@suse.de>
parents: 18841
diff changeset
614 void
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
615 parse_header (the_header, where)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
616 header the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
617 register char *where;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
618 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
619 register header old = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
620 do
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
621 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
622 char *field;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
623 register char *keyword = get_keyword (the_header->text->string, &field);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
624 if (strcmp (keyword, "TO") == 0)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
625 where = add_field (the_header->text->continuation, field, where);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
626 else if (strcmp (keyword, "CC") == 0)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
627 where = add_field (the_header->text->continuation, field, where);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
628 else if (strcmp (keyword, "BCC") == 0)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
629 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
630 where = add_field (the_header->text->continuation, field, where);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
631 the_header->previous->next = the_header->next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
632 the_header->next->previous = the_header->previous;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
633 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
634 else if (strcmp (keyword, "FCC") == 0)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
635 setup_files (the_header->text->continuation, field);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
636 the_header = the_header->next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
637 } while (the_header != old);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
638 *where = '\0';
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
639 return;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
640 }
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
641
10265
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
642 /* Read lines from the input until we get a blank line.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
643 Create a list of `header' objects, one for each header field,
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
644 each of which points to a list of `line_list' objects,
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
645 one for each line in that field.
c53a70ec8d85 (xmalloc, xrealloc): Add casts.
Richard M. Stallman <rms@gnu.org>
parents: 9621
diff changeset
646 Continuation lines are grouped in the headers they continue. */
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
647
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
648 header
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
649 read_header ()
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
650 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
651 register header the_header = ((header) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
652 register line_list *next_line = ((line_list *) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
653
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
654 init_linebuffer (&lb);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
655
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
656 do
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
657 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
658 long length;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
659 register char *line;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
660
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
661 readline (&lb, stdin);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
662 line = lb.buffer;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
663 length = strlen (line);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
664 if (length == 0) break;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
665
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
666 if (has_keyword (line))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
667 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
668 register header old = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
669 the_header = new_header ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
670 if (old == ((header) NULL))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
671 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
672 the_header->next = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
673 the_header->previous = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
674 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
675 else
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
676 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
677 the_header->previous = old;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
678 the_header->next = old->next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
679 old->next = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
680 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
681 next_line = &(the_header->text);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
682 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
683
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
684 if (next_line == ((line_list *) NULL))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
685 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
686 /* Not a valid header */
55442
a47704955f8d Throughout, replace 0 destined for `exit' arg with `EXIT_SUCCESS'.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 52401
diff changeset
687 exit (EXIT_FAILURE);
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
688 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
689 *next_line = new_list ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
690 (*next_line)->string = alloc_string (length);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
691 strcpy (((*next_line)->string), line);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
692 next_line = &((*next_line)->continuation);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
693 *next_line = NIL;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
694
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
695 } while (true);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
696
70278
8e7233f487a3 (read_header): Give fatal error if input has no header.
Richard M. Stallman <rms@gnu.org>
parents: 69790
diff changeset
697 if (! the_header)
8e7233f487a3 (read_header): Give fatal error if input has no header.
Richard M. Stallman <rms@gnu.org>
parents: 69790
diff changeset
698 fatal ("input message has no header");
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
699 return the_header->next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
700 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
701
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
702 void
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
703 write_header (the_header)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
704 header the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
705 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
706 register header old = the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
707 do
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
708 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
709 register line_list the_list;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
710 for (the_list = the_header->text;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
711 the_list != NIL;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
712 the_list = the_list->continuation)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
713 put_line (the_list->string);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
714 the_header = the_header->next;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
715 } while (the_header != old);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
716 put_line ("");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
717 return;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
718 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
719
15683
5f9426e991a3 Declare main as int, not void.
Karl Heuer <kwzh@gnu.org>
parents: 15099
diff changeset
720 int
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
721 main (argc, argv)
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
722 int argc;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
723 char **argv;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
724 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
725 char *command_line;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
726 header the_header;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
727 long name_length;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
728 char *mail_program_name;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
729 char buf[BUFLEN + 1];
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
730 register int size;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
731 FILE *the_pipe;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
732
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
733 extern char *getenv ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
734
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
735 mail_program_name = getenv ("FAKEMAILER");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
736 if (!(mail_program_name && *mail_program_name))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
737 mail_program_name = MAIL_PROGRAM_NAME;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
738 name_length = strlen (mail_program_name);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
739
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
740 my_name = MY_NAME;
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
741 the_streams = ((stream_list) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
742 the_date = ((char *) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
743 the_user = ((char *) NULL);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
744
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
745 the_header = read_header ();
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
746 command_line = alloc_string (name_length + args_size (the_header));
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
747 strcpy (command_line, mail_program_name);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
748 parse_header (the_header, &command_line[name_length]);
42181
358035cb58d9 Conditionally include config.h.
Pavel Janík <Pavel@Janik.cz>
parents: 42134
diff changeset
749
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
750 the_pipe = popen (command_line, "w");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
751 if (the_pipe == ((FILE *) NULL))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
752 fatal ("cannot open pipe to real mailer");
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
753
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
754 add_a_stream (the_pipe, pclose);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
755
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
756 write_header (the_header);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
757
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
758 /* Dump the message itself */
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
759
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
760 while (!feof (stdin))
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
761 {
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
762 size = fread (buf, 1, BUFLEN, stdin);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
763 buf[size] = '\0';
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
764 put_string (buf);
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
765 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
766
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
767 exit (close_the_streams ());
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
768 }
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
769
5447
6f0905b05218 (main) [MSDOS]: Dummy stub just to make the file compile.
Richard M. Stallman <rms@gnu.org>
parents: 4696
diff changeset
770 #endif /* not MSDOS */
18
71c0ddb55b6d Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
771 #endif /* not BSD 4.2 (or newer) */
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 42469
diff changeset
772
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 42469
diff changeset
773 /* arch-tag: acb0afa6-315a-4c5b-b9e3-def5725c8783
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 42469
diff changeset
774 (do not change this comment) */
55442
a47704955f8d Throughout, replace 0 destined for `exit' arg with `EXIT_SUCCESS'.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 52401
diff changeset
775
a47704955f8d Throughout, replace 0 destined for `exit' arg with `EXIT_SUCCESS'.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 52401
diff changeset
776 /* fakemail.c ends here */