Wykres commitów

658 Commity (6752c6a66ac21495b63026f21d29f6426d73f98f)

Autor SHA1 Wiadomość Data
Paul Sokolovsky eff1250e3b asyncio_micro: Optimize size of SysCall objects.
We have to have type header for any object, so use type to "store"
information about syscall type (my initial idea was to have single
syscall class and dispatch on its attribute, that would save memory
on having bunch of classes, but would increase size of each syscall
object).
2014-10-21 01:31:58 +03:00
Paul Sokolovsky 06c8c6ce8f asyncio_micro: Move handle() method to SysCall base class. 2014-10-21 01:31:58 +03:00
Paul Sokolovsky 6115b451ea asyncio_micro: Clean up logging. 2014-10-21 01:31:58 +03:00
Paul Sokolovsky 4af1cf5a30 asyncio_micro: Support just plain "yield" for cooperative control yield. 2014-10-21 01:31:58 +03:00
Paul Sokolovsky d0d2810b0c asyncio_micro: Rename StreamWriter.write() to awrite().
This method has different semantics than original asyncio, so rename to avoid
confusion. Original asyncio's is not a coroutine, while ours is.
2014-10-21 01:31:58 +03:00
Paul Sokolovsky 9c3a3cd5ed asyncio_micro: Add basic HTTP server example. 2014-10-21 01:31:58 +03:00
Paul Sokolovsky 15cc7aa7b7 asyncio_micro: Implement proper write() handling.
TODO: Test!
2014-10-21 01:31:58 +03:00
Paul Sokolovsky 6e61c501ac asyncio_micro: Support readall semantics and handle non-blocking read() well.
Non-blocking read()/write() may return None if there's no data, and that's
not EOF.
2014-10-21 01:31:58 +03:00
Paul Sokolovsky fe85cca848 asyncio_micro: Add support for starting a coroutine concurrently.
Just yield it as a value. Also, improve logging/error reporting.
2014-10-21 01:31:58 +03:00
Paul Sokolovsky bfaf6b8d19 asyncio_micro: IODone syscall should return to coroutine. 2014-10-21 01:31:58 +03:00
Paul Sokolovsky acd25d05fc asyncio_micro: Implement start_server(). 2014-10-21 01:31:58 +03:00
Paul Sokolovsky b86919a6ff asyncio_micro: StreamReader, StreamWriter: add more methods. 2014-10-21 01:31:58 +03:00
Paul Sokolovsky 1c647189f1 asyncio_micro: Work around stupid Python closures.
Which don't close variables, just variable references.
2014-10-21 01:31:58 +03:00
Paul Sokolovsky 0b5ca354e2 asyncio_micro: Rename from asyncio.
As this is not compliant with asyncio API, can't be called asyncio, and
"micro" is just good moniker for what it's intended to be.
2014-10-21 01:31:58 +03:00
Paul Sokolovsky 4071bb5e74 asyncio: Clean up code a bit. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky bce6c1cadf asyncio: Remove polling sleep implementation, it belongs in async_slow. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 2feacf5a50 asyncio_slow: Add example of wait() from docs. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 3949d4f8b6 asyncio_slow: Fix wait: again, should not schedule anything itself. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 0b1d9a0493 asyncio_slow: Add Future examples from docs. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 30a0586732 asyncio_slow: Implement loop.stop(). 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 8d1ae59f3a asyncio_slow: run_until_complete() should not schedule anyhing.
Everything should be scheduled either already, or async() does this.
2014-10-21 01:31:57 +03:00
Paul Sokolovsky 4a3a4927c4 asyncio_slow: Add example on chaining coros using "yield from" from docs. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky ce54259e95 asyncio_slow: Add example for scheduling coro using Task. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky fdc3e21820 asyncio_slow: Add coroutine example from docs. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky d50091b802 asyncio_slow: Add callback example from docs. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 6c419ad0ec asyncio_slow: Fix call_soon(), add call_later(). 2014-10-21 01:31:57 +03:00
Paul Sokolovsky c78c27c1dd asyncio_slow: Start new upstream API-compatible asyncio implementation.
The trait of this implementation is that it doesn't use priority queue and
time scheduling, and instead does its all operations using polling, starting
with such basic one as sleep. On the other hand, this tries to implement
all (well, much) of upstream asyncio API and warts.

asyncio_slow: Rename from asyncio_micro.

It may turn out that this won't be "micro" at all. The main trait of this
implementation is that it stay 100% API compatible with upstream (in
those APIs which are implemented of course). It will also keep inefficient
implementation of event loop scheduling, to discourage its use. Here we go.
2014-10-21 01:31:57 +03:00
Paul Sokolovsky f0ce7978ce asyncio: Add basic asyncio stream interface test. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 0adccf0ab1 asyncio: Handle end of stream condition properly.
By removing any IO watches for associated file handle. The way it's
implemented tries to preserve OS-like separation between event loop and
tasks. So, stream to finish watching fd for IO also issues syscall,
instead of calling methods on loop instance directly. Calling method on
loop would be more efficient, but will require storing reference to loop
in each stream. And those separation matters...
2014-10-21 01:31:57 +03:00
Paul Sokolovsky fa273cae71 asyncio: Add basic loop.call_soon() test. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 179d0447f1 asyncio: Add asyncio.async() dummy factory function.
Not Task bloat implemented (so far?), so just identity function for CPython
compatibility.
2014-10-21 01:31:57 +03:00
Paul Sokolovsky e1537df79d asyncio: Add remove_reader()/remove_writer(). 2014-10-21 01:31:57 +03:00
Paul Sokolovsky f79b960890 asyncio: Use logging and errno modules. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 517c6ea084 asyncio: Add dumb debug output. 2014-10-21 01:31:57 +03:00
Paul Sokolovsky 02daa74b24 asyncio: Start adding asyncio stream interface. 2014-10-21 01:31:56 +03:00
Paul Sokolovsky ac0038f9a7 asyncio: Support read/write syscalls, and route vals both ways between coros. 2014-10-21 01:31:56 +03:00
Paul Sokolovsky 85071250f1 asyncio: EpollEventLoop.wait(): support infinite wait. 2014-10-21 01:31:56 +03:00
Paul Sokolovsky a71d4f45c1 asyncio: Make run_forever() actually run forever. 2014-10-21 01:31:56 +03:00
Paul Sokolovsky ee495b3807 asyncio: Recover eventloop's ability to work with callbacks.
Actually, coroutine support for call_soon() is a hack, in big asyncio coroutine
should be wrapped in Task object.
2014-10-21 01:31:56 +03:00
Paul Sokolovsky b42f8e383b asyncio: Implement subclass implementing filedes watching interface. 2014-10-21 01:31:56 +03:00
Paul Sokolovsky 80cea91b98 asyncio: Initial prototype implementation. 2014-10-21 01:31:56 +03:00
Paul Sokolovsky b45774b85b README.md: Tweak a bit. 2014-10-19 14:29:10 +03:00
Paul Sokolovsky e42b955c1d socket: Update for rename microsocket -> usocket. 2014-10-11 05:18:49 +03:00
Paul Sokolovsky d33f35334b _libc: Release 0.2.1. 2014-10-11 05:17:14 +03:00
blmorris 814071f45b _libc: Add support for MacOS X (using "libc.dylib"). 2014-10-06 23:39:22 +03:00
Damien George f2cb007ce5 sqlite3: Change return type of column_double from "f" to "d".
ffi now works properly with double return type, so this function can
return the correct type.  Can confirm that sqlite3_column_double now
works correctly on 32-bit and 64-bit x86.
2014-09-10 21:06:54 +01:00
Paul Sokolovsky bc1ea4fc21 _libc: Version 0.2. 2014-09-08 20:02:42 +03:00
Paul Sokolovsky 165fbbd768 select: Add yet another workaround for struct epoll_event, this time for x86_64.
So, it's now clear that dealing with this struct should be rather moved on C side.
2014-09-06 19:36:28 +03:00
Paul Sokolovsky 22da54bc83 os: Version 0.1.9. 2014-09-06 17:13:28 +03:00
Paul Sokolovsky a9fd762b81 os: listdir(), walk(): Handle unicode strings properly.
CPython lib reference specifies that listdir() should accept both bytes and
str argument, and return value type should match the argument. But no such
stipulation is made for walk(), so we just return strings.
2014-09-06 17:06:07 +03:00