* 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:
naruse 2015-04-23 23:41:16 +00:00
Родитель 9892a4b1ae
Коммит 7bf5ba1b49
3 изменённых файлов: 15 добавлений и 236 удалений

Просмотреть файл

@ -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

Просмотреть файл

@ -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);