mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* win32/win32.c: remove bcc related code.
* include/ruby/win32.h: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@50380 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
9892a4b1ae
commit
7bf5ba1b49
3 changed files with 15 additions and 236 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
Fri Apr 24 08:40:13 2015 NARUSE, Yui <naruse@ruby-lang.org>
|
||||||
|
|
||||||
|
* win32/win32.c: remove bcc related code.
|
||||||
|
|
||||||
|
* include/ruby/win32.h: ditto.
|
||||||
|
|
||||||
Fri Apr 24 08:21:07 2015 NARUSE, Yui <naruse@ruby-lang.org>
|
Fri Apr 24 08:21:07 2015 NARUSE, Yui <naruse@ruby-lang.org>
|
||||||
|
|
||||||
* win32/win32.c (rb_acrt_lowio_lock_fh): wrap _pioinfo(i)->lock.
|
* win32/win32.c (rb_acrt_lowio_lock_fh): wrap _pioinfo(i)->lock.
|
||||||
|
|
|
@ -77,7 +77,7 @@ extern "C++" { /* template without extern "C++" */
|
||||||
#endif
|
#endif
|
||||||
#include <io.h>
|
#include <io.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#if defined __MINGW32__ || __BORLANDC__ >= 0x0580
|
#if defined __MINGW32__
|
||||||
# include <stdint.h>
|
# include <stdint.h>
|
||||||
#else
|
#else
|
||||||
# if !defined(_INTPTR_T_DEFINED)
|
# if !defined(_INTPTR_T_DEFINED)
|
||||||
|
@ -163,28 +163,11 @@ typedef int clockid_t;
|
||||||
#define sleep(x) rb_w32_Sleep((x)*1000)
|
#define sleep(x) rb_w32_Sleep((x)*1000)
|
||||||
#define Sleep(msec) (void)rb_w32_Sleep(msec)
|
#define Sleep(msec) (void)rb_w32_Sleep(msec)
|
||||||
#define fstati64(fd,st) rb_w32_fstati64(fd,st)
|
#define fstati64(fd,st) rb_w32_fstati64(fd,st)
|
||||||
#ifdef __BORLANDC__
|
|
||||||
#define creat(p, m) _creat(p, m)
|
|
||||||
#define eof() _eof()
|
|
||||||
#define filelength(h) _filelength(h)
|
|
||||||
#define mktemp(t) _mktemp(t)
|
|
||||||
#define tell(h) _tell(h)
|
|
||||||
#define _open _sopen
|
|
||||||
#define sopen _sopen
|
|
||||||
#undef fopen
|
|
||||||
#define fopen(p, m) rb_w32_fopen(p, m)
|
|
||||||
#undef fdopen
|
|
||||||
#define fdopen(h, m) rb_w32_fdopen(h, m)
|
|
||||||
#undef fsopen
|
|
||||||
#define fsopen(p, m, sh) rb_w32_fsopen(p, m, sh)
|
|
||||||
#endif /* __BORLANDC__ */
|
|
||||||
|
|
||||||
#undef execv
|
#undef execv
|
||||||
#define execv(path,argv) rb_w32_aspawn(P_OVERLAY,path,argv)
|
#define execv(path,argv) rb_w32_aspawn(P_OVERLAY,path,argv)
|
||||||
#if !defined(__BORLANDC__)
|
|
||||||
#undef isatty
|
#undef isatty
|
||||||
#define isatty(h) rb_w32_isatty(h)
|
#define isatty(h) rb_w32_isatty(h)
|
||||||
#endif /* __BORLANDC__ */
|
|
||||||
|
|
||||||
#undef mkdir
|
#undef mkdir
|
||||||
#define mkdir(p, m) rb_w32_mkdir(p, m)
|
#define mkdir(p, m) rb_w32_mkdir(p, m)
|
||||||
|
@ -198,9 +181,7 @@ typedef int clockid_t;
|
||||||
#define off_t __int64
|
#define off_t __int64
|
||||||
#define stat stati64
|
#define stat stati64
|
||||||
#define fstat(fd,st) fstati64(fd,st)
|
#define fstat(fd,st) fstati64(fd,st)
|
||||||
#if defined(__BORLANDC__)
|
#if !defined(_MSC_VER) || RT_VER < 80
|
||||||
#define stati64(path, st) rb_w32_stati64(path, st)
|
|
||||||
#elif !defined(_MSC_VER) || RT_VER < 80
|
|
||||||
#define stati64 _stati64
|
#define stati64 _stati64
|
||||||
#ifndef _stati64
|
#ifndef _stati64
|
||||||
#define _stati64(path, st) rb_w32_stati64(path, st)
|
#define _stati64(path, st) rb_w32_stati64(path, st)
|
||||||
|
@ -334,9 +315,7 @@ extern int fcntl(int, int, ...);
|
||||||
extern int rb_w32_set_nonblock(int);
|
extern int rb_w32_set_nonblock(int);
|
||||||
extern rb_pid_t rb_w32_getpid(void);
|
extern rb_pid_t rb_w32_getpid(void);
|
||||||
extern rb_pid_t rb_w32_getppid(void);
|
extern rb_pid_t rb_w32_getppid(void);
|
||||||
#if !defined(__BORLANDC__)
|
|
||||||
extern int rb_w32_isatty(int);
|
extern int rb_w32_isatty(int);
|
||||||
#endif
|
|
||||||
extern int rb_w32_uchdir(const char *);
|
extern int rb_w32_uchdir(const char *);
|
||||||
extern int rb_w32_mkdir(const char *, int);
|
extern int rb_w32_mkdir(const char *, int);
|
||||||
extern int rb_w32_umkdir(const char *, int);
|
extern int rb_w32_umkdir(const char *, int);
|
||||||
|
@ -355,13 +334,6 @@ extern char rb_w32_fd_is_text(int);
|
||||||
extern int rb_w32_fstati64(int, struct stati64 *);
|
extern int rb_w32_fstati64(int, struct stati64 *);
|
||||||
extern int rb_w32_dup2(int, int);
|
extern int rb_w32_dup2(int, int);
|
||||||
|
|
||||||
#ifdef __BORLANDC__
|
|
||||||
extern off_t _lseeki64(int, off_t, int);
|
|
||||||
extern FILE *rb_w32_fopen(const char *, const char *);
|
|
||||||
extern FILE *rb_w32_fdopen(int, const char *);
|
|
||||||
extern FILE *rb_w32_fsopen(const char *, const char *, int);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <float.h>
|
#include <float.h>
|
||||||
|
|
||||||
#if defined _MSC_VER && _MSC_VER >= 1800 && defined INFINITY
|
#if defined _MSC_VER && _MSC_VER >= 1800 && defined INFINITY
|
||||||
|
@ -402,19 +374,6 @@ __declspec(dllimport) extern int finite(double);
|
||||||
#define S_IFIFO _S_IFIFO
|
#define S_IFIFO _S_IFIFO
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if 0 && defined __BORLANDC__
|
|
||||||
#undef S_ISDIR
|
|
||||||
#undef S_ISFIFO
|
|
||||||
#undef S_ISBLK
|
|
||||||
#undef S_ISCHR
|
|
||||||
#undef S_ISREG
|
|
||||||
#define S_ISDIR(m) (((unsigned short)(m) & S_IFMT) == S_IFDIR)
|
|
||||||
#define S_ISFIFO(m) (((unsigned short)(m) & S_IFMT) == S_IFIFO)
|
|
||||||
#define S_ISBLK(m) (((unsigned short)(m) & S_IFMT) == S_IFBLK)
|
|
||||||
#define S_ISCHR(m) (((unsigned short)(m) & S_IFMT) == S_IFCHR)
|
|
||||||
#define S_ISREG(m) (((unsigned short)(m) & S_IFMT) == S_IFREG)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined S_IRUSR && !defined __MINGW32__
|
#if !defined S_IRUSR && !defined __MINGW32__
|
||||||
#define S_IRUSR 0400
|
#define S_IRUSR 0400
|
||||||
#endif
|
#endif
|
||||||
|
|
200
win32/win32.c
200
win32/win32.c
|
@ -89,19 +89,12 @@ static char *w32_getenv(const char *name, UINT cp);
|
||||||
#undef setsockopt
|
#undef setsockopt
|
||||||
#undef dup2
|
#undef dup2
|
||||||
|
|
||||||
#if defined __BORLANDC__
|
#if RUBY_MSVCRT_VERSION >= 140
|
||||||
# define _filbuf _fgetc
|
# define _filbuf _fgetc_nolock
|
||||||
# define _flsbuf _fputc
|
# define _flsbuf _fputc_nolock
|
||||||
# define enough_to_get(n) (--(n) >= 0)
|
|
||||||
# define enough_to_put(n) (++(n) < 0)
|
|
||||||
#else
|
|
||||||
# if RUBY_MSVCRT_VERSION >= 140
|
|
||||||
# define _filbuf _fgetc_nolock
|
|
||||||
# define _flsbuf _fputc_nolock
|
|
||||||
# endif
|
|
||||||
# define enough_to_get(n) (--(n) >= 0)
|
|
||||||
# define enough_to_put(n) (--(n) >= 0)
|
|
||||||
#endif
|
#endif
|
||||||
|
#define enough_to_get(n) (--(n) >= 0)
|
||||||
|
#define enough_to_put(n) (--(n) >= 0)
|
||||||
|
|
||||||
#ifdef WIN32_DEBUG
|
#ifdef WIN32_DEBUG
|
||||||
#define Debug(something) something
|
#define Debug(something) something
|
||||||
|
@ -2245,20 +2238,6 @@ rb_w32_closedir(DIR *dirp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if (defined _MT || defined __MSVCRT__) && !defined __BORLANDC__
|
|
||||||
#define MSVCRT_THREADS
|
|
||||||
#endif
|
|
||||||
#ifdef MSVCRT_THREADS
|
|
||||||
# define MTHREAD_ONLY(x) x
|
|
||||||
# define STHREAD_ONLY(x)
|
|
||||||
#elif defined(__BORLANDC__)
|
|
||||||
# define MTHREAD_ONLY(x)
|
|
||||||
# define STHREAD_ONLY(x)
|
|
||||||
#else
|
|
||||||
# define MTHREAD_ONLY(x)
|
|
||||||
# define STHREAD_ONLY(x) x
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if RUBY_MSVCRT_VERSION >= 140
|
#if RUBY_MSVCRT_VERSION >= 140
|
||||||
typedef struct {
|
typedef struct {
|
||||||
union
|
union
|
||||||
|
@ -2290,10 +2269,8 @@ typedef struct {
|
||||||
intptr_t osfhnd; /* underlying OS file HANDLE */
|
intptr_t osfhnd; /* underlying OS file HANDLE */
|
||||||
char osfile; /* attributes of file (e.g., open in text mode?) */
|
char osfile; /* attributes of file (e.g., open in text mode?) */
|
||||||
char pipech; /* one char buffer for handles opened on pipes */
|
char pipech; /* one char buffer for handles opened on pipes */
|
||||||
#ifdef MSVCRT_THREADS
|
|
||||||
int lockinitflag;
|
int lockinitflag;
|
||||||
CRITICAL_SECTION lock;
|
CRITICAL_SECTION lock;
|
||||||
#endif
|
|
||||||
#if RUBY_MSVCRT_VERSION >= 80
|
#if RUBY_MSVCRT_VERSION >= 80
|
||||||
char textmode;
|
char textmode;
|
||||||
char pipech2[2];
|
char pipech2[2];
|
||||||
|
@ -2305,7 +2282,6 @@ typedef struct {
|
||||||
#define _CRTIMP __declspec(dllimport)
|
#define _CRTIMP __declspec(dllimport)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(__BORLANDC__)
|
|
||||||
EXTERN_C _CRTIMP ioinfo * __pioinfo[];
|
EXTERN_C _CRTIMP ioinfo * __pioinfo[];
|
||||||
static inline ioinfo* _pioinfo(int);
|
static inline ioinfo* _pioinfo(int);
|
||||||
|
|
||||||
|
@ -2314,8 +2290,8 @@ static inline ioinfo* _pioinfo(int);
|
||||||
#define _osfhnd(i) (_pioinfo(i)->osfhnd)
|
#define _osfhnd(i) (_pioinfo(i)->osfhnd)
|
||||||
#define _osfile(i) (_pioinfo(i)->osfile)
|
#define _osfile(i) (_pioinfo(i)->osfile)
|
||||||
#define _pipech(i) (_pioinfo(i)->pipech)
|
#define _pipech(i) (_pioinfo(i)->pipech)
|
||||||
#define rb_acrt_lowio_lock_fh(i) MTHREAD_ONLY(EnterCriticalSection(&_pioinfo(i)->lock))
|
#define rb_acrt_lowio_lock_fh(i) EnterCriticalSection(&_pioinfo(i)->lock)
|
||||||
#define rb_acrt_lowio_unlock_fh(i) MTHREAD_ONLY(LeaveCriticalSection(&_pioinfo(i)->lock))
|
#define rb_acrt_lowio_unlock_fh(i) LeaveCriticalSection(&_pioinfo(i)->lock)
|
||||||
|
|
||||||
#if RUBY_MSVCRT_VERSION >= 80
|
#if RUBY_MSVCRT_VERSION >= 80
|
||||||
static size_t pioinfo_extra = 0; /* workaround for VC++8 SP1 */
|
static size_t pioinfo_extra = 0; /* workaround for VC++8 SP1 */
|
||||||
|
@ -2339,9 +2315,6 @@ set_pioinfo_extra(void)
|
||||||
pioinfo_extra = 0;
|
pioinfo_extra = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
#define pioinfo_extra 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static inline ioinfo*
|
static inline ioinfo*
|
||||||
_pioinfo(int fd)
|
_pioinfo(int fd)
|
||||||
|
@ -2453,20 +2426,6 @@ init_stdhandle(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* License: Ruby's */
|
|
||||||
#ifdef __BORLANDC__
|
|
||||||
static int
|
|
||||||
rb_w32_open_osfhandle(intptr_t osfhandle, int flags)
|
|
||||||
{
|
|
||||||
int fd = _open_osfhandle(osfhandle, flags);
|
|
||||||
if (fd == -1) {
|
|
||||||
errno = EMFILE; /* too many open files */
|
|
||||||
_doserrno = 0L; /* not an OS error */
|
|
||||||
}
|
|
||||||
return fd;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#undef getsockopt
|
#undef getsockopt
|
||||||
|
|
||||||
/* License: Ruby's */
|
/* License: Ruby's */
|
||||||
|
@ -2502,15 +2461,6 @@ rb_w32_strerror(int e)
|
||||||
DWORD source = 0;
|
DWORD source = 0;
|
||||||
char *p;
|
char *p;
|
||||||
|
|
||||||
#if defined __BORLANDC__ && defined ENOTEMPTY // _sys_errlist is broken
|
|
||||||
switch (e) {
|
|
||||||
case ENAMETOOLONG:
|
|
||||||
return "Filename too long";
|
|
||||||
case ENOTEMPTY:
|
|
||||||
return "Directory not empty";
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (e < 0 || e > sys_nerr) {
|
if (e < 0 || e > sys_nerr) {
|
||||||
if (e < 0)
|
if (e < 0)
|
||||||
e = GetLastError();
|
e = GetLastError();
|
||||||
|
@ -5049,17 +4999,8 @@ rb_w32_fstat(int fd, struct stat *st)
|
||||||
int ret = fstat(fd, st);
|
int ret = fstat(fd, st);
|
||||||
|
|
||||||
if (ret) return ret;
|
if (ret) return ret;
|
||||||
#ifdef __BORLANDC__
|
|
||||||
st->st_mode &= ~(S_IWGRP | S_IWOTH);
|
|
||||||
#else
|
|
||||||
if (GetEnvironmentVariableW(L"TZ", NULL, 0) == 0 && GetLastError() == ERROR_ENVVAR_NOT_FOUND) return ret;
|
if (GetEnvironmentVariableW(L"TZ", NULL, 0) == 0 && GetLastError() == ERROR_ENVVAR_NOT_FOUND) return ret;
|
||||||
#endif
|
|
||||||
if (GetFileInformationByHandle((HANDLE)_get_osfhandle(fd), &info)) {
|
if (GetFileInformationByHandle((HANDLE)_get_osfhandle(fd), &info)) {
|
||||||
#ifdef __BORLANDC__
|
|
||||||
if (!(info.dwFileAttributes & FILE_ATTRIBUTE_READONLY)) {
|
|
||||||
st->st_mode |= S_IWUSR;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
st->st_atime = filetime_to_unixtime(&info.ftLastAccessTime);
|
st->st_atime = filetime_to_unixtime(&info.ftLastAccessTime);
|
||||||
st->st_mtime = filetime_to_unixtime(&info.ftLastWriteTime);
|
st->st_mtime = filetime_to_unixtime(&info.ftLastWriteTime);
|
||||||
st->st_ctime = filetime_to_unixtime(&info.ftCreationTime);
|
st->st_ctime = filetime_to_unixtime(&info.ftCreationTime);
|
||||||
|
@ -5074,15 +5015,10 @@ rb_w32_fstati64(int fd, struct stati64 *st)
|
||||||
struct stat tmp;
|
struct stat tmp;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
#ifndef __BORLANDC__
|
|
||||||
if (GetEnvironmentVariableW(L"TZ", NULL, 0) == 0 && GetLastError() == ERROR_ENVVAR_NOT_FOUND) return _fstati64(fd, st);
|
if (GetEnvironmentVariableW(L"TZ", NULL, 0) == 0 && GetLastError() == ERROR_ENVVAR_NOT_FOUND) return _fstati64(fd, st);
|
||||||
#endif
|
|
||||||
ret = fstat(fd, &tmp);
|
ret = fstat(fd, &tmp);
|
||||||
|
|
||||||
if (ret) return ret;
|
if (ret) return ret;
|
||||||
#ifdef __BORLANDC__
|
|
||||||
tmp.st_mode &= ~(S_IWGRP | S_IWOTH);
|
|
||||||
#endif
|
|
||||||
COPY_STAT(tmp, *st, +);
|
COPY_STAT(tmp, *st, +);
|
||||||
stati64_handle((HANDLE)_get_osfhandle(fd), st);
|
stati64_handle((HANDLE)_get_osfhandle(fd), st);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -5096,11 +5032,6 @@ stati64_handle(HANDLE h, struct stati64 *st)
|
||||||
DWORD attr = (DWORD)-1;
|
DWORD attr = (DWORD)-1;
|
||||||
|
|
||||||
if (GetFileInformationByHandle(h, &info)) {
|
if (GetFileInformationByHandle(h, &info)) {
|
||||||
#ifdef __BORLANDC__
|
|
||||||
if (!(info.dwFileAttributes & FILE_ATTRIBUTE_READONLY)) {
|
|
||||||
st->st_mode |= S_IWUSR;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
st->st_size = ((__int64)info.nFileSizeHigh << 32) | info.nFileSizeLow;
|
st->st_size = ((__int64)info.nFileSizeHigh << 32) | info.nFileSizeLow;
|
||||||
st->st_atime = filetime_to_unixtime(&info.ftLastAccessTime);
|
st->st_atime = filetime_to_unixtime(&info.ftLastAccessTime);
|
||||||
st->st_mtime = filetime_to_unixtime(&info.ftLastWriteTime);
|
st->st_mtime = filetime_to_unixtime(&info.ftLastWriteTime);
|
||||||
|
@ -5564,44 +5495,6 @@ rb_w32_ftruncate(int fd, off_t length)
|
||||||
return rb_chsize(h, length);
|
return rb_chsize(h, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __BORLANDC__
|
|
||||||
/* License: Ruby's */
|
|
||||||
off_t
|
|
||||||
_filelengthi64(int fd)
|
|
||||||
{
|
|
||||||
DWORD u, l;
|
|
||||||
int e;
|
|
||||||
|
|
||||||
l = GetFileSize((HANDLE)_get_osfhandle(fd), &u);
|
|
||||||
if (l == (DWORD)-1L && (e = GetLastError())) {
|
|
||||||
errno = map_errno(e);
|
|
||||||
return (off_t)-1;
|
|
||||||
}
|
|
||||||
return ((off_t)u << 32) | l;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* License: Ruby's */
|
|
||||||
off_t
|
|
||||||
_lseeki64(int fd, off_t offset, int whence)
|
|
||||||
{
|
|
||||||
long u, l;
|
|
||||||
int e;
|
|
||||||
HANDLE h = (HANDLE)_get_osfhandle(fd);
|
|
||||||
|
|
||||||
if (!h) {
|
|
||||||
errno = EBADF;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
u = (long)(offset >> 32);
|
|
||||||
if ((l = SetFilePointer(h, (long)offset, &u, whence)) == -1L &&
|
|
||||||
(e = GetLastError())) {
|
|
||||||
errno = map_errno(e);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
return ((off_t)u << 32) | l;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* License: Ruby's */
|
/* License: Ruby's */
|
||||||
static long
|
static long
|
||||||
filetime_to_clock(FILETIME *ft)
|
filetime_to_clock(FILETIME *ft)
|
||||||
|
@ -5645,22 +5538,6 @@ catch_interrupt(void)
|
||||||
RUBY_CRITICAL(rb_w32_wait_events(NULL, 0, 0));
|
RUBY_CRITICAL(rb_w32_wait_events(NULL, 0, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined __BORLANDC__
|
|
||||||
#undef read
|
|
||||||
/* License: Ruby's */
|
|
||||||
int
|
|
||||||
read(int fd, void *buf, size_t size)
|
|
||||||
{
|
|
||||||
int ret = _read(fd, buf, size);
|
|
||||||
if ((ret < 0) && (errno == EPIPE)) {
|
|
||||||
errno = 0;
|
|
||||||
ret = 0;
|
|
||||||
}
|
|
||||||
catch_interrupt();
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#undef fgetc
|
#undef fgetc
|
||||||
/* License: Ruby's */
|
/* License: Ruby's */
|
||||||
int
|
int
|
||||||
|
@ -5672,11 +5549,6 @@ rb_w32_getc(FILE* stream)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
c = _filbuf(stream);
|
c = _filbuf(stream);
|
||||||
#if defined __BORLANDC__
|
|
||||||
if ((c == EOF) && (errno == EPIPE)) {
|
|
||||||
clearerr(stream);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
catch_interrupt();
|
catch_interrupt();
|
||||||
}
|
}
|
||||||
return c;
|
return c;
|
||||||
|
@ -7274,7 +7146,6 @@ rb_w32_uchmod(const char *path, int mode)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(__BORLANDC__)
|
|
||||||
/* License: Ruby's */
|
/* License: Ruby's */
|
||||||
int
|
int
|
||||||
rb_w32_isatty(int fd)
|
rb_w32_isatty(int fd)
|
||||||
|
@ -7291,63 +7162,6 @@ rb_w32_isatty(int fd)
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
//
|
|
||||||
// Fix bcc32's stdio bug
|
|
||||||
//
|
|
||||||
|
|
||||||
#ifdef __BORLANDC__
|
|
||||||
/* License: Ruby's */
|
|
||||||
static int
|
|
||||||
too_many_files(void)
|
|
||||||
{
|
|
||||||
FILE *f;
|
|
||||||
for (f = _streams; f < _streams + _nfile; f++) {
|
|
||||||
if (f->fd < 0) return 0;
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#undef fopen
|
|
||||||
/* License: Ruby's */
|
|
||||||
FILE *
|
|
||||||
rb_w32_fopen(const char *path, const char *mode)
|
|
||||||
{
|
|
||||||
FILE *f = (errno = 0, fopen(path, mode));
|
|
||||||
if (f == NULL && errno == 0) {
|
|
||||||
if (too_many_files())
|
|
||||||
errno = EMFILE;
|
|
||||||
}
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* License: Ruby's */
|
|
||||||
FILE *
|
|
||||||
rb_w32_fdopen(int handle, const char *type)
|
|
||||||
{
|
|
||||||
FILE *f = (errno = 0, _fdopen(handle, (char *)type));
|
|
||||||
if (f == NULL && errno == 0) {
|
|
||||||
if (handle < 0)
|
|
||||||
errno = EBADF;
|
|
||||||
else if (too_many_files())
|
|
||||||
errno = EMFILE;
|
|
||||||
}
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* License: Ruby's */
|
|
||||||
FILE *
|
|
||||||
rb_w32_fsopen(const char *path, const char *mode, int shflags)
|
|
||||||
{
|
|
||||||
FILE *f = (errno = 0, _fsopen(path, mode, shflags));
|
|
||||||
if (f == NULL && errno == 0) {
|
|
||||||
if (too_many_files())
|
|
||||||
errno = EMFILE;
|
|
||||||
}
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_MSC_VER) && RUBY_MSVCRT_VERSION <= 60
|
#if defined(_MSC_VER) && RUBY_MSVCRT_VERSION <= 60
|
||||||
extern long _ftol(double);
|
extern long _ftol(double);
|
||||||
|
|
Loading…
Reference in a new issue