# Linotype Linotype is a simple ruby implementation of the [Letterpress for iOS](http://www.atebits.com/letterpress/) game mechanic. Letterpress was created by [Loren Brichter](http://twitter.com/lorenb) and is [sold on iTunes](https://itunes.apple.com/us/app/letterpress-word-game/id526619424?ls=1&mt=8). Linotype is meant to be used to write other programs such as simple player command line games, cheating/simulation programs, web-based versions, or whatever else you can think of. My goal is that the community will submit pull requests to this project so that programs can share a common engine. The project was inspired by this [tweet by Andy Baio](https://twitter.com/waxpancake/statuses/261966416507465728). The project was started by [@barelyknown](http://twitter.com/barelyknown). ## Installation $ gem install linotype ## Usage The library provides a very simple interface using built in Ruby objects. The goal of the design is to use object oriented design strategies internally but to keep the public interface very simple to make it easy to use and extend. Here's a basic rundown of the primary public methods: > game = Linotype::Game.new > game.board => [ [ {:letter=>"I", :row=>0, :column=>0, :covered_by=>nil, :defended=>false}, {:letter=>"E", :row=>0, :column=>1, :covered_by=>nil, :defended=>false}, {:letter=>"X", :row=>0, :column=>2, :covered_by=>nil, :defended=>false}, {:letter=>"A", :row=>0, :column=>3, :covered_by=>nil, :defended=>false}, {:letter=>"C", :row=>0, :column=>4, :covered_by=>nil, :defended=>false} ], [ {:letter=>"R", :row=>1, :column=>0, :covered_by=>nil, :defended=>false}, {:letter=>"F", :row=>1, :column=>1, :covered_by=>nil, :defended=>false}, {:letter=>"D", :row=>1, :column=>2, :covered_by=>nil, :defended=>false}, {:letter=>"S", :row=>1, :column=>3, :covered_by=>nil, :defended=>false}, {:letter=>"B", :row=>1, :column=>4, :covered_by=>nil, :defended=>false} ], [ {:letter=>"B", :row=>2, :column=>0, :covered_by=>nil, :defended=>false}, {:letter=>"L", :row=>2, :column=>1, :covered_by=>nil, :defended=>false}, {:letter=>"K", :row=>2, :column=>2, :covered_by=>nil, :defended=>false}, {:letter=>"Q", :row=>2, :column=>3, :covered_by=>nil, :defended=>false}, {:letter=>"P", :row=>2, :column=>4, :covered_by=>nil, :defended=>false} ], [ {:letter=>"S", :row=>3, :column=>0, :covered_by=>nil, :defended=>false}, {:letter=>"O", :row=>3, :column=>1, :covered_by=>nil, :defended=>false}, {:letter=>"K", :row=>3, :column=>2, :covered_by=>nil, :defended=>false}, {:letter=>"P", :row=>3, :column=>3, :covered_by=>nil, :defended=>false}, {:letter=>"W", :row=>3, :column=>4, :covered_by=>nil, :defended=>false} ], [ {:letter=>"L", :row=>4, :column=>0, :covered_by=>nil, :defended=>false}, {:letter=>"U", :row=>4, :column=>1, :covered_by=>nil, :defended=>false}, {:letter=>"J", :row=>4, :column=>2, :covered_by=>nil, :defended=>false}, {:letter=>"Y", :row=>4, :column=>3, :covered_by=>nil, :defended=>false}, {:letter=>"D", :row=>4, :column=>4, :covered_by=>nil, :defended=>false} ] ] > game.play({ row: 3, column: 1 }, {row: 3, column: 0}) => true > game.moves => [{:player=>1, :word=>"OS", :valid=>true, :invalid_reason=>nil, :player_sequence=>1, :total_sequence=>1} > game.scores => {1=>2, 2=>0} > game.play({ row: 1, column: 0 }, {row: 1, column: 1}) => false > game.moves.last => {:player=>2, :word=>"RF", :valid=>false, :invalid_reason=>"is not in dictionary", :player_sequence=>1, :total_sequence=>1} # pass by playing a nil move > game.play => true > game.play => true > game.over? => true > game.winner => 1 ## Dictionary The default dictionary is based on the standard `words` file provide UNIX systems. On Mac OS X this file is located at `/usr/share/dict/words`. This probably isn't the right dictionary for the game, but it's something to start with. It probably makes sense to enable custom dictionaries at the game level by passing in an argument when the game is initialized. But, it'll be easy to extend from here. ## Feature Ideas * Game board loading from string * Game board loading from iOS screen shot * Word suggestions * Game simulation with strategy suggestion * One player command line game * Vowel/consonant ratio setting for random boards * Built in dictionaries for different languages or topics ## Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create new Pull Request 6. Thanks <3