summaryrefslogtreecommitdiff
path: root/mail/thunderbird/patches/patch-aw
blob: fc04dc962a973e7b995e7d2e1d48d79b2bae1060 (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
$NetBSD: patch-aw,v 1.9 2012/03/10 11:42:38 ryoon Exp $

--- mozilla/xulrunner/stub/nsXULStub.cpp.orig	2012-02-16 10:25:33.000000000 +0000
+++ mozilla/xulrunner/stub/nsXULStub.cpp
@@ -44,6 +44,29 @@
 #include "nsILocalFile.h"
 
 #include <stdarg.h>
+#if defined(__NetBSD__)
+#include <sys/resource.h>
+/*
+ * On netbsd-4, ulimit -n is 64 by default; too few for us.
+ */
+static void netbsd_fixrlimit(void) {
+       struct rlimit rlp;
+       if (getrlimit(RLIMIT_NOFILE, &rlp) == -1) {
+	       fprintf(stderr, "warning: getrlimit failed\n");
+	       return;
+       }
+       if (rlp.rlim_cur >= 512)
+	       return;
+       if (rlp.rlim_max < 512) {
+	       fprintf(stderr, "warning: hard limit of 'ulimit -n' too low\n");
+	       rlp.rlim_cur = rlp.rlim_max;
+       }
+       else
+	       rlp.rlim_cur = 512;
+       if (setrlimit(RLIMIT_NOFILE, &rlp) == -1)
+	       fprintf(stderr, "warning: setrlimit failed\n");
+}
+#endif
 
 #ifdef XP_WIN
 #include <windows.h>
@@ -202,7 +225,9 @@ main(int argc, char **argv)
   char greDir[MAXPATHLEN];
   bool greFound = false;
 
-#if defined(XP_MACOSX)
+#if defined(__NetBSD__)
+  netbsd_fixrlimit();
+#elif defined(XP_MACOSX)
   CFBundleRef appBundle = CFBundleGetMainBundle();
   if (!appBundle)
     return 1;