Skip to main content

No project description provided

Project description

VimQuestCLI

This is a vim implementation in python that tries to implement game using the vim shortcuts.

Why python ?

I love python. Maybe one day it's going to be converted in Rust (for easy webassembly and faster execution). But for now it's python 3.8.

Choice when doing executions

Executor :

  • local (the python vim implementation)
  • vim (calling vim to execute stuff, for compatibility tests)

Terminal handling :

  • Curses wrapper : the way it's usually done in python. It allows for curses to catch the input.
  • "manual" curses : Without using the full curses capabilities.

Execution loop :

  • One method to start the whole loop.
  • One method that have the input as argument and returns what to print.

The python version doesn't have just vim capabilities, but allows to expand for allowing for hooks and data attached to the cells.

Todo

  • Separate presentation layer

  • Add a vim executor (to be able to compare tests).

  • Have a context that is not a copy but modify itself (for speed).

  • Have a bunch of hooks, and use them to have game modes.

  • Have a command to choose between game modes.

  • See how neovim is made so I can use the same architecture.

  • Maybe have syntax highliting for game modes too ?

  • Activate the UTF-8, see how I can activate it.

  • Create docker images for website and terminal.

  • Add git hook for cleaning python before commit.

  • Use unicode characters (not necesseraly emojii) with colors for differents things happening.

BUG CORRECTION :

  • Clean codebase.
  • ANSI is blinking.
  • Image location is not working.
  • Size of the terminal is not used.
  • Unicode block behavior is inconsistent.
    • Maybe having replacement for unicode that include colors.

References

Now vim implementationthat I could use for corectness :

ncurses implementation : https://github.com/mscdex/node-ncurses Maybe this implementation would be easier to understand than the c ncurses one.

Next steps to cover

  • hjkl x
  • [number]command
  • i
  • aA
  • dd
  • wbe
  • v, Shift-v
  • ypP
  • "ci"

Next step.

Vim core. That execute the commands and return a status. From a Contains the screen size and

Vim window. That take that buffer and return a screen. (matrix of data points with metadata).

Attachable are game modes.

Then there is terminal that push characters and returns a

Use an alternate screen : https://stackoverflow.com/questions/11023929/using-the-alternate-screen-in-a-bash-script

For inspiration :

  • Nethack

Add keystroker counts for speed. Info box to see what's happening in the game.

Game ideas :

  • Enemies coming at you and you have to delete the terrain that is underneath them without running out of terrain yourself. But if they touch you, you're dead and has to restart the game.

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

vim_quest_cli-0.1.15.tar.gz (33.1 kB view details)

Uploaded Source

Built Distribution

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

vim_quest_cli-0.1.15-py3-none-any.whl (46.4 kB view details)

Uploaded Python 3

File details

Details for the file vim_quest_cli-0.1.15.tar.gz.

File metadata

  • Download URL: vim_quest_cli-0.1.15.tar.gz
  • Upload date:
  • Size: 33.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/5.4.72-microsoft-standard-WSL2

File hashes

Hashes for vim_quest_cli-0.1.15.tar.gz
Algorithm Hash digest
SHA256 3a3295e9982c61c6bb0a5c3400839ad9f78b400ce6d280840e2241af049a865d
MD5 b23192be09152e7c2bddff8c541c397f
BLAKE2b-256 a95f2ecb479bf29378155af256a45401be6f8efdad7bbca4f394093c019dd671

See more details on using hashes here.

File details

Details for the file vim_quest_cli-0.1.15-py3-none-any.whl.

File metadata

  • Download URL: vim_quest_cli-0.1.15-py3-none-any.whl
  • Upload date:
  • Size: 46.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/5.4.72-microsoft-standard-WSL2

File hashes

Hashes for vim_quest_cli-0.1.15-py3-none-any.whl
Algorithm Hash digest
SHA256 8baad68d406c1600a1f03b192de1d008cb855cbc8ebd7adcca30e0b52c39c059
MD5 4c254a4ca5bbd4f3de5132b999a86ead
BLAKE2b-256 41dae92c0fac67040c928050d1f83c6dc6175331a52cf8cfc4f2b874a9aac65f

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