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
64e736ba
Kaydet (Commit)
64e736ba
authored
Eki 02, 1998
tarafından
Guido van Rossum
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Some new blood and some updated versions.
üst
fdb8fb8b
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
467 additions
and
14 deletions
+467
-14
exceptio.py
Lib/dos-8x3/exceptio.py
+20
-12
posixpat.py
Lib/dos-8x3/posixpat.py
+2
-0
py_compi.py
Lib/dos-8x3/py_compi.py
+9
-1
stringio.py
Lib/dos-8x3/stringio.py
+14
-1
test_lon.py
Lib/dos-8x3/test_lon.py
+252
-0
test_mim.py
Lib/dos-8x3/test_mim.py
+170
-0
threadin.py
Lib/dos-8x3/threadin.py
+0
-0
No files found.
Lib/dos-8x3/exceptio.py
Dosyayı görüntüle @
64e736ba
"""Class based built-in exception hierarchy.
This is a new feature whereby all the standard built-in exceptions,
traditionally string objects, are replaced with classes. This gives
Python's exception handling mechanism a more object-oriented feel.
New with Python 1.5, all standard built-in exceptions are now class objects by
default. This gives Python's exception handling mechanism a more
object-oriented feel. Traditionally they were string objects. Python will
fallback to string based exceptions if the interpreter is invoked with the -X
option, or if some failure occurs during class exception initialization (in
this case a warning will be printed).
Most existing code should continue to work with class based
exceptions. Some tricky uses of IOError may break, but the most
common uses should work.
Most existing code should continue to work with class based exceptions. Some
tricky uses of IOError may break, but the most common uses should work.
To disable this feature, start the Python executable with the -X option.
Here is a rundown of the class hierarchy. You can change this by editing this
file, but it isn't recommended. The class names described here are expected
to be found by the bltinmodule.c file.
Here is a rundown of the class hierarchy. You can change this by
editing this file, but it isn't recommended. The classes with a `*'
are new with this feature. They are defined as tuples containing the
derived exceptions when string-based exceptions are used
.
The classes with a `*' are new as of Python 1.5. They are defined as tuples
containing the derived exceptions when string-based exceptions are used. If
you define your own class based exceptions, they should be derived from
Exception
.
Exception(*)
|
...
...
@@ -22,7 +26,11 @@ Exception(*)
+-- SystemExit
+-- KeyboardInterrupt
+-- ImportError
+-- IOError
+-- EnvironmentError(*)
| |
| +-- IOError
| +-- OSError(*)
|
+-- EOFError
+-- RuntimeError
+-- NameError
...
...
Lib/dos-8x3/posixpat.py
Dosyayı görüntüle @
64e736ba
...
...
@@ -354,6 +354,8 @@ def normpath(path):
while
i
<
len
(
comps
):
if
comps
[
i
]
==
'.'
:
del
comps
[
i
]
while
i
<
len
(
comps
)
and
comps
[
i
]
==
''
:
del
comps
[
i
]
elif
comps
[
i
]
==
'..'
and
i
>
0
and
comps
[
i
-
1
]
not
in
(
''
,
'..'
):
del
comps
[
i
-
1
:
i
+
1
]
i
=
i
-
1
...
...
Lib/dos-8x3/py_compi.py
Dosyayı görüntüle @
64e736ba
...
...
@@ -51,7 +51,15 @@ def compile(file, cfile=None, dfile=None):
f
.
close
()
if
codestring
and
codestring
[
-
1
]
!=
'
\n
'
:
codestring
=
codestring
+
'
\n
'
codeobject
=
__builtin__
.
compile
(
codestring
,
dfile
or
file
,
'exec'
)
try
:
codeobject
=
__builtin__
.
compile
(
codestring
,
dfile
or
file
,
'exec'
)
except
SyntaxError
,
detail
:
import
traceback
,
sys
,
string
lines
=
traceback
.
format_exception_only
(
SyntaxError
,
detail
)
for
line
in
lines
:
sys
.
stderr
.
write
(
string
.
replace
(
line
,
'File "<string>"'
,
'File "
%
s"'
%
(
dfile
or
file
)))
return
if
not
cfile
:
cfile
=
file
+
(
__debug__
and
'c'
or
'o'
)
fc
=
open
(
cfile
,
'wb'
)
...
...
Lib/dos-8x3/stringio.py
Dosyayı görüntüle @
64e736ba
...
...
@@ -41,8 +41,12 @@ class StringIO:
self
.
closed
=
1
del
self
.
buf
,
self
.
pos
def
isatty
(
self
):
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
return
0
def
seek
(
self
,
pos
,
mode
=
0
):
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
if
self
.
buflist
:
self
.
buf
=
self
.
buf
+
string
.
joinfields
(
self
.
buflist
,
''
)
self
.
buflist
=
[]
...
...
@@ -52,8 +56,12 @@ class StringIO:
pos
=
pos
+
self
.
len
self
.
pos
=
max
(
0
,
pos
)
def
tell
(
self
):
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
return
self
.
pos
def
read
(
self
,
n
=
-
1
):
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
if
self
.
buflist
:
self
.
buf
=
self
.
buf
+
string
.
joinfields
(
self
.
buflist
,
''
)
self
.
buflist
=
[]
...
...
@@ -65,6 +73,8 @@ class StringIO:
self
.
pos
=
newpos
return
r
def
readline
(
self
,
length
=
None
):
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
if
self
.
buflist
:
self
.
buf
=
self
.
buf
+
string
.
joinfields
(
self
.
buflist
,
''
)
self
.
buflist
=
[]
...
...
@@ -87,6 +97,8 @@ class StringIO:
line
=
self
.
readline
()
return
lines
def
write
(
self
,
s
):
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
if
not
s
:
return
if
self
.
pos
>
self
.
len
:
self
.
buflist
.
append
(
'
\0
'
*
(
self
.
pos
-
self
.
len
))
...
...
@@ -105,7 +117,8 @@ class StringIO:
def
writelines
(
self
,
list
):
self
.
write
(
string
.
joinfields
(
list
,
''
))
def
flush
(
self
):
pass
if
self
.
closed
:
raise
ValueError
,
"I/O operation on closed file"
def
getvalue
(
self
):
if
self
.
buflist
:
self
.
buf
=
self
.
buf
+
string
.
joinfields
(
self
.
buflist
,
''
)
...
...
Lib/dos-8x3/test_lon.py
0 → 100644
Dosyayı görüntüle @
64e736ba
from
test_support
import
TestFailed
,
verbose
from
string
import
join
from
random
import
random
,
randint
# SHIFT should match the value in longintrepr.h for best testing.
SHIFT
=
15
BASE
=
2
**
SHIFT
MASK
=
BASE
-
1
# Max number of base BASE digits to use in test cases. Doubling
# this will at least quadruple the runtime.
MAXDIGITS
=
10
# build some special values
special
=
map
(
long
,
[
0
,
1
,
2
,
BASE
,
BASE
>>
1
])
special
.
append
(
0x5555555555555555
L
)
special
.
append
(
0xaaaaaaaaaaaaaaaa
L
)
# some solid strings of one bits
p2
=
4L
# 0 and 1 already added
for
i
in
range
(
2
*
SHIFT
):
special
.
append
(
p2
-
1
)
p2
=
p2
<<
1
del
p2
# add complements & negations
special
=
special
+
map
(
lambda
x
:
~
x
,
special
)
+
\
map
(
lambda
x
:
-
x
,
special
)
# ------------------------------------------------------------ utilities
# Use check instead of assert so the test still does something
# under -O.
def
check
(
ok
,
*
args
):
if
not
ok
:
raise
TestFailed
,
join
(
map
(
str
,
args
),
" "
)
# Get quasi-random long consisting of ndigits digits (in base BASE).
# quasi == the most-significant digit will not be 0, and the number
# is constructed to contain long strings of 0 and 1 bits. These are
# more likely than random bits to provoke digit-boundary errors.
# The sign of the number is also random.
def
getran
(
ndigits
):
assert
ndigits
>
0
nbits_hi
=
ndigits
*
SHIFT
nbits_lo
=
nbits_hi
-
SHIFT
+
1
answer
=
0L
nbits
=
0
r
=
int
(
random
()
*
(
SHIFT
*
2
))
|
1
# force 1 bits to start
while
nbits
<
nbits_lo
:
bits
=
(
r
>>
1
)
+
1
bits
=
min
(
bits
,
nbits_hi
-
nbits
)
assert
1
<=
bits
<=
SHIFT
nbits
=
nbits
+
bits
answer
=
answer
<<
bits
if
r
&
1
:
answer
=
answer
|
((
1
<<
bits
)
-
1
)
r
=
int
(
random
()
*
(
SHIFT
*
2
))
assert
nbits_lo
<=
nbits
<=
nbits_hi
if
random
()
<
0.5
:
answer
=
-
answer
return
answer
# Get random long consisting of ndigits random digits (relative to base
# BASE). The sign bit is also random.
def
getran2
(
ndigits
):
answer
=
0L
for
i
in
range
(
ndigits
):
answer
=
(
answer
<<
SHIFT
)
|
randint
(
0
,
MASK
)
if
random
()
<
0.5
:
answer
=
-
answer
return
answer
# --------------------------------------------------------------- divmod
def
test_division_2
(
x
,
y
):
q
,
r
=
divmod
(
x
,
y
)
q2
,
r2
=
x
/
y
,
x
%
y
check
(
q
==
q2
,
"divmod returns different quotient than / for"
,
x
,
y
)
check
(
r
==
r2
,
"divmod returns different mod than
%
for"
,
x
,
y
)
check
(
x
==
q
*
y
+
r
,
"x != q*y + r after divmod on"
,
x
,
y
)
if
y
>
0
:
check
(
0
<=
r
<
y
,
"bad mod from divmod on"
,
x
,
y
)
else
:
check
(
y
<
r
<=
0
,
"bad mod from divmod on"
,
x
,
y
)
def
test_division
(
maxdigits
=
MAXDIGITS
):
print
"long / *
%
divmod"
digits
=
range
(
1
,
maxdigits
+
1
)
for
lenx
in
digits
:
x
=
getran
(
lenx
)
for
leny
in
digits
:
y
=
getran
(
leny
)
or
1L
test_division_2
(
x
,
y
)
# -------------------------------------------------------------- ~ & | ^
def
test_bitop_identities_1
(
x
):
check
(
x
&
0
==
0
,
"x & 0 != 0 for"
,
x
)
check
(
x
|
0
==
x
,
"x | 0 != x for"
,
x
)
check
(
x
^
0
==
x
,
"x ^ 0 != x for"
,
x
)
check
(
x
&
-
1
==
x
,
"x & -1 != x for"
,
x
)
check
(
x
|
-
1
==
-
1
,
"x | -1 != -1 for"
,
x
)
check
(
x
^
-
1
==
~
x
,
"x ^ -1 != ~x for"
,
x
)
check
(
x
==
~~
x
,
"x != ~~x for"
,
x
)
check
(
x
&
x
==
x
,
"x & x != x for"
,
x
)
check
(
x
|
x
==
x
,
"x | x != x for"
,
x
)
check
(
x
^
x
==
0
,
"x ^ x != 0 for"
,
x
)
check
(
x
&
~
x
==
0
,
"x & ~x != 0 for"
,
x
)
check
(
x
|
~
x
==
-
1
,
"x | ~x != -1 for"
,
x
)
check
(
x
^
~
x
==
-
1
,
"x ^ ~x != -1 for"
,
x
)
check
(
-
x
==
1
+
~
x
==
~
(
x
-
1
),
"not -x == 1 + ~x == ~(x-1) for"
,
x
)
for
n
in
range
(
2
*
SHIFT
):
p2
=
2L
**
n
check
(
x
<<
n
>>
n
==
x
,
"x << n >> n != x for"
,
x
,
n
)
check
(
x
/
p2
==
x
>>
n
,
"x / p2 != x >> n for x n p2"
,
x
,
n
,
p2
)
check
(
x
*
p2
==
x
<<
n
,
"x * p2 != x << n for x n p2"
,
x
,
n
,
p2
)
check
(
x
&
-
p2
==
x
>>
n
<<
n
==
x
&
~
(
p2
-
1
),
"not x & -p2 == x >> n << n == x & ~(p2 - 1) for x n p2"
,
x
,
n
,
p2
)
def
test_bitop_identities_2
(
x
,
y
):
check
(
x
&
y
==
y
&
x
,
"x & y != y & x for"
,
x
,
y
)
check
(
x
|
y
==
y
|
x
,
"x | y != y | x for"
,
x
,
y
)
check
(
x
^
y
==
y
^
x
,
"x ^ y != y ^ x for"
,
x
,
y
)
check
(
x
^
y
^
x
==
y
,
"x ^ y ^ x != y for"
,
x
,
y
)
check
(
x
&
y
==
~
(
~
x
|
~
y
),
"x & y != ~(~x | ~y) for"
,
x
,
y
)
check
(
x
|
y
==
~
(
~
x
&
~
y
),
"x | y != ~(~x & ~y) for"
,
x
,
y
)
check
(
x
^
y
==
(
x
|
y
)
&
~
(
x
&
y
),
"x ^ y != (x | y) & ~(x & y) for"
,
x
,
y
)
check
(
x
^
y
==
(
x
&
~
y
)
|
(
~
x
&
y
),
"x ^ y == (x & ~y) | (~x & y) for"
,
x
,
y
)
check
(
x
^
y
==
(
x
|
y
)
&
(
~
x
|
~
y
),
"x ^ y == (x | y) & (~x | ~y) for"
,
x
,
y
)
def
test_bitop_identities_3
(
x
,
y
,
z
):
check
((
x
&
y
)
&
z
==
x
&
(
y
&
z
),
"(x & y) & z != x & (y & z) for"
,
x
,
y
,
z
)
check
((
x
|
y
)
|
z
==
x
|
(
y
|
z
),
"(x | y) | z != x | (y | z) for"
,
x
,
y
,
z
)
check
((
x
^
y
)
^
z
==
x
^
(
y
^
z
),
"(x ^ y) ^ z != x ^ (y ^ z) for"
,
x
,
y
,
z
)
check
(
x
&
(
y
|
z
)
==
(
x
&
y
)
|
(
x
&
z
),
"x & (y | z) != (x & y) | (x & z) for"
,
x
,
y
,
z
)
check
(
x
|
(
y
&
z
)
==
(
x
|
y
)
&
(
x
|
z
),
"x | (y & z) != (x | y) & (x | z) for"
,
x
,
y
,
z
)
def
test_bitop_identities
(
maxdigits
=
MAXDIGITS
):
print
"long bit-operation identities"
for
x
in
special
:
test_bitop_identities_1
(
x
)
digits
=
range
(
1
,
maxdigits
+
1
)
for
lenx
in
digits
:
x
=
getran
(
lenx
)
test_bitop_identities_1
(
x
)
for
leny
in
digits
:
y
=
getran
(
leny
)
test_bitop_identities_2
(
x
,
y
)
test_bitop_identities_3
(
x
,
y
,
getran
((
lenx
+
leny
)
/
2
))
# ------------------------------------------------------ hex oct str atol
def
slow_format
(
x
,
base
):
if
(
x
,
base
)
==
(
0
,
8
):
# this is an oddball!
return
"0L"
digits
=
[]
sign
=
0
if
x
<
0
:
sign
,
x
=
1
,
-
x
while
x
:
x
,
r
=
divmod
(
x
,
base
)
digits
.
append
(
int
(
r
))
digits
.
reverse
()
digits
=
digits
or
[
0
]
return
'-'
[:
sign
]
+
\
{
8
:
'0'
,
10
:
''
,
16
:
'0x'
}[
base
]
+
\
join
(
map
(
lambda
i
:
"0123456789ABCDEF"
[
i
],
digits
),
''
)
+
\
"L"
def
test_format_1
(
x
):
from
string
import
atol
for
base
,
mapper
in
(
8
,
oct
),
(
10
,
str
),
(
16
,
hex
):
got
=
mapper
(
x
)
expected
=
slow_format
(
x
,
base
)
check
(
got
==
expected
,
mapper
.
__name__
,
"returned"
,
got
,
"but expected"
,
expected
,
"for"
,
x
)
check
(
atol
(
got
,
0
)
==
x
,
'atol("
%
s", 0) !='
%
got
,
x
)
def
test_format
(
maxdigits
=
MAXDIGITS
):
print
"long str/hex/oct/atol"
for
x
in
special
:
test_format_1
(
x
)
for
i
in
range
(
10
):
for
lenx
in
range
(
1
,
maxdigits
+
1
):
x
=
getran
(
lenx
)
test_format_1
(
x
)
# ----------------------------------------------------------------- misc
def
test_misc
(
maxdigits
=
MAXDIGITS
):
print
"long miscellaneous operations"
import
sys
# check the extremes in int<->long conversion
hugepos
=
sys
.
maxint
hugeneg
=
-
hugepos
-
1
hugepos_aslong
=
long
(
hugepos
)
hugeneg_aslong
=
long
(
hugeneg
)
check
(
hugepos
==
hugepos_aslong
,
"long(sys.maxint) != sys.maxint"
)
check
(
hugeneg
==
hugeneg_aslong
,
"long(-sys.maxint-1) != -sys.maxint-1"
)
# long -> int should not fail for hugepos_aslong or hugeneg_aslong
try
:
check
(
int
(
hugepos_aslong
)
==
hugepos
,
"converting sys.maxint to long and back to int fails"
)
except
OverflowError
:
raise
TestFailed
,
"int(long(sys.maxint)) overflowed!"
try
:
check
(
int
(
hugeneg_aslong
)
==
hugeneg
,
"converting -sys.maxint-1 to long and back to int fails"
)
except
OverflowError
:
raise
TestFailed
,
"int(long(-sys.maxint-1)) overflowed!"
# but long -> int should overflow for hugepos+1 and hugeneg-1
x
=
hugepos_aslong
+
1
try
:
int
(
x
)
raise
ValueError
except
OverflowError
:
pass
except
:
raise
TestFailed
,
"int(long(sys.maxint) + 1) didn't overflow"
x
=
hugeneg_aslong
-
1
try
:
int
(
x
)
raise
ValueError
except
OverflowError
:
pass
except
:
raise
TestFailed
,
"int(long(-sys.maxint-1) - 1) didn't overflow"
# ---------------------------------------------------------------- do it
test_division
()
test_bitop_identities
()
test_format
()
test_misc
()
Lib/dos-8x3/test_mim.py
0 → 100644
Dosyayı görüntüle @
64e736ba
"""Test program for MimeWriter module.
The test program was too big to comfortably fit in the MimeWriter
class, so it's here in its own file.
This should generate Barry's example, modulo some quotes and newlines.
"""
from
MimeWriter
import
MimeWriter
SELLER
=
'''
\
INTERFACE Seller-1;
TYPE Seller = OBJECT
DOCUMENTATION "A simple Seller interface to test ILU"
METHODS
price():INTEGER,
END;
'''
BUYER
=
'''
\
class Buyer:
def __setup__(self, maxprice):
self._maxprice = maxprice
def __main__(self, kos):
"""Entry point upon arrival at a new KOS."""
broker = kos.broker()
# B4 == Barry's Big Bass Business :-)
seller = broker.lookup('Seller_1.Seller', 'B4')
if seller:
price = seller.price()
print 'Seller wants $', price, '... '
if price > self._maxprice:
print 'too much!'
else:
print "I'll take it!"
else:
print 'no seller found here'
'''
# Don't ask why this comment is here
STATE
=
'''
\
# instantiate a buyer instance and put it in a magic place for the KOS
# to find.
__kp__ = Buyer()
__kp__.__setup__(500)
'''
SIMPLE_METADATA
=
[
(
"Interpreter"
,
"python"
),
(
"Interpreter-Version"
,
"1.3"
),
(
"Owner-Name"
,
"Barry Warsaw"
),
(
"Owner-Rendezvous"
,
"bwarsaw@cnri.reston.va.us"
),
(
"Home-KSS"
,
"kss.cnri.reston.va.us"
),
(
"Identifier"
,
"hdl://cnri.kss/my_first_knowbot"
),
(
"Launch-Date"
,
"Mon Feb 12 16:39:03 EST 1996"
),
]
COMPLEX_METADATA
=
[
(
"Metadata-Type"
,
"complex"
),
(
"Metadata-Key"
,
"connection"
),
(
"Access"
,
"read-only"
),
(
"Connection-Description"
,
"Barry's Big Bass Business"
),
(
"Connection-Id"
,
"B4"
),
(
"Connection-Direction"
,
"client"
),
]
EXTERNAL_METADATA
=
[
(
"Metadata-Type"
,
"complex"
),
(
"Metadata-Key"
,
"generic-interface"
),
(
"Access"
,
"read-only"
),
(
"Connection-Description"
,
"Generic Interface for All Knowbots"
),
(
"Connection-Id"
,
"generic-kp"
),
(
"Connection-Direction"
,
"client"
),
]
def
main
():
import
sys
# Toplevel headers
toplevel
=
MimeWriter
(
sys
.
stdout
)
toplevel
.
addheader
(
"From"
,
"bwarsaw@cnri.reston.va.us"
)
toplevel
.
addheader
(
"Date"
,
"Mon Feb 12 17:21:48 EST 1996"
)
toplevel
.
addheader
(
"To"
,
"kss-submit@cnri.reston.va.us"
)
toplevel
.
addheader
(
"MIME-Version"
,
"1.0"
)
# Toplevel body parts
f
=
toplevel
.
startmultipartbody
(
"knowbot"
,
"801spam999"
,
[(
"version"
,
"0.1"
)],
prefix
=
0
)
f
.
write
(
"This is a multi-part message in MIME format.
\n
"
)
# First toplevel body part: metadata
md
=
toplevel
.
nextpart
()
md
.
startmultipartbody
(
"knowbot-metadata"
,
"802spam999"
)
# Metadata part 1
md1
=
md
.
nextpart
()
md1
.
addheader
(
"KP-Metadata-Type"
,
"simple"
)
md1
.
addheader
(
"KP-Access"
,
"read-only"
)
m
=
MimeWriter
(
md1
.
startbody
(
"message/rfc822"
))
for
key
,
value
in
SIMPLE_METADATA
:
m
.
addheader
(
"KPMD-"
+
key
,
value
)
m
.
flushheaders
()
del
md1
# Metadata part 2
md2
=
md
.
nextpart
()
for
key
,
value
in
COMPLEX_METADATA
:
md2
.
addheader
(
"KP-"
+
key
,
value
)
f
=
md2
.
startbody
(
"text/isl"
)
f
.
write
(
SELLER
)
del
md2
# Metadata part 3
md3
=
md
.
nextpart
()
f
=
md3
.
startbody
(
"message/external-body"
,
[(
"access-type"
,
"URL"
),
(
"URL"
,
"hdl://cnri.kss/generic-knowbot"
)])
m
=
MimeWriter
(
f
)
for
key
,
value
in
EXTERNAL_METADATA
:
md3
.
addheader
(
"KP-"
+
key
,
value
)
md3
.
startbody
(
"text/isl"
)
# Phantom body doesn't need to be written
md
.
lastpart
()
# Second toplevel body part: code
code
=
toplevel
.
nextpart
()
code
.
startmultipartbody
(
"knowbot-code"
,
"803spam999"
)
# Code: buyer program source
buyer
=
code
.
nextpart
()
buyer
.
addheader
(
"KP-Module-Name"
,
"BuyerKP"
)
f
=
buyer
.
startbody
(
"text/plain"
)
f
.
write
(
BUYER
)
code
.
lastpart
()
# Third toplevel body part: state
state
=
toplevel
.
nextpart
()
state
.
addheader
(
"KP-Main-Module"
,
"main"
)
state
.
startmultipartbody
(
"knowbot-state"
,
"804spam999"
)
# State: a bunch of assignments
st
=
state
.
nextpart
()
st
.
addheader
(
"KP-Module-Name"
,
"main"
)
f
=
st
.
startbody
(
"text/plain"
)
f
.
write
(
STATE
)
state
.
lastpart
()
# End toplevel body parts
toplevel
.
lastpart
()
main
()
Lib/dos-8x3/threadin.py
0 → 100644
Dosyayı görüntüle @
64e736ba
This diff is collapsed.
Click to expand it.
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