summaryrefslogtreecommitdiff
path: root/news/s-news/files/patch-qnews.c
blob: 415cbed2c9a7ffc85911bbc5fd45279f646d32e1 (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
--- qnews.c	2002-05-18 20:21:42.000000000 +0100
+++ qnews.c	2002-10-12 19:23:55.000000000 +0100
@@ -2,6 +2,8 @@
  *  S-News version 0.1.9 - A Simple News Server
  *  Copyright (C) 1998 Christopher John Purnell
  *                     cjp@lost.org.uk
+ *  flock modification (c) 2002 Tony Houghton
+ *  		       tony@realh.co.uk
  *
  *  This program is free software; you can redistribute it and/or modify
  *  it under the terms of the GNU General Public License as published by
@@ -22,7 +24,13 @@
 #include "config.h"
 #endif
 
+#include <sys/types.h>
 #include <sys/stat.h>
+#ifdef HAVE_SYS_FILE_H
+#include <sys/file.h>
+#endif
+#include <fcntl.h>
+
 #ifdef HAVE_UNISTD_H
 #include <unistd.h>
 #endif
@@ -79,15 +87,37 @@
 			if (match_group(ptr->value,line,end))
 			{
 				FILE *fp;
+			#ifdef HAVE_SYS_FILE_H
+				int fd;
+			#endif
 
 				sprintf(file,CONFDIR"/suck/%s/outgoing",
-					ptr->name);
+				    ptr->name);
 
-				if (!(fp = fopen(file,"a")))
+			#ifdef HAVE_SYS_FILE_H
+				if ((fd = open(file,O_WRONLY|O_APPEND|O_CREAT,
+						0644)) == -1)
 				{
-					perror(file);
-					return (1);
+				    perror(file);
+				    return (1);
+				}
+				if (flock(fd,LOCK_EX) == -1)
+				{
+				    perror(file);
+				    return (1);
+				}
+				if (!(fp = fdopen(fd,"a")))
+				{
+				    perror(file);
+				    return (1);
 				}
+			#else
+                                if (!(fp = fopen(file,"a")))
+                                {
+                                        perror(file);
+                                        return (1);
+                                }
+			#endif
 
 				if (fputs(line,fp) < 0 ||
 				    fputc('\n',fp) < 0)
@@ -103,6 +133,9 @@
 					return (1);
 				}
 
+				/* By commenting this break we can post to
+				 * multiple servers instead of stopping after
+				 * first match*/
 				break;
 			}
 		}
@@ -204,7 +237,7 @@
 				return (0);
 			break;
 		case '[':
-			if (str>=end)
+			if (str<end)
 			{
 				unsigned char rev,mat=0,l=0,h,u=*str;
 
@@ -229,6 +262,8 @@
 				if (mat==rev)
 					return (0);
 			}
+			else
+				return (0);
 			break;
 		default:
 			if (str>=end || *str!=c)