[vlc-devel] commit: Fix C++ linking ( Rémi Denis-Courmont )
git version control
git at videolan.org
Sun Apr 12 10:25:30 CEST 2009
vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Sun Apr 12 10:23:20 2009 +0300| [74eba5d80c924fac4802b0d53d75616ac57a4afa] | committer: Rémi Denis-Courmont
Fix C++ linking
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=74eba5d80c924fac4802b0d53d75616ac57a4afa
---
include/vlc_fixups.h | 62 +++++++++++++++++++++++++++++++++----------------
1 files changed, 42 insertions(+), 20 deletions(-)
diff --git a/include/vlc_fixups.h b/include/vlc_fixups.h
index 0a01cee..7c07079 100644
--- a/include/vlc_fixups.h
+++ b/include/vlc_fixups.h
@@ -39,12 +39,41 @@
# error Window CE support for *printf needs fixing.
#endif
+#if !defined (HAVE_GMTIME_R) || !defined (HAVE_LOCALTIME_R)
+# include <time.h> /* time_t */
+#endif
+
+#ifndef HAVE_LLDIV
+typedef struct
+{
+ long long quot; /* Quotient. */
+ long long rem; /* Remainder. */
+} lldiv_t;
+#endif
+
+#ifndef HAVE_REWIND
+# include <stdio.h> /* FILE */
+#endif
+
+#if !defined (HAVE_STRLCPY) || \
+ !defined (HAVE_STRNDUP) || \
+ !defined (HAVE_STRNLEN)
+# include <stddef.h> /* size_t */
+#endif
+
+#ifndef HAVE_VASPRINTF
+# include <stdarg.h> /* va_list */
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
#ifndef HAVE_STRDUP
char *strdup (const char *);
#endif
#ifndef HAVE_VASPRINTF
-# include <stdarg.h>
int vasprintf (char **, const char *, va_list);
#endif
@@ -53,17 +82,14 @@ int asprintf (char **, const char *, ...);
#endif
#ifndef HAVE_STRNLEN
-# include <stddef.h>
size_t strnlen (const char *, size_t);
#endif
#ifndef HAVE_STRNDUP
-# include <stddef.h>
char *strndup (const char *, size_t);
#endif
#ifndef HAVE_STRLCPY
-# include <stddef.h>
size_t strlcpy (char *, const char *, size_t);
#endif
@@ -88,22 +114,9 @@ long long atoll (const char *);
#endif
#ifndef HAVE_LLDIV
-typedef struct {
- long long quot; /* Quotient. */
- long long rem; /* Remainder. */
-} lldiv_t;
-
lldiv_t lldiv (long long, long long);
#endif
-#ifndef HAVE_GETENV
-static inline char *getenv (const char *name)
-{
- (void)name;
- return NULL;
-}
-#endif
-
#ifndef HAVE_STRCASECMP
int strcasecmp (const char *, const char *);
#endif
@@ -117,20 +130,29 @@ char *strcasestr (const char *, const char *);
#endif
#ifndef HAVE_GMTIME_R
-# include <time.h>
struct tm *gmtime_r (const time_t *, struct tm *);
#endif
#ifndef HAVE_LOCALTIME_R
-# include <time.h>
struct tm *localtime_r (const time_t *, struct tm *);
#endif
#ifndef HAVE_REWIND
-# include <stdio.h>
void rewind (FILE *);
#endif
+#ifdef __cplusplus
+} /* extern "C" */
+#endif
+
+#ifndef HAVE_GETENV
+static inline char *getenv (const char *name)
+{
+ (void)name;
+ return NULL;
+}
+#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)))
More information about the vlc-devel
mailing list