Hello community,

here is the log from the commit of package sox for openSUSE:Factory checked in 
at 2011-11-28 12:57:44
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/sox (Old)
 and      /work/SRC/openSUSE:Factory/.sox.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "sox", Maintainer is "[email protected]"

Changes:
--------
--- /work/SRC/openSUSE:Factory/sox/sox.changes  2011-09-23 12:46:41.000000000 
+0200
+++ /work/SRC/openSUSE:Factory/.sox.new/sox.changes     2011-11-28 
12:57:45.000000000 +0100
@@ -1,0 +2,13 @@
+Sun Nov 27 20:49:18 UTC 2011 - [email protected]
+
+- fix build on < 12.1 by not applying the O_CLOEXEC patch there as it is not in
+  the glibc
+- fix build on >= 12.1 by adding ncurses-devel to the BuildRequires
+
+-------------------------------------------------------------------
+Fri Nov 18 20:38:56 UTC 2011 - [email protected]
+
+- libsox: Use O_CLOEXEC where needed, this is specially important
+  in library code and even more here as threading is used.
+
+-------------------------------------------------------------------

New:
----
  sox-ocloexec.patch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ sox.spec ++++++
--- /var/tmp/diff_new_pack.iyJwq9/_old  2011-11-28 12:57:46.000000000 +0100
+++ /var/tmp/diff_new_pack.iyJwq9/_new  2011-11-28 12:57:46.000000000 +0100
@@ -37,6 +37,7 @@
 BuildRequires:  libvorbis-devel
 BuildRequires:  pkg-config
 BuildRequires:  wavpack-devel
+BuildRequires:  ncurses-devel
 %if %{with ffmpeg}
 BuildRequires:  libffmpeg-devel
 %endif
@@ -63,6 +64,8 @@
 Patch2:         %{name}-14.3.1-undefined.patch
 # PATCH-FIX-UPSTREAM %{name}-14.3.1-aliasing.patch sf#3072320 
[email protected] -- fix an aliasing problem as reported by post-build 
script
 Patch3:         %{name}-14.3.1-aliasing.patch
+#PATCH-FIX-OPENSUSE [email protected] linux/glibc specific patch to 
open all fds with O_CLOEXEC (not suitable for other OS)
+Patch4:         sox-ocloexec.patch
 BuildRoot:      %{_tmppath}/%{name}-%{version}-build
 
 %description
@@ -89,6 +92,9 @@
 %patch0 -p1
 %patch2
 %patch3
+%if 0%{?suse_version} > 1140
+%patch4
+%endif
 FAKE_BUILDDATE=$(LC_ALL=C date -u -r %{_sourcedir}/%{name}.changes '+%%b %%e 
%%Y')
 sed -i "s/__DATE__/\"$FAKE_BUILDDATE\"/" src/sox.c
 FAKE_BUILDTIME=$(LC_ALL=C date -u -r %{_sourcedir}/%{name}.changes 
'+%%H:%%M:%%S')
@@ -122,7 +128,8 @@
 %attr(0755,root,root) %{_bindir}/*
 # I don't know of anything which uses libsox, but if the soname changes perhaps
 # it's the time to split the package and follow SLPP
-%{_libdir}/libsox.so.1*
+%{_libdir}/libsox.so.1
+%{_libdir}/libsox.so.1.*
 %{_mandir}/man1/*
 %{_mandir}/man3/*
 %{_mandir}/man7/*

++++++ sox-ocloexec.patch ++++++
--- src/8svx.c.orig
+++ src/8svx.c
@@ -161,7 +161,7 @@ static int startread(sox_format_t * ft)
         chan1_pos = lsx_tell(ft);
 
         for (i = 1; i < channels; i++) {
-                if ((p->ch[i] = fopen(ft->filename, "rb")) == NULL)
+                if ((p->ch[i] = fopen(ft->filename, "rbe")) == NULL)
                 {
                         lsx_fail_errno(ft,errno,"Can't open channel file '%s'",
                                 ft->filename);
--- src/effects_i.c.orig
+++ src/effects_i.c
@@ -350,7 +350,7 @@ FILE * lsx_open_input_file(sox_effect_t
     effp->global_info->global_info->stdin_in_use_by = effp->handler.name;
     file = stdin;
   }
-  else if (!(file = fopen(filename, "r"))) {
+  else if (!(file = fopen(filename, "re"))) {
     lsx_fail("couldn't open file %s: %s", filename, strerror(errno));
     return NULL;
   }
--- src/noiseprof.c.orig
+++ src/noiseprof.c
@@ -75,7 +75,7 @@ static int sox_noiseprof_start(sox_effec
     effp->global_info->global_info->stdout_in_use_by = effp->handler.name;
     data->output_file = stdout;
   }
-  else if ((data->output_file = fopen(data->output_filename, "w")) == NULL) {
+  else if ((data->output_file = fopen(data->output_filename, "we")) == NULL) {
     lsx_fail("Couldn't open profile file %s: %s", data->output_filename, 
strerror(errno));
     return SOX_EOF;
   }
--- src/sox.c.orig
+++ src/sox.c
@@ -852,7 +852,7 @@ static char * * strtoargv(char * s, int
 
 static void read_user_effects(char *filename)
 {
-    FILE *file = fopen(filename, "rt");
+    FILE *file = fopen(filename, "rte");
     char s[FILENAME_MAX];
     int argc;
     char * * argv;
@@ -1189,7 +1189,7 @@ static int kbhit(void)
 static void adjust_volume(int delta)
 {
   char * from_env = getenv("MIXERDEV");
-  int vol1 = 0, vol2 = 0, fd = open(from_env? from_env : "/dev/mixer", O_RDWR);
+  int vol1 = 0, vol2 = 0, fd = open(from_env? from_env : "/dev/mixer", 
O_RDWR|O_CLOEXEC);
   if (fd >= 0) {
     if (ioctl(fd, MIXER_READ(SOUND_MIXER_PCM), &vol1) != -1) {
       int side1 = vol1 & 0xff, side2 = (vol1 >> 8) & 0xff;
@@ -1983,7 +1983,7 @@ static void read_comment_file(sox_commen
   int c;
   size_t text_length = 100;
   char * text = lsx_malloc(text_length + 1);
-  FILE * file = fopen(filename, "rt");
+  FILE * file = fopen(filename, "rte");
 
   if (file == NULL) {
     lsx_fail("Cannot open comment file `%s'", filename);
--- src/spectrogram.c.orig
+++ src/spectrogram.c
@@ -491,7 +491,7 @@ static int axis(double to, int max_steps
 static int stop(sox_effect_t * effp)
 {
   priv_t *    p        = (priv_t *) effp->priv;
-  FILE *      file     = fopen(p->out_name, "wb");
+  FILE *      file     = fopen(p->out_name, "wbe");
   uLong       font_len = 96 * font_y;
   int         chans    = effp->in_signal.channels;
   int         c_rows   = p->rows * chans + chans - 1;
--- src/formats.c.orig
+++ src/formats.c
@@ -366,7 +366,7 @@ static FILE * xfopen(char const * identi
   if (*identifier == '|') {
     FILE * f = NULL;
 #ifdef HAVE_POPEN
-    f = popen(identifier + 1, "r");
+    f = popen(identifier + 1, "re");
     *io_type = lsx_io_pipe;
 #else
     lsx_fail("this build of SoX cannot open pipes");
@@ -375,11 +375,12 @@ static FILE * xfopen(char const * identi
   }
   else if (is_url(identifier)) {
     FILE * f = NULL;
+/* XXX: really folks ? forking a wget process to get an URL.. (!!!!!) */
 #ifdef HAVE_POPEN
     char const * const command_format = "wget --no-check-certificate -q -O- 
\"%s\"";
     char * command = lsx_malloc(strlen(command_format) + strlen(identifier));
     sprintf(command, command_format, identifier);
-    f = popen(command, "r");
+    f = popen(command, "re");
     free(command);
     *io_type = lsx_io_url;
 #else
@@ -451,7 +452,7 @@ static sox_format_t * open_read(
 #ifdef HAVE_FMEMOPEN
         buffer? fmemopen(buffer, buffer_size, "rb") :
 #endif
-        xfopen(path, "rb", &ft->io_type);
+        xfopen(path, "rbe", &ft->io_type);
       type = io_types[ft->io_type];
       if (ft->fp == NULL) {
         lsx_fail("can't open input %s `%s': %s", type, path, strerror(errno));
@@ -849,7 +850,7 @@ static sox_format_t * open_write(
         buffer? fmemopen(buffer, buffer_size, "w+b") :
         buffer_ptr? open_memstream(buffer_ptr, buffer_size_ptr) :
 #endif
-        fopen(path, "w+b");
+        fopen(path, "w+be");
       if (ft->fp == NULL) {
         lsx_fail("can't open output file `%s': %s", path, strerror(errno));
         goto error;
@@ -1059,7 +1060,7 @@ int sox_parse_playlist(sox_playlist_call
   char * dirname = lsx_strdup(listname);
   char * slash_pos = LAST_SLASH(dirname);
   lsx_io_type io_type;
-  FILE * file = xfopen(listname, "r", &io_type);
+  FILE * file = xfopen(listname, "re", &io_type);
   char * filename;
   int c, result = SOX_SUCCESS;
 
--- src/libsox_i.c.orig
+++ src/libsox_i.c
@@ -34,7 +34,7 @@
 #else
   #define MKTEMP_X 0
 #endif
-
+#include <fcntl.h>
 #ifndef HAVE_MKSTEMP
   #include <fcntl.h>
   #include <sys/types.h>
@@ -54,7 +54,7 @@ FILE * lsx_tmpfile(void)
     int fildes;
     strcpy(name, sox_globals.tmp_path);
     strcat(name, end);
-    fildes = mkstemp(name);
+    fildes = mkostemp(name, O_CLOEXEC);
 #ifdef HAVE_UNISTD_H
     lsx_debug(FAKE_MKSTEMP "mkstemp, name=%s (unlinked)", name);
     unlink(name);
@@ -62,7 +62,7 @@ FILE * lsx_tmpfile(void)
     lsx_debug(FAKE_MKSTEMP "mkstemp, name=%s (O_TEMPORARY)", name);
 #endif
     free(name);
-    return fildes == -1? NULL : fdopen(fildes, "w+");
+    return fildes == -1? NULL : fdopen(fildes, "w+e");
   }
 
   /* Use standard tmpfile (delete on close); tmp dir is undefined: */
-- 
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to