aboutsummaryrefslogtreecommitdiffstats
path: root/mail/qmail-contrib/files/extra-patch-newaliases
blob: 4098f42cd45c063ffb86e8af3ce72120476df906 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
--- newaliases.c.orig   Tue May 19 13:25:42 1998
+++ newaliases.c    Mon Feb 13 09:53:58 2006
@@ -12,6 +12,10 @@
 
 #define FATAL "newaliases: fatal: "
 
+stralloc fnsrc = {0};
+stralloc fncdb = {0};
+stralloc fntmp = {0};
+
 void nomem()
 {
   strerr_die2x(111,FATAL,"out of memory");
@@ -26,11 +30,11 @@
 }
 void writeerr()
 {
-  strerr_die2sys(111,FATAL,"unable to write to /etc/aliases.tmp: ");
+  strerr_die4sys(111,FATAL,"unable to write to ",fntmp.s,": ");
 }
 void readerr()
 {
-  strerr_die2sys(111,FATAL,"unable to read /etc/aliases: ");
+  strerr_die4sys(111,FATAL,"unable to read ",fnsrc.s,": ");
 }
 void die_control()
 {
@@ -270,19 +274,32 @@
   if (cdbmss_add(&cdbmss,key.s,key.len,instr.s,instr.len) == -1) writeerr();
 }
 
-void main()
+void main(argc,argv)
+int argc;
+char **argv;
 {
   int fd;
 
   umask(033);
   readcontrols();
 
-  fd = open_read("/etc/aliases");
+  if (!stralloc_copys(&fnsrc,argv[1] ? argv[1] : "/etc/aliases")) nomem();
+  if (!stralloc_0(&fnsrc)) nomem();
+
+  if (!stralloc_copys(&fncdb,fnsrc.s)) nomem();
+  if (!stralloc_cats(&fncdb,".cdb")) nomem();
+  if (!stralloc_0(&fncdb)) nomem();
+
+  if (!stralloc_copys(&fntmp,fnsrc.s)) nomem();
+  if (!stralloc_cats(&fntmp,".tmp")) nomem();
+  if (!stralloc_0(&fntmp)) nomem();
+  
+  fd = open_read(fnsrc.s);
   if (fd == -1) readerr();
   substdio_fdbuf(&ssin,read,fd,inbuf,sizeof inbuf);
 
-  fd = open_trunc("/etc/aliases.tmp");
-  if (fd == -1) strerr_die2sys(111,FATAL,"unable to create /etc/aliases.tmp: ");
+  fd = open_trunc(fntmp.s);
+  if (fd == -1) strerr_die4sys(111,FATAL,"unable to create ",fntmp.s,": ");
   if (cdbmss_start(&cdbmss,fd) == -1) writeerr();
 
   if (!stralloc_copys(&line,"")) nomem();
@@ -314,8 +331,8 @@
   if (fsync(fd) == -1) writeerr();
   if (close(fd) == -1) writeerr(); /* NFS stupidity */
 
-  if (rename("/etc/aliases.tmp","/etc/aliases.cdb") == -1)
-    strerr_die2sys(111,FATAL,"unable to move /etc/aliases.tmp to /etc/aliases.cdb: ");
+  if (rename(fntmp.s,fncdb.s) == -1)
+    strerr_die6sys(111,FATAL,"unable to move ",fntmp.s," to ",fncdb.s,": ");
   
   _exit(0);
 }