summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Schlemmer <azarah@gentoo.org>2002-10-13 02:34:35 +0000
committerMartin Schlemmer <azarah@gentoo.org>2002-10-13 02:34:35 +0000
commit0c06232f41fa77e1b4aca7801f99cb7f543e28d4 (patch)
tree1fe288163a519b99b1b12327adc75e4b43f02c96 /sys-devel
parentfix for #9051 (diff)
downloadgentoo-2-0c06232f41fa77e1b4aca7801f99cb7f543e28d4.tar.gz
gentoo-2-0c06232f41fa77e1b4aca7801f99cb7f543e28d4.tar.bz2
gentoo-2-0c06232f41fa77e1b4aca7801f99cb7f543e28d4.zip
build/code generation fixes
Diffstat (limited to 'sys-devel')
-rw-r--r--sys-devel/flex/ChangeLog9
-rw-r--r--sys-devel/flex/files/digest-flex-2.5.4a-r51
-rw-r--r--sys-devel/flex/files/flex-2.5.4-glibc22.patch108
-rw-r--r--sys-devel/flex/files/flex-2.5.4a-gcc3.patch11
-rw-r--r--sys-devel/flex/files/flex-2.5.4a-gcc31.patch94
-rw-r--r--sys-devel/flex/files/flex-2.5.4a-skel.patch11
-rw-r--r--sys-devel/flex/flex-2.5.4a-r5.ebuild54
7 files changed, 287 insertions, 1 deletions
diff --git a/sys-devel/flex/ChangeLog b/sys-devel/flex/ChangeLog
index c1a591de927e..79850a6c1251 100644
--- a/sys-devel/flex/ChangeLog
+++ b/sys-devel/flex/ChangeLog
@@ -1,6 +1,13 @@
# ChangeLog for sys-devel/flex
# Copyright 2002 Gentoo Technologies, Inc.; Distributed under the GPL
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/flex/ChangeLog,v 1.1 2002/02/01 21:53:38 gbevin Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/flex/ChangeLog,v 1.2 2002/10/13 02:34:35 azarah Exp $
+
+*flex-2.5.4a-r5 (13 Oct 2002)
+
+ 13 Oct 2002; Martin Schlemmer <azarah@gentoo.org> ;
+
+ Add various Redhat patches to make it more gcc3 friendly. Fix
+ form in a few places.
*flex-2.5.4a-r4 (1 Feb 2002)
diff --git a/sys-devel/flex/files/digest-flex-2.5.4a-r5 b/sys-devel/flex/files/digest-flex-2.5.4a-r5
new file mode 100644
index 000000000000..701f9fb253a7
--- /dev/null
+++ b/sys-devel/flex/files/digest-flex-2.5.4a-r5
@@ -0,0 +1 @@
+MD5 bd8753d0b22e1f4ec87a553a73021adf flex-2.5.4a.tar.gz 380995
diff --git a/sys-devel/flex/files/flex-2.5.4-glibc22.patch b/sys-devel/flex/files/flex-2.5.4-glibc22.patch
new file mode 100644
index 000000000000..299aa70b4ec7
--- /dev/null
+++ b/sys-devel/flex/files/flex-2.5.4-glibc22.patch
@@ -0,0 +1,108 @@
+--- flex-2.5.4/initscan.c.broken Sat Sep 30 16:50:31 2000
++++ flex-2.5.4/initscan.c Sat Sep 30 16:51:34 2000
+@@ -10,7 +10,7 @@
+ #define YY_FLEX_MINOR_VERSION 5
+
+ #include <stdio.h>
+-
++#include <unistd.h>
+
+ /* cfront 1.2 defines "c_plusplus" instead of "__cplusplus" */
+ #ifdef c_plusplus
+@@ -23,7 +23,6 @@
+ #ifdef __cplusplus
+
+ #include <stdlib.h>
+-#include <unistd.h>
+
+ /* Use prototypes in function declarations. */
+ #define YY_USE_PROTOS
+@@ -3310,12 +3309,6 @@
+ yy_flex_free( (void *) b );
+ }
+
+-
+-#ifndef YY_ALWAYS_INTERACTIVE
+-#ifndef YY_NEVER_INTERACTIVE
+-extern int isatty YY_PROTO(( int ));
+-#endif
+-#endif
+
+ #ifdef YY_USE_PROTOS
+ void yy_init_buffer( YY_BUFFER_STATE b, FILE *file )
+--- flex-2.5.4/flex.skl.broken Sat Sep 30 16:51:05 2000
++++ flex-2.5.4/flex.skl Sat Sep 30 16:52:24 2000
+@@ -10,6 +10,7 @@
+
+ %-
+ #include <stdio.h>
++#include <unistd.h>
+ %*
+
+
+@@ -27,7 +28,6 @@
+ %+
+ class istream;
+ %*
+-#include <unistd.h>
+
+ /* Use prototypes in function declarations. */
+ #define YY_USE_PROTOS
+@@ -1177,11 +1177,6 @@
+
+
+ %-
+-#ifndef YY_ALWAYS_INTERACTIVE
+-#ifndef YY_NEVER_INTERACTIVE
+-extern int isatty YY_PROTO(( int ));
+-#endif
+-#endif
+
+ #ifdef YY_USE_PROTOS
+ void yy_init_buffer( YY_BUFFER_STATE b, FILE *file )
+@@ -1192,7 +1187,6 @@
+ #endif
+
+ %+
+-extern "C" int isatty YY_PROTO(( int ));
+ void yyFlexLexer::yy_init_buffer( YY_BUFFER_STATE b, istream* file )
+ %*
+
+--- flex-2.5.4/skel.c.broken Sat Sep 30 16:52:34 2000
++++ flex-2.5.4/skel.c Sat Sep 30 16:53:15 2000
+@@ -15,6 +15,7 @@
+ "",
+ "%-",
+ "#include <stdio.h>",
++ "#include <unistd.h>",
+ "%*",
+ "",
+ "",
+@@ -32,7 +33,6 @@
+ "%+",
+ "class istream;",
+ "%*",
+- "#include <unistd.h>",
+ "",
+ "/* Use prototypes in function declarations. */",
+ "#define YY_USE_PROTOS",
+@@ -1182,11 +1182,6 @@
+ "",
+ "",
+ "%-",
+- "#ifndef YY_ALWAYS_INTERACTIVE",
+- "#ifndef YY_NEVER_INTERACTIVE",
+- "extern int isatty YY_PROTO(( int ));",
+- "#endif",
+- "#endif",
+ "",
+ "#ifdef YY_USE_PROTOS",
+ "void yy_init_buffer( YY_BUFFER_STATE b, FILE *file )",
+@@ -1197,7 +1192,6 @@
+ "#endif",
+ "",
+ "%+",
+- "extern \"C\" int isatty YY_PROTO(( int ));",
+ "void yyFlexLexer::yy_init_buffer( YY_BUFFER_STATE b, istream* file )",
+ "%*",
+ "",
diff --git a/sys-devel/flex/files/flex-2.5.4a-gcc3.patch b/sys-devel/flex/files/flex-2.5.4a-gcc3.patch
new file mode 100644
index 000000000000..a73dc41bd26c
--- /dev/null
+++ b/sys-devel/flex/files/flex-2.5.4a-gcc3.patch
@@ -0,0 +1,11 @@
+--- flex-2.5.4/skel.c.orig Tue Nov 6 17:29:12 2001
++++ flex-2.5.4/skel.c Tue Nov 6 17:28:49 2001
+@@ -31,7 +31,7 @@
+ "",
+ "#include <stdlib.h>",
+ "%+",
+- "class istream;",
++ "#include <iostream.h>",
+ "%*",
+ "",
+ "/* Use prototypes in function declarations. */",
diff --git a/sys-devel/flex/files/flex-2.5.4a-gcc31.patch b/sys-devel/flex/files/flex-2.5.4a-gcc31.patch
new file mode 100644
index 000000000000..a8c01811923d
--- /dev/null
+++ b/sys-devel/flex/files/flex-2.5.4a-gcc31.patch
@@ -0,0 +1,94 @@
+--- flex-2.5.4/skel.c.gcc31 Wed Feb 20 12:15:18 2002
++++ flex-2.5.4/skel.c Wed Feb 20 12:15:18 2002
+@@ -31,7 +31,8 @@
+ "",
+ "#include <stdlib.h>",
+ "%+",
+- "#include <iostream.h>",
++ "#include <iostream>",
++ "using namespace std;",
+ "%*",
+ "",
+ "/* Use prototypes in function declarations. */",
+--- flex-2.5.4/FlexLexer.h.gcc31 Sun Jul 27 04:41:38 1997
++++ flex-2.5.4/FlexLexer.h Fri Mar 1 20:38:04 2002
+@@ -44,7 +44,7 @@
+ #ifndef __FLEX_LEXER_H
+ // Never included before - need to define base class.
+ #define __FLEX_LEXER_H
+-#include <iostream.h>
++#include <iostream>
+
+ extern "C++" {
+
+@@ -61,14 +61,14 @@
+ virtual void
+ yy_switch_to_buffer( struct yy_buffer_state* new_buffer ) = 0;
+ virtual struct yy_buffer_state*
+- yy_create_buffer( istream* s, int size ) = 0;
++ yy_create_buffer( std::istream* s, int size ) = 0;
+ virtual void yy_delete_buffer( struct yy_buffer_state* b ) = 0;
+- virtual void yyrestart( istream* s ) = 0;
++ virtual void yyrestart( std::istream* s ) = 0;
+
+ virtual int yylex() = 0;
+
+ // Call yylex with new input/output sources.
+- int yylex( istream* new_in, ostream* new_out = 0 )
++ int yylex( std::istream* new_in, std::ostream* new_out = 0 )
+ {
+ switch_streams( new_in, new_out );
+ return yylex();
+@@ -76,8 +76,8 @@
+
+ // Switch to new input/output streams. A nil stream pointer
+ // indicates "keep the current one".
+- virtual void switch_streams( istream* new_in = 0,
+- ostream* new_out = 0 ) = 0;
++ virtual void switch_streams( std::istream* new_in = 0,
++ std::ostream* new_out = 0 ) = 0;
+
+ int lineno() const { return yylineno; }
+
+@@ -104,17 +104,17 @@
+ public:
+ // arg_yyin and arg_yyout default to the cin and cout, but we
+ // only make that assignment when initializing in yylex().
+- yyFlexLexer( istream* arg_yyin = 0, ostream* arg_yyout = 0 );
++ yyFlexLexer( std::istream* arg_yyin = 0, std::ostream* arg_yyout = 0 );
+
+ virtual ~yyFlexLexer();
+
+ void yy_switch_to_buffer( struct yy_buffer_state* new_buffer );
+- struct yy_buffer_state* yy_create_buffer( istream* s, int size );
++ struct yy_buffer_state* yy_create_buffer( std::istream* s, int size );
+ void yy_delete_buffer( struct yy_buffer_state* b );
+- void yyrestart( istream* s );
++ void yyrestart( std::istream* s );
+
+ virtual int yylex();
+- virtual void switch_streams( istream* new_in, ostream* new_out );
++ virtual void switch_streams( std::istream* new_in, std::ostream* new_out );
+
+ protected:
+ virtual int LexerInput( char* buf, int max_size );
+@@ -125,7 +125,7 @@
+ int yyinput();
+
+ void yy_load_buffer_state();
+- void yy_init_buffer( struct yy_buffer_state* b, istream* s );
++ void yy_init_buffer( struct yy_buffer_state* b, std::istream* s );
+ void yy_flush_buffer( struct yy_buffer_state* b );
+
+ int yy_start_stack_ptr;
+@@ -140,8 +140,8 @@
+ yy_state_type yy_try_NUL_trans( yy_state_type current_state );
+ int yy_get_next_buffer();
+
+- istream* yyin; // input source for default LexerInput
+- ostream* yyout; // output sink for default LexerOutput
++ std::istream* yyin; // input source for default LexerInput
++ std::ostream* yyout; // output sink for default LexerOutput
+
+ struct yy_buffer_state* yy_current_buffer;
+
diff --git a/sys-devel/flex/files/flex-2.5.4a-skel.patch b/sys-devel/flex/files/flex-2.5.4a-skel.patch
new file mode 100644
index 000000000000..5f8222adf248
--- /dev/null
+++ b/sys-devel/flex/files/flex-2.5.4a-skel.patch
@@ -0,0 +1,11 @@
+--- flex-2.5.4/skel.c.skel Wed Aug 25 14:02:51 1999
++++ flex-2.5.4/skel.c Wed Aug 25 14:03:16 1999
+@@ -454,7 +454,7 @@
+ "YY_DECL",
+ " {",
+ " register yy_state_type yy_current_state;",
+- " register char *yy_cp, *yy_bp;",
++ " register char *yy_cp = NULL, *yy_bp = NULL;",
+ " register int yy_act;",
+ "",
+ "%% user's declarations go here",
diff --git a/sys-devel/flex/flex-2.5.4a-r5.ebuild b/sys-devel/flex/flex-2.5.4a-r5.ebuild
new file mode 100644
index 000000000000..c18e0750479e
--- /dev/null
+++ b/sys-devel/flex/flex-2.5.4a-r5.ebuild
@@ -0,0 +1,54 @@
+# Copyright 1999-2002 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/flex/flex-2.5.4a-r5.ebuild,v 1.1 2002/10/13 02:34:35 azarah Exp $
+
+S=${WORKDIR}/flex-2.5.4
+DESCRIPTION="GNU lexical analyser generator"
+SRC_URI="ftp://ftp.gnu.org/gnu/non-gnu/flex/flex-2.5.4a.tar.gz"
+HOMEPAGE="http://www.gnu.org/software/flex/flex.html"
+
+LICENSE="FLEX"
+SLOT="0"
+KEYWORDS="~x86 ~ppc ~sparc ~sparc64 ~alpha"
+
+DEPEND="virtual/glibc"
+RDEPEND="virtual/glibc"
+
+src_unpack() {
+ unpack ${A}
+
+ cd ${S}
+ # Some Redhat patches to fix various problems
+ patch -p1 < ${FILESDIR}/flex-2.5.4-glibc22.patch || die
+ patch -p1 < ${FILESDIR}/flex-2.5.4a-gcc3.patch || die
+ patch -p1 < ${FILESDIR}/flex-2.5.4a-gcc31.patch || die
+ patch -p1 < ${FILESDIR}/flex-2.5.4a-skel.patch || die
+}
+
+src_compile() {
+ ./configure --prefix=/usr \
+ --host=${CHOST} || die
+
+ if [ -z "`use static`" ]
+ then
+ emake || die
+ else
+ emake LDFLAGS=-static || die
+ fi
+}
+
+src_install() {
+ make prefix=${D}/usr \
+ mandir=${D}/usr/share/man/man1 \
+ install || die
+
+ if [ -z "`use build`" ]
+ then
+ dodoc COPYING NEWS README
+ else
+ rm -rf ${D}/usr/share ${D}/usr/include ${D}/usr/lib
+ fi
+
+ dosym flex /usr/bin/lex
+}
+