Bishop.cpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. #include "Bishop.h"
  2. #include "Position.h"
  3. #include <utility>
  4. #include <stdexcept>
  5. #include <iostream>
  6. Bishop::Bishop(Position pos, char c) {
  7. if (c != 'B' and c != 'W')
  8. throw std::invalid_argument("Impossible color of figure!");
  9. position = pos;
  10. color = c;
  11. }
  12. std::pair<int, Position*> Bishop::get_moves()
  13. {
  14. // У ладьи всегда 14 ходов, если нет преград
  15. Position* moves = new Position[14];
  16. int moveNum = 0;
  17. for(int i = 1; i < 8; i++) {
  18. for(int j = -1; j < 2; j+=2) {
  19. for(int k = -1; k < 2; k+=2) {
  20. // Не добавляем невозможные ходы
  21. if (not (position.posSym + i*j <= 'H' and position.posNum + i*k <= '8' and position.posSym + i*j >= 'A' and position.posNum + i*k >= '1'))
  22. continue;
  23. // Position создаст ошибку, если создать невозможный ход
  24. Position p;
  25. try {
  26. p = Position((char)(position.posSym+i*j), (char)(position.posNum+i*k));
  27. }
  28. catch (const std::invalid_argument) {
  29. continue;
  30. }
  31. moves[moveNum] = p;
  32. moveNum++;
  33. }
  34. }
  35. }
  36. return std::pair<int, Position*>(14, moves);
  37. }
  38. const char* Bishop::print()
  39. {
  40. const char* me;
  41. if (color == 'B')
  42. me = "♝";
  43. else
  44. me = "♗";
  45. return me;
  46. }