[Ffmpeg-cvslog] r7581 - in trunk/libavformat: http.c os_support.h rtp.c rtp_h264.c rtpproto.c rtsp.c tcp.c udp.c
mmu_man
subversion
Thu Jan 18 18:22:31 CET 2007
Author: mmu_man
Date: Thu Jan 18 18:22:30 2007
New Revision: 7581
Modified:
trunk/libavformat/http.c
trunk/libavformat/os_support.h
trunk/libavformat/rtp.c
trunk/libavformat/rtp_h264.c
trunk/libavformat/rtpproto.c
trunk/libavformat/rtsp.c
trunk/libavformat/tcp.c
trunk/libavformat/udp.c
Log:
The long awaited BeOS cleanup, phase 1
Modified: trunk/libavformat/http.c
==============================================================================
--- trunk/libavformat/http.c (original)
+++ trunk/libavformat/http.c Thu Jan 18 18:22:30 2007
@@ -23,11 +23,7 @@
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
-#ifndef __BEOS__
-# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
+#include <arpa/inet.h>
#include <netdb.h>
#include "base64.h"
Modified: trunk/libavformat/os_support.h
==============================================================================
--- trunk/libavformat/os_support.h (original)
+++ trunk/libavformat/os_support.h Thu Jan 18 18:22:30 2007
@@ -26,12 +26,18 @@
* @file os_support.h
* miscellaneous OS support macros and functions.
*
+ * - socklen_t typedef (BeOS, Innotek libc)
* - usleep() (Win32, BeOS, OS/2)
* - lseek() (Win32)
* - floatf() (OS/2)
* - strcasecmp() (OS/2)
+ * - closesocket()
*/
+#if defined(__BEOS__) || defined(__INNOTEK_LIBC__)
+typedef int socklen_t;
+#endif
+
#ifdef __MINGW32__
__declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds);
// # include <windows.h>
@@ -40,9 +46,23 @@
# define lseek(f,p,w) _lseeki64((f), (p), (w))
#endif
+/* XXX: check for Winsock here */
+#if 0
+#define HAVE_CLOSESOCKET 1
+#endif
+
#ifdef __BEOS__
-# ifndef usleep
+# include <sys/socket.h>
+# include <netinet/in.h>
+ /* not net_server ? */
+# if IPPROTO_TCP != 6
+# define HAVE_CLOSESOCKET 1
+# endif
+# include <BeBuild.h>
+ /* R5 didn't have usleep, fake it. Haiku and Zeta has it now. */
+# if B_BEOS_VERSION <= B_BEOS_VERSION_5
# include <OS.h>
+ /* doesn't set errno but that's enough */
# define usleep(t) snooze((bigtime_t)(t))
# endif
#endif
@@ -53,4 +73,9 @@
static inline int strcasecmp(const char* s1, const char* s2) { return stricmp(s1,s2); }
#endif
+/* most of the time closing a socket is just closing an fd */
+#if HAVE_CLOSESOCKET != 1
+#define closesocket close
+#endif
+
#endif /* _OS_SUPPORT_H */
Modified: trunk/libavformat/rtp.c
==============================================================================
--- trunk/libavformat/rtp.c (original)
+++ trunk/libavformat/rtp.c Thu Jan 18 18:22:30 2007
@@ -26,11 +26,7 @@
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
-#ifndef __BEOS__
-# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
+#include <arpa/inet.h>
#include <netdb.h>
#include "rtp_internal.h"
Modified: trunk/libavformat/rtp_h264.c
==============================================================================
--- trunk/libavformat/rtp_h264.c (original)
+++ trunk/libavformat/rtp_h264.c Thu Jan 18 18:22:30 2007
@@ -45,11 +45,7 @@
#include <sys/socket.h>
#include <netinet/in.h>
#include <assert.h>
-#ifndef __BEOS__
-# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
+#include <arpa/inet.h>
#include <netdb.h>
#include "rtp_internal.h"
Modified: trunk/libavformat/rtpproto.c
==============================================================================
--- trunk/libavformat/rtpproto.c (original)
+++ trunk/libavformat/rtpproto.c Thu Jan 18 18:22:30 2007
@@ -25,11 +25,7 @@
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
-#ifndef __BEOS__
-# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
+#include <arpa/inet.h>
#include <netdb.h>
#include <fcntl.h>
Modified: trunk/libavformat/rtsp.c
==============================================================================
--- trunk/libavformat/rtsp.c (original)
+++ trunk/libavformat/rtsp.c Thu Jan 18 18:22:30 2007
@@ -24,11 +24,7 @@
#include <sys/time.h>
#include <netinet/in.h>
#include <sys/socket.h>
-#ifndef __BEOS__
-# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
+#include <arpa/inet.h>
#include "rtp_internal.h"
Modified: trunk/libavformat/tcp.c
==============================================================================
--- trunk/libavformat/tcp.c (original)
+++ trunk/libavformat/tcp.c Thu Jan 18 18:22:30 2007
@@ -23,14 +23,7 @@
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
-#if defined(__BEOS__) || defined(__INNOTEK_LIBC__)
-typedef int socklen_t;
-#endif
-#ifndef __BEOS__
# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
#include <netdb.h>
#include <sys/time.h>
#include <fcntl.h>
@@ -127,7 +120,7 @@
ret = AVERROR_IO;
fail1:
if (fd >= 0)
- close(fd);
+ closesocket(fd);
av_free(s);
return ret;
}
@@ -213,11 +206,7 @@
static int tcp_close(URLContext *h)
{
TCPContext *s = h->priv_data;
-#ifdef CONFIG_BEOS_NETSERVER
closesocket(s->fd);
-#else
- close(s->fd);
-#endif
av_free(s);
return 0;
}
Modified: trunk/libavformat/udp.c
==============================================================================
--- trunk/libavformat/udp.c (original)
+++ trunk/libavformat/udp.c Thu Jan 18 18:22:30 2007
@@ -23,11 +23,7 @@
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
-#ifndef __BEOS__
# include <arpa/inet.h>
-#else
-# include "barpainet.h"
-#endif
#include <netdb.h>
#ifndef IPV6_ADD_MEMBERSHIP
@@ -214,11 +210,7 @@
fail:
if (udp_fd >= 0)
-#ifdef CONFIG_BEOS_NETSERVER
closesocket(udp_fd);
-#else
- close(udp_fd);
-#endif
if(res0)
freeaddrinfo(res0);
return -1;
@@ -421,11 +413,7 @@
return 0;
fail:
if (udp_fd >= 0)
-#ifdef CONFIG_BEOS_NETSERVER
closesocket(udp_fd);
-#else
- close(udp_fd);
-#endif
av_free(s);
return AVERROR_IO;
}
@@ -482,22 +470,20 @@
{
UDPContext *s = h->priv_data;
-#ifndef CONFIG_BEOS_NETSERVER
#ifndef CONFIG_IPV6
+#ifdef IP_DROP_MEMBERSHIP
if (s->is_multicast && !(h->flags & URL_WRONLY)) {
if (setsockopt(s->udp_fd, IPPROTO_IP, IP_DROP_MEMBERSHIP,
&s->mreq, sizeof(s->mreq)) < 0) {
perror("IP_DROP_MEMBERSHIP");
}
}
+#endif
#else
if (s->is_multicast && !(h->flags & URL_WRONLY))
udp_ipv6_leave_multicast_group(s->udp_fd, (struct sockaddr *)&s->dest_addr);
#endif
- close(s->udp_fd);
-#else
closesocket(s->udp_fd);
-#endif
av_free(s);
return 0;
}
More information about the ffmpeg-cvslog
mailing list