diff options
| author | Jérémy Zurcher <jeremy@asynk.ch> | 2023-09-11 13:44:48 +0200 | 
|---|---|---|
| committer | Jérémy Zurcher <jeremy@asynk.ch> | 2023-09-11 13:44:48 +0200 | 
| commit | 50686dd6037e7487479599c80890a683800f6a19 (patch) | |
| tree | 3068eaa45cf08d3058aa8f371d8af5d8dc1f63b5 /lib | |
| parent | 3616bd0a7dfe2235624b1ae97937b27899eaf75f (diff) | |
| download | colonial-twilight-50686dd6037e7487479599c80890a683800f6a19.zip colonial-twilight-50686dd6037e7487479599c80890a683800f6a19.tar.gz | |
Board : implement specs
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/colonial_twilight/board.rb | 63 | 
1 files changed, 0 insertions, 63 deletions
| diff --git a/lib/colonial_twilight/board.rb b/lib/colonial_twilight/board.rb index 4acf9b3..5fc46b7 100644 --- a/lib/colonial_twilight/board.rb +++ b/lib/colonial_twilight/board.rb @@ -690,66 +690,3 @@ end  # class ColonialTwilight::Sector  #   undef :adjacents=  # end - -if $PROGRAM_NAME == __FILE__ -  def check(board) -    # puts '--- Coastal' -    # board.spaces.select{ |s| s.coastal? }.each { |s| puts s.name } -    raise 'coastal sectors error' if board.spaces.select(&:coastal?).size != 14 -    # puts '--- not Mountain' -    # board.spaces.select{ |s| not s.mountain? }.each { |s| puts s.name } -    raise 'not moauntain sectors error' if board.spaces.reject(&:mountain?).size != 9 -    # puts '--- Border' -    # board.spaces.select{ |s| s.border? }.each { |s| puts s.name } -    raise 'border sectors error' if board.spaces.select(&:border?).size != 9 -    # puts '--- City' -    # board.spaces.select{ |s| s.city? }.each { |s| puts s.name } -    raise 'city sectors error' if board.spaces.select(&:city?).size != 3 - -    [[0, 11], [1, 9], [2, 9], [3, 1]].each do |p, n| -      # puts "--- Population #{p}" -      # board.spaces.select{ |s| s.pop==p }.each { |s| puts s.name } -      raise "population #{p} error" if board.spaces.select { |s| s.pop == p }.size != n -    end -    raise 'sectors count wrong' if board.sectors.size != 28 -  end - -  def check_forces what, board, vals -    sup, opp, gov, fln = 0, 0, 0, 0 -    ft, fp, at, ap, g = 0, 0, 0, 0, 0 -    gb, fb = 0, 0 -    board.spaces.each do |s| -      sup += 1 if s.alignment == :support -      opp += 1 if s.alignment == :oppose -      gov += 1 if s.control == :GOV -      fln += 1 if s.control == :FLN -      unless s.country? -        ft += s.french_troops -        fp += s.french_police -        at += s.algerian_troops -        ap += s.algerian_police -        gb += s.gov_bases -      end -      g += s.fln_underground -      fb += s.fln_bases -    end -    raise "wrong support #{sup} != #{vals[0]}" if sup != vals[0] -    raise "wrong oppose #{opp} != #{vals[1]}" if opp != vals[1] -    raise "wrong GOV control #{gov} != #{vals[2]}" if gov != vals[2] -    raise "wrong FLN control #{fln} != #{vals[3]}" if fln != vals[3] -    raise "wrong french troops #{ft} != #{vals[4]}" if ft != vals[4] -    raise "wrong french police  #{fp} != #{vals[5]}" if fp != vals[5] -    raise "wrong algerian troops #{at} != #{vals[6]}" if at != vals[6] -    raise "wrong algerian police #{ap} != #{vals[7]}" if ap != vals[7] -    raise "wrong Guerrillas #{g} != #{vals[8]}" if g != vals[8] -    raise "wrong GOV bases #{gb} != #{vals[9]}" if gb != vals[9] -    raise "wrong FLN bases #{fb} != #{vals[10]}" if fb != vals[10] -  end - -  b = ColonialTwilight::Board.new -  puts 'check' -  check b -  b.load :short -  check_forces 'short', b, [3, 7, 16, 3, 9, 17, 3, 7, 17, 4, 8] -  puts 'ok' -end | 
