Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
8e9ebfd3
Kaydet (Commit)
8e9ebfd3
authored
Kas 22, 1997
tarafından
Guido van Rossum
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
os2 patch by Jeff Rush
üst
c0b93191
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
459 additions
and
28 deletions
+459
-28
osdefs.h
Include/osdefs.h
+1
-1
os.py
Lib/os.py
+12
-0
test_select.py
Lib/test/test_select.py
+1
-1
test_signal.py
Lib/test/test_signal.py
+2
-3
posixmodule.c
Modules/posixmodule.c
+252
-5
selectmodule.c
Modules/selectmodule.c
+5
-0
signalmodule.c
Modules/signalmodule.c
+5
-0
socketmodule.c
Modules/socketmodule.c
+116
-15
timemodule.c
Modules/timemodule.c
+21
-1
importdl.c
Python/importdl.c
+38
-0
thread.c
Python/thread.c
+4
-0
thread_os2.h
Python/thread_os2.h
+2
-2
No files found.
Include/osdefs.h
Dosyayı görüntüle @
8e9ebfd3
...
@@ -44,7 +44,7 @@ PERFORMANCE OF THIS SOFTWARE.
...
@@ -44,7 +44,7 @@ PERFORMANCE OF THIS SOFTWARE.
#define DELIM '\n'
#define DELIM '\n'
#endif
#endif
#if defined(MS_WINDOWS) || defined(__BORLANDC__) || defined(__WATCOMC__) ||
defined(__DJGPP
__)
#if defined(MS_WINDOWS) || defined(__BORLANDC__) || defined(__WATCOMC__) ||
defined(__DJGPP__) || defined(__TOS_OS2
__)
#define SEP '\\'
#define SEP '\\'
#define ALTSEP '/'
#define ALTSEP '/'
#define MAXPATHLEN 256
#define MAXPATHLEN 256
...
...
Lib/os.py
Dosyayı görüntüle @
8e9ebfd3
...
@@ -59,6 +59,18 @@ elif 'dos' in _names:
...
@@ -59,6 +59,18 @@ elif 'dos' in _names:
import
dospath
import
dospath
path
=
dospath
path
=
dospath
del
dospath
del
dospath
elif
'os2'
in
_names
:
name
=
'os2'
curdir
=
'.'
;
pardir
=
'..'
;
sep
=
'
\\
'
;
pathsep
=
';'
defpath
=
'.;C:
\\
bin'
from
os2
import
*
try
:
from
os2
import
_exit
except
ImportError
:
pass
import
ntpath
path
=
ntpath
del
ntpath
elif
'mac'
in
_names
:
elif
'mac'
in
_names
:
name
=
'mac'
name
=
'mac'
curdir
=
':'
;
pardir
=
'::'
;
sep
=
':'
;
pathsep
=
'
\n
'
curdir
=
':'
;
pardir
=
'::'
;
sep
=
':'
;
pathsep
=
'
\n
'
...
...
Lib/test/test_select.py
Dosyayı görüntüle @
8e9ebfd3
...
@@ -35,7 +35,7 @@ else:
...
@@ -35,7 +35,7 @@ else:
def
test
():
def
test
():
import
sys
import
sys
if
sys
.
platform
[:
3
]
in
(
'win'
,
'mac'
):
if
sys
.
platform
[:
3
]
in
(
'win'
,
'mac'
,
'os2'
):
if
verbose
:
if
verbose
:
print
"Can't test select easily on"
,
sys
.
platform
print
"Can't test select easily on"
,
sys
.
platform
return
return
...
...
Lib/test/test_signal.py
Dosyayı görüntüle @
8e9ebfd3
...
@@ -4,9 +4,8 @@ import signal
...
@@ -4,9 +4,8 @@ import signal
import
os
import
os
import
sys
import
sys
if
sys
.
platform
[:
3
]
==
'win'
:
if
sys
.
platform
[:
3
]
in
(
'win'
,
'os2'
):
raise
ImportError
,
"Can't test signal on Windows"
raise
ImportError
,
"Can't test signal on
%
s"
%
sys
.
platform
[:
3
]
if
verbose
:
if
verbose
:
x
=
'-x'
x
=
'-x'
...
...
Modules/posixmodule.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -46,10 +46,16 @@ standardized by the C Standard and the POSIX standard (a thinly\n\
...
@@ -46,10 +46,16 @@ standardized by the C Standard and the POSIX standard (a thinly\n\
disguised Unix interface). Refer to the library manual and
\n
\
disguised Unix interface). Refer to the library manual and
\n
\
corresponding Unix manual entries for more information on calls."
;
corresponding Unix manual entries for more information on calls."
;
#include "Python.h"
#include "Python.h"
#if defined(PYOS_OS2)
#define INCL_DOS
#define INCL_DOSERRORS
#define INCL_DOSPROCESS
#define INCL_NOPMAPI
#include <os2.h>
#endif
#include <sys/types.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/stat.h>
#ifdef HAVE_SYS_WAIT_H
#ifdef HAVE_SYS_WAIT_H
...
@@ -68,6 +74,24 @@ corresponding Unix manual entries for more information on calls.";
...
@@ -68,6 +74,24 @@ corresponding Unix manual entries for more information on calls.";
/* Various compilers have only certain posix functions */
/* Various compilers have only certain posix functions */
/* XXX Gosh I wish these were all moved into config.h */
/* XXX Gosh I wish these were all moved into config.h */
#if defined(PYCC_VACPP) && defined(PYOS_OS2)
#define HAVE_EXECV 1
#define HAVE_GETCWD 1
#define HAVE_SYSTEM 1
#define HAVE_WAIT 1
#define HAVE_KILL 1
#define HAVE_PIPE 1
#define HAVE_POPEN 1
// #define HAVE_FORK 1
// #define HAVE_GETEGID 1
// #define HAVE_GETEUID 1
// #define HAVE_GETGID 1
// #define HAVE_GETPPID 1
// #define HAVE_GETUID 1
// #define HAVE_OPENDIR 1
#include <process.h>
#else
#ifdef __WATCOMC__
/* Watcom compiler */
#ifdef __WATCOMC__
/* Watcom compiler */
#define HAVE_GETCWD 1
#define HAVE_GETCWD 1
#define HAVE_OPENDIR 1
#define HAVE_OPENDIR 1
...
@@ -121,6 +145,7 @@ corresponding Unix manual entries for more information on calls.";
...
@@ -121,6 +145,7 @@ corresponding Unix manual entries for more information on calls.";
#endif
/* _MSC_VER */
#endif
/* _MSC_VER */
#endif
/* __BORLANDC__ */
#endif
/* __BORLANDC__ */
#endif
/* ! __WATCOMC__ */
#endif
/* ! __WATCOMC__ */
#endif
/* ! __IBMC__ */
#ifndef _MSC_VER
#ifndef _MSC_VER
...
@@ -143,13 +168,22 @@ extern int pclose();
...
@@ -143,13 +168,22 @@ extern int pclose();
extern
int
lstat
();
extern
int
lstat
();
extern
int
symlink
();
extern
int
symlink
();
#else
/* !HAVE_UNISTD_H */
#else
/* !HAVE_UNISTD_H */
#if defined(PYCC_VACPP)
extern
int
mkdir
Py_PROTO
((
char
*
));
#else
#if defined(__WATCOMC__) || defined(_MSC_VER)
#if defined(__WATCOMC__) || defined(_MSC_VER)
extern
int
mkdir
Py_PROTO
((
const
char
*
));
extern
int
mkdir
Py_PROTO
((
const
char
*
));
#else
#else
extern
int
mkdir
Py_PROTO
((
const
char
*
,
mode_t
));
extern
int
mkdir
Py_PROTO
((
const
char
*
,
mode_t
));
#endif
#endif
#endif
#if defined(__IBMC__) || defined(__IBMCPP__)
extern
int
chdir
Py_PROTO
((
char
*
));
extern
int
rmdir
Py_PROTO
((
char
*
));
#else
extern
int
chdir
Py_PROTO
((
const
char
*
));
extern
int
chdir
Py_PROTO
((
const
char
*
));
extern
int
rmdir
Py_PROTO
((
const
char
*
));
extern
int
rmdir
Py_PROTO
((
const
char
*
));
#endif
extern
int
chmod
Py_PROTO
((
const
char
*
,
mode_t
));
extern
int
chmod
Py_PROTO
((
const
char
*
,
mode_t
));
extern
int
chown
Py_PROTO
((
const
char
*
,
uid_t
,
gid_t
));
extern
int
chown
Py_PROTO
((
const
char
*
,
uid_t
,
gid_t
));
extern
char
*
getcwd
Py_PROTO
((
char
*
,
int
));
extern
char
*
getcwd
Py_PROTO
((
char
*
,
int
));
...
@@ -310,7 +344,7 @@ posix_2str(args, func)
...
@@ -310,7 +344,7 @@ posix_2str(args, func)
Py_BEGIN_ALLOW_THREADS
Py_BEGIN_ALLOW_THREADS
res
=
(
*
func
)(
path1
,
path2
);
res
=
(
*
func
)(
path1
,
path2
);
Py_END_ALLOW_THREADS
Py_END_ALLOW_THREADS
if
(
res
<
0
)
if
(
res
!=
0
)
return
posix_error
();
return
posix_error
();
Py_INCREF
(
Py_None
);
Py_INCREF
(
Py_None
);
return
Py_None
;
return
Py_None
;
...
@@ -480,7 +514,7 @@ posix_listdir(self, args)
...
@@ -480,7 +514,7 @@ posix_listdir(self, args)
PyObject
*
self
;
PyObject
*
self
;
PyObject
*
args
;
PyObject
*
args
;
{
{
/* XXX Should redo this putting the
three
versions of opendir
/* XXX Should redo this putting the
(now four)
versions of opendir
in separate files instead of having them all here... */
in separate files instead of having them all here... */
#if defined(MS_WIN32) && !defined(HAVE_OPENDIR)
#if defined(MS_WIN32) && !defined(HAVE_OPENDIR)
...
@@ -600,6 +634,78 @@ posix_listdir(self, args)
...
@@ -600,6 +634,78 @@ posix_listdir(self, args)
return
d
;
return
d
;
#else
#if defined(PYOS_OS2)
#ifndef MAX_PATH
#define MAX_PATH CCHMAXPATH
#endif
char
*
name
,
*
pt
;
int
len
;
PyObject
*
d
,
*
v
;
char
namebuf
[
MAX_PATH
+
5
];
HDIR
hdir
=
1
;
ULONG
srchcnt
=
1
;
FILEFINDBUF3
ep
;
APIRET
rc
;
if
(
!
PyArg_Parse
(
args
,
"s#"
,
&
name
,
&
len
))
return
NULL
;
if
(
len
>=
MAX_PATH
)
{
PyErr_SetString
(
PyExc_ValueError
,
"path too long"
);
return
NULL
;
}
strcpy
(
namebuf
,
name
);
for
(
pt
=
namebuf
;
*
pt
;
pt
++
)
if
(
*
pt
==
'/'
)
*
pt
=
'\\'
;
if
(
namebuf
[
len
-
1
]
!=
'\\'
)
namebuf
[
len
++
]
=
'\\'
;
strcpy
(
namebuf
+
len
,
"*.*"
);
if
((
d
=
PyList_New
(
0
))
==
NULL
)
return
NULL
;
rc
=
DosFindFirst
(
namebuf
,
// Wildcard Pattern to Match
&
hdir
,
// Handle to Use While Search Directory
FILE_READONLY
|
FILE_HIDDEN
|
FILE_SYSTEM
|
FILE_DIRECTORY
,
&
ep
,
sizeof
(
ep
),
// Structure to Receive Directory Entry
&
srchcnt
,
// Max and Actual Count of Entries Per Iteration
FIL_STANDARD
);
// Format of Entry (EAs or Not)
if
(
rc
!=
NO_ERROR
)
{
errno
=
ENOENT
;
return
posix_error
();
}
if
(
srchcnt
>
0
)
{
// If Directory is NOT Totally Empty,
do
{
if
(
ep
.
achName
[
0
]
==
'.'
&&
(
ep
.
achName
[
1
]
==
'\0'
||
ep
.
achName
[
1
]
==
'.'
&&
ep
.
achName
[
2
]
==
'\0'
))
continue
;
// Skip Over "." and ".." Names
strcpy
(
namebuf
,
ep
.
achName
);
// Leave Case of Name Alone -- In Native Form
// (Removed Forced Lowercasing Code)
v
=
PyString_FromString
(
namebuf
);
if
(
v
==
NULL
)
{
Py_DECREF
(
d
);
d
=
NULL
;
break
;
}
if
(
PyList_Append
(
d
,
v
)
!=
0
)
{
Py_DECREF
(
v
);
Py_DECREF
(
d
);
d
=
NULL
;
break
;
}
Py_DECREF
(
v
);
}
while
(
DosFindNext
(
hdir
,
&
ep
,
sizeof
(
ep
),
&
srchcnt
)
==
NO_ERROR
&&
srchcnt
>
0
);
}
return
d
;
#else
#else
char
*
name
;
char
*
name
;
...
@@ -642,6 +748,7 @@ posix_listdir(self, args)
...
@@ -642,6 +748,7 @@ posix_listdir(self, args)
return
d
;
return
d
;
#endif
/* !PYOS_OS2 */
#endif
/* !_MSC_VER */
#endif
/* !_MSC_VER */
#endif
/* !MS_WIN32 */
#endif
/* !MS_WIN32 */
}
}
...
@@ -661,7 +768,7 @@ posix_mkdir(self, args)
...
@@ -661,7 +768,7 @@ posix_mkdir(self, args)
if
(
!
PyArg_ParseTuple
(
args
,
"s|i"
,
&
path
,
&
mode
))
if
(
!
PyArg_ParseTuple
(
args
,
"s|i"
,
&
path
,
&
mode
))
return
NULL
;
return
NULL
;
Py_BEGIN_ALLOW_THREADS
Py_BEGIN_ALLOW_THREADS
#if defined(__WATCOMC__) || defined(_MSC_VER)
#if defined(__WATCOMC__) || defined(_MSC_VER)
|| defined(PYCC_VACPP)
res
=
mkdir
(
path
);
res
=
mkdir
(
path
);
#else
#else
res
=
mkdir
(
path
,
mode
);
res
=
mkdir
(
path
,
mode
);
...
@@ -1246,8 +1353,23 @@ posix_kill(self, args)
...
@@ -1246,8 +1353,23 @@ posix_kill(self, args)
int
pid
,
sig
;
int
pid
,
sig
;
if
(
!
PyArg_Parse
(
args
,
"(ii)"
,
&
pid
,
&
sig
))
if
(
!
PyArg_Parse
(
args
,
"(ii)"
,
&
pid
,
&
sig
))
return
NULL
;
return
NULL
;
#if defined(__TOS_OS2__)
if
(
sig
==
XCPT_SIGNAL_INTR
||
sig
==
XCPT_SIGNAL_BREAK
)
{
APIRET
rc
;
if
((
rc
=
DosSendSignalException
(
pid
,
sig
))
!=
NO_ERROR
)
return
posix_error
();
}
else
if
(
sig
==
XCPT_SIGNAL_KILLPROC
)
{
APIRET
rc
;
if
((
rc
=
DosKillProcess
(
DKP_PROCESS
,
pid
))
!=
NO_ERROR
)
return
posix_error
();
}
else
return
NULL
;
// Unrecognized Signal Requested
#else
if
(
kill
(
pid
,
sig
)
==
-
1
)
if
(
kill
(
pid
,
sig
)
==
-
1
)
return
posix_error
();
return
posix_error
();
#endif
Py_INCREF
(
Py_None
);
Py_INCREF
(
Py_None
);
return
Py_None
;
return
Py_None
;
}
}
...
@@ -1284,6 +1406,108 @@ static char posix_popen__doc__[] =
...
@@ -1284,6 +1406,108 @@ static char posix_popen__doc__[] =
"popen(command [, mode='r' [, bufsize]]) -> pipe
\n
\
"popen(command [, mode='r' [, bufsize]]) -> pipe
\n
\
Open a pipe to/from a command returning a file object."
;
Open a pipe to/from a command returning a file object."
;
#if defined(PYOS_OS2)
int
async_system
(
const
char
*
command
)
{
char
*
p
,
errormsg
[
256
],
args
[
1024
];
RESULTCODES
rcodes
;
APIRET
rc
;
char
*
shell
=
getenv
(
"COMSPEC"
);
if
(
!
shell
)
shell
=
"cmd"
;
strcpy
(
args
,
shell
);
p
=
&
args
[
strlen
(
args
)
+
1
];
strcpy
(
p
,
"/c "
);
strcat
(
p
,
command
);
p
+=
strlen
(
p
)
+
1
;
*
p
=
'\0'
;
rc
=
DosExecPgm
(
errormsg
,
sizeof
(
errormsg
),
EXEC_ASYNC
,
// Execute Async w/o Wait for Results
args
,
NULL
,
// Inherit Parent's Environment
&
rcodes
,
shell
);
return
rc
;
}
FILE
*
popen
(
const
char
*
command
,
const
char
*
mode
,
int
pipesize
)
{
HFILE
rhan
,
whan
;
FILE
*
retfd
=
NULL
;
APIRET
rc
=
DosCreatePipe
(
&
rhan
,
&
whan
,
pipesize
);
if
(
rc
!=
NO_ERROR
)
return
NULL
;
// ERROR - Unable to Create Anon Pipe
if
(
strchr
(
mode
,
'r'
)
!=
NULL
)
{
// Treat Command as a Data Source
int
oldfd
=
dup
(
1
);
// Save STDOUT Handle in Another Handle
DosEnterCritSec
();
// Stop Other Threads While Changing Handles
close
(
1
);
// Make STDOUT Available for Reallocation
if
(
dup2
(
whan
,
1
)
==
0
)
{
// Connect STDOUT to Pipe Write Side
DosClose
(
whan
);
// Close Now-Unused Pipe Write Handle
if
(
async_system
(
command
)
==
NO_ERROR
)
retfd
=
fdopen
(
rhan
,
"rb"
);
// And Return Pipe Read Handle
}
dup2
(
oldfd
,
1
);
// Reconnect STDOUT to Original Handle
DosExitCritSec
();
// Now Allow Other Threads to Run
close
(
oldfd
);
// And Close Saved STDOUT Handle
return
retfd
;
// Return fd of Pipe or NULL if Error
}
else
if
(
strchr
(
mode
,
'w'
))
{
// Treat Command as a Data Sink
int
oldfd
=
dup
(
0
);
// Save STDIN Handle in Another Handle
DosEnterCritSec
();
// Stop Other Threads While Changing Handles
close
(
0
);
// Make STDIN Available for Reallocation
if
(
dup2
(
rhan
,
0
)
==
0
)
{
// Connect STDIN to Pipe Read Side
DosClose
(
rhan
);
// Close Now-Unused Pipe Read Handle
if
(
async_system
(
command
)
==
NO_ERROR
)
retfd
=
fdopen
(
whan
,
"wb"
);
// And Return Pipe Write Handle
}
dup2
(
oldfd
,
0
);
// Reconnect STDIN to Original Handle
DosExitCritSec
();
// Now Allow Other Threads to Run
close
(
oldfd
);
// And Close Saved STDIN Handle
return
retfd
;
// Return fd of Pipe or NULL if Error
}
else
return
NULL
;
// ERROR - Invalid Mode (Neither Read nor Write)
}
static
PyObject
*
posix_popen
(
self
,
args
)
PyObject
*
self
;
PyObject
*
args
;
{
char
*
name
;
char
*
mode
=
"r"
;
int
bufsize
=
-
1
;
FILE
*
fp
;
PyObject
*
f
;
if
(
!
PyArg_ParseTuple
(
args
,
"s|si"
,
&
name
,
&
mode
,
&
bufsize
))
return
NULL
;
Py_BEGIN_ALLOW_THREADS
fp
=
popen
(
name
,
mode
,
(
bufsize
>
0
)
?
bufsize
:
4096
);
Py_END_ALLOW_THREADS
if
(
fp
==
NULL
)
return
posix_error
();
f
=
PyFile_FromFile
(
fp
,
name
,
mode
,
fclose
);
if
(
f
!=
NULL
)
PyFile_SetBufSize
(
f
,
bufsize
);
return
f
;
}
#else
static
PyObject
*
static
PyObject
*
posix_popen
(
self
,
args
)
posix_popen
(
self
,
args
)
PyObject
*
self
;
PyObject
*
self
;
...
@@ -1306,6 +1530,8 @@ posix_popen(self, args)
...
@@ -1306,6 +1530,8 @@ posix_popen(self, args)
PyFile_SetBufSize
(
f
,
bufsize
);
PyFile_SetBufSize
(
f
,
bufsize
);
return
f
;
return
f
;
}
}
#endif
#endif
/* HAVE_POPEN */
#endif
/* HAVE_POPEN */
...
@@ -1840,6 +2066,21 @@ posix_pipe(self, args)
...
@@ -1840,6 +2066,21 @@ posix_pipe(self, args)
PyObject
*
self
;
PyObject
*
self
;
PyObject
*
args
;
PyObject
*
args
;
{
{
#if defined(PYOS_OS2)
HFILE
read
,
write
;
APIRET
rc
;
if
(
!
PyArg_Parse
(
args
,
""
))
return
NULL
;
Py_BEGIN_ALLOW_THREADS
rc
=
DosCreatePipe
(
&
read
,
&
write
,
4096
);
Py_END_ALLOW_THREADS
if
(
rc
!=
NO_ERROR
)
return
posix_error
();
return
Py_BuildValue
(
"(ii)"
,
read
,
write
);
#else
#if !defined(MS_WIN32)
#if !defined(MS_WIN32)
int
fds
[
2
];
int
fds
[
2
];
int
res
;
int
res
;
...
@@ -1863,6 +2104,7 @@ posix_pipe(self, args)
...
@@ -1863,6 +2104,7 @@ posix_pipe(self, args)
return
posix_error
();
return
posix_error
();
return
Py_BuildValue
(
"(ii)"
,
read
,
write
);
return
Py_BuildValue
(
"(ii)"
,
read
,
write
);
#endif
/* MS_WIN32 */
#endif
/* MS_WIN32 */
#endif
}
}
#endif
/* HAVE_PIPE */
#endif
/* HAVE_PIPE */
...
@@ -2259,9 +2501,14 @@ all_ins(d)
...
@@ -2259,9 +2501,14 @@ all_ins(d)
#define INITFUNC initnt
#define INITFUNC initnt
#define MODNAME "nt"
#define MODNAME "nt"
#else
#else
#if defined(PYOS_OS2)
#define INITFUNC initos2
#define MODNAME "os2"
#else
#define INITFUNC initposix
#define INITFUNC initposix
#define MODNAME "posix"
#define MODNAME "posix"
#endif
#endif
#endif
void
void
INITFUNC
()
INITFUNC
()
...
...
Modules/selectmodule.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -48,6 +48,11 @@ extern void bzero();
...
@@ -48,6 +48,11 @@ extern void bzero();
#include <sys/types.h>
#include <sys/types.h>
#if defined(PYOS_OS2)
#include <sys/time.h>
#include <utils.h>
#endif
#ifdef MS_WINDOWS
#ifdef MS_WINDOWS
#include <winsock.h>
#include <winsock.h>
#else
#else
...
...
Modules/signalmodule.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -50,6 +50,11 @@ PERFORMANCE OF THIS SOFTWARE.
...
@@ -50,6 +50,11 @@ PERFORMANCE OF THIS SOFTWARE.
#define SIG_ERR ((RETSIGTYPE (*)())-1)
#define SIG_ERR ((RETSIGTYPE (*)())-1)
#endif
#endif
#if defined(PYOS_OS2)
#define NSIG 12
#include <process.h>
#endif
#ifndef NSIG
#ifndef NSIG
#ifdef _SIGMAX
#ifdef _SIGMAX
#define NSIG (_SIGMAX + 1)
/* For QNX */
#define NSIG (_SIGMAX + 1)
/* For QNX */
...
...
Modules/socketmodule.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -91,10 +91,25 @@ Socket methods:
...
@@ -91,10 +91,25 @@ Socket methods:
#include <unistd.h>
#include <unistd.h>
#endif
#endif
#if
ndef MS_WINDOWS
#if
!defined(MS_WINDOWS) && !defined(PYOS_OS2)
extern
int
gethostname
();
/* For Solaris, at least */
extern
int
gethostname
();
/* For Solaris, at least */
#endif
#endif
#if defined(PYCC_VACPP)
#include <types.h>
#include <io.h>
#include <sys/ioctl.h>
#include <utils.h>
#include <ctype.h>
#endif
#if defined(PYOS_OS2)
#define INCL_DOS
#define INCL_DOSERRORS
#define INCL_NOPMAPI
#include <os2.h>
#endif
#include <sys/types.h>
#include <sys/types.h>
#include "mytime.h"
#include "mytime.h"
...
@@ -136,6 +151,12 @@ extern int gethostname(); /* For Solaris, at least */
...
@@ -136,6 +151,12 @@ extern int gethostname(); /* For Solaris, at least */
#define FORCE_ANSI_FUNC_DEFS
#define FORCE_ANSI_FUNC_DEFS
#endif
#endif
#if defined(PYOS_OS2)
#define close soclose
#define NO_DUP
/* Sockets are Not Actual File Handles under OS/2 */
#define FORCE_ANSI_FUNC_DEFS
#endif
#ifdef FORCE_ANSI_FUNC_DEFS
#ifdef FORCE_ANSI_FUNC_DEFS
#define BUILD_FUNC_DEF_1( fnname, arg1type, arg1name ) \
#define BUILD_FUNC_DEF_1( fnname, arg1type, arg1name ) \
fnname( arg1type arg1name )
fnname( arg1type arg1name )
...
@@ -198,6 +219,36 @@ PySocket_Err()
...
@@ -198,6 +219,36 @@ PySocket_Err()
}
}
else
else
#endif
#endif
#if defined(PYOS_OS2)
if
(
sock_errno
()
!=
NO_ERROR
)
{
APIRET
rc
;
ULONG
msglen
;
char
outbuf
[
100
];
int
myerrorcode
=
sock_errno
();
/* Retrieve Socket-Related Error Message from MPTN.MSG File */
rc
=
DosGetMessage
(
NULL
,
0
,
outbuf
,
sizeof
(
outbuf
),
myerrorcode
-
SOCBASEERR
+
26
,
"mptn.msg"
,
&
msglen
);
if
(
rc
==
NO_ERROR
)
{
PyObject
*
v
;
outbuf
[
msglen
]
=
'\0'
;
/* OS/2 Doesn't Guarantee a Terminator */
if
(
strlen
(
outbuf
)
>
0
)
{
/* If Non-Empty Msg, Trim CRLF */
char
*
lastc
=
&
outbuf
[
strlen
(
outbuf
)
-
1
];
while
(
lastc
>
outbuf
&&
isspace
(
*
lastc
))
*
lastc
--
=
'\0'
;
/* Trim Trailing Whitespace (CRLF) */
}
v
=
Py_BuildValue
(
"(is)"
,
myerrorcode
,
outbuf
);
if
(
v
!=
NULL
)
{
PyErr_SetObject
(
PySocket_Error
,
v
);
Py_DECREF
(
v
);
}
return
NULL
;
}
}
#endif
return
PyErr_SetFromErrno
(
PySocket_Error
);
return
PyErr_SetFromErrno
(
PySocket_Error
);
}
}
...
@@ -527,16 +578,21 @@ BUILD_FUNC_DEF_2(PySocketSock_setblocking,PySocketSockObject*,s,PyObject*,args)
...
@@ -527,16 +578,21 @@ BUILD_FUNC_DEF_2(PySocketSock_setblocking,PySocketSockObject*,s,PyObject*,args)
return
NULL
;
return
NULL
;
Py_BEGIN_ALLOW_THREADS
Py_BEGIN_ALLOW_THREADS
#ifndef MS_WINDOWS
#ifndef MS_WINDOWS
#ifdef PYOS_OS2
block
=
!
block
;
ioctl
(
s
->
sock_fd
,
FIONBIO
,
(
caddr_t
)
&
block
,
sizeof
(
block
));
#else
/* !PYOS_OS2 */
delay_flag
=
fcntl
(
s
->
sock_fd
,
F_GETFL
,
0
);
delay_flag
=
fcntl
(
s
->
sock_fd
,
F_GETFL
,
0
);
if
(
block
)
if
(
block
)
delay_flag
&=
(
~
O_NDELAY
);
delay_flag
&=
(
~
O_NDELAY
);
else
else
delay_flag
|=
O_NDELAY
;
delay_flag
|=
O_NDELAY
;
fcntl
(
s
->
sock_fd
,
F_SETFL
,
delay_flag
);
fcntl
(
s
->
sock_fd
,
F_SETFL
,
delay_flag
);
#else
#endif
/* !PYOS_OS2 */
#else
/* MS_WINDOWS */
block
=
!
block
;
block
=
!
block
;
ioctlsocket
(
s
->
sock_fd
,
FIONBIO
,
(
u_long
*
)
&
block
);
ioctlsocket
(
s
->
sock_fd
,
FIONBIO
,
(
u_long
*
)
&
block
);
#endif
#endif
/* MS_WINDOWS */
Py_END_ALLOW_THREADS
Py_END_ALLOW_THREADS
Py_INCREF
(
Py_None
);
Py_INCREF
(
Py_None
);
...
@@ -883,7 +939,11 @@ BUILD_FUNC_DEF_2(PySocketSock_recvfrom,PySocketSockObject *,s, PyObject *,args)
...
@@ -883,7 +939,11 @@ BUILD_FUNC_DEF_2(PySocketSock_recvfrom,PySocketSockObject *,s, PyObject *,args)
Py_BEGIN_ALLOW_THREADS
Py_BEGIN_ALLOW_THREADS
n
=
recvfrom
(
s
->
sock_fd
,
PyString_AsString
(
buf
),
len
,
flags
,
n
=
recvfrom
(
s
->
sock_fd
,
PyString_AsString
(
buf
),
len
,
flags
,
#ifndef MS_WINDOWS
#ifndef MS_WINDOWS
#if defined(PYOS_OS2)
(
struct
sockaddr
*
)
addrbuf
,
&
addrlen
#else
(
ANY
*
)
addrbuf
,
&
addrlen
(
ANY
*
)
addrbuf
,
&
addrlen
#endif
#else
#else
(
struct
sockaddr
*
)
addrbuf
,
&
addrlen
(
struct
sockaddr
*
)
addrbuf
,
&
addrlen
#endif
#endif
...
@@ -1388,22 +1448,57 @@ NTinit()
...
@@ -1388,22 +1448,57 @@ NTinit()
#endif
/* MS_WINDOWS */
#endif
/* MS_WINDOWS */
#if defined(PYOS_OS2)
/* Additional initialization and cleanup for OS/2 */
static
void
OS2cleanup
()
{
/* No cleanup is necessary for OS/2 Sockets */
}
static
int
OS2init
()
{
char
reason
[
64
];
int
rc
=
sock_init
();
if
(
rc
==
0
)
{
atexit
(
OS2cleanup
);
return
1
;
// Indicate Success
}
sprintf
(
reason
,
"OS/2 TCP/IP Error# %d"
,
sock_errno
());
PyErr_SetString
(
PyExc_ImportError
,
reason
);
return
0
;
// Indicate Failure
}
#endif
/* PYOS_OS2 */
/* Initialize this module.
/* Initialize this module.
This is called when the first 'import socket' is done,
* This is called when the first 'import socket' is done,
via a table in config.c, if config.c is compiled with USE_SOCKET
* via a table in config.c, if config.c is compiled with USE_SOCKET
defined.
* defined.
*
For MS_WINDOWS (which means any Windows variant), this module
* For MS_WINDOWS (which means any Windows variant), this module
is actually called "_socket", and there's a wrapper "socket.py"
* is actually called "_socket", and there's a wrapper "socket.py"
which implements some missing functionality (such as makefile(),
* which implements some missing functionality (such as makefile(),
dup() and fromfd()). The import of "_socket" may fail with an
* dup() and fromfd()). The import of "_socket" may fail with an
ImportError exception if initialization of WINSOCK fails. When
* ImportError exception if initialization of WINSOCK fails. When
WINSOCK is initialized succesfully, a call to WSACleanup() is
* WINSOCK is initialized succesfully, a call to WSACleanup() is
scheduled to be made at exit time. */
* scheduled to be made at exit time.
*
* For OS/2, this module is also called "_socket" and uses a wrapper
* "socket.py" which implements that functionality that is missing
* when PC operating systems don't put socket descriptors in the
* operating system's filesystem layer.
*/
void
void
#if
def MS_WINDOWS
#if
defined(MS_WINDOWS) || defined(PYOS_OS2)
init_socket
()
init_socket
()
#else
#else
initsocket
()
initsocket
()
...
@@ -1415,7 +1510,13 @@ initsocket()
...
@@ -1415,7 +1510,13 @@ initsocket()
return
;
return
;
m
=
Py_InitModule
(
"_socket"
,
PySocket_methods
);
m
=
Py_InitModule
(
"_socket"
,
PySocket_methods
);
#else
#else
#if defined(__TOS_OS2__)
if
(
!
OS2init
())
return
;
m
=
Py_InitModule
(
"_socket"
,
PySocket_methods
);
#else
m
=
Py_InitModule
(
"socket"
,
PySocket_methods
);
m
=
Py_InitModule
(
"socket"
,
PySocket_methods
);
#endif
#endif
#endif
d
=
PyModule_GetDict
(
m
);
d
=
PyModule_GetDict
(
m
);
PySocket_Error
=
PyErr_NewException
(
"socket.error"
,
NULL
,
NULL
);
PySocket_Error
=
PyErr_NewException
(
"socket.error"
,
NULL
,
NULL
);
...
...
Modules/timemodule.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -59,7 +59,7 @@ PERFORMANCE OF THIS SOFTWARE.
...
@@ -59,7 +59,7 @@ PERFORMANCE OF THIS SOFTWARE.
#ifdef HAVE_FTIME
#ifdef HAVE_FTIME
#include <sys/timeb.h>
#include <sys/timeb.h>
#if
ndef MS_WINDOWS
#if
!defined(MS_WINDOWS) && !defined(PYOS_OS2)
extern
int
ftime
();
extern
int
ftime
();
#endif
/* MS_WINDOWS */
#endif
/* MS_WINDOWS */
#endif
/* HAVE_FTIME */
#endif
/* HAVE_FTIME */
...
@@ -85,6 +85,18 @@ extern int ftime();
...
@@ -85,6 +85,18 @@ extern int ftime();
#undef HAVE_CLOCK
/* We have our own version down below */
#undef HAVE_CLOCK
/* We have our own version down below */
#endif
/* MS_WIN32 */
#endif
/* MS_WIN32 */
#if defined(PYOS_OS2)
#define INCL_DOS
#define INCL_DOSERRORS
#define INCL_NOPMAPI
#include <os2.h>
#endif
#if defined(PYCC_VACPP)
#include <time.h>
#define timezone _timezone
#endif
/* Forward declarations */
/* Forward declarations */
static
int
floatsleep
Py_PROTO
((
double
));
static
int
floatsleep
Py_PROTO
((
double
));
static
double
floattime
Py_PROTO
(());
static
double
floattime
Py_PROTO
(());
...
@@ -588,10 +600,18 @@ floatsleep(double secs)
...
@@ -588,10 +600,18 @@ floatsleep(double secs)
Sleep
((
int
)(
secs
*
1000
));
Sleep
((
int
)(
secs
*
1000
));
Py_END_ALLOW_THREADS
Py_END_ALLOW_THREADS
#else
/* !MS_WIN32 */
#else
/* !MS_WIN32 */
#ifdef PYOS_OS2
/* This Sleep *IS* Interruptable by Exceptions */
if
(
DosSleep
(
secs
*
1000
)
!=
NO_ERROR
)
{
PyErr_SetFromErrno
(
PyExc_IOError
);
return
-
1
;
}
#else
/* !PYOS_OS2 */
/* XXX Can't interrupt this sleep */
/* XXX Can't interrupt this sleep */
Py_BEGIN_ALLOW_THREADS
Py_BEGIN_ALLOW_THREADS
sleep
((
int
)
secs
);
sleep
((
int
)
secs
);
Py_END_ALLOW_THREADS
Py_END_ALLOW_THREADS
#endif
/* !PYOS_OS2 */
#endif
/* !MS_WIN32 */
#endif
/* !MS_WIN32 */
#endif
/* !MSDOS */
#endif
/* !MSDOS */
#endif
/* !__WATCOMC__ */
#endif
/* !__WATCOMC__ */
...
...
Python/importdl.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -47,6 +47,7 @@ PERFORMANCE OF THIS SOFTWARE.
...
@@ -47,6 +47,7 @@ PERFORMANCE OF THIS SOFTWARE.
_AIX -- AIX style dynamic linking
_AIX -- AIX style dynamic linking
MS_WIN32 -- Windows NT style dynamic linking (using DLLs)
MS_WIN32 -- Windows NT style dynamic linking (using DLLs)
MS_WIN16 -- Windows 16-bit dynamic linking (using DLLs)
MS_WIN16 -- Windows 16-bit dynamic linking (using DLLs)
PYOS_OS2 -- IBM OS/2 dynamic linking (using DLLs)
_DL_FUNCPTR_DEFINED -- if the typedef dl_funcptr has been defined
_DL_FUNCPTR_DEFINED -- if the typedef dl_funcptr has been defined
USE_MAC_DYNAMIC_LOADING -- Mac CFM shared libraries
USE_MAC_DYNAMIC_LOADING -- Mac CFM shared libraries
SHORT_EXT -- short extension for dynamic module, e.g. ".so"
SHORT_EXT -- short extension for dynamic module, e.g. ".so"
...
@@ -76,6 +77,17 @@ typedef void (*dl_funcptr)();
...
@@ -76,6 +77,17 @@ typedef void (*dl_funcptr)();
#define LONG_EXT "module.sl"
#define LONG_EXT "module.sl"
#endif
#endif
#if defined(PYOS_OS2)
#define DYNAMIC_LINK
#define INCL_DOSERRORS
#define INCL_DOSMODULEMGR
#include <os2.h>
typedef
int
(
*
APIENTRY
dl_funcptr
)();
#define _DL_FUNCPTR_DEFINED 1
#define SHORT_EXT ".pyd"
#define LONG_EXT ".dll"
#endif
#if defined(__NetBSD__)
#if defined(__NetBSD__)
#define DYNAMIC_LINK
#define DYNAMIC_LINK
#define USE_SHLIB
#define USE_SHLIB
...
@@ -458,6 +470,32 @@ _PyImport_LoadDynamicModule(name, pathname, fp)
...
@@ -458,6 +470,32 @@ _PyImport_LoadDynamicModule(name, pathname, fp)
p
=
GetProcAddress
(
hDLL
,
funcname
);
p
=
GetProcAddress
(
hDLL
,
funcname
);
}
}
#endif
/* MS_WIN16 */
#endif
/* MS_WIN16 */
#if defined(PYOS_OS2)
{
APIRET
rc
;
HMODULE
hDLL
;
char
failreason
[
256
];
rc
=
DosLoadModule
(
failreason
,
sizeof
(
failreason
),
pathname
,
&
hDLL
);
if
(
rc
!=
NO_ERROR
)
{
char
errBuf
[
256
];
sprintf
(
errBuf
,
"DLL load failed, rc = %d, problem '%s': %s"
,
rc
,
failreason
);
PyErr_SetString
(
PyExc_ImportError
,
errBuf
);
return
NULL
;
}
rc
=
DosQueryProcAddr
(
hDLL
,
0L
,
funcname
,
&
p
);
if
(
rc
!=
NO_ERROR
)
p
=
NULL
;
/* Signify Failure to Acquire Entrypoint */
}
#endif
/* PYOS_OS2 */
#ifdef USE_DL
#ifdef USE_DL
p
=
dl_loadmod
(
Py_GetProgramName
(),
pathname
,
funcname
);
p
=
dl_loadmod
(
Py_GetProgramName
(),
pathname
,
funcname
);
#endif
/* USE_DL */
#endif
/* USE_DL */
...
...
Python/thread.c
Dosyayı görüntüle @
8e9ebfd3
...
@@ -149,6 +149,10 @@ void init_thread _P0()
...
@@ -149,6 +149,10 @@ void init_thread _P0()
#include "thread_nt.h"
#include "thread_nt.h"
#endif
#endif
#ifdef OS2_THREADS
#include "thread_os2.h"
#endif
/*
/*
#ifdef FOOBAR_THREADS
#ifdef FOOBAR_THREADS
#include "thread_foobar.h"
#include "thread_foobar.h"
...
...
Python/thread_os2.h
Dosyayı görüntüle @
8e9ebfd3
...
@@ -56,7 +56,7 @@ int start_new_thread(void (*func)(void *), void *arg)
...
@@ -56,7 +56,7 @@ int start_new_thread(void (*func)(void *), void *arg)
int
aThread
;
int
aThread
;
int
success
=
1
;
int
success
=
1
;
aThread
=
_beginthread
(
func
,
409
6
,
arg
);
aThread
=
_beginthread
(
func
,
NULL
,
6553
6
,
arg
);
if
(
aThread
==
-
1
)
{
if
(
aThread
==
-
1
)
{
success
=
0
;
success
=
0
;
...
@@ -210,7 +210,7 @@ void free_sema(type_sema aSemaphore)
...
@@ -210,7 +210,7 @@ void free_sema(type_sema aSemaphore)
}
}
void
down_sema
(
type_sema
aSemaphore
,
int
waitflag
)
int
down_sema
(
type_sema
aSemaphore
,
int
waitflag
)
{
{
return
-
1
;
return
-
1
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment