summaryrefslogtreecommitdiffstats
path: root/system/ksh-openbsd/patches/linux/history_c.diff
blob: 04731805a91c4add7c6be458e935aaa82290a99b (plain)
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
--- ksh-openbsd_cvs/history.c	2010-02-23 12:49:16.000000000 +0100
+++ ksh-openbsd_cvs.new/history.c	2010-04-01 21:01:24.133232595 +0200
@@ -17,6 +17,7 @@
 
 #include "sh.h"
 #include <sys/stat.h>
+#include "strlcat.h"
 
 #ifdef HISTORY
 # include <sys/file.h>
Linux specific modifications:
	- #include stdint.h for uint32_t
	- #define timespeccmp() which is sys/time.h in OpenBSD
	- Linux doesn't have any LOCK flags for open(2), so use flock(2) instead

--- ksh-openbsd_cvs/history.c	2011-09-01 08:09:51.486181269 +0200
+++ ksh-openbsd_cvs.new/history.c	2011-09-01 08:08:59.657181265 +0200
@@ -17,11 +17,17 @@
 #include "sh.h"
 #include <sys/stat.h>
 #include "strlcat.h"
+#include "stdint.h"
 
 #ifdef HISTORY
 # include <sys/file.h>
 # include <sys/mman.h>
 
+#define timespeccmp(tsp, usp, cmp)			\
+	(((tsp)->tv_sec == (usp)->tv_sec) ?		\
+	    ((tsp)->tv_nsec cmp (usp)->tv_nsec) :	\
+	    ((tsp)->tv_sec cmp (usp)->tv_sec))
+
 static void	writehistfile(FILE *);
 static FILE    *history_open(int *);
 static int	history_load(FILE *, Source *);
@@ -604,7 +610,9 @@
 	FILE		*f = NULL;
 	struct stat	sb;
 
-	if ((fd = open(hname, O_RDWR | O_CREAT | O_EXLOCK, 0600)) == -1)
+	if ((fd = open(hname, O_RDWR | O_CREAT, 0600)) == -1)
+		return (NULL);
+	if (flock(fd, LOCK_EX) == -1)
 		return (NULL);
 	f = fdopen(fd, "r+");
 	if (f == NULL) {