[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