Skip to main content

Cetra Grand Master | An oddly familiar block stacker in the command line!

Project description

cgm

Cetra Grand Master!

A block stacker game that you might find very familiar. Built with similar design to Tetris Grand Master in mind, but runs entirely in your terminal with much more modern mechanics.

how

pip install cetragm, or pipx install cetragm if you're on an externally managed system like Arch Linux. You may need the pygame module if you don't have it or if pip doesn't install it for you. Run cgm.

If you'd like to customise your controls, you may change them in /src/cgm/config.py under the project directory.

To change DAS (how long until inputs repeat) and ARR (how fast inputs repeat), you'll have to do it under your OS' settings for now. On Windows, it should be under the Mouse and Keyboard controls. On KDE Plasma, under System Settings > Keyboard > Repeat Rate. On Mac, go ask Tim Cook. On Gnome, go ask Richard Stallman's left foot. Otherwise, I'm sure you can figure it out.

what

Features:

  • Supports any terminal emulator, Windows or Linux. (Not tested on Mac but may work.)
  • Rebindable controls, including hard and soft drops as well as holds.
  • Grade system, up to the Gm grade (which I guarantee you won't get)
  • Full color!
  • Dynamic gravity (speed) as your level increases
  • Scoring system
  • Gameplay timer
  • 7-bag piece drawing and standard NEStris rotation system
  • 5-piece next queue and level display
  • Persistent TLS (or shadow piece)
  • TGM's 20G gravity after level 500
  • Proper ARE, lock delay, and line clear delay
  • Real-time gravity (not tied to frame rates)

Drawbacks:

  • Requires manual ARR/DAS and can't press two keys at once
  • Very sub-par rotation system
  • Scoring is slightly off
  • Lack of theming or menus at all, as well as a lose state
  • No sound (background or effect)

To add by next week:

  • The Super Rotation System and standard wallkicks
  • T-spins and detection for them
  • IHS and IRS (Inital Hold/Rotation System)
  • Full menu with configuration
  • Tiny optional input window via Pygame to add proper multi-key controls and DAS/ARR
  • Config config config! maybe even a new gamemode...

controls

You may configure these in config.py, but the defaults (and what I use) follow:

Buttons Function huh
a j Move Left
d l Move Right
space / c Rotate CW
z , q Rotate CCW
tab x . Rotate 180
s k Soft Drop move your piece down faster, but don't immediately lock it into place
w i Hard Drop move your piece as far down as it will go and lock it in place, skipping the delay
e v Hold Piece put a piece aside or switch to your held piece when it doesn't fit
esc p quit why would you ever want to do that?

why

Built for Hack Club's Siege program (week 10 and 11). Also, I like block stackers.

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

cetragm-0.1.0.tar.gz (25.4 kB view details)

Uploaded Source

Built Distribution

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

cetragm-0.1.0-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

Details for the file cetragm-0.1.0.tar.gz.

File metadata

  • Download URL: cetragm-0.1.0.tar.gz
  • Upload date:
  • Size: 25.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for cetragm-0.1.0.tar.gz
Algorithm Hash digest
SHA256 76ccc8996c2e957ab7fcf2d62136e7fc17e347c779b9c116c7ed9b123ffbdf68
MD5 831c6d385682634fa6233f07ad5e4035
BLAKE2b-256 f5c17e6e4eacfda990eab47f9e5ae7c8a59b902c442046f6364e0dd56de2cc12

See more details on using hashes here.

File details

Details for the file cetragm-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: cetragm-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 27.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for cetragm-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 963b810aec233a3374532502d4dea1eb1f538018097c0d0febe53e5e074eeb91
MD5 6231fda6a01d6417e0983b78e3a5f2e5
BLAKE2b-256 c7337689e8a2233bb80464d1cfd51f499739c8b64f3a71373d263a9ed31aac3c

See more details on using hashes here.

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