Commit 4b8ff272 authored by mmu_man's avatar mmu_man

The long awaited BeOS cleanup, phase 1

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@7581 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 52530e63
...@@ -23,11 +23,7 @@ ...@@ -23,11 +23,7 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#ifndef __BEOS__ #include <arpa/inet.h>
# include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include <netdb.h> #include <netdb.h>
#include "base64.h" #include "base64.h"
......
...@@ -26,12 +26,18 @@ ...@@ -26,12 +26,18 @@
* @file os_support.h * @file os_support.h
* miscellaneous OS support macros and functions. * miscellaneous OS support macros and functions.
* *
* - socklen_t typedef (BeOS, Innotek libc)
* - usleep() (Win32, BeOS, OS/2) * - usleep() (Win32, BeOS, OS/2)
* - lseek() (Win32) * - lseek() (Win32)
* - floatf() (OS/2) * - floatf() (OS/2)
* - strcasecmp() (OS/2) * - strcasecmp() (OS/2)
* - closesocket()
*/ */
#if defined(__BEOS__) || defined(__INNOTEK_LIBC__)
typedef int socklen_t;
#endif
#ifdef __MINGW32__ #ifdef __MINGW32__
__declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds); __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds);
// # include <windows.h> // # include <windows.h>
...@@ -40,9 +46,23 @@ __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds); ...@@ -40,9 +46,23 @@ __declspec(dllimport) void __stdcall Sleep(unsigned long dwMilliseconds);
# define lseek(f,p,w) _lseeki64((f), (p), (w)) # define lseek(f,p,w) _lseeki64((f), (p), (w))
#endif #endif
/* XXX: check for Winsock here */
#if 0
#define HAVE_CLOSESOCKET 1
#endif
#ifdef __BEOS__ #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> # include <OS.h>
/* doesn't set errno but that's enough */
# define usleep(t) snooze((bigtime_t)(t)) # define usleep(t) snooze((bigtime_t)(t))
# endif # endif
#endif #endif
...@@ -53,4 +73,9 @@ static inline int usleep(unsigned int t) { return _sleep2(t / 1000); } ...@@ -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); } static inline int strcasecmp(const char* s1, const char* s2) { return stricmp(s1,s2); }
#endif #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 */ #endif /* _OS_SUPPORT_H */
...@@ -26,11 +26,7 @@ ...@@ -26,11 +26,7 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#ifndef __BEOS__ #include <arpa/inet.h>
# include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include <netdb.h> #include <netdb.h>
#include "rtp_internal.h" #include "rtp_internal.h"
......
...@@ -45,11 +45,7 @@ ...@@ -45,11 +45,7 @@
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <assert.h> #include <assert.h>
#ifndef __BEOS__ #include <arpa/inet.h>
# include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include <netdb.h> #include <netdb.h>
#include "rtp_internal.h" #include "rtp_internal.h"
......
...@@ -25,11 +25,7 @@ ...@@ -25,11 +25,7 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#ifndef __BEOS__ #include <arpa/inet.h>
# include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include <netdb.h> #include <netdb.h>
#include <fcntl.h> #include <fcntl.h>
......
...@@ -24,11 +24,7 @@ ...@@ -24,11 +24,7 @@
#include <sys/time.h> #include <sys/time.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <sys/socket.h> #include <sys/socket.h>
#ifndef __BEOS__ #include <arpa/inet.h>
# include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include "rtp_internal.h" #include "rtp_internal.h"
......
...@@ -23,14 +23,7 @@ ...@@ -23,14 +23,7 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#if defined(__BEOS__) || defined(__INNOTEK_LIBC__)
typedef int socklen_t;
#endif
#ifndef __BEOS__
# include <arpa/inet.h> # include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include <netdb.h> #include <netdb.h>
#include <sys/time.h> #include <sys/time.h>
#include <fcntl.h> #include <fcntl.h>
...@@ -127,7 +120,7 @@ static int tcp_open(URLContext *h, const char *uri, int flags) ...@@ -127,7 +120,7 @@ static int tcp_open(URLContext *h, const char *uri, int flags)
ret = AVERROR_IO; ret = AVERROR_IO;
fail1: fail1:
if (fd >= 0) if (fd >= 0)
close(fd); closesocket(fd);
av_free(s); av_free(s);
return ret; return ret;
} }
...@@ -213,11 +206,7 @@ static int tcp_write(URLContext *h, uint8_t *buf, int size) ...@@ -213,11 +206,7 @@ static int tcp_write(URLContext *h, uint8_t *buf, int size)
static int tcp_close(URLContext *h) static int tcp_close(URLContext *h)
{ {
TCPContext *s = h->priv_data; TCPContext *s = h->priv_data;
#ifdef CONFIG_BEOS_NETSERVER
closesocket(s->fd); closesocket(s->fd);
#else
close(s->fd);
#endif
av_free(s); av_free(s);
return 0; return 0;
} }
......
...@@ -23,11 +23,7 @@ ...@@ -23,11 +23,7 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#ifndef __BEOS__
# include <arpa/inet.h> # include <arpa/inet.h>
#else
# include "barpainet.h"
#endif
#include <netdb.h> #include <netdb.h>
#ifndef IPV6_ADD_MEMBERSHIP #ifndef IPV6_ADD_MEMBERSHIP
...@@ -214,11 +210,7 @@ static int udp_ipv6_set_local(URLContext *h) { ...@@ -214,11 +210,7 @@ static int udp_ipv6_set_local(URLContext *h) {
fail: fail:
if (udp_fd >= 0) if (udp_fd >= 0)
#ifdef CONFIG_BEOS_NETSERVER
closesocket(udp_fd); closesocket(udp_fd);
#else
close(udp_fd);
#endif
if(res0) if(res0)
freeaddrinfo(res0); freeaddrinfo(res0);
return -1; return -1;
...@@ -421,11 +413,7 @@ static int udp_open(URLContext *h, const char *uri, int flags) ...@@ -421,11 +413,7 @@ static int udp_open(URLContext *h, const char *uri, int flags)
return 0; return 0;
fail: fail:
if (udp_fd >= 0) if (udp_fd >= 0)
#ifdef CONFIG_BEOS_NETSERVER
closesocket(udp_fd); closesocket(udp_fd);
#else
close(udp_fd);
#endif
av_free(s); av_free(s);
return AVERROR_IO; return AVERROR_IO;
} }
...@@ -482,22 +470,20 @@ static int udp_close(URLContext *h) ...@@ -482,22 +470,20 @@ static int udp_close(URLContext *h)
{ {
UDPContext *s = h->priv_data; UDPContext *s = h->priv_data;
#ifndef CONFIG_BEOS_NETSERVER
#ifndef CONFIG_IPV6 #ifndef CONFIG_IPV6
#ifdef IP_DROP_MEMBERSHIP
if (s->is_multicast && !(h->flags & URL_WRONLY)) { if (s->is_multicast && !(h->flags & URL_WRONLY)) {
if (setsockopt(s->udp_fd, IPPROTO_IP, IP_DROP_MEMBERSHIP, if (setsockopt(s->udp_fd, IPPROTO_IP, IP_DROP_MEMBERSHIP,
&s->mreq, sizeof(s->mreq)) < 0) { &s->mreq, sizeof(s->mreq)) < 0) {
perror("IP_DROP_MEMBERSHIP"); perror("IP_DROP_MEMBERSHIP");
} }
} }
#endif
#else #else
if (s->is_multicast && !(h->flags & URL_WRONLY)) if (s->is_multicast && !(h->flags & URL_WRONLY))
udp_ipv6_leave_multicast_group(s->udp_fd, (struct sockaddr *)&s->dest_addr); udp_ipv6_leave_multicast_group(s->udp_fd, (struct sockaddr *)&s->dest_addr);
#endif #endif
close(s->udp_fd);
#else
closesocket(s->udp_fd); closesocket(s->udp_fd);
#endif
av_free(s); av_free(s);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment