summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTavis Ormandy <taviso@gentoo.org>2003-10-11 09:42:51 +0000
committerTavis Ormandy <taviso@gentoo.org>2003-10-11 09:42:51 +0000
commit4071eb16b1ced28aa873e4554a548171567540dd (patch)
tree64fff9b383a5eb1d9c097b7f0067eeb109da5836 /dev-perl/X11-Protocol
parentApplying patch required for newer versions of FvwmTabs (diff)
downloadhistorical-4071eb16b1ced28aa873e4554a548171567540dd.tar.gz
historical-4071eb16b1ced28aa873e4554a548171567540dd.tar.bz2
historical-4071eb16b1ced28aa873e4554a548171567540dd.zip
Applying patch required for newer versions of FvwmTabs
Diffstat (limited to 'dev-perl/X11-Protocol')
-rw-r--r--dev-perl/X11-Protocol/Manifest4
-rw-r--r--dev-perl/X11-Protocol/X11-Protocol-0.51-r1.ebuild22
-rw-r--r--dev-perl/X11-Protocol/files/X11-Protocol-0.51.s2.patch182
-rw-r--r--dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r11
4 files changed, 207 insertions, 2 deletions
diff --git a/dev-perl/X11-Protocol/Manifest b/dev-perl/X11-Protocol/Manifest
index 6b6f2046d6b2..e58a9788b92b 100644
--- a/dev-perl/X11-Protocol/Manifest
+++ b/dev-perl/X11-Protocol/Manifest
@@ -1,6 +1,6 @@
MD5 5347595bcbabda730c87e3d5f9412688 X11-Protocol-0.51.ebuild 557
-MD5 62fbbe56766588edba149bfded564b59 X11-Protocol-0.51-r1.ebuild 644
-MD5 50aac1893ed3333cb29ba3afcd209cad ChangeLog 450
+MD5 761e38367e8793b583fd049f878251da X11-Protocol-0.51-r1.ebuild 656
+MD5 c6e6aff14b5a6fc07f71300b3be05c4f ChangeLog 658
MD5 f24e90787470f41e63101e1a77d646b6 files/digest-X11-Protocol-0.51-r1 68
MD5 f24e90787470f41e63101e1a77d646b6 files/digest-X11-Protocol-0.51 68
MD5 f76aed1895831b1029b2bbaff495eee6 files/X11-Protocol-0.51.s2.patch 5688
diff --git a/dev-perl/X11-Protocol/X11-Protocol-0.51-r1.ebuild b/dev-perl/X11-Protocol/X11-Protocol-0.51-r1.ebuild
new file mode 100644
index 000000000000..3148ee0bdee9
--- /dev/null
+++ b/dev-perl/X11-Protocol/X11-Protocol-0.51-r1.ebuild
@@ -0,0 +1,22 @@
+# Copyright 1999-2003 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-perl/X11-Protocol/X11-Protocol-0.51-r1.ebuild,v 1.1 2003/10/11 09:42:46 taviso Exp $
+
+inherit perl-module eutils
+
+S=${WORKDIR}/${P}
+DESCRIPTION="Client-side interface to the X11 Protocol"
+SRC_URI="http://www.cpan.org/modules/by-module/X11/${P}.tar.gz"
+HOMEPAGE="http://www.cpan.org/modules/by-module/X11/${P}.readme"
+
+SLOT="0"
+LICENSE="Artistic X11"
+KEYWORDS="~x86 ~alpha ~sparc"
+
+DEPEND="${DEPEND}
+ virtual/x11"
+
+src_unpack() {
+ unpack ${A}
+ cd ${S}; epatch ${FILESDIR}/X11-Protocol-0.51.s2.patch
+}
diff --git a/dev-perl/X11-Protocol/files/X11-Protocol-0.51.s2.patch b/dev-perl/X11-Protocol/files/X11-Protocol-0.51.s2.patch
new file mode 100644
index 000000000000..8eded5a697cd
--- /dev/null
+++ b/dev-perl/X11-Protocol/files/X11-Protocol-0.51.s2.patch
@@ -0,0 +1,182 @@
+*** Protocol.pm.orig Fri Aug 22 18:39:18 2003
+--- Protocol.pm Sat Oct 11 13:09:04 2003
+***************
+*** 15,21 ****
+
+ @EXPORT_OK = qw(pad padding padded hexi make_num_hash default_error_handler);
+
+! $VERSION = "0.51";
+
+ sub padding ($) {
+ my($x) = @_;
+--- 15,21 ----
+
+ @EXPORT_OK = qw(pad padding padded hexi make_num_hash default_error_handler);
+
+! $VERSION = "0.51.s2";
+
+ sub padding ($) {
+ my($x) = @_;
+***************
+*** 571,593 ****
+ return $mask;
+ }
+
+ sub default_error_handler {
+! my($self, $data) = @_;
+! my($type, $seq, $info, $minor_op, $major_op)
+! = unpack("xCSLSCxxxxxxxxxxxxxxxxxxxxx", $data);
+! my($t);
+! $t = join("", "Protocol error: bad $type (",
+! $self->do_interp('Error', $type), "); ",
+! "Sequence Number $seq\n",
+! " Opcode ($major_op, $minor_op) = ",
+! ($self->do_interp('Request', $major_op)
+! or $self->{'ext_request'}{$major_op}[$minor_op][0]), "\n");
+! if ($type == 2) {
+! $t .= " Bad value $info (" . hexi($info) . ")\n";
+! } elsif ($self->{'error_type'}[$type] & 1) {
+! $t .= " Bad resource $info (" . hexi($info) . ")\n";
+! }
+! croak($t);
+ }
+
+ sub handle_input {
+--- 571,598 ----
+ return $mask;
+ }
+
++ sub make_error_msg {
++ my($self, $data) = @_;
++ my($type, $seq, $info, $minor_op, $major_op)
++ = unpack("xCSLSCxxxxxxxxxxxxxxxxxxxxx", $data);
++ my($t);
++ $t = join("", "Protocol error: bad $type (",
++ $self->do_interp('Error', $type), "); ",
++ "Sequence Number $seq\n",
++ " Opcode ($major_op, $minor_op) = ",
++ ($self->do_interp('Request', $major_op)
++ or $self->{'ext_request'}{$major_op}[$minor_op][0]), "\n");
++ if ($type == 2) {
++ $t .= " Bad value $info (" . hexi($info) . ")\n";
++ } elsif ($self->{'error_type'}[$type] & 1) {
++ $t .= " Bad resource $info (" . hexi($info) . ")\n";
++ }
++ return $t;
++ }
++
+ sub default_error_handler {
+! my($self, $data) = @_;
+! croak($self->make_error_msg($data));
+ }
+
+ sub handle_input {
+***************
+*** 597,604 ****
+ $type_b = $self->get(1);
+ $type = unpack "C", $type_b;
+ if ($type == 0) {
+! &{$self->{'error_handler'}}($self, $type_b . $self->get(31));
+! return 0;
+ } elsif ($type > 1) {
+ if ($self->{'event_handler'} eq "queue") {
+ push @{$self->{'event_queue'}}, $type_b . $self->get(31);
+--- 602,614 ----
+ $type_b = $self->get(1);
+ $type = unpack "C", $type_b;
+ if ($type == 0) {
+! my $data = $type_b . $self->get(31);
+! my ($type, $seq, $info, $minor_op, $major_op)
+! = unpack("xCSLSCxxxxxxxxxxxxxxxxxxxxx", $data);
+! &{$self->{'error_handler'}}($self, $data);
+! # return 0 to denote an error & the sequence number to identify
+! # which request it applies to.
+! return (0, $seq);
+ } elsif ($type > 1) {
+ if ($self->{'event_handler'} eq "queue") {
+ push @{$self->{'event_queue'}}, $type_b . $self->get(31);
+***************
+*** 2031,2036 ****
+--- 2041,2047 ----
+ my($op, $args, $major, $minor) = (@_, 0);
+ my($data);
+ ($data, $minor) = (&{$op->[1]}($self, @$args), $minor);
++ # print($op->[0] . " req has seq: " . $self->{sequence_num} . "\n");
+ $minor = 0 unless defined $minor;
+ my($len) = (length($data) / 4) + 1;
+ croak "Request too long!\n" if $len > $self->{'maximum_request_length'};
+***************
+*** 2054,2061 ****
+ $self->give($self->assemble_request($op, \@args, $major, $minor));
+ $seq = $self->next_sequence();
+ $self->add_reply($seq & 0xffff, \$data);
+! $self->handle_input() until $data;
+ $self->delete_reply($seq & 0xffff);
+ return &{$op->[2]}($self, $data);
+ } elsif (@$op == 4) { # Many replies
+ my($seq, $data, @stuff, @ret);
+--- 2065,2077 ----
+ $self->give($self->assemble_request($op, \@args, $major, $minor));
+ $seq = $self->next_sequence();
+ $self->add_reply($seq & 0xffff, \$data);
+! while (1)
+! {
+! my @ret = $self->handle_input();
+! last if ($data || ($ret[0] == 0 && $ret[1] == $seq));
+! }
+ $self->delete_reply($seq & 0xffff);
++ return undef unless $data;
+ return &{$op->[2]}($self, $data);
+ } elsif (@$op == 4) { # Many replies
+ my($seq, $data, @stuff, @ret);
+***************
+*** 2063,2069 ****
+ $seq = $self->next_sequence();
+ $self->add_reply($seq & 0xffff, \$data);
+ for (;;) {
+! $data = 0; $self->handle_input() until $data;
+ @stuff = &{$op->[2]}($self, $data);
+ last unless @stuff;
+ if ($op->[3] eq "ARRAY") {
+--- 2079,2095 ----
+ $seq = $self->next_sequence();
+ $self->add_reply($seq & 0xffff, \$data);
+ for (;;) {
+! $data = 0;
+! while (1)
+! {
+! my @ret = $self->handle_input();
+! last if ($data || ($ret[0] == 0 && $ret[1] == $seq));
+! }
+! if (!$data)
+! {
+! $self->delete_reply($seq & 0xffff);
+! return undef;
+! }
+ @stuff = &{$op->[2]}($self, $data);
+ last unless @stuff;
+ if ($op->[3] eq "ARRAY") {
+***************
+*** 2392,2399 ****
+ $self->give($self->assemble_request($op, \@_, $major, $minor));
+ $seq = $self->next_sequence();
+ $self->add_reply($seq, \$data);
+! $self->handle_input() until $data;
+ $self->delete_reply($seq);
+ return &{$op->[2]}($self, $data);
+ };
+ } else { # ListFontsWithInfo
+--- 2418,2430 ----
+ $self->give($self->assemble_request($op, \@_, $major, $minor));
+ $seq = $self->next_sequence();
+ $self->add_reply($seq, \$data);
+! while (1)
+! {
+! my @ret = $self->handle_input();
+! last if ($data || ($ret[0] == 0 && $ret[1] == $seq));
+! }
+ $self->delete_reply($seq);
++ return undef unless $data;
+ return &{$op->[2]}($self, $data);
+ };
+ } else { # ListFontsWithInfo
diff --git a/dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r1 b/dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r1
new file mode 100644
index 000000000000..cfa240ad96fa
--- /dev/null
+++ b/dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r1
@@ -0,0 +1 @@
+MD5 62211641789f587ef45217ba72d9d8f3 X11-Protocol-0.51.tar.gz 86381