Bug 188451 - print/p5-Net-CUPS: build fails with new cups ports
Summary: print/p5-Net-CUPS: build fails with new cups ports
Status: Closed FIXED
Alias: None
Product: Ports & Packages
Classification: Unclassified
Component: Individual Port(s) (show other bugs)
Version: Latest
Hardware: Any Any
: Normal Affects Only Me
Assignee: Veniamin Gvozdikov
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2014-04-11 09:10 UTC by hiroto.kagotani
Modified: 2014-04-20 21:20 UTC (History)
0 users

See Also:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description hiroto.kagotani 2014-04-11 09:10:00 UTC
Building print/p5-Net-CUPS fails.
It shows the following error message.

--------
cc -c  -I/usr/local/include  -O2 -pipe -fno-strict-aliasing -O2 -pipe -fno-strict-aliasing    -DVERSION=\"0.61\"  -DXS_VERSION=\"0.61\" -DPIC -fPIC "-I/usr/local/lib/perl5/5.16/mach/CORE"   CUPS.c
CUPS.xs:10:10: fatal error: 'cups/image.h' file not found
#include <cups/image.h>
         ^
1 error generated.
*** [CUPS.o] Error code 1

make[1]: stopped in /usr/ports/print/p5-Net-CUPS/work/Net-CUPS-0.61
1 error
--------

When I modify <cups/image.h> to <cupsfilters/image.h> in CUPS.xs,
cc shows a lot of compilation errors for CUPS.xs.

How-To-Repeat: Just "make" in print/p5-Net-CUPS.
Comment 1 Edwin Groothuis freebsd_committer freebsd_triage 2014-04-11 09:10:04 UTC
Responsible Changed
From-To: freebsd-ports-bugs->vg

Over to maintainer (via the GNATS Auto Assign Tool)
Comment 2 hiroto.kagotani 2014-04-12 14:01:05 UTC
Patch for building with CUPS 1.6 has been filed on CPAN bug tracker.

https://rt.cpan.org/Public/Bug/Display.html?id=78583

-- 
Hiroto Kagotani
<hiroto.kagotani@gmail.com>
Comment 3 dfilter service freebsd_committer freebsd_triage 2014-04-20 21:02:10 UTC
Author: antoine
Date: Sun Apr 20 20:02:06 2014
New Revision: 351638
URL: http://svnweb.freebsd.org/changeset/ports/351638
QAT: https://qat.redports.org/buildarchive/r351638/

Log:
  Unbreak with new cups
  
  PR:		ports/188451
  Obtained from:	https://rt.cpan.org/Public/Bug/Display.html?id=78583
  With hat:	portmgr

Added:
  head/print/p5-Net-CUPS/files/
  head/print/p5-Net-CUPS/files/patch-CUPS.xs   (contents, props changed)
Modified:
  head/print/p5-Net-CUPS/Makefile

Modified: head/print/p5-Net-CUPS/Makefile
==============================================================================
--- head/print/p5-Net-CUPS/Makefile	Sun Apr 20 19:41:54 2014	(r351637)
+++ head/print/p5-Net-CUPS/Makefile	Sun Apr 20 20:02:06 2014	(r351638)
@@ -12,7 +12,8 @@ MAINTAINER=	vg@FreeBSD.org
 COMMENT=	Interface to the CUPS API
 
 BUILD_DEPENDS=	cups-config:${PORTSDIR}/print/cups-client
-LIB_DEPENDS=	libcupsimage.so:${PORTSDIR}/print/cups-image
+LIB_DEPENDS=	libcupsimage.so:${PORTSDIR}/print/cups-image \
+		libcupsfilters.so:${PORTSDIR}/print/cups-filters
 
 USES=		perl5
 USE_PERL5=	configure

Added: head/print/p5-Net-CUPS/files/patch-CUPS.xs
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/print/p5-Net-CUPS/files/patch-CUPS.xs	Sun Apr 20 20:02:06 2014	(r351638)
@@ -0,0 +1,165 @@
+Patch obtained from: https://rt.cpan.org/Public/Bug/Display.html?id=78583
+
+--- ./CUPS.xs.orig	2009-07-30 13:42:59.000000000 +0000
++++ ./CUPS.xs	2014-04-20 19:18:15.000000000 +0000
+@@ -5,9 +5,17 @@
+ #include "ppport.h"
+ 
+ #include <cups/cups.h>
++#if (CUPS_VERSION_MAJOR > 1) || (CUPS_VERSION_MINOR > 5)
++#define HAVE_CUPS_1_6 1
++#endif
++
+ /*#include <cups/backend.h>*/
+ #include <cups/http.h>
+-#include <cups/image.h>
++#ifdef HAVE_CUPS_1_6
++ #include <cupsfilters/image.h>
++#else
++ #include <cups/image.h>
++#endif
+ #include <cups/ipp.h>
+ #include <cups/ppd.h>
+ #include <cups/file.h>
+@@ -19,6 +27,17 @@
+ #include "const-c.inc"
+ #include "packer.c"
+ 
++#ifndef HAVE_CUPS_1_6
++#define ippGetGroupTag(attr)  attr->group_tag
++#define ippGetName(attr)      attr->name
++#define ippGetValueTag(attr)  attr->value_tag
++#define ippGetInteger(attr, element) attr->values[element].integer
++#define ippGetString(attr, element, language) attr->values[element].string.text
++#define ippGetStatusCode(ipp)  ipp->request.status.status_code
++#define ippFirstAttribute(ipp) ipp->current = ipp->attrs
++#define ippNextAttribute(ipp)  ipp->current = ipp->current->next
++#endif
++
+ static SV *password_cb = (SV*) NULL;
+ 
+ const char *
+@@ -200,7 +219,7 @@
+ 		if (response != NULL) {
+ 			attr = ippFindAttribute(response, "ppd-make", IPP_TAG_TEXT); 
+ 			rv = sv_newmortal();
+-			sv_setpv(rv, attr->values[0].string.text);
++			sv_setpv(rv, ippGetString(attr, 0, NULL));
+ 			XPUSHs(rv);
+ 			count++;
+ 
+@@ -211,7 +230,7 @@
+ 				}
+ 
+ 				rv = sv_newmortal();
+-				sv_setpv(rv, attr->values[0].string.text);
++				sv_setpv(rv, ippGetString(attr, 0, NULL));
+ 				XPUSHs(rv);
+ 				count++;
+ 			}			
+@@ -252,7 +271,7 @@
+ 									"ppd-make-and-model", 
+ 									IPP_TAG_TEXT); 
+ 			rv = sv_newmortal();
+-			sv_setpv(rv, attr->values[0].string.text);
++			sv_setpv(rv, ippGetString(attr, 0, NULL));
+ 			XPUSHs(rv);
+ 			count++;
+ 			while (attr != NULL) {
+@@ -263,7 +282,7 @@
+ 					break;
+ 				}
+ 				rv = sv_newmortal();
+-				sv_setpv(rv, attr->values[0].string.text);
++				sv_setpv(rv, ippGetString(attr, 0, NULL));
+ 				XPUSHs(rv);
+ 				count++;
+ 			}			
+@@ -356,14 +375,14 @@
+ 		if (response != NULL) {
+ 			attr = ippFindAttribute(response, "ppd-name", IPP_TAG_NAME );
+ 			while ((attr != NULL) && (i < 1)) {
+-				tmpppd = attr->values[0].string.text;	
++				tmpppd = ippGetString(attr, 0, NULL);	
+ 				attr = ippFindNextAttribute(response, 
+ 											"ppd-make", 
+ 											IPP_TAG_TEXT);
+ 				attr = ippFindNextAttribute(response, 
+ 											"ppd-make-and-model", 
+ 											IPP_TAG_TEXT);
+-				if (strcmp(attr->values[0].string.text, ppdfilename) == 0 ) {
++				if (strcmp(ippGetString(attr, 0, NULL), ppdfilename) == 0 ) {
+ 					/* return tmpppd; */
+ 					strcpy(test, tmpppd);	
+ 					break;	
+@@ -410,12 +429,12 @@
+ 			attr = ippFindNextAttribute(response, "printer-name", IPP_TAG_NAME);
+ 
+ 			while (attr != NULL) {
+-				if (strcmp(attr->values[0].string.text, device) == 0) { 
++				if (strcmp(ippGetString(attr, 0, NULL), device) == 0) { 
+ 					attr = ippFindNextAttribute( response, 
+ 												 attribute, 
+ 												 attribute_type);
+ 					rv = sv_newmortal();  
+-					sv_setpv( rv, attr->values[0].string.text); 
++					sv_setpv( rv, ippGetString(attr, 0, NULL)); 
+ 					XPUSHs( rv );
+ 					break;	
+ 				}					
+@@ -858,15 +877,15 @@
+ 		SV* rv = NULL;
+ 		int count = 0;
+ 		ipp_attribute_t* attr = NULL;
+-		for (attr = ipp->attrs; attr != NULL; attr = attr->next)
++		for (attr = ippFirstAttribute(ipp); attr != NULL; attr = ippNextAttribute(ipp))
+ 		{
+-			while (attr != NULL && attr->group_tag != IPP_TAG_JOB)
+- 		       attr = attr->next;
++			while (attr != NULL && ippGetGroupTag(attr) != IPP_TAG_JOB)
++ 		       attr = ippNextAttribute(ipp);
+ 
+ 			if (attr == NULL)
+ 				break;
+ 			rv = sv_newmortal();
+-			sv_setpv( rv, attr->name );
++			sv_setpv( rv, ippGetName(attr) );
+ 			XPUSHs( rv );
+ 			count++;
+ 		}
+@@ -880,27 +899,27 @@
+ 		SV* rv = NULL;
+ 		int count = 0;
+ 		ipp_attribute_t* attr = NULL;
+-		for (attr = ipp->attrs; attr != NULL; attr = attr->next)
++		for (attr = ippFirstAttribute(ipp); attr != NULL; attr = ippNextAttribute(ipp))
+ 		{
+-			while (attr != NULL && attr->group_tag != IPP_TAG_JOB)
+- 		       attr = attr->next;
++			while (attr != NULL && ippGetGroupTag(attr) != IPP_TAG_JOB)
++ 		       attr = ippNextAttribute(ipp);
+ 
+ 			if (attr == NULL)
+ 				break;
+ 
+-			if( !strcmp( attr->name, name ) )
++			if( !strcmp( ippGetName(attr), name ) )
+ 			{
+ 				rv = sv_newmortal();
+-				if( ( attr->value_tag == IPP_TAG_INTEGER ) ||
+-					( attr->value_tag == IPP_TAG_ENUM ) )
++				if( ( ippGetValueTag(attr) == IPP_TAG_INTEGER ) ||
++					( ippGetValueTag(attr) == IPP_TAG_ENUM ) )
+ 				{
+ 					/* We have a number with any luck ... */
+-					sv_setiv( rv, attr->values[0].integer );
++					sv_setiv( rv, ippGetInteger(attr, 0) );
+ 				}
+ 				else
+ 				{
+ 					/* We have a string ... maybe ... try to set it. */
+-					sv_setpv( rv, attr->values[0].string.text );
++					sv_setpv( rv, ippGetString(attr, 0, NULL) );
+ 				}
+ 
+ 				XPUSHs( rv );
_______________________________________________
svn-ports-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-ports-all
To unsubscribe, send any mail to "svn-ports-all-unsubscribe@freebsd.org"
Comment 4 dfilter service freebsd_committer freebsd_triage 2014-04-20 21:12:24 UTC
Author: antoine
Date: Sun Apr 20 20:12:20 2014
New Revision: 351640
URL: http://svnweb.freebsd.org/changeset/ports/351640
QAT: https://qat.redports.org/buildarchive/r351640/

Log:
  MFH: r351638
  
  Unbreak with new cups
  
  PR:		ports/188451
  Obtained from:	https://rt.cpan.org/Public/Bug/Display.html?id=78583
  With hat:	portmgr
  Approved by:	portmgr (self)

Added:
  branches/2014Q2/print/p5-Net-CUPS/files/
     - copied from r351638, head/print/p5-Net-CUPS/files/
Modified:
  branches/2014Q2/print/p5-Net-CUPS/Makefile
Directory Properties:
  branches/2014Q2/   (props changed)

Modified: branches/2014Q2/print/p5-Net-CUPS/Makefile
==============================================================================
--- branches/2014Q2/print/p5-Net-CUPS/Makefile	Sun Apr 20 20:10:43 2014	(r351639)
+++ branches/2014Q2/print/p5-Net-CUPS/Makefile	Sun Apr 20 20:12:20 2014	(r351640)
@@ -12,7 +12,8 @@ MAINTAINER=	vg@FreeBSD.org
 COMMENT=	Interface to the CUPS API
 
 BUILD_DEPENDS=	cups-config:${PORTSDIR}/print/cups-client
-LIB_DEPENDS=	libcupsimage.so:${PORTSDIR}/print/cups-image
+LIB_DEPENDS=	libcupsimage.so:${PORTSDIR}/print/cups-image \
+		libcupsfilters.so:${PORTSDIR}/print/cups-filters
 
 USES=		perl5
 USE_PERL5=	configure
_______________________________________________
svn-ports-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-ports-all
To unsubscribe, send any mail to "svn-ports-all-unsubscribe@freebsd.org"
Comment 5 Antoine Brodin freebsd_committer freebsd_triage 2014-04-20 21:12:58 UTC
State Changed
From-To: open->closed

Patch committed, thanks!