summaryrefslogtreecommitdiff
path: root/sysutils/parallel/files/patch-src__parallel
blob: 55027e8bed62e4f578bc31a6399de6a397b30dc6 (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
--- ./src/parallel.orig	2011-07-22 07:24:21.000000000 -0500
+++ ./src/parallel	2011-07-22 07:33:44.000000000 -0500
@@ -3963,28 +3963,42 @@
 
 # Maximal command line length (for -m and -X)
 sub max_length {
-    # Find the max_length of a command line
-    # Returns:
-    #   number of chars on the longest command line allowed
+    # FreeBSD code:
     if(not $Limits::Command::line_max_len) {
-	if($::opt_s) {
-	    if(is_acceptable_command_line_length($::opt_s)) {
-		$Limits::Command::line_max_len = $::opt_s;
-	    } else {
-		# -s is too long: Find the correct
-		$Limits::Command::line_max_len = binary_find_max_length(0,$::opt_s);
-	    }
-	    if($::opt_s <= $Limits::Command::line_max_len) {
-		$Limits::Command::line_max_len = $::opt_s;
-	    } else {
-		print STDERR "$Global::progname: value for -s option ",
-		"should be < $Limits::Command::line_max_len\n";
-	    }
-	} else {
-	    $Limits::Command::line_max_len = real_max_length();
-	}
+        $Limits::Command::line_max_len = `getconf ARG_MAX` - 1024;
+        if ($::opt_s) {
+            if ($::opt_s > $Limits::Command::line_max_len) {
+	      print STDERR "$Global::progname: ",
+	      "you are setting value for -s greater than $Limits::Command::line_max_len\n";
+            }
+            $Limits::Command::line_max_len = $::opt_s;
+        }
     }
     return $Limits::Command::line_max_len;
+
+#    ORIGINAL code:
+#    # Find the max_length of a command line
+#    # Returns:
+#    #   number of chars on the longest command line allowed
+#    if(not $Limits::Command::line_max_len) {
+#	if($::opt_s) {
+#	    if(is_acceptable_command_line_length($::opt_s)) {
+#		$Limits::Command::line_max_len = $::opt_s;
+#	    } else {
+#		# -s is too long: Find the correct
+#		$Limits::Command::line_max_len = binary_find_max_length(0,$::opt_s);
+#	    }
+#	    if($::opt_s <= $Limits::Command::line_max_len) {
+#		$Limits::Command::line_max_len = $::opt_s;
+#	    } else {
+#		print STDERR "$Global::progname: value for -s option ",
+#		"should be < $Limits::Command::line_max_len\n";
+#	    }
+#	} else {
+#	    $Limits::Command::line_max_len = real_max_length();
+#	}
+#    }
+#    return $Limits::Command::line_max_len;
 }
 
 sub real_max_length {