[vlc-devel] [PATCH] WinCE: add replacement getcwd() function
Pierre Ynard
linkfanel at yahoo.fr
Wed May 20 17:09:19 CEST 2009
As WinCE doesn't support working directories, this function is
basically empty, and merely returns an error.
If everyone is fine with this version, I'll commit it myself :)
diff --git a/compat/getcwd.c b/compat/getcwd.c
new file mode 100644
index 0000000..a238d05
--- /dev/null
+++ b/compat/getcwd.c
@@ -0,0 +1,38 @@
+/*****************************************************************************
+ * getcwd.c: POSIX getcwd() replacement
+ *****************************************************************************
+ * Copyright © 2009 the VideoLAN project
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
+ *****************************************************************************/
+
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#include <stddef.h>
+
+char *getcwd (char *buf, size_t size)
+{
+#ifdef UNDER_CE
+ /* Windows CE lacks any notion of working directory, so we just
+ * return an error, and set errno - oh wait, WinCE doesn't support
+ * errno either! */
+ (void) buf; (void) size;
+ return NULL;
+#else
+# error Unimplemented!
+#endif
+}
diff --git a/configure.ac b/configure.ac
index 8d51b84..0fba50e 100644
--- a/configure.ac
+++ b/configure.ac
@@ -578,7 +578,7 @@ dnl Check for usual libc functions
AC_CHECK_FUNCS([gettimeofday isatty sigrelse getpwuid_r memalign posix_memalign if_nametoindex getenv putenv setenv ctime_r lrintf daemon fork lstat posix_fadvise posix_madvise uselocale])
AC_FUNC_ALLOCA
AC_CHECK_FUNCS(fcntl)
-AC_REPLACE_FUNCS([asprintf atof atoll gmtime_r lldiv localtime_r rewind strcasecmp strcasestr strdup strlcpy strncasecmp strndup strnlen strsep strtof strtoll vasprintf swab])
+AC_REPLACE_FUNCS([asprintf atof atoll getcwd gmtime_r lldiv localtime_r rewind strcasecmp strcasestr strdup strlcpy strncasecmp strndup strnlen strsep strtof strtoll vasprintf swab])
AC_CHECK_FUNCS([stricmp strnicmp])
AC_CHECK_FUNCS(fdatasync,,
[AC_DEFINE(fdatasync, fsync, [Alias fdatasync() to fsync() if missing.])
diff --git a/include/vlc_fixups.h b/include/vlc_fixups.h
index 5636832..a02eece 100644
--- a/include/vlc_fixups.h
+++ b/include/vlc_fixups.h
@@ -44,7 +44,8 @@ typedef struct
#if !defined (HAVE_STRLCPY) || \
!defined (HAVE_STRNDUP) || \
- !defined (HAVE_STRNLEN)
+ !defined (HAVE_STRNLEN) || \
+ !defined (HAVE_GETCWD)
# include <stddef.h> /* size_t */
#endif
@@ -128,6 +129,10 @@ struct tm *localtime_r (const time_t *, struct tm *);
void rewind (FILE *);
#endif
+#ifndef HAVE_GETCWD
+char *getcwd (char *buf, size_t size);
+#endif
+
#ifdef __cplusplus
} /* extern "C" */
#endif
Regards,
--
Pierre Ynard
"Une âme dans un corps, c'est comme un dessin sur une feuille de papier."
More information about the vlc-devel
mailing list