Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 15 Jan 2010 19:09:40 GMT
From:      alberto villa <villa.alberto@gmail.com>
To:        freebsd-gnats-submit@FreeBSD.org
Subject:   ports/142869: [maintainer update] accessibility/speech-dispatcher fix building on FreeBSD < 8.0
Message-ID:  <201001151909.o0FJ9eGM081665@www.freebsd.org>
Resent-Message-ID: <201001151920.o0FJK2AK007807@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         142869
>Category:       ports
>Synopsis:       [maintainer update] accessibility/speech-dispatcher fix building on FreeBSD < 8.0
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          maintainer-update
>Submitter-Id:   current-users
>Arrival-Date:   Fri Jan 15 19:20:02 UTC 2010
>Closed-Date:
>Last-Modified:
>Originator:     alberto villa
>Release:        FreeBSD 9.0-CURRENT i386
>Organization:
>Environment:
FreeBSD echo.hoth 9.0-CURRENT FreeBSD 9.0-CURRENT #4: Tue Dec 29 17:05:23 CET 2009     root@echo.hoth:/usr/obj/usr/src/sys/TPR60  i386
>Description:
on FreeBSD < 8.0, build fails because of the missing implementation of getline()
>How-To-Repeat:
try to build accessibility/speech-dispatcher on FreeBSD 7 or 6
>Fix:
use the implementation found in /usr/ports/audio/raop_play/files/getline.*

added files:
files/extrapatch-src-c-api-Makefile.in
files/extrapatch-src-c-clients-say-Makefile.in
files/extrapatch-src-c-clients-spdsend-Makefile.in
files/extrapatch-src-modules-Makefile.in
files/extrapatch-src-server-Makefile.in
files/getline.c
files/getline.h

no PORTREVISION bump needed

Patch attached with submission follows:

diff -ruN /usr/ports/accessibility/speech-dispatcher/Makefile /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/Makefile
--- /usr/ports/accessibility/speech-dispatcher/Makefile	2010-01-08 09:23:59.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/Makefile	2010-01-15 19:55:03.262407050 +0100
@@ -84,7 +84,16 @@
 CONFIGURE_ARGS+=	--without-pulseaudio
 .endif
 
-pre-patch:
+.if ${OSVERSION} < 800000
+EXTRA_PATCHES=	${FILESDIR}/extrapatch-*
+.endif
+
+post-extract:
+.if ${OSVERSION} < 800000
+	${CP} ${FILESDIR}/getline.* ${WRKSRC}/src
+.endif
+
+post-patch:
 	@${REINPLACE_CMD} -e 's/-pthread/${PTHREAD_LIBS}/g' \
 		${WRKSRC}/ltmain.sh
 	@${REINPLACE_CMD} -e 's/-lpthread/${PTHREAD_LIBS}/g' \
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-api-Makefile.in /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-api-Makefile.in
--- /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-api-Makefile.in	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-api-Makefile.in	2010-01-15 19:52:59.000000000 +0100
@@ -0,0 +1,11 @@
+--- src/c/api/Makefile.in.orig	2010-01-15 19:51:09.284466853 +0100
++++ src/c/api/Makefile.in	2010-01-15 19:51:42.602485219 +0100
+@@ -54,7 +54,7 @@
+ libLTLIBRARIES_INSTALL = $(INSTALL)
+ LTLIBRARIES = $(lib_LTLIBRARIES)
+ libspeechd_la_DEPENDENCIES =
+-am_libspeechd_la_OBJECTS = libspeechd.lo
++am_libspeechd_la_OBJECTS = libspeechd.lo ../../getline.$(OBJEXT)
+ libspeechd_la_OBJECTS = $(am_libspeechd_la_OBJECTS)
+ libspeechd_la_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
+ 	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-say-Makefile.in /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-say-Makefile.in
--- /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-say-Makefile.in	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-say-Makefile.in	2010-01-15 19:46:55.000000000 +0100
@@ -0,0 +1,11 @@
+--- src/c/clients/say/Makefile.in.orig	2010-01-15 19:45:48.339555703 +0100
++++ src/c/clients/say/Makefile.in	2010-01-15 19:46:05.488979035 +0100
+@@ -45,7 +45,7 @@
+ am__installdirs = "$(DESTDIR)$(bindir)"
+ binPROGRAMS_INSTALL = $(INSTALL_PROGRAM)
+ PROGRAMS = $(bin_PROGRAMS)
+-am_spd_say_OBJECTS = say.$(OBJEXT) options.$(OBJEXT)
++am_spd_say_OBJECTS = say.$(OBJEXT) options.$(OBJEXT) ../../../getline.$(OBJEXT)
+ spd_say_OBJECTS = $(am_spd_say_OBJECTS)
+ spd_say_DEPENDENCIES = $(c_api)/libspeechd.la
+ DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-spdsend-Makefile.in /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-spdsend-Makefile.in
--- /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-spdsend-Makefile.in	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-c-clients-spdsend-Makefile.in	2010-01-15 19:47:20.000000000 +0100
@@ -0,0 +1,11 @@
+--- src/c/clients/spdsend/Makefile.in.orig	2010-01-15 19:46:14.737593506 +0100
++++ src/c/clients/spdsend/Makefile.in	2010-01-15 19:46:29.284418153 +0100
+@@ -47,7 +47,7 @@
+ binPROGRAMS_INSTALL = $(INSTALL_PROGRAM)
+ PROGRAMS = $(bin_PROGRAMS)
+ am_spdsend_OBJECTS = spdsend.$(OBJEXT) server.$(OBJEXT) \
+-	client.$(OBJEXT) common.$(OBJEXT)
++	client.$(OBJEXT) common.$(OBJEXT) ../../../getline.$(OBJEXT)
+ spdsend_OBJECTS = $(am_spdsend_OBJECTS)
+ spdsend_DEPENDENCIES =
+ DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-modules-Makefile.in /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-modules-Makefile.in
--- /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-modules-Makefile.in	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-modules-Makefile.in	2010-01-15 19:49:35.000000000 +0100
@@ -0,0 +1,55 @@
+--- src/modules/Makefile.in.orig	2010-01-15 19:47:30.277280590 +0100
++++ src/modules/Makefile.in	2010-01-15 19:49:05.729978711 +0100
+@@ -57,44 +57,44 @@
+ 	"$(DESTDIR)$(snddatadir)"
+ modulebinPROGRAMS_INSTALL = $(INSTALL_PROGRAM)
+ PROGRAMS = $(modulebin_PROGRAMS)
+-am_sd_cicero_OBJECTS = cicero.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_cicero_OBJECTS = cicero.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_cicero_OBJECTS = $(am_sd_cicero_OBJECTS)
+ sd_cicero_DEPENDENCIES =
+-am_sd_dummy_OBJECTS = dummy.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_dummy_OBJECTS = dummy.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_dummy_OBJECTS = $(am_sd_dummy_OBJECTS)
+ sd_dummy_DEPENDENCIES =
+ sd_dummy_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
+ 	--mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(sd_dummy_LDFLAGS) \
+ 	$(LDFLAGS) -o $@
+-am_sd_espeak_OBJECTS = espeak.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_espeak_OBJECTS = espeak.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_espeak_OBJECTS = $(am_sd_espeak_OBJECTS)
+ sd_espeak_DEPENDENCIES =
+ sd_espeak_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
+ 	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+ 	$(sd_espeak_LDFLAGS) $(LDFLAGS) -o $@
+-am_sd_festival_OBJECTS = festival.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_festival_OBJECTS = festival.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_festival_OBJECTS = $(am_sd_festival_OBJECTS)
+ sd_festival_DEPENDENCIES =
+ sd_festival_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
+ 	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+ 	$(sd_festival_LDFLAGS) $(LDFLAGS) -o $@
+-am_sd_flite_OBJECTS = flite.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_flite_OBJECTS = flite.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_flite_OBJECTS = $(am_sd_flite_OBJECTS)
+ am__DEPENDENCIES_1 =
+ sd_flite_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1)
+ sd_flite_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
+ 	--mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(sd_flite_LDFLAGS) \
+ 	$(LDFLAGS) -o $@
+-am_sd_generic_OBJECTS = generic.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_generic_OBJECTS = generic.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_generic_OBJECTS = $(am_sd_generic_OBJECTS)
+ sd_generic_DEPENDENCIES =
+-am_sd_ibmtts_OBJECTS = ibmtts.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_ibmtts_OBJECTS = ibmtts.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_ibmtts_OBJECTS = $(am_sd_ibmtts_OBJECTS)
+ sd_ibmtts_DEPENDENCIES =
+ sd_ibmtts_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
+ 	$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+ 	$(sd_ibmtts_LDFLAGS) $(LDFLAGS) -o $@
+-am_sd_ivona_OBJECTS = ivona.$(OBJEXT) module_utils.$(OBJEXT)
++am_sd_ivona_OBJECTS = ivona.$(OBJEXT) module_utils.$(OBJEXT) ../getline.$(OBJEXT)
+ sd_ivona_OBJECTS = $(am_sd_ivona_OBJECTS)
+ sd_ivona_DEPENDENCIES =
+ sd_ivona_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-server-Makefile.in /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-server-Makefile.in
--- /usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-server-Makefile.in	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/extrapatch-src-server-Makefile.in	2010-01-15 19:45:30.000000000 +0100
@@ -0,0 +1,11 @@
+--- src/server/Makefile.in.orig	2010-01-15 19:44:32.014987477 +0100
++++ src/server/Makefile.in	2010-01-15 19:44:56.313346422 +0100
+@@ -50,7 +50,7 @@
+ 	parse.$(OBJEXT) set.$(OBJEXT) alloc.$(OBJEXT) \
+ 	compare.$(OBJEXT) speaking.$(OBJEXT) options.$(OBJEXT) \
+ 	output.$(OBJEXT) sem_functions.$(OBJEXT) \
+-	index_marking.$(OBJEXT)
++	index_marking.$(OBJEXT) ../getline.$(OBJEXT)
+ speech_dispatcher_OBJECTS = $(am_speech_dispatcher_OBJECTS)
+ speech_dispatcher_DEPENDENCIES =
+ speech_dispatcher_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/getline.c /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/getline.c
--- /usr/ports/accessibility/speech-dispatcher/files/getline.c	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/getline.c	2010-01-15 19:42:09.644314641 +0100
@@ -0,0 +1,169 @@
+/* getline.c -- Replacement for GNU C library function getline
+
+Copyright (C) 1993 Free Software Foundation, Inc.
+
+This program is free software; you can redistribute it and/or
+modify it under the terms of the GNU General Public License as
+published by the Free Software Foundation; either version 2 of the
+License, or (at your option) any later version.
+
+This program is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+General Public License for more details.  */
+
+/* Written by Jan Brittenson, bson@gnu.ai.mit.edu.  */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <sys/types.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <assert.h>
+#include <errno.h>
+#include "getline.h"
+
+/* Always add at least this many bytes when extending the buffer.  */
+#define MIN_CHUNK 64
+
+/* Read up to (and including) a TERMINATOR from STREAM into *LINEPTR
+   + OFFSET (and null-terminate it).  If LIMIT is non-negative, then
+   read no more than LIMIT chars.
+
+   *LINEPTR is a pointer returned from malloc (or NULL), pointing to
+   *N characters of space.  It is realloc'd as necessary.  
+
+   Return the number of characters read (not including the null
+   terminator), or -1 on error or EOF.  On a -1 return, the caller
+   should check feof(), if not then errno has been set to indicate the
+   error.  */
+
+int
+getstr (lineptr, n, stream, terminator, offset, limit)
+     char **lineptr;
+     size_t *n;
+     FILE *stream;
+     int terminator;
+     int offset;
+     int limit;
+{
+  int nchars_avail;		/* Allocated but unused chars in *LINEPTR.  */
+  char *read_pos;		/* Where we're reading into *LINEPTR. */
+  int ret;
+
+  if (!lineptr || !n || !stream)
+    {
+      errno = EINVAL;
+      return -1;
+    }
+
+  if (!*lineptr)
+    {
+      *n = MIN_CHUNK;
+      *lineptr = malloc (*n);
+      if (!*lineptr)
+	{
+	  errno = ENOMEM;
+	  return -1;
+	}
+      *lineptr[0] = '\0';
+    }
+
+  nchars_avail = *n - offset;
+  read_pos = *lineptr + offset;
+
+  for (;;)
+    {
+      int save_errno;
+      register int c;
+
+      if (limit == 0)
+          break;
+      else
+      {
+          c = getc (stream);
+
+          /* If limit is negative, then we shouldn't pay attention to
+             it, so decrement only if positive. */
+          if (limit > 0)
+              limit--;
+      }
+
+      save_errno = errno;
+
+      /* We always want at least one char left in the buffer, since we
+	 always (unless we get an error while reading the first char)
+	 NUL-terminate the line buffer.  */
+
+      assert((*lineptr + *n) == (read_pos + nchars_avail));
+      if (nchars_avail < 2)
+	{
+	  if (*n > MIN_CHUNK)
+	    *n *= 2;
+	  else
+	    *n += MIN_CHUNK;
+
+	  nchars_avail = *n + *lineptr - read_pos;
+	  *lineptr = realloc (*lineptr, *n);
+	  if (!*lineptr)
+	    {
+	      errno = ENOMEM;
+	      return -1;
+	    }
+	  read_pos = *n - nchars_avail + *lineptr;
+	  assert((*lineptr + *n) == (read_pos + nchars_avail));
+	}
+
+      if (ferror (stream))
+	{
+	  /* Might like to return partial line, but there is no
+	     place for us to store errno.  And we don't want to just
+	     lose errno.  */
+	  errno = save_errno;
+	  return -1;
+	}
+
+      if (c == EOF)
+	{
+	  /* Return partial line, if any.  */
+	  if (read_pos == *lineptr)
+	    return -1;
+	  else
+	    break;
+	}
+
+      *read_pos++ = c;
+      nchars_avail--;
+
+      if (c == terminator)
+	/* Return the line.  */
+	break;
+    }
+
+  /* Done - NUL terminate and return the number of chars read.  */
+  *read_pos = '\0';
+
+  ret = read_pos - (*lineptr + offset);
+  return ret;
+}
+
+int
+getline (lineptr, n, stream)
+     char **lineptr;
+     size_t *n;
+     FILE *stream;
+{
+  return getstr (lineptr, n, stream, '\n', 0, GETLINE_NO_LIMIT);
+}
+
+int
+getline_safe (lineptr, n, stream, limit)
+     char **lineptr;
+     size_t *n;
+     FILE *stream;
+     int limit;
+{
+  return getstr (lineptr, n, stream, '\n', 0, limit);
+}
diff -ruN /usr/ports/accessibility/speech-dispatcher/files/getline.h /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/getline.h
--- /usr/ports/accessibility/speech-dispatcher/files/getline.h	1970-01-01 01:00:00.000000000 +0100
+++ /usr/jail/7_2_release/usr/ports/accessibility/speech-dispatcher/files/getline.h	2010-01-15 18:47:28.572521925 +0100
@@ -0,0 +1,23 @@
+#ifndef _getline_h_
+#define _getline_h_ 1
+
+#include <stdio.h>
+
+#if defined (__GNUC__) || (defined (__STDC__) && __STDC__)
+#define __PROTO(args) args
+#else
+#define __PROTO(args) ()
+#endif  /* GCC.  */
+
+#define GETLINE_NO_LIMIT -1
+
+int
+  getline __PROTO ((char **_lineptr, size_t *_n, FILE *_stream));
+int
+  getline_safe __PROTO ((char **_lineptr, size_t *_n, FILE *_stream,
+                         int limit));
+int
+  getstr __PROTO ((char **_lineptr, size_t *_n, FILE *_stream,
+		   int _terminator, int _offset, int limit));
+
+#endif /* _getline_h_ */


>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201001151909.o0FJ9eGM081665>