Game 2048 written in a language with dependent types.
Switch branches/tags
Nothing to show
Clone or download
Latest commit 2ab8a29 Oct 19, 2016
Type Name Latest commit message Commit time
Failed to load latest commit information.
2048-dependent.idr remove useless code May 12, 2016
2048.idr remove useless code May 12, 2016
Makefile initial commit May 12, 2016 misc fix Oct 19, 2016

#2048 in Idris

Author: Guannan Wei

This project aims to learn & show dependent type programming in Idris.

I implemented two versions of game 2048:

  • 2048.idr shows how to achieve it in Idris just using traditional type system.

  • 2048-dependent.idr is the version using dependent type. The most important data structure is dependent list Vect, and it also utilize built-in proof to ensure pre-conditions and post-conditions are satisfied.


You should have installed Idris (version 0.11 or later), see Idris Documentation.

  • run make all to compile both two versions,

  • run make 2048 to compile ordinary version,

  • run make 2048-dep to compile the dependent type version.

How to play

  • w and press enter for move up,
  • a for move left,
  • s for move down,
  • d for move right,
  • and q to quit the game.

Have fun!