Metadata-Version: 2.4
Name: literalenum
Version: 0.2.0
Summary: A Python typing construct that provides namespaced literal constants with advanced typing features.
Project-URL: Homepage, https://github.com/modularizer/literalenum
Project-URL: Repository, https://github.com/modularizer/literalenum
Project-URL: Issues, https://github.com/modularizer/literalenum/issues
Author-email: Torin Halsted <modularizer@gmail.com>
License: Unlicense
License-File: LICENSE
Keywords: python,typehinting
Requires-Python: >=3.10
Description-Content-Type: text/markdown

from sample_str_enum_solutions.a_strenum import HttpMethod

# LiteralEnum

**LiteralEnum** is an experiment/prototype for a proposed Python typing construct: 
a *finite, named set of runtime literals* (usually strings) that type checkers can treat as 
an **exhaustive `Literal[...]` union**.

> Status: Prototype / exploration for typing-sig discussion. Not an accepted PEP.

## Why this exists
In typed Python today you often have to pick one:

- `Enum` / `StrEnum`: great runtime namespace, but APIs want callers to pass enum members instead of raw strings
- `Literal[...]`: great static checking, but no runtime namespace/iteration/validation

So people duplicate values or accept `str` and validate at runtime.

LiteralEnum aims to make the common case a single source of truth.

It’s designed for “protocol token” style values—HTTP methods, event names, command identifiers, config keys—where you want:
- **plain literals at runtime** (e.g. `"GET"`),
- **namespaced constants** (e.g. `HttpMethod.GET`), and
- **static exhaustiveness checking** (i.e. the type is equivalent to `Literal["GET", "POST", ...]`).

---
## Table of Contents
- [Typing discussion](https://discuss.python.org/t/proposal-literalenum-runtime-literals-with-static-exhaustiveness/106000) with the Python community
- [PEP.md](/PEP.md) is a draft PEP
- [LITMUS.md](/LITMUS.md) describes the project goals
- [TYPING_DISCUSSION.md](/TYPING_DISCUSSION.md) is shows drafts from the discussion
- [src/typing_literalenum.py](/src/typing_literalenum.py) is a the draft of the core runtime functionality (proposed to become `typing.LiteralEnum` or `typing_extensions.LiteralEnum`)
- [src/literalenum](/src/literalenum) is the full proposed PyPi module
- [src/literalenum/mypy_plugin.py](/src/literalenum/mypy_plugin.py) is an experimental **mypy plugin**
- [src/literalenum/samples](/src/literalenum/samples) shows sample usage
- [src/literalenum/stubgen.py](/src/literalenum/stubgen.py) provides tools for generating stubs, usable through CLI tool `lestub`

---

## Quickstart

## Install

This repo is currently set up as a package under `src/`.

```bash
#python -m venv .venv
#source .venv/bin/activate
pip install literalenum
```
## Realistic Current Usage
```python
from typing import Literal
from literalenum import LiteralEnum

HttpMethodT = Literal["GET", "POST", "DELETE"]
class HttpMethod(LiteralEnum):
    GET = "GET"
    POST = "POST"
    DELETE = "DELETE"

def handle(method: HttpMethodT) -> None:
    print(f"{method=}")

handle("GET")          # this should type-check ✅ 
handle(HttpMethod.GET) # this should type-check ✅ 
handle("git")          # ❌ should be rejected by a type checker

assert HttpMethod.GET == "GET"
assert list(HttpMethod) == ["GET", "POST", "DELETE"]
assert "GET" in HttpMethod
print(HttpMethod.keys())
print(HttpMethod.values())
print(HttpMethod.mapping)
```

## Optimistic Future Usage
```python
from typing import LiteralEnum # NOT valid right now

class HttpMethod(LiteralEnum):
    GET = "GET"
    POST = "POST"
    DELETE = "DELETE"

def handle(method: HttpMethod) -> None:
    print(f"{method=}")

handle("GET")          # the GOAL is that this should type-check ✅ , in reality: it will not unless typecheckers change
handle(HttpMethod.GET) # the GOAL is that this should type-check ✅ , in reality: it will not unless typecheckers change
handle("git")          # ❌ should be rejected by a type checker

assert HttpMethod.GET == "GET"
assert list(HttpMethod) == ["GET", "POST", "DELETE"]
assert "GET" in HttpMethod
print(HttpMethod.keys())
print(HttpMethod.values())
print(HttpMethod.mapping)
```

---

## Contributing / discussion

Actively looking for feedback!
Please comment at https://discuss.python.org/t/proposal-literalenum-runtime-literals-with-static-exhaustiveness/106000

It would be especially helpful if you are familiar with mypy/pright/pylance and have suggestions on how
a future Python version could support the type hinting goals.

---

## License

This project is released into the **public domain** under **The Unlicense**.

You are free to copy, modify, publish, use, compile, sell, or distribute this software,
either in source code form or as a compiled binary, for any purpose, commercial or non-commercial,
and by any means.

See the `LICENSE` file for full details.

