Skip to main content

Monsters for your language games.

Project description

     .─') _                                       .─') _                  
    (  OO) )                                     ( OO ) )            
  ░██████  ░██ ░██   ░██               ░██       ░██ ░██                                 
 ░██   ░██ ░██       ░██               ░██       ░██                                     
░██        ░██ ░██░████████  ░███████ ░████████  ░██ ░██░████████   ░████████ ░███████  
░██  █████ ░██ ░██   ░██    ░██('─.░██ ░██    ░██ ░██ ░██░██    ░██ ░██.─')░██ ░██        
░██     ██ ░██ ░██   ░██    ░██( OO ) ╱░██    ░██ ░██ ░██░██    ░██ ░██(OO)░██ ░███████  
  ░██  ░███ ░██ ░██   ░██   ░██    ░██ ░██    ░██ ░██ ░██░██    ░██ ░██  o░███      ░██ 
  ░█████░█ ░██ ░██   ░████   ░███████  ░██    ░██ ░██ ░██░██    ░██  ░█████░██ ░███████  
                                                                    ░██            
                                                                ░███████             

                        Every language game breeds monsters.

Python Versions PyPI version Wheel Linting and Typing
Entropy Budget Chaos Charm
Lore Compliance

Glitchlings are utilities for corrupting the text inputs to your language models in deterministic, linguistically principled ways.
Each embodies a different way that documents can be compromised in the wild.

If reinforcement learning environments are games, then Glitchlings are enemies to breathe new life into old challenges.

They do this by breaking surface patterns in the input while keeping the target output intact.

Some Glitchlings are petty nuisances. Some Glitchlings are eldritch horrors.
Together, they create truly nightmarish scenarios for your language models.

After all, what good is general intelligence if it can't handle a little chaos?

-The Curator

Quickstart

pip install -U glitchlings

Glitchlings requires Python 3.10 or newer.

from glitchlings import Gaggle, SAMPLE_TEXT, Typogre, Mim1c, Rushmore

gaggle = Gaggle(
    [
        Rushmore(rate=0.02),
        Rushmore(modes="duplicate", seed=404),
        Mim1c(rate=0.02),
        Typogre(rate=0.03),
    ]
)

print(gaggle(SAMPLE_TEXT))

Onҽ m‎ھ‎rning, wһen Gregor Samƽa woke from trouble𝐝 𝑑reams, he found himself transformed in his bed into a horrible vermin‎٠‎ He l lay on his armour-like back, and if he lifted his head a little he could see his brown belly, slightlh domed and divided by arches ino stiff sections. The bedding was adly able to cover it and and seemed ready to slide off any moment. His many legxs, pitifully thin compared with the size of the the rest of him, waved about helplessly ashe looked looked.

Consult the Glitchlings Usage Guide for end-to-end instructions spanning the Python API, CLI, HuggingFace, PyTorch, and Prime Intellect integrations, and the autodetected Rust pipeline (enabled whenever the extension is present).

Motivation

If your model performs well on a particular task, but not when Glitchlings are present, it's a sign that it hasn't actually generalized to the problem.

Conversely, training a model to perform well in the presence of the types of perturbations introduced by Glitchlings should help it generalize better.

Your First Battle

Summon your chosen Glitchling (or a few, if ya nasty) and call it on your text or slot it into Dataset.map(...), supplying a seed if desired. Glitchlings are standard Python classes, so you can instantiate them with whatever parameters fit your scenario:

from glitchlings import Gaggle, Typogre, Mim1c

custom_typogre = Typogre(rate=0.1)
selective_mimic = Mim1c(rate=0.05, classes=["LATIN", "GREEK"])

gaggle = Gaggle([custom_typogre, selective_mimic], seed=99)
print(gaggle("Summoned heroes do not fear the glitch."))

Calling a Glitchling on a str transparently calls .corrupt(str, ...) -> str. This means that as long as your glitchlings get along logically, they play nicely with one another.

When summoned as or gathered into a Gaggle, the Glitchlings will automatically order themselves into attack waves, based on the scope of the change they make:

  1. Document
  2. Paragraph
  3. Sentence
  4. Word
  5. Character

They're horrible little gremlins, but they're not unreasonable.

Command-Line Interface (CLI)

Keyboard warriors can challenge them directly via the glitchlings command:

# Discover which glitchlings are currently on the loose.
glitchlings --list
   Typogre — scope: Character, order: early
     Hokey — scope: Character, order: first
     Mim1c — scope: Character, order: last
   Ekkokin — scope: Word, order: early
    Pedant — scope: Word, order: late
  Jargoyle — scope: Word, order: normal
  Rushmore — scope: Word, order: normal
  Redactyl — scope: Word, order: normal
 Spectroll — scope: Word, order: normal
Scannequin — scope: Character, order: late
    Zeedub — scope: Character, order: last
# Review the full CLI contract.
glitchlings --help
usage: glitchlings [-h] [-g SPEC] [-s SEED] [-f FILE] [--sample] [--diff]
                   [--list] [-c CONFIG]
                   [text ...] {build-lexicon} ...

Summon glitchlings to corrupt text. Provide input text as an argument, via
--file, or pipe it on stdin.

positional arguments:
  text                  Text to corrupt. If omitted, stdin is used or --sample
                        provides fallback text.
  {build-lexicon}
    build-lexicon       Generate synonym caches backed by vector embeddings.

options:
  -h, --help            show this help message and exit
  -g SPEC, --glitchling SPEC
                        Glitchling to apply, optionally with parameters like
                        Typogre(rate=0.05). Repeat for multiples; defaults to
                        all built-ins.
  -s SEED, --seed SEED  Seed controlling deterministic corruption order
                        (default: 151).
  -f FILE, --file FILE  Read input text from a file instead of the command
                        line argument.
  --sample              Use the included SAMPLE_TEXT when no other input is
                        provided.
  --diff                Show a unified diff between the original and corrupted
                        text.
  --list                List available glitchlings and exit.
  -c CONFIG, --config CONFIG
                        Load glitchlings from a YAML configuration file.
# Run Typogre against the contents of a file and inspect the diff.
glitchlings -g typogre --file documents/report.txt --diff

# Configure glitchlings inline by passing keyword arguments.
glitchlings -g "Typogre(rate=0.05)" "Ghouls just wanna have fun"

# Pipe text straight into the CLI for an on-the-fly corruption.
echo "Beware LLM-written flavor-text" | glitchlings -g mim1c

# Load a roster from a YAML attack configuration.
glitchlings --config experiments/chaos.yaml "Let slips the glitchlings of war"

Attack configurations live in plain YAML files so you can version-control experiments without touching code:

# experiments/chaos.yaml
seed: 31337
glitchlings:
  - name: Typogre
    rate: 0.04
  - "Rushmore(rate=0.12, unweighted=True)"
  - name: Zeedub
    parameters:
      rate: 0.02
      characters: ["\u200b", "\u2060"]

Pass the file to glitchlings --config or load it from Python with glitchlings.load_attack_config and glitchlings.build_gaggle.

Development

Follow the development setup guide for editable installs, automated tests, and tips on enabling the Rust pipeline while you hack on new glitchlings.

Starter 'lings

For maintainability reasons, all Glitchling have consented to be given nicknames once they're in your care. See the Monster Manual for a complete bestiary.

Typogre

What a nice word, would be a shame if something happened to it.

Fatfinger. Typogre introduces character-level errors (duplicating, dropping, adding, or swapping) based on the layout of a keyboard (QWERTY by default, with Dvorak and Colemak variants built-in).

Args

  • rate (float): The maximum number of edits to make as a percentage of the length (default: 0.02, 2%).
  • keyboard (str): Keyboard layout key-neighbor map to use (default: "CURATOR_QWERTY"; also accepts "QWERTY", "DVORAK", "COLEMAK", and "AZERTY").
  • seed (int): The random seed for reproducibility (default: 151).

Apostrofae

It looks like you're trying to paste some text. Can I help?

Paperclip Manager. Apostrofae scans for balanced runs of straight quotes, apostrophes, and backticks before replacing them with randomly sampled smart-quote pairs from a curated lookup table. The swap happens in-place so contractions and unpaired glyphs remain untouched.

Args

  • seed (int): Optional seed controlling the deterministic smart-quote sampling (default: 151).

Mim1c

Wait, was that...?

Confusion. Mim1c replaces non-space characters with Unicode Confusables, characters that are distinct but would not usually confuse a human reader.

Args

  • rate (float): The maximum proportion of characters to replace (default: 0.02, 2%).
  • classes (list[str] | "all"): Restrict replacements to these Unicode script classes (default: ["LATIN", "GREEK", "CYRILLIC"]).
  • banned_characters (Collection[str]): Characters that must never appear as replacements (default: none).
  • seed (int): The random seed for reproducibility (default: 151).

Hokey

She's soooooo coooool!

Passionista. Hokey sometimes gets a little excited and elongates words for emphasis.

Args

  • rate (float): Share of high-scoring tokens to stretch (default: 0.3).
  • extension_min / extension_max (int): Bounds for extra repetitions (defaults: 2 / 5).
  • word_length_threshold (int): Preferred maximum alphabetic length; longer words are damped instead of excluded (default: 6).
  • base_p (float): Base probability for the heavy-tailed sampler (default: 0.45).
  • seed (int): The random seed for reproducibility (default: 151).

Apocryphal Glitchling contributed by Chloé Nunes

Scannequin

How can a computer need reading glasses?

OCR Artifacts. Scannequin mimics optical character recognition errors by swapping visually similar character sequences (like rn↔m, cl↔d, O↔0, l/I/1).

Args

  • rate (float): The maximum proportion of eligible confusion spans to replace (default: 0.02, 2%).
  • seed (int): The random seed for reproducibility (default: 151).

Zeedub

Watch your step around here.

Invisible Ink. Zeedub slips zero-width codepoints between non-space character pairs, forcing models to reason about text whose visible form masks hidden glyphs.

Args

  • rate (float): Expected number of zero-width insertions as a proportion of eligible bigrams (default: 0.02, 2%).
  • characters (Sequence[str]): Optional override for the pool of zero-width strings to inject (default: curated invisibles such as U+200B, U+200C, U+200D, U+FEFF, U+2060).
  • seed (int): The random seed for reproducibility (default: 151).

Ekkokin

Did you hear what I heard?

Echo Chamber. Ekkokin swaps words with curated homophones so the text still sounds right while the spelling drifts. Groups are normalised to prevent duplicates and casing is preserved when substitutions fire.

Args

  • rate (float): Maximum proportion of eligible words to replace with homophones (default: 0.02, 2%).
  • seed (int): The random seed for reproducibility (default: 151).

Jargoyle

Uh oh. The worst person you know just bought a thesaurus.

Sesquipedalianism. Jargoyle, the insufferable Glitchling, replaces words from selected parts of speech with synonyms at random, without regard for connotational or denotational differences.

Args

  • rate (float): The maximum proportion of words to replace (default: 0.01, 1%).
  • part_of_speech: The WordNet-style part(s) of speech to target (default: nouns). Accepts wn.NOUN, wn.VERB, wn.ADJ, wn.ADV, any iterable of those tags, or the string "any" to include them all. Vector/graph backends ignore this filter while still honouring deterministic sampling.
  • seed (int): The random seed for reproducibility (default: 151).

Rushmore

I accidentally an entire word.

Tactical Scrambler. Rushmore now orchestrates the full word-level triad—deletions, duplications, and adjacent swaps—that previously lived in separate glitchlings. Select the behaviours you need with the modes parameter (or pass "all") and Rushmore executes them in a deterministic order while sharing one RNG.

Args

  • modes: Choose which word-level attacks to enable. Accepts "delete", "duplicate", "swap", any iterable of those tokens, a corresponding RushmoreMode, or the string "all".
  • rate (float): Global rate applied when per-mode rates are unspecified (default: 0.01, 1%).
  • delete_rate, duplicate_rate, swap_rate (float): Optional per-mode overrides.
  • unweighted (bool): Apply uniform sampling to all modes (default: False).
  • delete_unweighted, duplicate_unweighted (bool | None): Per-mode overrides for weighting strategy.
  • seed (int): The random seed for reproducibility (default: 151).

Redactyl

Oops, that was my black highlighter.

FOIA Reply. Redactyl obscures random words in your document like an NSA analyst with a bad sense of humor.

Args

  • replacement_char (str): The character to use for redaction (default: FULL_BLOCK).
  • rate (float): The maximum proportion of words to redact (default: 0.025, 2.5%).
  • merge_adjacent (bool): Whether to redact the space between adjacent redacted words (default: False).
  • unweighted (bool): Sample words uniformly instead of biasing toward longer tokens (default: False).
  • seed (int): The random seed for reproducibility (default: 151).

Field Report: Uncontained Specimens

Containment procedures pending

  • nylingual backtranslates portions of text.
  • glothopper introduces code-switching effects, blending languages or dialects.
  • palimpsest rewrites, but leaves accidental traces of the past.
  • vesuvius is an apocryphal Glitchling with ties to [Nosy, aren't we? -The Curator]

Apocrypha

Cave paintings and oral tradition contain many depictions of strange, otherworldly Glitchlings.
These Apocryphal Glitchling are said to possess unique abilities or behaviors.
If you encounter one of these elusive beings, please document your findings and share them with The Curator.

Ensuring Reproducible Corruption

Every Glitchling should own its own independent random.Random instance. That means:

  • No random.seed(...) calls touch Python's global RNG.
  • Supplying a seed when you construct a Glitchling (or when you summon(...)) makes its behavior reproducible.
  • Re-running a Gaggle with the same master seed and the same input text (and same external data!) yields identical corruption output.
  • Corruption functions are written to accept an rng parameter internally so that all randomness is centralized and testable.

At Wits' End?

If you're trying to add a new glitchling and can't seem to make it deterministic, here are some places to look for determinism-breaking code:

  1. Search for any direct calls to random.choice, random.shuffle, or set(...) ordering without going through the provided rng.
  2. Ensure you sort collections before shuffling or sampling.
  3. Make sure indices are chosen from a stable reference (e.g., original text) when applying length‑changing edits.
  4. Make sure there are enough sort keys to maintain stability.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

glitchlings-0.7.0-cp313-cp313-win_amd64.whl (1.2 MB view details)

Uploaded CPython 3.13Windows x86-64

glitchlings-0.7.0-cp313-cp313-manylinux_2_28_x86_64.whl (1.4 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.28+ x86-64

glitchlings-0.7.0-cp313-cp313-macosx_11_0_universal2.whl (1.3 MB view details)

Uploaded CPython 3.13macOS 11.0+ universal2 (ARM64, x86-64)

glitchlings-0.7.0-cp312-cp312-win_amd64.whl (1.2 MB view details)

Uploaded CPython 3.12Windows x86-64

glitchlings-0.7.0-cp312-cp312-manylinux_2_28_x86_64.whl (1.4 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ x86-64

glitchlings-0.7.0-cp312-cp312-macosx_11_0_universal2.whl (1.3 MB view details)

Uploaded CPython 3.12macOS 11.0+ universal2 (ARM64, x86-64)

glitchlings-0.7.0-cp311-cp311-win_amd64.whl (1.2 MB view details)

Uploaded CPython 3.11Windows x86-64

glitchlings-0.7.0-cp311-cp311-manylinux_2_28_x86_64.whl (1.4 MB view details)

Uploaded CPython 3.11manylinux: glibc 2.28+ x86-64

glitchlings-0.7.0-cp311-cp311-macosx_11_0_universal2.whl (1.3 MB view details)

Uploaded CPython 3.11macOS 11.0+ universal2 (ARM64, x86-64)

glitchlings-0.7.0-cp310-cp310-win_amd64.whl (1.2 MB view details)

Uploaded CPython 3.10Windows x86-64

glitchlings-0.7.0-cp310-cp310-manylinux_2_28_x86_64.whl (1.4 MB view details)

Uploaded CPython 3.10manylinux: glibc 2.28+ x86-64

glitchlings-0.7.0-cp310-cp310-macosx_11_0_universal2.whl (1.3 MB view details)

Uploaded CPython 3.10macOS 11.0+ universal2 (ARM64, x86-64)

File details

Details for the file glitchlings-0.7.0-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 0ddfad9d3e8723dd8214f7bfab16ca83117639ce49a9e09726baf39b0bea415b
MD5 046843c99c497d60da61be7b5f7091b7
BLAKE2b-256 1e4b4af2e896bbf0671aaec41b8e5a9c68b5e609ec89314c5910103ef047c7e7

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp313-cp313-win_amd64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp313-cp313-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp313-cp313-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 13f70fcefa3eba36cb608c187f9705deae6ed12705c8449054d8f95558deb6c9
MD5 d899ca8d17835ffc20f2da5a928ea372
BLAKE2b-256 c86812d9ff37e7753bb1ad8c078b6ac5a57b4a86faa2746a1ddacc879e3d5f0f

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp313-cp313-manylinux_2_28_x86_64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp313-cp313-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp313-cp313-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 521aa0415872455d6f3c45f1086c1d40105bb9d389eb793d29c0a9eb2a3d779b
MD5 ff707e29b1650fe89fdc2b861affa247
BLAKE2b-256 276a7b7c45594b7cb5c3f6a7d86d3a9b3c7a3643506d418443d98c37b4081e4e

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp313-cp313-macosx_11_0_universal2.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 9190ed65867d8d0679a89ebc746c43ebe9e74819fdfbe3b6f368e13bf05933d4
MD5 5bc981f8be586a3ac43995184cfd485f
BLAKE2b-256 be81306e493908c6449bbd8168cf04072e4d36547018173d150f257ae05e18b5

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp312-cp312-win_amd64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp312-cp312-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp312-cp312-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 eb6e13d60a4bfa23f29fc1699324338a74567e8d656e1a80c36d70364d84f2d6
MD5 97b140aa464065b3e518307aa69b4a4b
BLAKE2b-256 eb882f9c70c50bc8fa67b0d7fe7f91c04368d05a04cf0def4c70f5f9b1008cb3

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp312-cp312-manylinux_2_28_x86_64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp312-cp312-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp312-cp312-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 f460d002049e26bfa352aac3112978489b6dbf454c79f70f4a72470df1a44f48
MD5 a8aff9ce340d43211becf2399bfbe23f
BLAKE2b-256 9bca7f47d554506e2d66a25aaf10752d9679ebf8dd11a5d1636e9fd4deffe08e

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp312-cp312-macosx_11_0_universal2.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 46555dea7510cef7627a5e140c7a6f925e1eacb2869756202e2af3936356776e
MD5 897e581c13029c167a056d8e1a53c0cb
BLAKE2b-256 ab72677e5582fc8d0d9095b118a9eb2af0b2f1dbbab420c9eb5ba5e28772b71f

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp311-cp311-win_amd64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp311-cp311-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp311-cp311-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 281b4935bf69702bbf2076d8e04a9076dc5ffbab6473a1923ebbce96686e74e2
MD5 966f29645daaaed5c764d28f99743719
BLAKE2b-256 cc510b9170f9da3783bc999b9ccbb5d9b82a9789e4b340fcaa17e18c52721ad1

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp311-cp311-manylinux_2_28_x86_64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp311-cp311-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp311-cp311-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 6a6a12cbebc0f1c5f1de207f4c35cfa31d3fb07d7e331d04a3d1c3bd4a233135
MD5 cd7c79844308823c9be012a136e6b9d5
BLAKE2b-256 17b00bac91dda934455e331366ed6a13e5d1484ee7888b4af2b91e42b5e188af

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp311-cp311-macosx_11_0_universal2.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 1f46bf601a98eb6e4d8e24102f62c1d2430b62f462b41f2c146df1efb10f1757
MD5 b3d8c480ce6b9b01db16f3ff6a98ec4e
BLAKE2b-256 9e30b44c778c43307c3a2215407c4cdc89f36f707eee883ebcaf692c8eefb6d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp310-cp310-win_amd64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp310-cp310-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp310-cp310-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 e3696d58279686fa5a66dfe9efb90d24bbf202236de3bb3bd1a3e149ffdd690b
MD5 f61271baae54d301b9dd88b926812f7f
BLAKE2b-256 cd5c2537e4208ecc47d2e9e1ab262517c57ada3b6bd1566824e882962f6771b5

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp310-cp310-manylinux_2_28_x86_64.whl:

Publisher: publish.yml on osoleve/glitchlings

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

File details

Details for the file glitchlings-0.7.0-cp310-cp310-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for glitchlings-0.7.0-cp310-cp310-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 72ef033565b97ef8f6b23f54fa419d152949d6e9419ba1a46ca7445badd4e271
MD5 2f18b30828a21211d3d0c913ede2f6a2
BLAKE2b-256 416fded7e7e91b2ecbf7e0474f5654e00aa178935622d22af97bc5585481be6a

See more details on using hashes here.

Provenance

The following attestation bundles were made for glitchlings-0.7.0-cp310-cp310-macosx_11_0_universal2.whl:

Publisher: publish.yml on osoleve/glitchlings

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