|
- diff -Naur Python-3.8.0-orig/Include/iscygpty.h Python-3.8.0/Include/iscygpty.h
- --- Python-3.8.0-orig/Include/iscygpty.h 1970-01-01 03:00:00.000000000 +0300
- +++ Python-3.8.0/Include/iscygpty.h 2019-10-22 10:04:39.461927600 +0300
- @@ -0,0 +1,41 @@
- +/*
- + * iscygpty.h -- part of ptycheck
- + * https://github.com/k-takata/ptycheck
- + *
- + * Copyright (c) 2015-2017 K.Takata
- + *
- + * You can redistribute it and/or modify it under the terms of either
- + * the MIT license (as described below) or the Vim license.
- + *
- + * Permission is hereby granted, free of charge, to any person obtaining
- + * a copy of this software and associated documentation files (the
- + * "Software"), to deal in the Software without restriction, including
- + * without limitation the rights to use, copy, modify, merge, publish,
- + * distribute, sublicense, and/or sell copies of the Software, and to
- + * permit persons to whom the Software is furnished to do so, subject to
- + * the following conditions:
- + *
- + * The above copyright notice and this permission notice shall be
- + * included in all copies or substantial portions of the Software.
- + *
- + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- + * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
- + * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- + * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- + * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- + */
- +
- +#ifndef _ISCYGPTY_H
- +#define _ISCYGPTY_H
- +
- +#ifdef _WIN32
- +int is_cygpty(int fd);
- +int is_cygpty_used(void);
- +#else
- +#define is_cygpty(fd) 0
- +#define is_cygpty_used() 0
- +#endif
- +
- +#endif /* _ISCYGPTY_H */
- diff -Naur Python-3.8.0-orig/Makefile.pre.in Python-3.8.0/Makefile.pre.in
- --- Python-3.8.0-orig/Makefile.pre.in 2019-10-22 10:04:25.063102300 +0300
- +++ Python-3.8.0/Makefile.pre.in 2019-10-22 10:04:39.867528300 +0300
- @@ -346,6 +346,7 @@
- Python/import.o \
- Python/importdl.o \
- Python/initconfig.o \
- + Python/iscygpty.o \
- Python/marshal.o \
- Python/modsupport.o \
- Python/mysnprintf.o \
- @@ -1011,6 +1012,7 @@
- $(srcdir)/Include/import.h \
- $(srcdir)/Include/interpreteridobject.h \
- $(srcdir)/Include/intrcheck.h \
- + $(srcdir)/Include/iscygpty.h \
- $(srcdir)/Include/iterobject.h \
- $(srcdir)/Include/listobject.h \
- $(srcdir)/Include/longintrepr.h \
- diff -Naur Python-3.8.0-orig/Modules/_io/fileio.c Python-3.8.0/Modules/_io/fileio.c
- --- Python-3.8.0-orig/Modules/_io/fileio.c 2019-10-14 16:34:47.000000000 +0300
- +++ Python-3.8.0/Modules/_io/fileio.c 2019-10-22 10:04:40.273129000 +0300
- @@ -18,6 +18,7 @@
- #endif
- #include <stddef.h> /* For offsetof */
- #include "_iomodule.h"
- +#include "iscygpty.h"
-
- /*
- * Known likely problems:
- @@ -1119,7 +1120,7 @@
- return err_closed();
- Py_BEGIN_ALLOW_THREADS
- _Py_BEGIN_SUPPRESS_IPH
- - res = isatty(self->fd);
- + res = isatty(self->fd) || is_cygpty(self->fd);
- _Py_END_SUPPRESS_IPH
- Py_END_ALLOW_THREADS
- return PyBool_FromLong(res);
- diff -Naur Python-3.8.0-orig/Modules/main.c Python-3.8.0/Modules/main.c
- --- Python-3.8.0-orig/Modules/main.c 2019-10-14 16:34:47.000000000 +0300
- +++ Python-3.8.0/Modules/main.c 2019-10-22 10:04:41.068730400 +0300
- @@ -5,6 +5,7 @@
- #include "pycore_pylifecycle.h"
- #include "pycore_pymem.h"
- #include "pycore_pystate.h"
- +#include "iscygpty.h"
-
- #ifdef __FreeBSD__
- # include <fenv.h> /* fedisableexcept() */
- @@ -103,7 +104,7 @@
- static int
- stdin_is_interactive(const PyConfig *config)
- {
- - return (isatty(fileno(stdin)) || config->interactive);
- + return (isatty(fileno(stdin)) || config->interactive || is_cygpty(fileno(stdin)));
- }
-
-
- diff -Naur Python-3.8.0-orig/Modules/posixmodule.c Python-3.8.0/Modules/posixmodule.c
- --- Python-3.8.0-orig/Modules/posixmodule.c 2019-10-22 10:02:48.171332100 +0300
- +++ Python-3.8.0/Modules/posixmodule.c 2019-10-22 10:04:41.489931200 +0300
- @@ -34,6 +34,7 @@
- FSCTL_GET_REPARSE_POINT is not exported with WIN32_LEAN_AND_MEAN. */
- # include <windows.h>
- #endif
- +#include "iscygpty.h"
-
- #include "pycore_ceval.h" /* _PyEval_ReInitThreads() */
- #include "pycore_pystate.h" /* _PyRuntime */
- @@ -9258,7 +9259,7 @@
- {
- int return_value;
- _Py_BEGIN_SUPPRESS_IPH
- - return_value = isatty(fd);
- + return_value = isatty(fd) || is_cygpty(fd);
- _Py_END_SUPPRESS_IPH
- return return_value;
- }
- diff -Naur Python-3.8.0-orig/Python/frozenmain.c Python-3.8.0/Python/frozenmain.c
- --- Python-3.8.0-orig/Python/frozenmain.c 2019-10-14 16:34:47.000000000 +0300
- +++ Python-3.8.0/Python/frozenmain.c 2019-10-22 10:04:41.895531900 +0300
- @@ -4,6 +4,7 @@
- #include "Python.h"
- #include "pycore_pystate.h"
- #include <locale.h>
- +#include "iscygpty.h"
-
- #ifdef MS_WINDOWS
- extern void PyWinFreeze_ExeInit(void);
- @@ -107,7 +108,7 @@
- else
- sts = 0;
-
- - if (inspect && isatty((int)fileno(stdin)))
- + if (inspect && (isatty((int)fileno(stdin)) || is_cygpty((int)fileno(stdin))))
- sts = PyRun_AnyFile(stdin, "<stdin>") != 0;
-
- #ifdef MS_WINDOWS
- diff -Naur Python-3.8.0-orig/Python/iscygpty.c Python-3.8.0/Python/iscygpty.c
- --- Python-3.8.0-orig/Python/iscygpty.c 1970-01-01 03:00:00.000000000 +0300
- +++ Python-3.8.0/Python/iscygpty.c 2019-10-22 10:04:42.301132600 +0300
- @@ -0,0 +1,185 @@
- +/*
- + * iscygpty.c -- part of ptycheck
- + * https://github.com/k-takata/ptycheck
- + *
- + * Copyright (c) 2015-2017 K.Takata
- + *
- + * You can redistribute it and/or modify it under the terms of either
- + * the MIT license (as described below) or the Vim license.
- + *
- + * Permission is hereby granted, free of charge, to any person obtaining
- + * a copy of this software and associated documentation files (the
- + * "Software"), to deal in the Software without restriction, including
- + * without limitation the rights to use, copy, modify, merge, publish,
- + * distribute, sublicense, and/or sell copies of the Software, and to
- + * permit persons to whom the Software is furnished to do so, subject to
- + * the following conditions:
- + *
- + * The above copyright notice and this permission notice shall be
- + * included in all copies or substantial portions of the Software.
- + *
- + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- + * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
- + * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- + * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- + * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- + */
- +
- +#ifdef _WIN32
- +
- +#include <ctype.h>
- +#include <io.h>
- +#include <wchar.h>
- +#include <windows.h>
- +
- +#ifdef USE_FILEEXTD
- +/* VC 7.1 or earlier doesn't support SAL. */
- +# if !defined(_MSC_VER) || (_MSC_VER < 1400)
- +# define __out
- +# define __in
- +# define __in_opt
- +# endif
- +/* Win32 FileID API Library:
- + * http://www.microsoft.com/en-us/download/details.aspx?id=22599
- + * Needed for WinXP. */
- +# include <fileextd.h>
- +#else /* USE_FILEEXTD */
- +/* VC 8 or earlier. */
- +# if defined(_MSC_VER) && (_MSC_VER < 1500)
- +# ifdef ENABLE_STUB_IMPL
- +# define STUB_IMPL
- +# else
- +# error "Win32 FileID API Library is required for VC2005 or earlier."
- +# endif
- +# endif
- +#endif /* USE_FILEEXTD */
- +
- +
- +#include "iscygpty.h"
- +
- +//#define USE_DYNFILEID
- +#ifdef USE_DYNFILEID
- +typedef BOOL (WINAPI *pfnGetFileInformationByHandleEx)(
- + HANDLE hFile,
- + FILE_INFO_BY_HANDLE_CLASS FileInformationClass,
- + LPVOID lpFileInformation,
- + DWORD dwBufferSize
- +);
- +static pfnGetFileInformationByHandleEx pGetFileInformationByHandleEx = NULL;
- +
- +# ifndef USE_FILEEXTD
- +static BOOL WINAPI stub_GetFileInformationByHandleEx(
- + HANDLE hFile,
- + FILE_INFO_BY_HANDLE_CLASS FileInformationClass,
- + LPVOID lpFileInformation,
- + DWORD dwBufferSize
- + )
- +{
- + return FALSE;
- +}
- +# endif
- +
- +static void setup_fileid_api(void)
- +{
- + if (pGetFileInformationByHandleEx != NULL) {
- + return;
- + }
- + pGetFileInformationByHandleEx = (pfnGetFileInformationByHandleEx)
- + GetProcAddress(GetModuleHandle(TEXT("kernel32.dll")),
- + "GetFileInformationByHandleEx");
- + if (pGetFileInformationByHandleEx == NULL) {
- +# ifdef USE_FILEEXTD
- + pGetFileInformationByHandleEx = GetFileInformationByHandleEx;
- +# else
- + pGetFileInformationByHandleEx = stub_GetFileInformationByHandleEx;
- +# endif
- + }
- +}
- +#else
- +# define pGetFileInformationByHandleEx GetFileInformationByHandleEx
- +# define setup_fileid_api()
- +#endif
- +
- +
- +#define is_wprefix(s, prefix) \
- + (wcsncmp((s), (prefix), sizeof(prefix) / sizeof(WCHAR) - 1) == 0)
- +
- +/* Check if the fd is a cygwin/msys's pty. */
- +int is_cygpty(int fd)
- +{
- +#ifdef STUB_IMPL
- + return 0;
- +#else
- + HANDLE h;
- + int size = sizeof(FILE_NAME_INFO) + sizeof(WCHAR) * (MAX_PATH - 1);
- + FILE_NAME_INFO *nameinfo;
- + WCHAR *p = NULL;
- +
- + setup_fileid_api();
- +
- + h = (HANDLE) _get_osfhandle(fd);
- + if (h == INVALID_HANDLE_VALUE) {
- + return 0;
- + }
- + /* Cygwin/msys's pty is a pipe. */
- + if (GetFileType(h) != FILE_TYPE_PIPE) {
- + return 0;
- + }
- + nameinfo = malloc(size + sizeof(WCHAR));
- + if (nameinfo == NULL) {
- + return 0;
- + }
- + /* Check the name of the pipe:
- + * '\{cygwin,msys}-XXXXXXXXXXXXXXXX-ptyN-{from,to}-master' */
- + if (pGetFileInformationByHandleEx(h, FileNameInfo, nameinfo, size)) {
- + nameinfo->FileName[nameinfo->FileNameLength / sizeof(WCHAR)] = L'\0';
- + p = nameinfo->FileName;
- + if (is_wprefix(p, L"\\cygwin-")) { /* Cygwin */
- + p += 8;
- + } else if (is_wprefix(p, L"\\msys-")) { /* MSYS and MSYS2 */
- + p += 6;
- + } else {
- + p = NULL;
- + }
- + if (p != NULL) {
- + while (*p && isxdigit(*p)) /* Skip 16-digit hexadecimal. */
- + ++p;
- + if (is_wprefix(p, L"-pty")) {
- + p += 4;
- + } else {
- + p = NULL;
- + }
- + }
- + if (p != NULL) {
- + while (*p && isdigit(*p)) /* Skip pty number. */
- + ++p;
- + if (is_wprefix(p, L"-from-master")) {
- + //p += 12;
- + } else if (is_wprefix(p, L"-to-master")) {
- + //p += 10;
- + } else {
- + p = NULL;
- + }
- + }
- + }
- + free(nameinfo);
- + return (p != NULL);
- +#endif /* STUB_IMPL */
- +}
- +
- +/* Check if at least one cygwin/msys pty is used. */
- +int is_cygpty_used(void)
- +{
- + int fd, ret = 0;
- +
- + for (fd = 0; fd < 3; fd++) {
- + ret |= is_cygpty(fd);
- + }
- + return ret;
- +}
- +
- +#endif /* _WIN32 */
- +
- +/* vim: set ts=4 sw=4: */
- diff -Naur Python-3.8.0-orig/Python/pylifecycle.c Python-3.8.0/Python/pylifecycle.c
- --- Python-3.8.0-orig/Python/pylifecycle.c 2019-10-14 16:34:47.000000000 +0300
- +++ Python-3.8.0/Python/pylifecycle.c 2019-10-22 10:04:42.691133300 +0300
- @@ -24,6 +24,7 @@
- #include "ast.h"
- #include "marshal.h"
- #include "osdefs.h"
- +#include "iscygpty.h"
- #include <locale.h>
-
- #ifdef HAVE_SIGNAL_H
- @@ -2349,7 +2350,7 @@
- int
- Py_FdIsInteractive(FILE *fp, const char *filename)
- {
- - if (isatty((int)fileno(fp)))
- + if (isatty((int)fileno(fp)) || is_cygpty((int)fileno(fp)))
- return 1;
- if (!Py_InteractiveFlag)
- return 0;
- --- Python-3.8.7/Python/bltinmodule.c.orig 2020-12-21 17:25:24.000000000 +0100
- +++ Python-3.8.7/Python/bltinmodule.c 2021-01-06 16:50:48.899457200 +0100
- @@ -1,6 +1,7 @@
- /* Built-in functions */
-
- #include "Python.h"
- +#include "iscygpty.h"
- #include <ctype.h>
- #include "ast.h"
- #undef Yield /* undefine macro conflicting with <winbase.h> */
- @@ -1980,7 +1981,7 @@
- Py_DECREF(tmp);
- if (fd < 0 && PyErr_Occurred())
- return NULL;
- - tty = fd == fileno(stdin) && isatty(fd);
- + tty = fd == fileno(stdin) && (isatty(fd) || is_cygpty(fd));
- }
- if (tty) {
- tmp = _PyObject_CallMethodId(fout, &PyId_fileno, NULL);
- @@ -1993,7 +1994,7 @@
- Py_DECREF(tmp);
- if (fd < 0 && PyErr_Occurred())
- return NULL;
- - tty = fd == fileno(stdout) && isatty(fd);
- + tty = fd == fileno(stdout) && (isatty(fd) || is_cygpty(fd));
- }
- }
-
- --- Python-3.8.7/Objects/fileobject.c.orig 2020-12-21 17:25:24.000000000 +0100
- +++ Python-3.8.7/Objects/fileobject.c 2021-01-06 16:51:19.605061600 +0100
- @@ -2,6 +2,7 @@
-
- #define PY_SSIZE_T_CLEAN
- #include "Python.h"
- +#include "iscygpty.h"
- #include "pycore_pystate.h"
-
- #if defined(HAVE_GETC_UNLOCKED) && !defined(_Py_MEMORY_SANITIZER)
- @@ -434,7 +435,7 @@
- }
-
- Py_BEGIN_ALLOW_THREADS
- - res = isatty(self->fd);
- + res = isatty(self->fd) || is_cygpty(self->fd);
- Py_END_ALLOW_THREADS
-
- return PyBool_FromLong(res);
- --- Python-3.8.7/Python/fileutils.c.orig 2020-12-21 17:25:24.000000000 +0100
- +++ Python-3.8.7/Python/fileutils.c 2021-01-06 16:50:56.153853200 +0100
- @@ -1,4 +1,5 @@
- #include "Python.h"
- +#include "iscygpty.h"
- #include "pycore_fileutils.h"
- #include "osdefs.h"
- #include <locale.h>
- @@ -59,7 +60,7 @@
- #endif
- int valid;
- _Py_BEGIN_SUPPRESS_IPH
- - valid = isatty(fd);
- + valid = isatty(fd) || is_cygpty(fd);
- _Py_END_SUPPRESS_IPH
- if (!valid)
- Py_RETURN_NONE;
|