aboutsummaryrefslogtreecommitdiffstats
path: root/devel/libgtop2/files
diff options
context:
space:
mode:
authorbland <bland@FreeBSD.org>2003-09-03 11:18:55 +0800
committerbland <bland@FreeBSD.org>2003-09-03 11:18:55 +0800
commit97318940a30135bb8922f725894d5c928a9928a6 (patch)
tree5a67728228b55a8c67e68a97d6fee3ad9c30bc8c /devel/libgtop2/files
parent552b1cb0d049dfb24d53ee6e40500b4aa9a8e4a8 (diff)
downloadfreebsd-ports-gnome-97318940a30135bb8922f725894d5c928a9928a6.tar.gz
freebsd-ports-gnome-97318940a30135bb8922f725894d5c928a9928a6.tar.zst
freebsd-ports-gnome-97318940a30135bb8922f725894d5c928a9928a6.zip
Fix illegal function argument list referencing. This gets back
user process list in g-s-m on -CURRENT.
Diffstat (limited to 'devel/libgtop2/files')
-rw-r--r--devel/libgtop2/files/patch-lib::lib.pl62
1 files changed, 62 insertions, 0 deletions
diff --git a/devel/libgtop2/files/patch-lib::lib.pl b/devel/libgtop2/files/patch-lib::lib.pl
new file mode 100644
index 000000000000..6e08ba030855
--- /dev/null
+++ b/devel/libgtop2/files/patch-lib::lib.pl
@@ -0,0 +1,62 @@
+--- lib/lib.pl.orig Mon Sep 1 20:17:45 2003
++++ lib/lib.pl Wed Sep 3 11:53:12 2003
+@@ -116,6 +116,8 @@
+ $param_decl = '';
+ $send_size = '';
+ $send_ptr = '';
++ $send_buf_decl = '';
++ $send_buf = '';
+ $nr_params = (@params = split(/:/, $param_def, 9999));
+ for ($param = 1; $param <= $nr_params; $param++) {
+ $list = $params[$param];
+@@ -135,28 +137,37 @@
+
+ $fields[$field];
+ $call_param = $call_param . ', ' . $fields[$field];
+- if ($send_ptr eq '') {
+- $send_ptr = "\n\tconst void *send_ptr = &" .
+-
+- $fields[$field] . ';';
+- }
+- if ($send_size eq '') {
+- $send_size = "\n\tconst size_t send_size =\n\t\t";
++ if ($send_buf eq '') {
++ $send_size = "\n\tconst size_t send_size = ";
++ $send_ptr = "\n\tconst void *send_ptr = &";
++ if ($nr_params == 1 && $count == 1) {
++ $send_size = $send_size . 'sizeof (' . $fields[$field] . ');';
++ $send_ptr = $send_ptr . $fields[$field] . ';';
++ last;
++ }
++ $send_size = $send_size . 'sizeof (send_buf);';
++ $send_ptr = $send_ptr . 'send_buf;';
+ }
+ else {
+- $send_size = $send_size . ' + ';
++ $send_buf_decl = $send_buf_decl . ' ';
++ $send_buf = $send_buf . ', ';
+ }
+- $send_size = $send_size . 'sizeof (' . $fields[$field] . ')';
++ $send_buf_decl = $send_buf_decl . '' . $convert{$type} . ' ' .
++
++ $fields[$field] . ';';
++ $send_buf = $send_buf . '' . $fields[$field];
+ }
+ }
+- if ($send_size ne '') {
+- $send_size = $send_size . ';';
+- }
+- else {
++ if ($send_size eq '') {
+ $send_size = "\n\tconst size_t send_size = 0;";
+ }
+ if ($send_ptr eq '') {
+ $send_ptr = "\n\tconst void *send_ptr = NULL;";
++ }
++ if ($send_buf ne '') {
++ $send_ptr = "\n\tconst struct { " . $send_buf_decl . " } send_buf =\n" .
++ "\t\t{ " . $send_buf . ' };' .
++ $send_ptr;
+ }
+ }
+