cogen 0.1.6
Coroutines and asynchronous I/O using enhanced generators from python 2.5, including a enhanced WSGI server.
Latest Version: 0.2.1
Overview
This is a library for network oriented, coroutine based programming.
cogen's goal is to enable writing code in a synchronous and easy manner in the form of generators that yield calls and receive the result from that yield. These calls translate to asynchronous and fast os calls in cogen's internals.
Notable features
- a WSGI server, HTTP1.1 compliant, with asynchronous extensions
- use epoll, kqueue where supported, select based otherwise
- a Queue with the same interface as the standard library Queue, but for coroutines
Quick introduction
Programming with cogen library should be straightforward, similar with programming threads but without all the problems. A coroutine is just a generator wrapped in a operation handling class:
@coroutine
def mycoro(bla):
result = yield <operation>
result = yield <operation>
- the operation instructs the scheduler what to do with the coroutine: suspend it till something happens, add another coro in the scheduler, raise a event and so on.
- if a operation has a result associated then the yield will return that result (eg. a string or a (connection, address) tuple) otherwise it will return the operation instance.
Echo server example
from cogen.core import sockets
from cogen.core import schedulers
from cogen.core.coroutine import coroutine
@coroutine
def server():
srv = sockets.Socket()
print type(srv)
srv.bind(('localhost',777))
srv.listen(10)
while 1:
print "Listening..."
conn, addr = yield srv.accept()
print "Connection from %s:%s" % addr
m.add(handler, args=(conn, addr))
@coroutine
def handler(sock, addr):
yield sock.write("WELCOME TO ECHO SERVER !\r\n")
while 1:
line = yield sock.readline(8192)
if line.strip() == 'exit':
yield sock.write("GOOD BYE")
sock.close()
return
yield sock.write(line)
m = schedulers.Scheduler()
m.add(server)
m.run()
Links
Development
Takes place at: http://code.google.com/p/cogen/
Grab the latest and greatest from trunk with:
easy_install cogen==dev
| File | Type | Py Version | Uploaded on | Size | # downloads |
|---|---|---|---|---|---|
| cogen-0.1.6.zip (md5) | Source | 2008-02-23 17:48:37 | 237KB | 133 | |
| cogen-0.1.6-py2.5.egg (md5) | Python Egg | 2.5 | 2008-02-23 17:48:37 | 97KB | 217 |
- Author: Maries Ionel Cristian <ionel dot mc at gmail dot com>
- Home Page: http://code.google.com/p/cogen/
-
Categories
- Development Status :: 3 - Alpha
- Environment :: Web Environment
- Intended Audience :: Developers
- Intended Audience :: System Administrators
- License :: OSI Approved :: MIT License
- Operating System :: Microsoft :: Windows
- Operating System :: POSIX
- Programming Language :: Python
- Topic :: Internet :: WWW/HTTP :: HTTP Servers
- Topic :: Internet :: WWW/HTTP :: WSGI :: Server
- Topic :: System :: Networking
- Package Index Owner: ionel
- DOAP record: cogen-0.1.6.xml
Log in to rate this package.
