summaryrefslogtreecommitdiff
path: root/x11-wm/bbkeys/files/patch-src_Netclient.cpp
diff options
context:
space:
mode:
authorChristian Weisgerber <naddy@FreeBSD.org>2010-08-07 13:58:15 +0000
committerChristian Weisgerber <naddy@FreeBSD.org>2010-08-07 13:58:15 +0000
commit94e9c4a8dbc8cdd6f1b7e4e11a90b9a60b780295 (patch)
tree96fbb6e656f458f4067bbb5fa7811194b7a25892 /x11-wm/bbkeys/files/patch-src_Netclient.cpp
parentThe NASA Vision Workbench (VW) is a general purpose image processing and (diff)
(1) LP64 fix: XGetWindowProperty() passes 32-bit values in long ints.
(2) Remove pkg-message, which isn't needed any longer. Submitted by: A.J.Caines@halplant.com (maintainer) (2) Approved by: A.J.Caines@halplant.com (maintainer) (1)
Diffstat (limited to 'x11-wm/bbkeys/files/patch-src_Netclient.cpp')
-rw-r--r--x11-wm/bbkeys/files/patch-src_Netclient.cpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/x11-wm/bbkeys/files/patch-src_Netclient.cpp b/x11-wm/bbkeys/files/patch-src_Netclient.cpp
new file mode 100644
index 000000000000..1aea8e54b8e9
--- /dev/null
+++ b/x11-wm/bbkeys/files/patch-src_Netclient.cpp
@@ -0,0 +1,45 @@
+--- src/Netclient.cpp.orig
++++ src/Netclient.cpp
+@@ -141,6 +141,7 @@
+ int result;
+ unsigned long maxread = nelements;
+ bool ret = False;
++ int bsize;
+
+ // try get the first element
+ result = XGetWindowProperty(_display.XDisplay(), win, atom, 0l, 1l, False,
+@@ -149,18 +150,19 @@
+ ret = (result == Success && ret_type == type && ret_size == size &&
+ nelements > 0);
+ if (ret) {
++ bsize = (size == 32) ? sizeof(long) : size/8;
+ if (ret_bytes == 0 || maxread <= nelements) {
+ // we got the whole property's value
+- *value = new unsigned char[nelements * size/8 + 1];
+- memcpy(*value, c_val, nelements * size/8 + 1);
++ *value = new unsigned char[nelements * bsize + 1];
++ memcpy(*value, c_val, nelements * bsize + 1);
+ } else {
+ // get the entire property since it is larger than one long
+ XFree(c_val);
+ // the number of longs that need to be retreived to get the property's
+ // entire value. The last + 1 is the first long that we retrieved above.
+ int remain = (ret_bytes - 1)/sizeof(long) + 1 + 1;
+- if (remain > size/8 * (signed)maxread) // dont get more than the max
+- remain = size/8 * (signed)maxread;
++ if (remain > bsize * (signed)maxread) // dont get more than the max
++ remain = bsize * (signed)maxread;
+ result = XGetWindowProperty(_display.XDisplay(), win, atom, 0l, remain, False, type,
+ &ret_type, &ret_size, &nelements, &ret_bytes,
+ &c_val);
+@@ -174,8 +176,8 @@
+ if (! ret)
+ return getValue(win, atom, type, maxread, value, size);
+
+- *value = new unsigned char[nelements * size/8 + 1];
+- memcpy(*value, c_val, nelements * size/8 + 1);
++ *value = new unsigned char[nelements * bsize + 1];
++ memcpy(*value, c_val, nelements * bsize + 1);
+ }
+ }
+ if (c_val) XFree(c_val);