]> git.sesse.net Git - ffmpeg/commitdiff
localtime_r patch by (Glenn Maynard <g_sf at zewt dot org>)
authorGlenn Maynard <g_sf@zewt.org>
Thu, 4 Sep 2003 09:52:39 +0000 (09:52 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Thu, 4 Sep 2003 09:52:39 +0000 (09:52 +0000)
Originally committed as revision 2204 to svn://svn.ffmpeg.org/ffmpeg/trunk

configure
libavformat/Makefile
libavformat/dvcore.c
libavformat/localtime_r.c [new file with mode: 0644]
libavformat/localtime_r.h [new file with mode: 0644]
libavformat/strptime.c

index f2537542743d10a558c27c563dd34e9759ee129b..81d2d4510b3a36da38eba298377e8a6d74cccbb0 100755 (executable)
--- a/configure
+++ b/configure
@@ -574,6 +574,16 @@ if $cc -o $TMPE $TMPC 2> /dev/null ; then
   strptime=yes
 fi
 
+cat > $TMPC << EOF
+#include <time.h>
+int main( void ) { localtime_r(NULL, NULL); }
+EOF
+
+localtime_r=no
+if $cc -o $TMPE $TMPC 2> /dev/null ; then
+  localtime_r=yes
+fi
+
 if test "$zlib" = "yes"; then
 # check for zlib - mmu_man
 cat > $TMPC << EOF
@@ -920,6 +930,11 @@ if test "$strptime" = "yes" ; then
 else
   echo "BUILD_STRPTIME=yes" >> config.mak
 fi
+if test "$localtime_r" = "yes" ; then
+  echo "#define HAVE_LOCALTIME_R 1" >> $TMPH
+else
+  echo "BUILD_LOCALTIME_R=yes" >> config.mak
+fi
 if test "$imlib2" = "yes" ; then
   echo "HAVE_IMLIB2=yes" >> config.mak
 fi
index e064cf613b83b6a4bc889eac4ad0159ba39b734f..866fdd5f7b784cd07438fa298300a5e6f89be211 100644 (file)
@@ -34,6 +34,10 @@ ifeq ($(BUILD_STRPTIME),yes)
 OBJS+= strptime.o
 endif
 
+ifeq ($(BUILD_LOCALTIME_R),yes)
+OBJS+= localtime_r.o
+endif
+
 ifeq ($(CONFIG_VIDEO4LINUX),yes)
 OBJS+= grab.o
 endif
index c6d5ed6a954dab19cdfe0db711448199bc507865..57864c5f81f6ef321a69febcda7a67963c05ff37 100644 (file)
@@ -21,6 +21,7 @@
  */
 #include "avformat.h"
 #include "dvcore.h"
+#include "localtime_r.h"
 
 /*
  * The reason why the following three big ugly looking tables are
diff --git a/libavformat/localtime_r.c b/libavformat/localtime_r.c
new file mode 100644 (file)
index 0000000..1b619a4
--- /dev/null
@@ -0,0 +1,43 @@
+/* Convert a string representation of time to a time value.
+   Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+   Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library 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
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "localtime_r.h"
+
+#if !defined(HAVE_LOCALTIME_R)
+/* Approximate localtime_r as best we can in its absence.  */
+#include <time.h>
+
+struct tm *
+localtime_r (t, tp)
+     const time_t *t;
+     struct tm *tp;
+{
+  struct tm *l = localtime (t);
+  if (! l)
+    return 0;
+  *tp = *l;
+  return tp;
+}
+#endif /* !defined(HAVE_LOCALTIME_R) */
+
diff --git a/libavformat/localtime_r.h b/libavformat/localtime_r.h
new file mode 100644 (file)
index 0000000..a3f8bec
--- /dev/null
@@ -0,0 +1,42 @@
+/* strptime.h
+ *
+ * $Id$
+ *
+ * Ethereal - Network traffic analyzer
+ * By Gerald Combs <gerald@ethereal.com>
+ * Copyright 1998 Gerald Combs
+ *
+ * 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.
+ * 
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ */
+
+#ifndef __LOCALTIME_R_H__
+#define __LOCALTIME_R_H__
+
+/*
+ * Version of "localtime_r()", for the benefit of OSes that don't have it.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#if !defined(HAVE_LOCALTIME_R)
+#include <time.h>
+/* Approximate localtime_r as best we can in its absence.  */
+# define localtime_r my_localtime_r
+extern struct tm *localtime_r(const time_t *, struct tm *);
+#endif
+
+#endif
index 7aece6a08e7ea23152c989659ac68fa0a033cc40..45645384babd53a830b47e23d838f39cc49c439a 100644 (file)
@@ -37,6 +37,7 @@
 #endif
 
 #include "strptime.h"
+#include "localtime_r.h"
 
 #ifndef __P
 # if defined (__GNUC__) || (defined (__STDC__) && __STDC__)
 # endif  /* GCC.  */
 #endif  /* Not __P.  */
 
-#if ! HAVE_LOCALTIME_R && ! defined localtime_r
-# ifdef _LIBC
-#  define localtime_r __localtime_r
-# else
-/* Approximate localtime_r as best we can in its absence.  */
-#  define localtime_r my_localtime_r
-static struct tm *localtime_r __P ((const time_t *, struct tm *));
-static struct tm *
-localtime_r (t, tp)
-     const time_t *t;
-     struct tm *tp;
-{
-  struct tm *l = localtime (t);
-  if (! l)
-    return 0;
-  *tp = *l;
-  return tp;
-}
-# endif /* ! _LIBC */
-#endif /* ! HAVE_LOCALTIME_R && ! defined (localtime_r) */
-
-
 #define match_char(ch1, ch2) if (ch1 != ch2) return NULL
 #if defined __GNUC__ && __GNUC__ >= 2
 # define match_string(cs1, s2) \