Browse Source

refactoring: fight function switched to structs

remotes/origin/encIntegration
János 2 years ago
parent
commit
d6cdcd00a6
  1. 18
      src/c/encounter.c

18
src/c/encounter.c

@ -72,22 +72,21 @@ int switchTurns(int currentTurn)
int fight(Character *character, enemy* enemy) int fight(Character *character, enemy* enemy)
{ {
int playerH = getCharacterHealthPoints(character);
int playerDamage = getCharacterAttack(character);
int playerArmor = getCharacterArmor(character);
int playerH = 0;
int currentTurn = 2; int currentTurn = 2;
char decision; char decision;
while (playerAlive(playerH) && getEnemyHealth(enemy) > 0)
while (playerAlive(getCharacterHealthPoints(character)) && getEnemyHealth(enemy) > 0)
{ {
if (currentTurn != 1) if (currentTurn != 1)
{ {
decision = playerInputChar(); decision = playerInputChar();
switch(decision){ switch(decision){
case 'a': case 'a':
enemyDamaged(enemy, playerDamage);
enemyDamaged(enemy, getCharacterAttack(character));
break; break;
case 'h': case 'h':
playerH = playerHealth(playerH, -10, playerArmor, character);
playerH = playerHealth(getCharacterHealthPoints(character), -10, getCharacterArmor(character), character);
setCharacterHealthPoints(character, playerH);
break; break;
case 'f': case 'f':
return 2; return 2;
@ -102,19 +101,20 @@ int fight(Character *character, enemy* enemy)
} }
else else
{ {
playerH = playerHealth(playerH, getEnemyDamage(enemy), playerArmor, character);
playerH = playerHealth(getCharacterHealthPoints(character), getEnemyDamage(enemy), getCharacterArmor(character), character);
setCharacterHealthPoints(character, playerH);
} }
} }
currentTurn = switchTurns(currentTurn); currentTurn = switchTurns(currentTurn);
} }
if (playerAlive(playerH))
if (playerAlive(getCharacterHealthPoints(character)))
{ {
return 1; return 1;
} }
else else
{ {
return 0; return 0;
}
}
} }
int randomIntRange(int min, int max) int randomIntRange(int min, int max)

Loading…
Cancel
Save