#if !defined (HAVE_STRLCPY) || \
!defined (HAVE_STRNDUP) || \
- !defined (HAVE_STRNLEN) || \
- !defined (HAVE_GETCWD)
+ !defined (HAVE_STRNLEN)
# include <stddef.h> /* size_t */
#endif
# include <sys/types.h> /* ssize_t, pid_t */
#endif
+#if !defined (HAVE_DIRFD) || \
+ !defined (HAVE_FDOPENDIR)
+# include <dirent.h>
+#endif
+
#ifdef __cplusplus
extern "C" {
#endif
-#ifndef HAVE_STRDUP
-char *strdup (const char *);
+/* stdio.h */
+#ifndef HAVE_ASPRINTF
+int asprintf (char **, const char *, ...);
+#endif
+
+#ifndef HAVE_FLOCKFILE
+void flockfile (FILE *);
+int ftrylockfile (FILE *);
+void funlockfile (FILE *);
+int getc_unlocked (FILE *);
+int getchar_unlocked (void);
+int putc_unlocked (int, FILE *);
+int putchar_unlocked (int);
+#endif
+
+#ifndef HAVE_GETDELIM
+ssize_t getdelim (char **, size_t *, int, FILE *);
+ssize_t getline (char **, size_t *, FILE *);
+#endif
+
+#ifndef HAVE_REWIND
+void rewind (FILE *);
#endif
#ifndef HAVE_VASPRINTF
int vasprintf (char **, const char *, va_list);
#endif
-#ifndef HAVE_ASPRINTF
-int asprintf (char **, const char *, ...);
+/* string.h */
+#ifndef HAVE_STRCASECMP
+int strcasecmp (const char *, const char *);
+#endif
+
+#ifndef HAVE_STRCASESTR
+char *strcasestr (const char *, const char *);
+#endif
+
+#ifndef HAVE_STRDUP
+char *strdup (const char *);
+#endif
+
+#ifndef HAVE_STRNCASECMP
+int strncasecmp (const char *, const char *, size_t);
#endif
#ifndef HAVE_STRNLEN
size_t strlcpy (char *, const char *, size_t);
#endif
-#ifndef HAVE_STRTOF
-float strtof (const char *, char **);
+#ifndef HAVE_STRSEP
+char *strsep (char **, const char *);
#endif
-#ifndef HAVE_ATOF
-double atof (const char *);
+#ifndef HAVE_STRTOK_R
+char *strtok_r(char *, const char *, char **);
#endif
-#ifndef HAVE_STRTOLL
-long long int strtoll (const char *, char **, int);
+/* stdlib.h */
+#ifndef HAVE_ATOF
+#ifndef __ANDROID__
+double atof (const char *);
#endif
-
-#ifndef HAVE_STRSEP
-char *strsep (char **, const char *);
#endif
#ifndef HAVE_ATOLL
lldiv_t lldiv (long long, long long);
#endif
-#ifndef HAVE_STRCASECMP
-int strcasecmp (const char *, const char *);
+#ifndef HAVE_STRTOF
+#ifndef __ANDROID__
+float strtof (const char *, char **);
#endif
-
-#ifndef HAVE_STRNCASECMP
-int strncasecmp (const char *, const char *, size_t);
#endif
-#ifndef HAVE_STRCASESTR
-char *strcasestr (const char *, const char *);
+#ifndef HAVE_STRTOLL
+long long int strtoll (const char *, char **, int);
#endif
+/* time.h */
#ifndef HAVE_GMTIME_R
struct tm *gmtime_r (const time_t *, struct tm *);
#endif
struct tm *localtime_r (const time_t *, struct tm *);
#endif
-#ifndef HAVE_REWIND
-void rewind (FILE *);
+/* unistd.h */
+#ifndef HAVE_GETPID
+pid_t getpid (void);
#endif
-#ifndef HAVE_GETCWD
-char *getcwd (char *buf, size_t size);
+#ifndef HAVE_FSYNC
+int fsync (int fd);
#endif
-#ifndef HAVE_GETDELIM
-ssize_t getdelim (char **, size_t *, int, FILE *);
-ssize_t getline (char **, size_t *, FILE *);
+/* dirent.h */
+#ifndef HAVE_DIRFD
+#if defined(__APPLE__) || defined(__OS2__)
+#undef dirfd
#endif
-
-#ifndef HAVE_GETPID
-pid_t getpid (void);
+int dirfd (DIR *);
#endif
-#ifndef HAVE_STRTOK_R
-char *strtok_r(char *, const char *, char **);
+#ifndef HAVE_FDOPENDIR
+DIR *fdopendir (int);
#endif
#ifdef __cplusplus
} /* extern "C" */
#endif
+/* stdlib.h */
#ifndef HAVE_GETENV
static inline char *getenv (const char *name)
{
}
#endif
-/* Alignment of critical static data structures */
-#ifdef ATTRIBUTE_ALIGNED_MAX
-# define ATTR_ALIGN(align) __attribute__ ((__aligned__ ((ATTRIBUTE_ALIGNED_MAX < align) ? ATTRIBUTE_ALIGNED_MAX : align)))
-#else
-# define ATTR_ALIGN(align)
+#ifndef HAVE_SETENV
+int setenv (const char *, const char *, int);
+int unsetenv (const char *);
#endif
+/* locale.h */
#ifndef HAVE_USELOCALE
#define LC_NUMERIC_MASK 0
#define LC_MESSAGES_MASK 0
}
#endif
+/* Alignment of critical static data structures */
+#ifdef ATTRIBUTE_ALIGNED_MAX
+# define ATTR_ALIGN(align) __attribute__ ((__aligned__ ((ATTRIBUTE_ALIGNED_MAX < align) ? ATTRIBUTE_ALIGNED_MAX : align)))
+#else
+# define ATTR_ALIGN(align)
+#endif
+
/* libintl support */
#define _(str) vlc_gettext (str)
#define N_(str) gettext_noop (str)
/* Socket stuff */
#ifndef HAVE_INET_PTON
-# define inet_pton vlc_inet_pton
-#endif
-
-#ifndef HAVE_INET_NTOP
-# define inet_ntop vlc_inet_ntop
+int inet_pton(int, const char *, void *);
+const char *inet_ntop(int, const void *, char *, int);
#endif
-#ifndef HAVE_POLL
+#ifndef HAVE_STRUCT_POLLFD
enum
{
POLLIN=1,
unsigned events;
unsigned revents;
};
-
+#endif
+#ifndef HAVE_POLL
# define poll(a, b, c) vlc_poll(a, b, c)
#elif defined (HAVE_MAEMO)
# include <poll.h>
# define poll(a, b, c) vlc_poll(a, b, c)
-int vlc_poll (struct pollfd *, unsigned, int);
#endif
-#ifndef HAVE_SEARCH_H
+#ifndef HAVE_IF_NAMEINDEX
+#include <errno.h>
+struct if_nameindex
+{
+ unsigned if_index;
+ char *if_name;
+};
+# ifndef HAVE_IF_NAMETOINDEX
+# define if_nametoindex(name) atoi(name)
+# endif
+# define if_nameindex() (errno = ENOBUFS, NULL)
+# define if_freenameindex(list) (void)0
+#endif
+/* search.h */
+#ifndef HAVE_SEARCH_H
typedef struct entry {
char *key;
void *data;
leaf
} VISIT;
-#ifdef _SEARCH_PRIVATE
-typedef struct node {
- char *key;
- struct node *llink, *rlink;
-} node_t;
-#endif
-
void *tsearch( const void *key, void **rootp, int(*cmp)(const void *, const void *) );
void *tfind( const void *key, const void **rootp, int(*cmp)(const void *, const void *) );
void *tdelete( const void *key, void **rootp, int(*cmp)(const void *, const void *) );
void twalk( const void *root, void(*action)(const void *nodep, VISIT which, int depth) );
void tdestroy( void *root, void (*free_node)(void *nodep) );
-#endif
-
-#ifndef HAVE_TDESTROY
-// If search.h is not present we are already building tdestroy
-# ifdef HAVE_SEARCH_H
+#else // HAVE_SEARCH_H
+# ifndef HAVE_TDESTROY
# define tdestroy vlc_tdestroy
# endif
#endif
long nrand48 (unsigned short subi[3]);
#endif
+#ifdef __ANDROID__
+# undef __linux__
+# ifndef __cplusplus
+# define __cplusplus 0
+# endif
+# include <pthread.h>
+# if __cplusplus == 0
+# undef __cplusplus
+# endif
+char *tempnam(const char *, const char *);
+#endif // ANDROID
+
+#ifdef __OS2__
+# undef HAVE_FORK /* Implementation of fork() is imperfect on OS/2 */
+#endif
+
#endif /* !LIBVLC_FIXUPS_H */