Difference between revisions of "Frag"

From HaskellWiki
Jump to navigation Jump to search
m
(link rainbyte/frag)
 
Line 18: Line 18:
 
== Requirements ==
 
== Requirements ==
   
* GHC 6.8 or greater, providing HOpenGL-2.0.
+
* GHC 8 (2017 fork) or GHC 6.8 or greater, providing HOpenGL-2.0.
* OpenGL drivers that support the vertex array and multitexture OpenGL extensions
+
* OpenGL drivers that support the vertex array and multi-texture OpenGL extensions
 
* Frag has portability problems. It is known to work on i386 and AMD64, and known not to work on big-endian systems.
 
* Frag has portability problems. It is known to work on i386 and AMD64, and known not to work on big-endian systems.
   
Line 26: Line 26:
 
== Download ==
 
== Download ==
   
The code can be downloaded from
+
The original code can be downloaded from
 
[http://hackage.haskell.org/cgi-bin/hackage-scripts/package/frag Hackage]; it is also distributed via a Darcs repository:
 
[http://hackage.haskell.org/cgi-bin/hackage-scripts/package/frag Hackage]; it is also distributed via a Darcs repository:
   
 
darcs get http://code.haskell.org/frag
 
darcs get http://code.haskell.org/frag
   
  +
A port for GHC 8 is available: https://github.com/rainbyte/frag
[[Darcs]] is the standard revision control system of the Haskell community.
 
   
 
== Contributions ==
 
== Contributions ==
   
Frag needs contributions from the community! Darcs send patches to
+
Frag needs contributions from the community! Submit pull requests to https://github.com/rainbyte/frag
[http://www.cse.unsw.edu.au/~dons/ Don Stewart].
 
   
 
== Screenshots ==
 
== Screenshots ==

Latest revision as of 11:31, 5 May 2017

Frag

Frag1.png

Frag is a 3D first person shooting game written in Haskell, by Mun Hon Cheong. It is licensed under the GPL. The design and implementation of Frag is described in Mun's 2005 undergraduate thesis, Functional Programming and 3D Games. An AI system for Frag is described in Jayatheeban Soundararajan's 2007 undergrad thesis, also titled Functional Programming and 3D Games.

YouTube Video

Features

  • Yampa, a domain-specific embedded language for the programming of hybrid systems that using the concepts of Functional Reactive Programming (FRP) was used to program the game entities.
  • The Quake 3 BSP level format, Q3Map2, and the MD3 format for models and animations are used in this game.
  • Sven Panne's OpenGL binding, HOpenGL is used to render graphics.

Requirements

  • GHC 8 (2017 fork) or GHC 6.8 or greater, providing HOpenGL-2.0.
  • OpenGL drivers that support the vertex array and multi-texture OpenGL extensions
  • Frag has portability problems. It is known to work on i386 and AMD64, and known not to work on big-endian systems.

See the blog article A Haskell eye for the windows guy for the list of requirements and how to install for Windows users.

Download

The original code can be downloaded from Hackage; it is also distributed via a Darcs repository:

darcs get http://code.haskell.org/frag

A port for GHC 8 is available: https://github.com/rainbyte/frag

Contributions

Frag needs contributions from the community! Submit pull requests to https://github.com/rainbyte/frag

Screenshots

(Note that these screenshots are of the old level, which was replaced for copyright reasons.)

Frag2.png

Frag3.png

Frag4.png

Frag5.png

BibTeX Entry

@mastersthesis{Frag,
    author   = {Mun Hon Cheong},
    title    = {Functional Programming and 3D Games},
    year     = {2005},
    month    = {November},
    school   = {University of New South Wales},
    address  = {Sydney, Australia},
    abstract = {Games are commonly programmed in imperative languages.
                Functional languages have been known to have benefits but have
                rarely been used to program games. In this thesis we implement
                a first person shooting game in Haskell and Yampa. The merits
                of this approach are examined.}
}