Tyler Goodlet
095c94b1d2
Fix `Portal.run_in_actor()` returns `None` bug
...
Fixes the issue where if the main remote task returns `None`,
`Portal.result()` would erroneously wait again on the underlying feeder
mem chan since `None` was being used as the cache flag. Instead set the
flag as the channel uid and consider the result collected when set to
anything else (since it would be odd to return that value from a remote
task when you already can read it as part of portal/channel apis).
2021-11-20 13:02:08 -05:00
Tyler Goodlet
f32ccd76aa
Add `Portal.result()` is None test case
...
This demonstrates a bug where if the remote `.run_in_actor()` task
returns `None` then multiple calls to `Portal.result()` will hang
forever...
2021-11-20 13:02:08 -05:00
goodboy
b527fdbe1a
Merge pull request #263 from goodboy/early_deth_fixes
...
Early deth fixes
2021-11-08 21:23:09 -05:00
Tyler Goodlet
6b0366fe04
Guard against TCP server never started on cancel
2021-11-07 23:49:32 -05:00
Tyler Goodlet
dbe5d96d66
Fix missing yield in lock acquirer
2021-11-07 23:48:05 -05:00
goodboy
08fa55a8c3
Merge pull request #260 from goodboy/clusters_and_hot_tips
...
Clusters and hot tips
2021-11-04 12:02:14 -04:00
Tyler Goodlet
546e1b2fa3
Drop unecessary partial
2021-11-04 10:41:25 -04:00
Tyler Goodlet
94a6fefede
Add `open_actor_cluster()` eg. to readme
2021-11-02 15:42:19 -04:00
Tyler Goodlet
74f460eba7
Make auto generated child names <parent_name>.<name>
2021-11-02 15:40:15 -04:00
Tyler Goodlet
4cbb8641de
Add an `open_actor_cluster()` usage example
2021-11-02 15:37:36 -04:00
Tyler Goodlet
7efb7da300
Start a hot tips for devs doc
2021-11-02 15:08:20 -04:00
goodboy
2c12d39617
Merge pull request #259 from goodboy/alpha3
...
Alpha3
2021-11-02 14:47:28 -04:00
Tyler Goodlet
6a063b3814
Bump release date by a day
2021-11-02 12:59:26 -04:00
Tyler Goodlet
9da1abeecd
Super naive attempt to skip 3.10 on windows
2021-11-02 12:19:58 -04:00
Tyler Goodlet
3452e18e6d
Toss 3.10 into CI
2021-11-01 14:12:42 -04:00
Tyler Goodlet
8fdc548676
Alpha3 version bump and release notes
2021-11-01 14:02:45 -04:00
goodboy
5dbe8e4b14
Merge pull request #241 from goodboy/trionics
...
Trionics
2021-10-27 13:09:11 -04:00
goodboy
9c13827a14
Merge pull request #256 from overclockworked64/241-news-fragment
...
Add a news fragment
2021-10-27 12:38:15 -04:00
overclockworked64
6da76949fd
Fix the syntax and point to the new package
2021-10-27 17:03:25 +02:00
overclockworked64
49dd230b4f
Add a newline
2021-10-25 20:01:21 +02:00
overclockworked64
c7f59bd483
Add a news fragment
2021-10-25 19:17:42 +02:00
Tyler Goodlet
083b73ad4a
Test: don't grab debug lock if not in mode
2021-10-25 10:22:41 -04:00
goodboy
925af28092
Merge pull request #254 from goodboy/graceful_gather
...
Change to `gather_contexts()`, use event for graceful exit
2021-10-25 10:14:01 -04:00
Tyler Goodlet
d0f5c7a5e2
Change to `gather_contexts()`, use event for graceful exit
...
The api we've made here is actually closer to `asyncio.gather()` but
with opening async context managers instead of funcs. Use another event
to allow for graceful teardown of children on non-cancellation exits
and add a doc string.
2021-10-24 14:00:01 -04:00
goodboy
ebf080b8a2
Merge pull request #253 from overclockworked64/fix-type-annotation
...
Fix type annotations
2021-10-23 19:09:11 -04:00
overclockworked64
50400359b8
Fix type annotations
2021-10-24 00:47:26 +02:00
goodboy
71b8f9f1ea
Merge pull request #252 from goodboy/246_facepalm_backup
...
Trionics improvements from @overclockworked64
2021-10-23 18:10:17 -04:00
overclockworked64
b91adcf38d
Get rid of external teardown trigger
2021-10-23 16:17:30 -04:00
overclockworked64
87e3d32992
Get rid of external teardown trigger because #245 resolves the problem
2021-10-23 16:17:30 -04:00
overclockworked64
04895b9d5e
Get rid of dumb random uid and use current actor's uid
2021-10-23 16:17:30 -04:00
overclockworked64
b7a4641674
Allow specifying start_method and hard_kill
2021-10-23 16:17:30 -04:00
overclockworked64
c1089dbd95
Add a clustering test
2021-10-23 16:17:30 -04:00
overclockworked64
3130a04c61
Rename a variable and fix type annotations
2021-10-23 16:17:29 -04:00
overclockworked64
6f9229cd09
Cancel nursery
2021-10-23 16:17:29 -04:00
overclockworked64
6e6baf250b
Make sure the ID is a str
2021-10-23 16:17:29 -04:00
overclockworked64
73cbb2388a
Avoid RuntimeError by not using current_actor's uid
2021-10-23 16:17:29 -04:00
overclockworked64
2815f1c343
Make 'async_enter_all' take a teardown trigger which '_enter_and_wait' will wait on
2021-10-23 16:17:29 -04:00
overclockworked64
21afc69ac7
Postpone evaluation of annotations
2021-10-23 16:17:29 -04:00
overclockworked64
7d502cef74
Add 'open_actor_cluster' to __all__
2021-10-23 16:17:29 -04:00
overclockworked64
76767a3d7e
Add 'trio.trionics' to setup.py
2021-10-23 16:17:29 -04:00
Tyler Goodlet
c372367cc2
Fix *args-like type annot
2021-10-23 15:54:40 -04:00
Tyler Goodlet
9ddd75733c
Lul, fix everything for cluster helper
2021-10-23 15:54:40 -04:00
Tyler Goodlet
8ba10315c1
Fix type path to new `_supervise` mod
2021-10-23 15:54:40 -04:00
Tyler Goodlet
97006c904c
Expose `Lagged` for broadcasting
2021-10-23 15:54:40 -04:00
Tyler Goodlet
79fb1d0ebc
Fix top level nursery import
2021-10-23 15:54:40 -04:00
Tyler Goodlet
1e917fdb1d
Add an async actor cluster spawner prototype
2021-10-23 15:54:40 -04:00
Tyler Goodlet
4114eb1d25
Move broadcast channel parts into trionics
2021-10-23 15:54:40 -04:00
Tyler Goodlet
680a841282
Start `trionics` sub-pkg with `async_enter_all()`
...
Since it seems we're building out more and more higher level primitives
in order to support certain parallel style actor trees and messaging
patterns (eg. task broadcast channels), we might as well start a new
sub-package for purely `trio` constructions. We hereby dub this
the realm of `trionics` (like electronics but for trios instead of
electrons).
To kick things off, add an `async_enter_all()` concurrent
exit-stack-like context manager API which will concurrently spawn
a sequence of provided async context managers and deliver their ordered
results but with proper support for `trio` cancellation semantics.
The stdlib's `AsyncExitStack` is not compatible with nurseries not
`trio` tasks (which are cancelled) since as task will be suspended on
the stack after push and does not ever hit a checkpoint until the stack
is closed.
2021-10-23 15:54:40 -04:00
Tyler Goodlet
340ddba4ae
Rename the nursery module to `_supervise`
2021-10-23 15:54:40 -04:00
goodboy
be5582aae3
Merge pull request #248 from overclockworked64/patch-ci
...
Drop 3.8 support
2021-10-23 15:53:55 -04:00