summaryrefslogtreecommitdiff
path: root/mail/qmail-contrib/files/extra-patch-newaliases
blob: 58a5341f70776b890e2b43e8a8f1b71cc1676fdd (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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
*** newaliases.c.orig	Fri Apr 24 17:34:58 1998
--- newaliases.c	Fri Apr 24 17:38:32 1998
***************
*** 12,17 ****
--- 12,21 ----
  
  #define FATAL "newaliases: fatal: "
  
+ stralloc fnsrc = {0};
+ stralloc fncdb = {0};
+ stralloc fntmp = {0};
+ 
  void nomem()
  {
    strerr_die2x(111,FATAL,"out of memory");
***************
*** 26,36 ****
  }
  void writeerr()
  {
!   strerr_die2sys(111,FATAL,"unable to write to /etc/aliases.tmp: ");
  }
  void readerr()
  {
!   strerr_die2sys(111,FATAL,"unable to read /etc/aliases: ");
  }
  void die_control()
  {
--- 30,40 ----
  }
  void writeerr()
  {
!   strerr_die4sys(111,FATAL,"unable to write to ",fntmp.s,": ");
  }
  void readerr()
  {
!   strerr_die4sys(111,FATAL,"unable to read ",fnsrc.s,": ");
  }
  void die_control()
  {
***************
*** 270,288 ****
    if (cdbmss_add(&cdbmss,key.s,key.len,instr.s,instr.len) == -1) writeerr();
  }
  
! void main()
  {
    int fd;
  
    umask(033);
    readcontrols();
  
!   fd = open_read("/etc/aliases");
    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: ");
    if (cdbmss_start(&cdbmss,fd) == -1) writeerr();
  
    if (!stralloc_copys(&line,"")) nomem();
--- 274,305 ----
    if (cdbmss_add(&cdbmss,key.s,key.len,instr.s,instr.len) == -1) writeerr();
  }
  
! void main(argc,argv)
! int argc;
! char **argv;
  {
    int fd;
  
    umask(033);
    readcontrols();
  
!   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(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,321 ****
    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: ");
    
    _exit(0);
  }
--- 331,338 ----
    if (fsync(fd) == -1) writeerr();
    if (close(fd) == -1) writeerr(); /* NFS stupidity */
  
!   if (rename(fntmp.s,fncdb.s) == -1)
!     strerr_die6sys(111,FATAL,"unable to move ",fntmp.s," to ",fncdb.s,": ");
    
    _exit(0);
  }