Merge pull request 'Set the matrix size of a new piece to its minimum size' (#45) from matrixMinimumSize into master
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				continuous-integration/drone/push Build is passing
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	continuous-integration/drone/push Build is passing
				
			Reviewed-on: #45 Reviewed-by: Mat_02 <diletomatteo@gmail.com>
This commit is contained in:
		@ -55,6 +55,8 @@ public class Piece extends Shape{
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    public void RotateRight(int times){
 | 
					    public void RotateRight(int times){
 | 
				
			||||||
        while(times > 0) {
 | 
					        while(times > 0) {
 | 
				
			||||||
 | 
					            height = matrix.length;
 | 
				
			||||||
 | 
					            width = matrix[0].length;
 | 
				
			||||||
            boolean[][] temp_matrix = new boolean[width][height];
 | 
					            boolean[][] temp_matrix = new boolean[width][height];
 | 
				
			||||||
            for (int i = 0; i < width; i++) {
 | 
					            for (int i = 0; i < width; i++) {
 | 
				
			||||||
                for (int j = 0; j < height; j++) {
 | 
					                for (int j = 0; j < height; j++) {
 | 
				
			||||||
@ -70,9 +72,10 @@ public class Piece extends Shape{
 | 
				
			|||||||
    public boolean equals(Object obj) {
 | 
					    public boolean equals(Object obj) {
 | 
				
			||||||
        if(obj instanceof Piece){
 | 
					        if(obj instanceof Piece){
 | 
				
			||||||
            Piece pieceObj = (Piece) obj;
 | 
					            Piece pieceObj = (Piece) obj;
 | 
				
			||||||
            if( pieceObj.getPosition().equals(this.getPosition()) && pieceObj.getShape().equals(getShape())) {
 | 
					            if (pieceObj.getPosition() != null && this.getPosition() != null){
 | 
				
			||||||
                return true;
 | 
					                return pieceObj.getPosition().equals(this.getPosition()) && pieceObj.getShape().equals(getShape());
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					            return pieceObj.getShape().equals(getShape());
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        return false;
 | 
					        return false;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,8 @@
 | 
				
			|||||||
package school_project;
 | 
					package school_project;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import school_project.Utils.Array;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.io.Serializable;
 | 
					import java.io.Serializable;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
@ -21,14 +23,52 @@ public class Shape implements Serializable, Cloneable{
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public void setShape(boolean[][] matrix) throws IllegalArgumentException{
 | 
					    public void setShape(boolean[][] matrix) throws IllegalArgumentException{
 | 
				
			||||||
        height = matrix.length;
 | 
					 | 
				
			||||||
        width = matrix[0].length;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for (boolean[] row: matrix){
 | 
					        for (boolean[] row: matrix){
 | 
				
			||||||
            if(row.length != width){
 | 
					            if(row.length != matrix[0].length){
 | 
				
			||||||
                throw new IllegalArgumentException("The argument should be a square matrix");
 | 
					                throw new IllegalArgumentException("The argument should be a square matrix");
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (int i = 0; i < matrix.length; i++) {
 | 
				
			||||||
 | 
					            if(!Array.isRowOnlyFalse(matrix, i)) {
 | 
				
			||||||
 | 
					                for (int j = 0; j < i; j++) {
 | 
				
			||||||
 | 
					                    matrix = Array.MatrixRemoveRow(matrix, 0);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (int i = matrix.length-1; i >= 0; i--) {
 | 
				
			||||||
 | 
					            if(!Array.isRowOnlyFalse(matrix, i)) {
 | 
				
			||||||
 | 
					                for (int j = matrix.length-1; j > i; j--) {
 | 
				
			||||||
 | 
					                    matrix = Array.MatrixRemoveRow(matrix, j);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (int i = 0; i < matrix[0].length; i++) {
 | 
				
			||||||
 | 
					            if(!Array.isColumnOnlyFalse(matrix, i)) {
 | 
				
			||||||
 | 
					                for (int j = 0; j < i; j++) {
 | 
				
			||||||
 | 
					                    matrix = Array.MatrixRemoveColumn(matrix, 0);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (int i = matrix[0].length-1; i >= 0; i--){
 | 
				
			||||||
 | 
					            if(!Array.isColumnOnlyFalse(matrix, i)) {
 | 
				
			||||||
 | 
					                for (int j = matrix[0].length-1; j > i; j--) {
 | 
				
			||||||
 | 
					                    matrix = Array.MatrixRemoveColumn(matrix, j);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        height = matrix.length;
 | 
				
			||||||
 | 
					        width = matrix[0].length;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        this.matrix = matrix;
 | 
					        this.matrix = matrix;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -10,4 +10,52 @@ public class Array{
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
        return ret;
 | 
					        return ret;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public static boolean[][] MatrixRemoveRow(boolean[][] o, int row){
 | 
				
			||||||
 | 
					        boolean[][] newMatrix = new boolean[o.length - 1][o[0].length];
 | 
				
			||||||
 | 
					        int newRow = 0;
 | 
				
			||||||
 | 
					        for (int i = 0; i < o.length; i++) {
 | 
				
			||||||
 | 
					            if(i == row)
 | 
				
			||||||
 | 
					                i++;
 | 
				
			||||||
 | 
					            if(i >= o.length)
 | 
				
			||||||
 | 
					                continue;
 | 
				
			||||||
 | 
					            newMatrix[newRow] = o[i];
 | 
				
			||||||
 | 
					            newRow++;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return newMatrix;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public static boolean[][] MatrixRemoveColumn(boolean[][] o, int col){
 | 
				
			||||||
 | 
					        boolean[][] newMatrix = new boolean[o.length][o[0].length - 1];
 | 
				
			||||||
 | 
					        for (int i = 0; i < o.length; i++) {
 | 
				
			||||||
 | 
					            int newCol = 0;
 | 
				
			||||||
 | 
					            for(int j = 0; j < o[0].length; j++){
 | 
				
			||||||
 | 
					                if(j == col)
 | 
				
			||||||
 | 
					                    j++;
 | 
				
			||||||
 | 
					                if(j >= o[0].length)
 | 
				
			||||||
 | 
					                    continue;
 | 
				
			||||||
 | 
					                newMatrix[i][newCol] = o[i][j];
 | 
				
			||||||
 | 
					                newCol++;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return newMatrix;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public static boolean isRowOnlyFalse(boolean[][] o, int row){
 | 
				
			||||||
 | 
					        boolean mark = true;
 | 
				
			||||||
 | 
					        for (int i = 0; i < o[row].length; i++) {
 | 
				
			||||||
 | 
					            if(o[row][i])
 | 
				
			||||||
 | 
					                mark = false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return mark;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public static boolean isColumnOnlyFalse(boolean[][] o, int column){
 | 
				
			||||||
 | 
					        boolean mark = true;
 | 
				
			||||||
 | 
					        for (int i = 0; i < o.length; i++) {
 | 
				
			||||||
 | 
					            if(o[i][column])
 | 
				
			||||||
 | 
					                mark = false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return mark;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -17,7 +17,6 @@ class PieceTest {
 | 
				
			|||||||
        boolean[][] piece1_matrix_result = {
 | 
					        boolean[][] piece1_matrix_result = {
 | 
				
			||||||
                {true, false, true},
 | 
					                {true, false, true},
 | 
				
			||||||
                {true, true, false},
 | 
					                {true, true, false},
 | 
				
			||||||
                {false, false, false},
 | 
					 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        boolean[][] piece2_matrix = {
 | 
					        boolean[][] piece2_matrix = {
 | 
				
			||||||
@ -31,7 +30,6 @@ class PieceTest {
 | 
				
			|||||||
        };
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        boolean[][] piece3_matrix_result = {
 | 
					        boolean[][] piece3_matrix_result = {
 | 
				
			||||||
                {false, false, false},
 | 
					 | 
				
			||||||
                {false, true, true},
 | 
					                {false, true, true},
 | 
				
			||||||
                {true, false, true},
 | 
					                {true, false, true},
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,9 @@
 | 
				
			|||||||
package school_project;
 | 
					package school_project;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.junit.jupiter.api.Test;
 | 
					import org.junit.jupiter.api.Test;
 | 
				
			||||||
 | 
					import school_project.Utils.Array;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Arrays;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import static org.junit.jupiter.api.Assertions.*;
 | 
					import static org.junit.jupiter.api.Assertions.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -29,6 +32,30 @@ class ShapeTest {
 | 
				
			|||||||
                {true}
 | 
					                {true}
 | 
				
			||||||
        };
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        boolean[][] matrix_shape5 = {
 | 
				
			||||||
 | 
					                {false, false, false, false, false},
 | 
				
			||||||
 | 
					                {false, false, false, false, false},
 | 
				
			||||||
 | 
					                {false, true, true, true, false},
 | 
				
			||||||
 | 
					                {false, true, false, true, false},
 | 
				
			||||||
 | 
					                {false, false, false, false, false},
 | 
				
			||||||
 | 
					                {false, false, false, false, false},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        boolean[][] matrix_shape5_result = {
 | 
				
			||||||
 | 
					                {true, true, true},
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        boolean[][] matrix_shape6 = {
 | 
				
			||||||
 | 
					                {true, false},
 | 
				
			||||||
 | 
					                {false, false}
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        boolean[][] matrix_shape6_result = {
 | 
				
			||||||
 | 
					                {true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        System.out.println(Array.isRowOnlyFalse(matrix_shape1, 0));
 | 
				
			||||||
        Shape shape1 = new Shape();
 | 
					        Shape shape1 = new Shape();
 | 
				
			||||||
        shape1.setShape(matrix_shape1);
 | 
					        shape1.setShape(matrix_shape1);
 | 
				
			||||||
        assertEquals(3, shape1.getHeight());
 | 
					        assertEquals(3, shape1.getHeight());
 | 
				
			||||||
@ -44,5 +71,11 @@ class ShapeTest {
 | 
				
			|||||||
        assertEquals(3, shape4.getHeight());
 | 
					        assertEquals(3, shape4.getHeight());
 | 
				
			||||||
        assertEquals(1, shape4.getWidth());
 | 
					        assertEquals(1, shape4.getWidth());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Shape shape5 = new Shape(matrix_shape5);
 | 
				
			||||||
 | 
					        assertArrayEquals(matrix_shape5_result, shape5.getShape());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Shape shape6 = new Shape(matrix_shape6);
 | 
				
			||||||
 | 
					        assertArrayEquals(matrix_shape6_result, shape6.getShape());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -23,4 +23,59 @@ class ArrayTest {
 | 
				
			|||||||
        a[1][1] = true;
 | 
					        a[1][1] = true;
 | 
				
			||||||
        assertArrayEquals(b, c);
 | 
					        assertArrayEquals(b, c);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void matrixRemoveRow() {
 | 
				
			||||||
 | 
					        boolean[][] a = new boolean[][] {
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					                {false, false, false},
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        boolean[][] b = new boolean[][] {
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        boolean[][] result = Array.MatrixRemoveRow(a, 1);
 | 
				
			||||||
 | 
					        assertArrayEquals(b, result);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void matrixRemoveColumn() {
 | 
				
			||||||
 | 
					        boolean[][] a = new boolean[][] {
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					                {false, false, false},
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        boolean[][] b = new boolean[][] {
 | 
				
			||||||
 | 
					                {true, true},
 | 
				
			||||||
 | 
					                {false, false},
 | 
				
			||||||
 | 
					                {true, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        boolean[][] result = Array.MatrixRemoveColumn(a, 1);
 | 
				
			||||||
 | 
					        assertArrayEquals(b, result);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void isRowOnlyFalse() {
 | 
				
			||||||
 | 
					        boolean[][] a = new boolean[][] {
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					                {false, false, false},
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        assertTrue(Array.isRowOnlyFalse(a, 1));
 | 
				
			||||||
 | 
					        assertFalse(Array.isRowOnlyFalse(a, 0));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void isColumnOnlyFalse() {
 | 
				
			||||||
 | 
					        boolean[][] a = new boolean[][] {
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					                {false, false, false},
 | 
				
			||||||
 | 
					                {true, false, true},
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        assertTrue(Array.isColumnOnlyFalse(a, 1));
 | 
				
			||||||
 | 
					        assertFalse(Array.isColumnOnlyFalse(a, 0));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user