Subject: pkg/36322: x11/Xaw-Xpm doesn't build on NetBSD-current
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: Holger Weiss <holger@jhweiss.de>
List: pkgsrc-bugs
Date: 05/13/2007 21:35:02
>Number: 36322
>Category: pkg
>Synopsis: x11/Xaw-Xpm doesn't build on NetBSD-current
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: pkg-manager
>State: open
>Class: sw-bug
>Submitter-Id: net
>Arrival-Date: Sun May 13 21:35:02 +0000 2007
>Originator: Holger Weiss
>Release: NetBSD 4.99.19
>Organization:
Individual Network Berlin e.V.
>Environment:
System: NetBSD pandora.jhweiss.de 4.99.19 NetBSD 4.99.19 (PANDORA) #2: Sun May 6 04:02:02 CEST 2007 holger@pandora.jhweiss.de:/usr/build/obj/sys/arch/i386/compile/PANDORA i386
Architecture: i386
Machine: i386
>Description:
GCC 4.x doesn't accept casting an lvalue, therefore building x11/Xaw-Xpm
bails out with the following error at various places on (at least)
NetBSD-current:
| cc -c -I. -I/usr/pkg/include -I/usr/X11R6/include -DCSRG_BASED -DFUNCPROTO=15 -DNARROWPROTO -DHAS_WCHAR_H -DHAS_WCTYPE_H -DNO_WIDEC_H -DARROW_SCROLLBAR -DUSEGRAY -DSUN_AUDIO -O2 -fno-strict-aliasing Command.c -o unshared/Command.o
| Command.c: In function 'SetValues':
| Command.c:656: error: invalid lvalue in assignment
| Command.c:666: error: invalid lvalue in assignment
| Command.c: In function 'Realize':
| Command.c:720: error: invalid lvalue in assignment
| Command.c:728: error: invalid lvalue in assignment
|
| [wrapper.sh] note: The real command line, after the pkgsrc wrapper, was:
| /usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.gcc/bin/gcc -c -I. -I/usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.buildlink/include -I/usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.x11-buildlink/include -DCSRG_BASED -DFUNCPROTO=15 -DNARROWPROTO -DHAS_WCHAR_H -DHAS_WCTYPE_H -DNO_WIDEC_H -DARROW_SCROLLBAR -DUSEGRAY -DSUN_AUDIO -O2 -fno-strict-aliasing Command.c -o unshared/Command.o -L/usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.buildlink/lib
After fixing those, building x11/Xaw-Xpm fails as follows:
| cc -c -I. -I/usr/pkg/include -I/usr/X11R6/include -DCSRG_BASED -DFUNCPROTO=15 -DNARROWPROTO -DHAS_WCHAR_H -DHAS_WCTYPE_H -DNO_WIDEC_H -DARROW_SCROLLBAR -DUSEGRAY -DSUN_AUDIO -O2 -fno-strict-aliasing laylex.c -o unshared/laylex.o
| laylex.l:65: error: static declaration of 'count' follows non-static declaration
| laylex.l:28: error: previous implicit declaration of 'count' was here
| laylex.l: In function 'LayYYlook':
| laylex.l:557: warning: incompatible implicit declaration of built-in function 'exit'
| laylex.l:577: warning: incompatible implicit declaration of built-in function 'exit'
| laylex.l:595: warning: incompatible implicit declaration of built-in function 'exit'
| laylex.l:613: warning: incompatible implicit declaration of built-in function 'exit'
|
| [wrapper.sh] note: The real command line, after the pkgsrc wrapper, was:
| /usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.gcc/bin/gcc -c -I. -I/usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.buildlink/include -I/usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.x11-buildlink/include -DCSRG_BASED -DFUNCPROTO=15 -DNARROWPROTO -DHAS_WCHAR_H -DHAS_WCTYPE_H -DNO_WIDEC_H -DARROW_SCROLLBAR -DUSEGRAY -DSUN_AUDIO -O2 -fno-strict-aliasing laylex.c -o unshared/laylex.o -L/usr/pkgsrc/x11/Xaw-Xpm/work.pandora/.buildlink/lib
>How-To-Repeat:
Using GCC 4.x:
$ cd pkgsrc/x11/Xaw-Xpm && make
>Fix:
The following patch fixes compilation on NetBSD-current:
Index: distinfo
===================================================================
RCS file: /cvsroot/pkgsrc/x11/Xaw-Xpm/distinfo,v
retrieving revision 1.5
diff -u -r1.5 distinfo
--- distinfo 29 Jan 2007 18:36:29 -0000 1.5
+++ distinfo 13 May 2007 21:07:17 -0000
@@ -3,10 +3,13 @@
SHA1 (Xaw-XPM-1.1.tar.gz) = 8d85d0a96c86f46da9dcf21eef8daf3a7dd64c7f
RMD160 (Xaw-XPM-1.1.tar.gz) = a97a08af7459ada39c7b97a69cf1b05d3e570343
Size (Xaw-XPM-1.1.tar.gz) = 1188556 bytes
-SHA1 (patch-aa) = b220f322f3a8a82400144defecb65bb2121ba997
+SHA1 (patch-aa) = 0f92a521da3a12374c72f580ee5d74b93648d88f
SHA1 (patch-ab) = a2e4249ab6d9dce2b98452cf60c0d49e281cde7b
SHA1 (patch-ac) = 4bf9c4870a2b1fcc32a5a2809763da8c14a55d19
SHA1 (patch-ad) = b1de4e1008c0b5791df3c32e5520b7823d203237
SHA1 (patch-ae) = 9e163e8daa63099f732292a00449202dd54b7ddd
SHA1 (patch-af) = 993be70d46216dff66b6710f001351e2e0ccf929
-SHA1 (patch-ag) = da8c9e1348ae7b1bf97cf47cca6fb9e1a8c8cf6d
+SHA1 (patch-ag) = 417fd798660f9d6a71b7075222a3b00d4b206ae1
+SHA1 (patch-ah) = 765004798816b3bd6d3641fcd5246d0621658f75
+SHA1 (patch-ai) = bd97e186cb8b51c0cd0a37938ceb875d85c3bb19
+SHA1 (patch-aj) = 14255172936fe1ad86ade735ced898293b94170e
Index: patches/patch-aa
===================================================================
RCS file: /cvsroot/pkgsrc/x11/Xaw-Xpm/patches/patch-aa,v
retrieving revision 1.3
diff -u -r1.3 patch-aa
--- patches/patch-aa 28 Jun 1999 09:11:13 -0000 1.3
+++ patches/patch-aa 13 May 2007 21:07:17 -0000
@@ -3,8 +3,84 @@
Handle wide signal masks.
--- Xpm.c.orig Tue Nov 26 13:40:26 1996
-+++ Xpm.c Mon Jun 28 10:04:57 1999
-@@ -206,9 +206,8 @@
++++ Xpm.c
+@@ -46,7 +46,7 @@ char directory[MAXPATHLEN];
+ }
+ chdir(directory);
+ }
+- (PixmapNode *)PixList.first = (PixmapNode *)pixnode;
++ PixList.first = (PixmapNode *)pixnode;
+ pixnode->next = NULL;
+ PixList.n_entries = 1;
+ pixnode->filename = filename;
+@@ -55,18 +55,18 @@ char directory[MAXPATHLEN];
+
+ /* Is the pixmap already in the list? */
+
+- (PixmapNode *)pixnode = (PixmapNode *)PixList.first;
++ pixnode = (PixmapNode *)PixList.first;
+ for(;;)
+ {
+ if(strncmp(filename,pixnode->filename, MAXPATHLEN) == 0)
+ return((Pixmap *)&pixnode->pixmap);
+ if(pixnode->next == NULL) break;
+- (PixmapNode *)pixnode = (PixmapNode *)pixnode->next;
++ pixnode = (PixmapNode *)pixnode->next;
+ }
+
+ /* Didnt find the pixmap...make a new one */
+
+- (PixmapNode *)pixnew = (void *)malloc(sizeof(PixmapNode));
++ pixnew = (void *)malloc(sizeof(PixmapNode));
+
+ XGetWindowAttributes(XtDisplay(w) ,DefaultRootWindow(XtDisplay(w)),&root_att);
+ orig_att.closeness=65536;
+@@ -86,7 +86,7 @@ char directory[MAXPATHLEN];
+ }
+ chdir(directory);
+ }
+- (PixmapNode *)pixnode->next = (PixmapNode *)pixnew;
++ pixnode->next = (PixmapNode *)pixnew;
+ pixnew->filename = filename;
+ pixnew->next = NULL;
+ return((Pixmap *)&pixnew->pixmap);
+@@ -105,7 +105,7 @@ XpmAttributes orig_att;
+ char error_buf[BUFSIZ];
+ char directory[MAXPATHLEN];
+
+- (PixmapNode *)pixnode = (PixmapNode *)PixList.first;
++ pixnode = (PixmapNode *)PixList.first;
+ for(;;)
+ {
+ if(strncmp(filename,pixnode->filename, MAXPATHLEN) == 0)
+@@ -114,7 +114,7 @@ char directory[MAXPATHLEN];
+ break;
+ }
+ if(pixnode->next == NULL) break;
+- (PixmapNode *)pixnode = (PixmapNode *)pixnode->next;
++ pixnode = (PixmapNode *)pixnode->next;
+ }
+ if(found)
+ {
+@@ -140,7 +140,7 @@ char directory[MAXPATHLEN];
+ }
+ else
+ {
+- (PixmapNode *)pixnew = (void *)malloc(sizeof(PixmapNode));
++ pixnew = (void *)malloc(sizeof(PixmapNode));
+ XGetWindowAttributes(XtDisplay(w) ,DefaultRootWindow(XtDisplay(w)),&root_att);
+ orig_att.closeness=65536;
+ orig_att.colormap=root_att.colormap;
+@@ -159,7 +159,7 @@ char directory[MAXPATHLEN];
+ }
+ chdir(directory);
+ }
+- (PixmapNode *)pixnode->next = (PixmapNode *)pixnew;
++ pixnode->next = (PixmapNode *)pixnew;
+ pixnew->filename = filename;
+ pixnew->next = NULL;
+ return((Pixmap *)&pixnew->mask);
+@@ -206,9 +206,8 @@ char *soundfile;
sigchld.
*/
new.sa_handler=SigHandle;
Index: patches/patch-ag
===================================================================
RCS file: /cvsroot/pkgsrc/x11/Xaw-Xpm/patches/patch-ag,v
retrieving revision 1.1
diff -u -r1.1 patch-ag
--- patches/patch-ag 29 Jan 2007 18:36:29 -0000 1.1
+++ patches/patch-ag 13 May 2007 21:07:17 -0000
@@ -11,7 +11,15 @@
extern int LayYYlineno;
struct LayYYsvf {
struct LayYYwork *LayYYstoff;
-@@ -68,6 +68,16 @@ static char *LayYYsourcebase, *LayYYsour
+@@ -61,6 +61,7 @@ extern struct LayYYsvf LayYYsvec[], *Lay
+ #include "LayoutP.h"
+ #include "laygram.h"
+ static char *LayYYsourcebase, *LayYYsource;
++static int count (char *, char);
+
+ #define input() (*LayYYsource++)
+ #define unput(c) (--LayYYsource)
+@@ -68,6 +69,16 @@ static char *LayYYsourcebase, *LayYYsour
# define YYNEWLINE 10
LayYYlex(){
int nstr; extern int LayYYprevious;
Index: patches/patch-ah
===================================================================
RCS file: patches/patch-ah
diff -N patches/patch-ah
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ patches/patch-ah 13 May 2007 21:07:17 -0000
@@ -0,0 +1,40 @@
+$NetBSD$
+
+--- Command.c.orig 1996-11-11 09:38:27.000000000 -0000
++++ Command.c
+@@ -651,7 +651,7 @@ Cardinal *num_args;
+ if(oldcbw->command.setpixmap != cbw->command.setpixmap &&
+ cbw->command.setpixmap != None)
+ {
+- (CommandWidget)cbw->command.setpix =
++ cbw->command.setpix =
+ InsertPixmap(cbw, ((CommandWidget)cbw)->command.setpixmap,
+ ((CommandWidget)cbw)->simple.pixdir);
+ if ((Pixmap)*cbw->command.setpix == (Pixmap)NULL)
+@@ -661,7 +661,7 @@ Cardinal *num_args;
+ if(oldcbw->command.hlpixmap != cbw->command.hlpixmap &&
+ cbw->command.hlpixmap != None)
+ {
+- (CommandWidget)cbw->command.hlpix =
++ cbw->command.hlpix =
+ InsertPixmap(cbw, ((CommandWidget)cbw)->command.hlpixmap,
+ ((CommandWidget)cbw)->simple.pixdir);
+ if ((Pixmap)*cbw->command.hlpix == (Pixmap)NULL)
+@@ -715,7 +715,7 @@ static void Realize(w, valueMask, attrib
+
+ if(cbw->command.setpixmap != None)
+ {
+- (Pixmap *)cbw->command.setpix =
++ cbw->command.setpix =
+ (Pixmap *)InsertPixmap(w, cbw->command.setpixmap,
+ cbw->simple.pixdir);
+ if( (Pixmap) *cbw->command.setpix == (Pixmap)NULL)
+@@ -723,7 +723,7 @@ static void Realize(w, valueMask, attrib
+ }
+ if(cbw->command.hlpixmap != None)
+ {
+- (Pixmap *)cbw->command.hlpix =
++ cbw->command.hlpix =
+ (Pixmap *)InsertPixmap(w, cbw->command.hlpixmap,
+ cbw->simple.pixdir);
+ if( (Pixmap) *cbw->command.hlpix == (Pixmap)NULL)
Index: patches/patch-ai
===================================================================
RCS file: patches/patch-ai
diff -N patches/patch-ai
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ patches/patch-ai 13 May 2007 21:07:17 -0000
@@ -0,0 +1,13 @@
+$NetBSD$
+
+--- Panner.c.orig 1996-10-26 07:59:58.000000000 -0000
++++ Panner.c
+@@ -556,7 +556,7 @@ static void Realize (gw, valuemaskp, att
+ (gw, valuemaskp, attr);
+ if(pw->panner.sliderpixmap != None)
+ {
+- (Pixmap *)((PannerWidget)pw)->panner.spix =
++ ((PannerWidget)pw)->panner.spix =
+ (Pixmap *)InsertPixmap(pw, ((PannerWidget)pw)->panner.sliderpixmap,
+ ((PannerWidget)pw)->simple.pixdir);
+ if((Pixmap)*((PannerWidget)pw)->panner.spix == (Pixmap)NULL)
Index: patches/patch-aj
===================================================================
RCS file: patches/patch-aj
diff -N patches/patch-aj
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ patches/patch-aj 13 May 2007 21:07:17 -0000
@@ -0,0 +1,13 @@
+$NetBSD$
+
+--- Scrollbar.c.orig 1996-11-26 09:07:53.000000000 -0000
++++ Scrollbar.c
+@@ -1086,7 +1086,7 @@ static void Realize (w, valueMask, attri
+ }
+ if(((ScrollbarWidget)sbw)->scrollbar.thumbpixmap != None)
+ {
+- (Pixmap *)((ScrollbarWidget)sbw)->scrollbar.thumbpix =
++ ((ScrollbarWidget)sbw)->scrollbar.thumbpix =
+ InsertPixmap(sbw, ((ScrollbarWidget)sbw)->scrollbar.thumbpixmap,
+ ((ScrollbarWidget)sbw)->simple.pixdir);
+ if((Pixmap)*sbw->scrollbar.thumbpix == (Pixmap)NULL)