X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=support%2Fmph.h;h=0c8b37fdd93075a090e5ccb9ab967da059d2a00a;hb=569026428aa0d2db5167f63f51abc2819d78d631;hp=49a5e9781fcfd121a5998b6adf55b6bc79ad45ef;hpb=699e59742843044f6efa1726b7cb64f19d909e64;p=mono.git diff --git a/support/mph.h b/support/mph.h index 49a5e9781fc..0c8b37fdd93 100644 --- a/support/mph.h +++ b/support/mph.h @@ -17,6 +17,9 @@ * * See the typedefs for type size assumptions. These typedefs *must* be kept * in sync with the types used in Mono.Posix.dll. + * + * See also: + * http://developer.apple.com/documentation/Darwin/Reference/ManPages/ */ #ifndef INC_mph_H @@ -26,16 +29,28 @@ #include /* LONG_MAX, ULONG_MAX */ #include /* for ERANGE */ -#include /* for g* types, etc. */ +#include /* for g* types, etc. */ #ifdef HAVE_STDINT_H #include /* for SIZE_MAX */ #endif -#if __APPLE__ || __BSD__ +#include "map-icalls.h" + +#if __APPLE__ || __BSD__ || __FreeBSD__ #define MPH_ON_BSD #endif +#ifdef __GNUC__ +#define MPH_INTERNAL __attribute__((visibility("hidden"))) +#else +#define MPH_INTERNAL +#endif + +#if defined (PLATFORM_WIN32) && !defined (EOVERFLOW) +#define EOVERFLOW 75 +#endif /* def PLATFORM_WIN32 && ndef EOVERFLOW */ + typedef gint64 mph_blkcnt_t; typedef gint64 mph_blksize_t; typedef guint64 mph_dev_t; @@ -49,6 +64,8 @@ typedef guint32 mph_gid_t; typedef guint32 mph_uid_t; typedef gint64 mph_time_t; typedef gint64 mph_clock_t; +typedef guint64 mph_fsblkcnt_t; +typedef guint64 mph_fsfilcnt_t; #ifdef HAVE_LARGE_FILE_SUPPORT #define MPH_OFF_T_MAX G_MAXINT64 @@ -93,8 +110,13 @@ typedef gint64 mph_clock_t; #define mph_return_val_if_size_t_overflow(var, ret) \ _mph_return_val_if_cb_(var, ret, mph_have_size_t_overflow) +#define mph_return_val_if_ssize_t_overflow(var, ret) \ + _mph_return_val_if_cb_(var, ret, mph_have_long_overflow) + #define mph_return_if_size_t_overflow(var) mph_return_val_if_size_t_overflow(var, -1) +#define mph_return_if_ssize_t_overflow(var) mph_return_val_if_ssize_t_overflow(var, -1) + #define mph_have_off_t_overflow(var) \ (((var) < MPH_OFF_T_MIN) || ((var) > MPH_OFF_T_MAX)) @@ -126,6 +148,12 @@ recheck_range (int ret) return 0; } +MPH_INTERNAL char* +_mph_copy_structure_strings ( + void *to, const size_t *to_offsets, + const void *from, const size_t *from_offsets, + size_t num_strings); + #endif /* ndef INC_mph_H */ /*