Skip to content
Snippets Groups Projects
Select Git revision
  • 2277ffbd4db8701dc51b74ce208a8794f9c7b525
  • master default protected
  • 61-upgrade-framework-and-dependencies
  • 42-add-allowed-categories-in-settings-page
  • 44-improve-app-metadata
  • 23-add-tip-response-on-clic-on-button
  • Release_1.11.0_55 protected
  • Release_1.10.2_54 protected
  • Release_1.10.1_53 protected
  • Release_1.10.0_52 protected
  • Release_1.9.0_51 protected
  • Release_1.8.0_50 protected
  • Release_1.7.0_49 protected
  • Release_1.6.2_48 protected
  • Release_1.6.1_47 protected
  • Release_1.6.0_46 protected
  • Release_1.5.1_45 protected
  • Release_1.5.0_44 protected
  • Release_1.4.1_43 protected
  • Release_1.4.0_42 protected
  • Release_1.3.1_41 protected
  • Release_1.3.0_40 protected
  • Release_1.2.33_39 protected
  • Release_1.2.32_38 protected
  • Release_1.2.31_37 protected
  • Release_1.2.30_36 protected
26 results

home.dart

Blame
  • board.dart 1.21 KiB
    import 'package:puissance4/utils/tools.dart';
    
    typedef BoardCells = List<List<int>>;
    
    class Board {
      Board({
        required this.cells,
      });
    
      BoardCells cells = const [];
    
      factory Board.createNull() {
        return Board(
          cells: [],
        );
      }
    
      factory Board.createNew({
        required BoardCells cells,
      }) {
        return Board(
          cells: cells,
        );
      }
    
      int getCellValue({required int row, required int col}) {
        return cells[row][col];
      }
    
      void setCellValue({required int row, required int col, required int value}) {
        cells[row][col] = value;
      }
    
      void dump() {
        printlog('');
        String line = '--';
        for (int i = 0; i < cells[0].length; i++) {
          line += '-';
        }
        printlog(line);
        for (int rowIndex = 0; rowIndex < cells.length; rowIndex++) {
          String currentLine = '';
          for (int colIndex = 0; colIndex < cells[rowIndex].length; colIndex++) {
            currentLine += getCellValue(row: rowIndex, col: colIndex).toString();
          }
          printlog('|$currentLine|');
        }
        printlog(line);
        printlog('');
      }
    
      @override
      String toString() {
        return '$Board(${toJson()})';
      }
    
      Map<String, dynamic>? toJson() {
        return <String, dynamic>{
          'cells': cells,
        };
      }
    }