/* -----------------------------------------------------------------------------
*
- * (c) The University of Glasgow 2001-2002
+ * (c) The University of Glasgow 2001-2004
*
* Definitions for package `base' which are visible in Haskell land.
*
#define __HSBASE_H__
#include "ghcconfig.h"
+
#include "HsBaseConfig.h"
+
+/* ultra-evil... */
+#undef PACKAGE_BUGREPORT
+#undef PACKAGE_NAME
+#undef PACKAGE_STRING
+#undef PACKAGE_TARNAME
+#undef PACKAGE_VERSION
+
#include "HsFFI.h"
#include <stdio.h>
#include "lockFile.h"
#include "dirUtils.h"
+#include "runProcess.h"
+
#if defined(mingw32_TARGET_OS)
#include <io.h>
#include <fcntl.h>
#include <shlobj.h>
#endif
-/* in system.c */
-HsInt systemCmd(HsAddr cmd);
-
-/* in rawSystem.c */
-#if defined(mingw32_TARGET_OS)
-HsInt rawSystem(HsAddr cmd);
-#else
-HsInt rawSystem(HsAddr cmd, HsAddr args);
-#endif
-
/* in inputReady.c */
int inputReady(int fd, int msecs, int isSock);
/* in Signals.c */
extern HsInt nocldstop;
+#if !defined(mingw32_TARGET_OS)
+/* in execvpe.c */
+extern int execvpe(char *name, char *const argv[], char **envp);
+extern void pPrPr_disableITimers (void);
+#endif
+
/* -----------------------------------------------------------------------------
64-bit operations, defined in longlong.c
-------------------------------------------------------------------------- */
INLINE int __hsposix_SIGTTOU() { return SIGTTOU; }
INLINE int __hsposix_SIGUSR1() { return SIGUSR1; }
INLINE int __hsposix_SIGUSR2() { return SIGUSR2; }
-#if HAVE_SIGPOLL
+#ifdef SIGPOLL
INLINE int __hsposix_SIGPOLL() { return SIGPOLL; }
#endif
INLINE int __hsposix_SIGPROF() { return SIGPROF; }
INLINE int __hsposix_SIG_BLOCK() { return SIG_BLOCK; }
INLINE int __hsposix_SIG_UNBLOCK() { return SIG_UNBLOCK; }
INLINE int __hsposix_SIG_SETMASK() { return SIG_SETMASK; }
+
#endif /* mingw32_TARGET_OS */
// These are wrapped because on some OSs (eg. Linux) they are
INLINE int __hscore_CSIDL_PERSONAL() { return CSIDL_PERSONAL; }
#endif
+/* ToDo: write a feature test that doesn't assume 'environ' to
+ * be in scope at link-time. */
+extern char** environ;
+INLINE char **__hscore_environ() { return environ; }
+
#endif /* __HSBASE_H__ */