From a02b3fcefdcfac0ce069af754d1a9a84a00889f7 Mon Sep 17 00:00:00 2001 From: Gwenhael Le Moine Date: Sat, 21 May 2011 16:54:34 +0700 Subject: [PATCH] move_1_step doesn't affect the real position of objectToMove --- star.rb | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/star.rb b/star.rb index 3efd8b1..62f4745 100644 --- a/star.rb +++ b/star.rb @@ -295,7 +295,8 @@ class Star dy = 0 unless dy new_x = @positions[ objectToMove ][ :x ] + dx new_y = @positions[ objectToMove ][ :y ] + dy - @positions[ objectToMove ] = { :x => new_x, :y => new_y } + { :x => new_x, :y => new_y } + end def move( direction, objectToMove ) @@ -315,6 +316,7 @@ class Star ( @board[ newpos[ :y ] + d[ :v ] ][ newpos[ :x ] + d[ :h ] ] == 'V' ) || ( objectToMove == :ball && @board[ newpos[ :y ] + d[ :v ] ][ newpos[ :x ] + d[ :h ] ] == 'G' ) + newpos[ :x ] = newpos[ :x ] + d[ :h ] newpos[ :y ] = newpos[ :y ] + d[ :v ] @@ -415,9 +417,9 @@ class TestBla < Test::Unit::TestCase st = Star.new puts st.to_s - st.move_1_step( :down, :ball ) - - assert_equal( 1, st.positions[ :ball ][ :x ] ) - assert_equal( 2, st.positions[ :ball ][ :y ] ) + result = st.move_1_step( :down, :ball ) + + assert_equal( 1, result[ :x ] ) + assert_equal( 2, result[ :y ] ) end end