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
7b3b3dc8
Kaydet (Commit)
7b3b3dc8
authored
Eyl 09, 2016
tarafından
Guido van Rossum
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Merge asyncio upstream.
üst
9b32bda8
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
94 additions
and
14 deletions
+94
-14
base_events.py
Lib/asyncio/base_events.py
+1
-1
coroutines.py
Lib/asyncio/coroutines.py
+2
-2
futures.py
Lib/asyncio/futures.py
+18
-6
tasks.py
Lib/asyncio/tasks.py
+4
-4
test_events.py
Lib/test/test_asyncio/test_events.py
+1
-1
test_futures.py
Lib/test/test_asyncio/test_futures.py
+68
-0
No files found.
Lib/asyncio/base_events.py
Dosyayı görüntüle @
7b3b3dc8
...
...
@@ -363,7 +363,7 @@ class BaseEventLoop(events.AbstractEventLoop):
"""
self
.
_check_closed
()
new_task
=
not
isinstance
(
future
,
futures
.
F
uture
)
new_task
=
not
futures
.
isfuture
(
f
uture
)
future
=
tasks
.
ensure_future
(
future
,
loop
=
self
)
if
new_task
:
# An exception is raised if the future didn't complete, so there
...
...
Lib/asyncio/coroutines.py
Dosyayı görüntüle @
7b3b3dc8
...
...
@@ -204,8 +204,8 @@ def coroutine(func):
@functools.wraps
(
func
)
def
coro
(
*
args
,
**
kw
):
res
=
func
(
*
args
,
**
kw
)
if
isinstance
(
res
,
futures
.
Future
)
or
inspect
.
isgenerator
(
res
)
or
\
isinstance
(
res
,
CoroWrapper
):
if
(
futures
.
isfuture
(
res
)
or
inspect
.
isgenerator
(
res
)
or
isinstance
(
res
,
CoroWrapper
)
):
res
=
yield
from
res
elif
_AwaitableABC
is
not
None
:
# If 'func' returns an Awaitable (new in 3.5) we
...
...
Lib/asyncio/futures.py
Dosyayı görüntüle @
7b3b3dc8
...
...
@@ -110,6 +110,16 @@ class _TracebackLogger:
self
.
loop
.
call_exception_handler
({
'message'
:
msg
})
def
isfuture
(
obj
):
"""Check for a Future.
This returns True when obj is a Future instance or is advertising
itself as duck-type compatible by setting _asyncio_future_blocking.
See comment in Future for more details.
"""
return
getattr
(
obj
,
'_asyncio_future_blocking'
,
None
)
is
not
None
class
Future
:
"""This class is *almost* compatible with concurrent.futures.Future.
...
...
@@ -423,15 +433,17 @@ def _chain_future(source, destination):
If destination is cancelled, source gets cancelled too.
Compatible with both asyncio.Future and concurrent.futures.Future.
"""
if
not
isinstance
(
source
,
(
Future
,
concurrent
.
futures
.
Future
)):
if
not
isfuture
(
source
)
and
not
isinstance
(
source
,
concurrent
.
futures
.
Future
):
raise
TypeError
(
'A future is required for source argument'
)
if
not
isinstance
(
destination
,
(
Future
,
concurrent
.
futures
.
Future
)):
if
not
isfuture
(
destination
)
and
not
isinstance
(
destination
,
concurrent
.
futures
.
Future
):
raise
TypeError
(
'A future is required for destination argument'
)
source_loop
=
source
.
_loop
if
is
instance
(
source
,
Futur
e
)
else
None
dest_loop
=
destination
.
_loop
if
is
instance
(
destination
,
Future
)
else
None
source_loop
=
source
.
_loop
if
is
future
(
sourc
e
)
else
None
dest_loop
=
destination
.
_loop
if
is
future
(
destination
)
else
None
def
_set_state
(
future
,
other
):
if
is
instance
(
future
,
F
uture
):
if
is
future
(
f
uture
):
_copy_future_state
(
other
,
future
)
else
:
_set_concurrent_future_state
(
future
,
other
)
...
...
@@ -455,7 +467,7 @@ def _chain_future(source, destination):
def
wrap_future
(
future
,
*
,
loop
=
None
):
"""Wrap concurrent.futures.Future object."""
if
is
instance
(
future
,
F
uture
):
if
is
future
(
f
uture
):
return
future
assert
isinstance
(
future
,
concurrent
.
futures
.
Future
),
\
'concurrent.futures.Future is expected, got {!r}'
.
format
(
future
)
...
...
Lib/asyncio/tasks.py
Dosyayı görüntüle @
7b3b3dc8
...
...
@@ -333,7 +333,7 @@ def wait(fs, *, loop=None, timeout=None, return_when=ALL_COMPLETED):
Note: This does not raise TimeoutError! Futures that aren't done
when the timeout occurs are returned in the second set.
"""
if
isinstance
(
fs
,
futures
.
Future
)
or
coroutines
.
iscoroutine
(
fs
):
if
futures
.
isfuture
(
fs
)
or
coroutines
.
iscoroutine
(
fs
):
raise
TypeError
(
"expect a list of futures, not
%
s"
%
type
(
fs
)
.
__name__
)
if
not
fs
:
raise
ValueError
(
'Set of coroutines/Futures is empty.'
)
...
...
@@ -462,7 +462,7 @@ def as_completed(fs, *, loop=None, timeout=None):
Note: The futures 'f' are not necessarily members of fs.
"""
if
isinstance
(
fs
,
futures
.
Future
)
or
coroutines
.
iscoroutine
(
fs
):
if
futures
.
isfuture
(
fs
)
or
coroutines
.
iscoroutine
(
fs
):
raise
TypeError
(
"expect a list of futures, not
%
s"
%
type
(
fs
)
.
__name__
)
loop
=
loop
if
loop
is
not
None
else
events
.
get_event_loop
()
todo
=
{
ensure_future
(
f
,
loop
=
loop
)
for
f
in
set
(
fs
)}
...
...
@@ -538,7 +538,7 @@ def ensure_future(coro_or_future, *, loop=None):
If the argument is a Future, it is returned directly.
"""
if
isinstance
(
coro_or_future
,
futures
.
F
uture
):
if
futures
.
isfuture
(
coro_or_f
uture
):
if
loop
is
not
None
and
loop
is
not
coro_or_future
.
_loop
:
raise
ValueError
(
'loop argument must agree with Future'
)
return
coro_or_future
...
...
@@ -614,7 +614,7 @@ def gather(*coros_or_futures, loop=None, return_exceptions=False):
arg_to_fut
=
{}
for
arg
in
set
(
coros_or_futures
):
if
not
isinstance
(
arg
,
futures
.
Future
):
if
not
futures
.
isfuture
(
arg
):
fut
=
ensure_future
(
arg
,
loop
=
loop
)
if
loop
is
None
:
loop
=
fut
.
_loop
...
...
Lib/test/test_asyncio/test_events.py
Dosyayı görüntüle @
7b3b3dc8
...
...
@@ -793,7 +793,7 @@ class EventLoopTestsMixin:
loop
.
connect_accepted_socket
(
(
lambda
:
proto
),
conn
,
ssl
=
server_ssl
))
loop
.
run_forever
()
conn
.
close
()
proto
.
transport
.
close
()
lsock
.
close
()
thread
.
join
(
1
)
...
...
Lib/test/test_asyncio/test_futures.py
Dosyayı görüntüle @
7b3b3dc8
...
...
@@ -25,6 +25,74 @@ def last_cb():
pass
class
DuckFuture
:
# Class that does not inherit from Future but aims to be duck-type
# compatible with it.
_asyncio_future_blocking
=
False
__cancelled
=
False
__result
=
None
__exception
=
None
def
cancel
(
self
):
if
self
.
done
():
return
False
self
.
__cancelled
=
True
return
True
def
cancelled
(
self
):
return
self
.
__cancelled
def
done
(
self
):
return
(
self
.
__cancelled
or
self
.
__result
is
not
None
or
self
.
__exception
is
not
None
)
def
result
(
self
):
assert
not
self
.
cancelled
()
if
self
.
__exception
is
not
None
:
raise
self
.
__exception
return
self
.
__result
def
exception
(
self
):
assert
not
self
.
cancelled
()
return
self
.
__exception
def
set_result
(
self
,
result
):
assert
not
self
.
done
()
assert
result
is
not
None
self
.
__result
=
result
def
set_exception
(
self
,
exception
):
assert
not
self
.
done
()
assert
exception
is
not
None
self
.
__exception
=
exception
def
__iter__
(
self
):
if
not
self
.
done
():
self
.
_asyncio_future_blocking
=
True
yield
self
assert
self
.
done
()
return
self
.
result
()
class
DuckTests
(
test_utils
.
TestCase
):
def
setUp
(
self
):
self
.
loop
=
self
.
new_test_loop
()
self
.
addCleanup
(
self
.
loop
.
close
)
def
test_wrap_future
(
self
):
f
=
DuckFuture
()
g
=
asyncio
.
wrap_future
(
f
)
assert
g
is
f
def
test_ensure_future
(
self
):
f
=
DuckFuture
()
g
=
asyncio
.
ensure_future
(
f
)
assert
g
is
f
class
FutureTests
(
test_utils
.
TestCase
):
def
setUp
(
self
):
...
...
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