]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
The long awaited BeOS cleanup, phase 1
authormmu_man <mmu_man@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Thu, 18 Jan 2007 17:22:30 +0000 (17:22 +0000)
committermmu_man <mmu_man@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Thu, 18 Jan 2007 17:22:30 +0000 (17:22 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@7581 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavformat/http.c
libavformat/os_support.h
libavformat/rtp.c
libavformat/rtp_h264.c
libavformat/rtpproto.c
libavformat/rtsp.c
libavformat/tcp.c
libavformat/udp.c

index f150f6684cf182d60e8bf4b534498eb4b9f44e2c..0a588871bb267331ad7370861d20493d20983cc7 100644 (file)
 #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"
index 88d07ef50c216077ce29888b62cdafb0f2eb3ad2..6f915351fe70626b8471bdeba5e73ef3a38c18f0 100644 (file)
  * @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 @@ __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds);
 #  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 usleep(unsigned int t) { return _sleep2(t / 1000); }
 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 */
index 37a2862892edb56684b15eb4680401b5c964be58..0ac0a7d213bfe482f9cfbe562bf8884b9eafc06d 100644 (file)
 #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"
index 2568e9ea57ffd5e3952c7fb693d512ed76660dc2..68066aaca0e9bd48adcf2f723b8ac1c48e96a957 100644 (file)
 #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"
index d31c509c22b47af82c04b4850353ffc801b57573..14850c48c1dcc8197dc86979e95e9defebc3ff2c 100644 (file)
 #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>
 
index 787cdd6851117f1c0d742817eb3709dd4f88921a..2bc6bb249aac51cbe382fbdefcddf714b593dd35 100644 (file)
 #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"
 
index 93755c4978ae8ffdf48095df5764c44a7ba908e3..9544773111989d0f7151fed3251bd0d415146bf1 100644 (file)
 #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 @@ static int tcp_open(URLContext *h, const char *uri, int flags)
     ret = AVERROR_IO;
  fail1:
     if (fd >= 0)
-        close(fd);
+        closesocket(fd);
     av_free(s);
     return ret;
 }
@@ -213,11 +206,7 @@ static int tcp_write(URLContext *h, uint8_t *buf, int size)
 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;
 }
index 96fa4e152c1c54ea5a3ade4f869f00c05367da3c..3a309c610a4b1bdceb94676d50d9f445ff50f42b 100644 (file)
 #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 @@ static int udp_ipv6_set_local(URLContext *h) {
 
  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 @@ static int udp_open(URLContext *h, const char *uri, int flags)
     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 @@ static int udp_close(URLContext *h)
 {
     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;
 }