Skip to main content

A tonio-powered fork of uvicorn.

Project description

toncorn

An ASGI web server for free-threaded Python, powered by tonio.

toncorn is a fork of uvicorn that swaps the asyncio runtime for tonio.

Install

$ pip install toncorn

toncorn requires free-threaded CPython 3.14 or newer (python3.14t) and runs PYTHON_GIL=0. Linux and macOS only; Windows is not supported and won't be (tonio doesn't target it).

For the optional protocol/parser extras (matching upstream uvicorn's [standard] set):

$ pip install 'toncorn[standard]'

Quickstart

example.py:

async def app(scope, receive, send):
    assert scope["type"] == "http"
    await send({
        "type": "http.response.start",
        "status": 200,
        "headers": [(b"content-type", b"text/plain")],
    })
    await send({
        "type": "http.response.body",
        "body": b"Hello, world!",
    })

Run it:

$ PYTHON_GIL=0 toncorn example:app

You'll see a banner identifying the toncorn version and the uvicorn version it tracks:

INFO:     toncorn 0.48.0.0 (uvicorn 0.48.0)
INFO:     Started server process [12345]
INFO:     Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)

The package ships both import toncorn and import uvicorn — the source tree lives under the original uvicorn package name to keep the diff against upstream small, and toncorn is a thin re-export. Pick whichever import you prefer; they expose the same Config, Server, run, main.

Note: this means toncorn and the real PyPI uvicorn collide on the uvicorn import name; don't install both in the same environment.

Programmatic use

import toncorn
toncorn.run("example:app", host="127.0.0.1", port=8000)

Or with an explicit Config + Server:

import toncorn

config = toncorn.Config(app=app, host="127.0.0.1", port=8000)
server = toncorn.Server(config)
server.run()

Differences from uvicorn

  • Runtime is tonio, not asyncio. There's no --loop flag, no uvloop/asyncio switch. Everything runs on a single tonio runtime with a configurable thread pool.
  • Concurrency model is threads, not processes. The old --workers N flag is replaced by --threads N, which sizes the tonio scheduler's thread pool. No multiprocessing supervisor, no preforked workers, no graceful-restart process orchestration.
  • No --reload. The auto-reload supervisor is gone. Use your editor's hot-reload or a separate process manager during development.
  • No Windows support. POSIX only.
  • No in-tree WSGI middleware. The deprecated WSGI bridge has been removed; use a2wsgi or asgiref.wsgi if you need WSGI compatibility.
  • Python 3.14+ only. Earlier Python versions are not supported.

The version number reflects both upstream and fork: {uvicorn}.{toncorn}, so 0.48.0.0 tracks uvicorn 0.48.0 with toncorn patch 0. Patch-level releases against the same uvicorn baseline bump the last segment (0.48.0.00.48.0.1).

Upstream tracking

The source tree under uvicorn/ is kept as close to upstream uvicorn as possible to make merges/rebases tractable. Fork-specific changes are intentionally minimal and called out where they appear. The toncorn/ package is a re-export shim plus the toncorn-specific version.

License

BSD-3-Clause, same as upstream uvicorn. See LICENSE.md.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

toncorn-0.49.0.0.tar.gz (59.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

toncorn-0.49.0.0-py3-none-any.whl (49.3 kB view details)

Uploaded Python 3

File details

Details for the file toncorn-0.49.0.0.tar.gz.

File metadata

  • Download URL: toncorn-0.49.0.0.tar.gz
  • Upload date:
  • Size: 59.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for toncorn-0.49.0.0.tar.gz
Algorithm Hash digest
SHA256 c28eb7f28b30e9238b85baee1214be6ac71f4533baf51e0b06136536fa8920eb
MD5 4ce4849d588dd16f27ed7352003efa96
BLAKE2b-256 8c8b791d6f2367bb039bc59fb19d07f202df98b2cbe8c56f10b0d658b8849a7d

See more details on using hashes here.

Provenance

The following attestation bundles were made for toncorn-0.49.0.0.tar.gz:

Publisher: publish.yml on gi0baro/toncorn

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file toncorn-0.49.0.0-py3-none-any.whl.

File metadata

  • Download URL: toncorn-0.49.0.0-py3-none-any.whl
  • Upload date:
  • Size: 49.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for toncorn-0.49.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ea2d1e3f96ba558806aac8f36176f37987f5ab4f805890ba83b6057aebb56ac3
MD5 2b9768594e57c3a3349823d3db3b2508
BLAKE2b-256 9e67f08b39c453233353fcef55957ae446bf52b16e5d00d8584b90d85fb8a259

See more details on using hashes here.

Provenance

The following attestation bundles were made for toncorn-0.49.0.0-py3-none-any.whl:

Publisher: publish.yml on gi0baro/toncorn

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page