summaryrefslogtreecommitdiff
path: root/include/ruby/missing.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/ruby/missing.h')
-rw-r--r--include/ruby/missing.h268
1 files changed, 57 insertions, 211 deletions
diff --git a/include/ruby/missing.h b/include/ruby/missing.h
index aea6c9088d..62d65b0aff 100644
--- a/include/ruby/missing.h
+++ b/include/ruby/missing.h
@@ -1,76 +1,37 @@
-#ifndef RUBY_MISSING_H /*-*-C++-*-vi:se ft=cpp:*/
-#define RUBY_MISSING_H 1
-/**
- * @author $Author$
- * @date Sat May 11 23:46:03 JST 2002
- * @copyright This file is a part of the programming language Ruby.
- * Permission is hereby granted, to either redistribute and/or
- * modify this file, provided that the conditions mentioned in the
- * file COPYING are met. Consult the file for details.
- * @brief Prototype for *.c in ./missing, and for missing timeval struct.
- */
-#include "ruby/internal/config.h"
-
-#ifdef STDC_HEADERS
-# include <stddef.h>
-#endif
-
-#if defined(__cplusplus)
-# include <cmath>
-#else
-# include <math.h> /* for INFINITY and NAN */
-#endif
-
-#ifdef RUBY_ALTERNATIVE_MALLOC_HEADER
-# include RUBY_ALTERNATIVE_MALLOC_HEADER
-#endif
-
-#if defined(HAVE_TIME_H)
-# include <time.h>
-#endif
-
-#if defined(HAVE_SYS_TIME_H)
-# include <sys/time.h>
-#endif
+/************************************************
-#ifdef HAVE_SYS_STAT_H
-# include <sys/stat.h>
-#endif
+ missing.h - prototype for *.c in ./missing, and
+ for missing timeval struct
-#ifdef HAVE_UNISTD_H
-# include <unistd.h>
-#endif
+ $Author$
+ created at: Sat May 11 23:46:03 JST 2002
-#ifdef HAVE_STDIO_H
-# include <stdio.h>
-#endif
+************************************************/
-#ifdef HAVE_IEEEFP_H
-# include <ieeefp.h>
-#endif
-
-#include "ruby/internal/dllexport.h"
-#include "ruby/internal/attr/format.h"
+#ifndef RUBY_MISSING_H
+#define RUBY_MISSING_H 1
-#ifndef M_PI
-# define M_PI 3.14159265358979323846
+#if defined(__cplusplus)
+extern "C" {
+#if 0
+} /* satisfy cc-mode */
#endif
-#ifndef M_PI_2
-# define M_PI_2 (M_PI/2)
#endif
-#if !defined(HAVE_STRUCT_TIMEVAL)
+#if defined(HAVE_SYS_TIME_H)
+# include <sys/time.h>
+#elif !defined(_WIN32)
+# define time_t long
struct timeval {
time_t tv_sec; /* seconds */
long tv_usec; /* microseconds */
};
-#endif /* HAVE_STRUCT_TIMEVAL */
+#endif
+#if defined(HAVE_SYS_TYPES_H)
+# include <sys/types.h>
+#endif
#if !defined(HAVE_STRUCT_TIMESPEC)
-/* :BEWARE: @shyouhei warns that IT IS A WRONG IDEA to define our own version
- * of struct timespec here. `clock_gettime` is a system call, and your kernel
- * could expect something other than just `long` (results stack smashing if
- * that happens). See also https://ewontfix.com/19/ */
struct timespec {
time_t tv_sec; /* seconds */
long tv_nsec; /* nanoseconds */
@@ -84,7 +45,9 @@ struct timezone {
};
#endif
-RBIMPL_SYMBOL_EXPORT_BEGIN()
+#ifndef RUBY_EXTERN
+#define RUBY_EXTERN extern
+#endif
#ifndef HAVE_ACOSH
RUBY_EXTERN double acosh(double);
@@ -96,12 +59,16 @@ RUBY_EXTERN double atanh(double);
RUBY_EXTERN char *crypt(const char *, const char *);
#endif
+#ifndef HAVE_DUP2
+RUBY_EXTERN int dup2(int, int);
+#endif
+
#ifndef HAVE_EACCESS
RUBY_EXTERN int eaccess(const char*, int);
#endif
-#ifndef HAVE_ROUND
-RUBY_EXTERN double round(double); /* numeric.c */
+#ifndef HAVE_FINITE
+RUBY_EXTERN int finite(double);
#endif
#ifndef HAVE_FLOCK
@@ -135,42 +102,20 @@ RUBY_EXTERN double lgamma_r(double, int *);
RUBY_EXTERN double cbrt(double);
#endif
-#if !defined(INFINITY) || !defined(NAN)
-union bytesequence4_or_float {
- unsigned char bytesequence[4];
- float float_value;
-};
-#endif
-
-#ifndef INFINITY
-/** @internal */
-RUBY_EXTERN const union bytesequence4_or_float rb_infinity;
-# define INFINITY (rb_infinity.float_value)
-# define USE_RB_INFINITY 1
-#endif
-
-#ifndef NAN
-/** @internal */
-RUBY_EXTERN const union bytesequence4_or_float rb_nan;
-# define NAN (rb_nan.float_value)
-# define USE_RB_NAN 1
-#endif
-
-#ifndef HUGE_VAL
-# define HUGE_VAL ((double)INFINITY)
-#endif
-
-#ifndef HAVE_FINITE
-# define HAVE_FINITE 1
-# define finite(x) isfinite(x)
+#ifndef isinf
+# ifndef HAVE_ISINF
+# if defined(HAVE_FINITE) && defined(HAVE_ISNAN)
+# define isinf(x) (!finite(x) && !isnan(x))
+# else
+RUBY_EXTERN int isinf(double);
+# endif
+# endif
#endif
-#ifndef HAVE_NAN
-RUBY_EXTERN double nan(const char *);
-#endif
-
-#ifndef HAVE_NEXTAFTER
-RUBY_EXTERN double nextafter(double x, double y);
+#ifndef isnan
+# ifndef HAVE_ISNAN
+RUBY_EXTERN int isnan(double);
+# endif
#endif
/*
@@ -202,6 +147,12 @@ RUBY_EXTERN char *strerror(int);
RUBY_EXTERN char *strstr(const char *, const char *);
#endif
+/*
+#ifndef HAVE_STRTOL
+RUBY_EXTERN long strtol(const char *, char **, int);
+#endif
+*/
+
#ifndef HAVE_STRLCPY
RUBY_EXTERN size_t strlcpy(char *, const char*, size_t);
#endif
@@ -210,133 +161,28 @@ RUBY_EXTERN size_t strlcpy(char *, const char*, size_t);
RUBY_EXTERN size_t strlcat(char *, const char*, size_t);
#endif
+#ifndef HAVE_SIGNBIT
+RUBY_EXTERN int signbit(double x);
+#endif
+
#ifndef HAVE_FFS
RUBY_EXTERN int ffs(int);
#endif
#ifdef BROKEN_CLOSE
-# include <sys/types.h>
-# include <sys/socket.h>
+#include <sys/types.h>
+#include <sys/socket.h>
RUBY_EXTERN int ruby_getpeername(int, struct sockaddr *, socklen_t *);
RUBY_EXTERN int ruby_getsockname(int, struct sockaddr *, socklen_t *);
RUBY_EXTERN int ruby_shutdown(int, int);
RUBY_EXTERN int ruby_close(int);
#endif
-#ifndef HAVE_SETPROCTITLE
-RBIMPL_ATTR_FORMAT(RBIMPL_PRINTF_FORMAT, 1, 2)
-RUBY_EXTERN void setproctitle(const char *fmt, ...);
-#endif
-
-#ifdef HAVE_EXPLICIT_BZERO
-# /* Take that. */
-#elif defined(SecureZeroMemory)
-# define explicit_bzero(b, len) SecureZeroMemory(b, len)
-#else
-RUBY_EXTERN void explicit_bzero(void *b, size_t len);
-#endif
-
-#ifndef HAVE_TZSET
-RUBY_EXTERN void tzset(void);
-#endif
-
-#ifndef HAVE_POSIX_MADVISE
-RUBY_EXTERN int posix_madvise(void *, size_t, int);
-#endif
-
-#ifndef HAVE_GETEUID
-RUBY_EXTERN rb_uid_t geteuid(void);
-#endif
-
-#ifndef HAVE_GETUID
-RUBY_EXTERN rb_uid_t getuid(void);
-#endif
-
-#ifndef HAVE_GETEGID
-RUBY_EXTERN rb_gid_t getegid(void);
-#endif
-
-#ifndef HAVE_GETGID
-RUBY_EXTERN rb_gid_t getgid(void);
-#endif
-
-#ifndef HAVE_GETLOGIN
-RUBY_EXTERN char *getlogin(void);
-#endif
-
-#ifndef HAVE_GETPPID
-RUBY_EXTERN rb_pid_t getppid(void);
-#endif
-
-#ifndef HAVE_UMASK
-RUBY_EXTERN rb_mode_t umask(rb_mode_t);
-#endif
-
-#ifndef HAVE_CHMOD
-RUBY_EXTERN int chmod(const char *, rb_mode_t);
-#endif
-
-#ifndef HAVE_CHOWN
-RUBY_EXTERN int chown(const char *, rb_uid_t, rb_gid_t);
-#endif
-
-#ifndef HAVE_PCLOSE
-RUBY_EXTERN int pclose(FILE *);
-#endif
-
-#ifndef HAVE_POPEN
-RUBY_EXTERN FILE *popen(const char *, const char *);
-#endif
-
-#ifndef HAVE_PIPE
-RUBY_EXTERN int pipe(int [2]);
-#endif
-
-#ifndef HAVE_DUP
-RUBY_EXTERN int dup(int);
-#endif
-
-#ifndef HAVE_DUP2
-RUBY_EXTERN int dup2(int, int);
-#endif
-
-#ifndef HAVE_KILL
-RUBY_EXTERN int kill(rb_pid_t, int);
-#endif
-
-#ifndef HAVE_EXECL
-RUBY_EXTERN int execl(const char *, const char *, ...);
-#endif
-
-#ifndef HAVE_EXECLE
-RUBY_EXTERN int execle(const char *, const char *, ...);
-#endif
-
-#ifndef HAVE_EXECV
-RUBY_EXTERN int execv(const char *, char *const []);
-#endif
-
-#ifndef HAVE_EXECVE
-RUBY_EXTERN int execve(const char *, char *const [], char *const []);
-#endif
-
-#ifndef HAVE_SHUTDOWN
-RUBY_EXTERN int shutdown(int, int);
-#endif
-
-#ifndef HAVE_SYSTEM
-RUBY_EXTERN int system(const char *);
-#endif
-
-#ifndef WNOHANG
-# define WNOHANG 0
+#if defined(__cplusplus)
+#if 0
+{ /* satisfy cc-mode */
#endif
-
-#ifndef HAVE_WAITPID
-# define HAVE_WAITPID 1
-RUBY_EXTERN rb_pid_t waitpid(rb_pid_t, int *, int);
+} /* extern "C" { */
#endif
-RBIMPL_SYMBOL_EXPORT_END()
-
#endif /* RUBY_MISSING_H */