summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'dev-perl/X11-Protocol')
-rw-r--r--dev-perl/X11-Protocol/ChangeLog5
-rw-r--r--dev-perl/X11-Protocol/Manifest4
-rw-r--r--dev-perl/X11-Protocol/X11-Protocol-0.51-r2.ebuild (renamed from dev-perl/X11-Protocol/X11-Protocol-0.51.ebuild)11
-rw-r--r--dev-perl/X11-Protocol/files/X11-Protocol-0.51_2.patch129
-rw-r--r--dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r2 (renamed from dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51)0
5 files changed, 143 insertions, 6 deletions
diff --git a/dev-perl/X11-Protocol/ChangeLog b/dev-perl/X11-Protocol/ChangeLog
index 90dad4adfc61..b9e984926d7e 100644
--- a/dev-perl/X11-Protocol/ChangeLog
+++ b/dev-perl/X11-Protocol/ChangeLog
@@ -1,6 +1,9 @@
# ChangeLog for dev-perl/X11-Protocol
# Copyright 2000-2003 Gentoo Technologies, Inc.; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/dev-perl/X11-Protocol/ChangeLog,v 1.4 2003/10/13 17:09:27 taviso Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-perl/X11-Protocol/ChangeLog,v 1.5 2003/10/21 14:05:54 taviso Exp $
+
+ 21 Oct 2003; Tavis Ormandy <taviso@gentoo.org> X11-Protocol-0.51.ebuild:
+ updated patch.
13 Oct 2003; Tavis Ormandy <taviso@gentoo.org> X11-Protocol-0.51-r1.ebuild:
stable.
diff --git a/dev-perl/X11-Protocol/Manifest b/dev-perl/X11-Protocol/Manifest
index e70a2aa4b6e8..76575c617ee4 100644
--- a/dev-perl/X11-Protocol/Manifest
+++ b/dev-perl/X11-Protocol/Manifest
@@ -1,6 +1,6 @@
-MD5 06f724c30106cdd4940dddf0da514a37 X11-Protocol-0.51-r2.ebuild 652
+MD5 b7a1d32f76047d6b76ca3819e5818918 X11-Protocol-0.51-r2.ebuild 655
MD5 d4aa49c319a5f8bdf45948cb707555bd X11-Protocol-0.51-r1.ebuild 653
-MD5 0ce7b08ae2b2c9301887a42a4ca08c52 ChangeLog 840
+MD5 c112899e44edeafd40006f0dc8369b4a ChangeLog 840
MD5 e2d8f1bf77722def1dd432e26455c818 metadata.xml 305
MD5 f24e90787470f41e63101e1a77d646b6 files/digest-X11-Protocol-0.51-r1 68
MD5 f24e90787470f41e63101e1a77d646b6 files/digest-X11-Protocol-0.51-r2 68
diff --git a/dev-perl/X11-Protocol/X11-Protocol-0.51.ebuild b/dev-perl/X11-Protocol/X11-Protocol-0.51-r2.ebuild
index cafa704bd647..89c4f5bdc250 100644
--- a/dev-perl/X11-Protocol/X11-Protocol-0.51.ebuild
+++ b/dev-perl/X11-Protocol/X11-Protocol-0.51-r2.ebuild
@@ -1,8 +1,8 @@
# 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.ebuild,v 1.3 2003/10/07 14:27:47 taviso Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-perl/X11-Protocol/X11-Protocol-0.51-r2.ebuild,v 1.1 2003/10/21 14:05:54 taviso Exp $
-inherit perl-module
+inherit perl-module eutils
S=${WORKDIR}/${P}
DESCRIPTION="Client-side interface to the X11 Protocol"
@@ -11,7 +11,12 @@ HOMEPAGE="http://www.cpan.org/modules/by-module/X11/${P}.readme"
SLOT="0"
LICENSE="Artistic X11"
-KEYWORDS="x86 alpha ~sparc"
+KEYWORDS="~x86 ~alpha ~sparc"
DEPEND="${DEPEND}
virtual/x11"
+
+src_unpack() {
+ unpack ${A}
+ cd ${S}; epatch ${FILESDIR}/X11-Protocol-0.51_2.patch
+}
diff --git a/dev-perl/X11-Protocol/files/X11-Protocol-0.51_2.patch b/dev-perl/X11-Protocol/files/X11-Protocol-0.51_2.patch
new file mode 100644
index 000000000000..82c5f0a4cfcd
--- /dev/null
+++ b/dev-perl/X11-Protocol/files/X11-Protocol-0.51_2.patch
@@ -0,0 +1,129 @@
+--- Protocol.pm.orig Fri Aug 22 18:39:18 2003
++++ Protocol.pm Sun Oct 12 11:57:47 2003
+@@ -15,7 +15,7 @@
+
+ @EXPORT_OK = qw(pad padding padded hexi make_num_hash default_error_handler);
+
+-$VERSION = "0.51";
++$VERSION = "0.51_2";
+
+ sub padding ($) {
+ my($x) = @_;
+@@ -571,23 +571,28 @@
+ 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) = @_;
+- 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);
++ my($self, $data) = @_;
++ croak($self->make_error_msg($data));
+ }
+
+ sub handle_input {
+@@ -597,8 +602,13 @@
+ $type_b = $self->get(1);
+ $type = unpack "C", $type_b;
+ if ($type == 0) {
+- &{$self->{'error_handler'}}($self, $type_b . $self->get(31));
+- return 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,6 +2041,7 @@
+ 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,8 +2065,13 @@
+ $self->give($self->assemble_request($op, \@args, $major, $minor));
+ $seq = $self->next_sequence();
+ $self->add_reply($seq & 0xffff, \$data);
+- $self->handle_input() until $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,7 +2079,17 @@
+ $seq = $self->next_sequence();
+ $self->add_reply($seq & 0xffff, \$data);
+ for (;;) {
+- $data = 0; $self->handle_input() until $data;
++ $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,8 +2418,13 @@
+ $self->give($self->assemble_request($op, \@_, $major, $minor));
+ $seq = $self->next_sequence();
+ $self->add_reply($seq, \$data);
+- $self->handle_input() until $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 b/dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r2
index cfa240ad96fa..cfa240ad96fa 100644
--- a/dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51
+++ b/dev-perl/X11-Protocol/files/digest-X11-Protocol-0.51-r2