Basically github.com/mpereira/tty-solitaire with some of the PRs applied
Go to file
2024-11-26 22:25:01 +01:00
resources Add gameplay GIF. 2013-12-24 15:30:33 -02:00
src Merge remote-tracking branch 'AZMCODE/tty-solitaire/auto-win-disable' 2024-11-26 22:25:01 +01:00
tests Fix all memory leaks reported by valgrind 2019-01-21 16:02:04 -05:00
.gitignore Only update this pattern at root. 2013-12-24 15:30:20 -02:00
CHANGELOG Release 1.3.1 2021-09-03 17:03:20 +01:00
LICENSE Since 2010. 2018-08-17 14:36:00 +02:00
Makefile Drop GCC -fcommon so that the new default -fno-common is used 2021-11-03 13:56:31 +01:00
README Release 1.3.1 2021-09-03 17:03:20 +01:00
TODO.md Updated TODO. 2011-06-19 19:40:24 -03:00

# -*-org-*-

* tty-solitaire
  Ncurses-based klondike solitaire game.

  #+CAPTION: ttysolitaire gameplay
  [[https://raw.github.com/mpereira/tty-solitaire/master/resources/ttysolitaire.gif]]

** Dependencies
   - Terminal emulator with UTF-8 support
   - C library with multibyte locales support
   - Ncurses with wide-char/UTF-8 support

** Install
   [[https://repology.org/project/tty-solitaire/versions][https://repology.org/badge/vertical-allrepos/tty-solitaire.svg]]

*** Using package managers
**** Arch Linux
     #+begin_src bash
     pacman -S tty-solitaire
     #+end_src

**** macOS
     #+begin_src bash
     brew install tty-solitaire
     #+end_src

**** Debian [[https://wiki.debian.org/DebianTesting][testing]]
     #+begin_src bash
     apt install tty-solitaire
     #+end_src

**** Nix
     #+begin_src bash
     nix-env --install tty-solitaire
     #+end_src

**** Void Linux
     #+begin_src bash
     xbps-install -S tty-solitaire
     #+end_src

**** FreeBSD
     #+begin_src bash
     pkg install tty-solitaire
     #+end_src

**** Slackware
     [[https://www.slackbuilds.org/repository/14.2/games/tty-solitaire/][Via Slackbuilds]].

**** ALT Linux
     #+begin_src bash
     apt-get install tty-solitaire
     #+end_src

   We still need help making tty-solitaire available on Ubuntu, Fedora, Gentoo,
   and more. Please give us a hand at [[https://github.com/mpereira/tty-solitaire/issues/29][issue #29]] if you think you can help.

*** From source
**** Install Ncurses
     tty-solitaire depends on Ncurses. Some platforms provide it out of the box
     and some don't, so you might need to install it yourself.

***** Ubuntu
      #+begin_src bash
      sudo apt-get install libncurses5-dev libncursesw5-dev
      #+end_src

***** macOS
      macOS has Ncurses with wide character support out of the box, so *there's
      nothing you need to do*.

      *If* for some reason you want to use other Ncurses libraries (from
      Macports, Homebrew, etc.) you are able to do it by specifying =LDLAGS= in
      the make invocation. See [[https://github.com/mpereira/tty-solitaire/pull/8][this pull request]] for more information.

**** Install tty-solitaire
     #+begin_src bash
     wget -O tty-solitaire-v1.3.1.tar.gz https://github.com/mpereira/tty-solitaire/archive/v1.3.1.tar.gz
     tar xvf tty-solitaire-v1.3.1.tar.gz
     cd tty-solitaire-1.3.1
     make
     sudo make install
     #+end_src

** Play
   Run in your favorite shell:

   #+begin_src bash
   ttysolitaire
   #+end_src

** Usage
   #+begin_src text
   usage: ./ttysolitaire [OPTIONS]
     -v, --version              Show version
     -h, --help                 Show this message
     -p, --passes               Number of passes through the deck  (default: 3)
         --four-color-deck      Draw unique card suit colors       (default: false)
         --no-background-color  Don't draw background color        (default: false)
   #+end_src

** Development
*** Get the code
    #+begin_src bash
    git clone https://github.com/mpereira/tty-solitaire.git
    #+end_src

*** Run the unit tests
    #+begin_src bash
    make test
    #+end_src

*** [[https://invisible-island.net/ncurses/man/ncurses.3x.html][Ncurses documentation]]

*** [[https://tldp.org/HOWTO/NCURSES-Programming-HOWTO/][Ncurses programming HOWTO]]

** Author
   [[http://murilopereira.com][Murilo Pereira]]

** License
   [[https://github.com/mpereira/tty-solitaire/blob/master/LICENSE][MIT]]