save to move to e3

This commit is contained in:
Hugo LAMY
2022-02-22 15:18:39 +01:00
parent 985d90bb8c
commit bb6c0515b1
6 changed files with 53 additions and 45 deletions

View File

@@ -11,7 +11,7 @@ ClapTrap::ClapTrap( std::string name ) {
_hit = _dHit; _hit = _dHit;
_energy = _dEnergy; _energy = _dEnergy;
_attack = _dAttack; _attack = _dAttack;
_number = ClapTrap::_totalNumber; _number = getTotalNumber();
std::cout << _class << " " << _name << " nb:" << _number << " created\n"; std::cout << _class << " " << _name << " nb:" << _number << " created\n";
return; return;
} }
@@ -20,7 +20,8 @@ ClapTrap::ClapTrap( ClapTrap const & src ) {
ClapTrap::_increaseNumber(); ClapTrap::_increaseNumber();
_class = _dClass; _class = _dClass;
*this = src; *this = src;
std::cout << _class << " " << _name << " nb:" << _number << " copied from " << src._class << "-" << src._name << "-" << src._number << "\n"; _number = getTotalNumber();
std::cout << _class << " " << _name << "-" << _number << " copied from " << src._class << "-" << src._name << "-" << src._number << "\n";
return; return;
} }
@@ -29,7 +30,7 @@ ClapTrap::ClapTrap( ClapTrap const & src ) {
*********************************************/ *********************************************/
ClapTrap::~ClapTrap( void ) { ClapTrap::~ClapTrap( void ) {
std::cout << _class << " " << _name << " nb:" << _number << " destructed\n"; std::cout << _class << " " << _name << "-" << _number << " destructed\n";
return; return;
} }
@@ -48,7 +49,7 @@ ClapTrap & ClapTrap::operator=( ClapTrap const & rhs ) {
_number = rhs.getNumber(); _number = rhs.getNumber();
} }
std::cout << _class << " " << _name << " nb:" << _number << " assigned\n"; std::cout << _class << " " << _name << "-" << _number << " assigned\n";
return *this; return *this;
} }
@@ -63,6 +64,7 @@ int ClapTrap::getHit() const {return _hit;}
int ClapTrap::getEnergy() const {return _energy;} int ClapTrap::getEnergy() const {return _energy;}
int ClapTrap::getAttack() const {return _attack;} int ClapTrap::getAttack() const {return _attack;}
int ClapTrap::getNumber() const {return _number;} int ClapTrap::getNumber() const {return _number;}
int ClapTrap::getTotalNumber() const {return _totalNumber;}
void ClapTrap::_increaseNumber() {ClapTrap::_totalNumber++;} void ClapTrap::_increaseNumber() {ClapTrap::_totalNumber++;}
/********************************************* /*********************************************

View File

@@ -29,12 +29,14 @@ public:
protected: protected:
std::string _name; int getTotalNumber() const;
std::string _class;
int _hit; std::string _name;
int _energy; std::string _class;
int _attack; int _hit;
int _number; int _energy;
int _attack;
int _number;
void _increaseNumber(); void _increaseNumber();

View File

@@ -7,7 +7,8 @@
NAME = robots NAME = robots
CC = c++ CC = c++
CFLAGS = -Wall -Wextra -Werror $(INCLUDES) -std=c++98 #CFLAGS = -Wall -Wextra -Werror $(INCLUDES) -std=c++98
CFLAGS = $(INCLUDES) -std=c++98
VPATH = $(D_SRCS) VPATH = $(D_SRCS)

View File

@@ -9,14 +9,15 @@ ScavTrap::ScavTrap( std::string name ) : ClapTrap(name) {
_hit = _dHit; _hit = _dHit;
_energy = _dEnergy; _energy = _dEnergy;
_attack = _dAttack; _attack = _dAttack;
std::cout << _class << " " << _name << " nb:" << _number << " created\n"; std::cout << _class << " " << _name << "-" << _number << " created\n";
return; return;
} }
ScavTrap::ScavTrap( ScavTrap const & src ) : ClapTrap() { ScavTrap::ScavTrap( ScavTrap const & src ) : ClapTrap() {
_class = _dClass; _class = _dClass;
*this = src; *this = src;
std::cout << _class << " " << _name << " nb:" << _number << " copied from " << src._class << "-" << src._name << "-" << src._number << "\n"; _number = getTotalNumber();
std::cout << _class << " " << _name << "-" << _number << " copied from " << src._class << "-" << src._name << "-" << src._number << "\n";
return; return;
} }
@@ -25,7 +26,7 @@ ScavTrap::ScavTrap( ScavTrap const & src ) : ClapTrap() {
*********************************************/ *********************************************/
ScavTrap::~ScavTrap( void ) { ScavTrap::~ScavTrap( void ) {
std::cout << _class << " " << _name << " nb:" << _number << " destructed\n"; std::cout << _class << " " << _name << "-" << _number << " destructed\n";
return; return;
} }
@@ -37,13 +38,15 @@ ScavTrap & ScavTrap::operator=( ScavTrap const & rhs ) {
if ( this != &rhs ) if ( this != &rhs )
{ {
_hit = rhs.getHit(); ClapTrap::operator=(rhs);
_energy = rhs.getEnergy(); // _name = rhs.getName();
_attack = rhs.getAttack(); // _hit = rhs.getHit();
_name = rhs.getName(); // _energy = rhs.getEnergy();
// _attack = rhs.getAttack();
// _name = rhs.getName();
} }
std::cout << _class << " " << _name << " nb:" << _number << " assigned\n"; std::cout << _class << "T " << _name << "-" << _number << " assigned\n";
return *this; return *this;
} }
@@ -53,7 +56,7 @@ ScavTrap & ScavTrap::operator=( ScavTrap const & rhs ) {
*********************************************/ *********************************************/
void ScavTrap::guardGate() { void ScavTrap::guardGate() {
std::cout << _class << " " << _name << " entered special mode Gate Keeper\n"; std::cout << _class << " " << _name << "-" << _number << " entered special mode Gate Keeper\n";
} }
/********************************************* /*********************************************

View File

@@ -46,33 +46,33 @@ void goAttack(ScavTrap & robot1, ClapTrap & robot2) {
int main() { int main() {
// ClapTrap robot1("robot1"); ClapTrap robot1("robot1");
// ScavTrap robot2("robot2"); ScavTrap robot2("robot2");
// ScavTrap robot3("robot3"); robot2.guardGate();
// ClapTrap robot4("robot4"); ScavTrap robot3("robot3");
ClapTrap robot4("robot4");
std::cout << "assignement 1:\n"; std::cout << "\nassignement 1 (ClapTrap(ScavTrap)):\n";
ScavTrap robotmp1("robot5"); ClapTrap robot5(robot2);
robotmp1.guardGate(); // robot5.guardGate();
ClapTrap robot6(robotmp1); // PBM : it says it's a ScavTrap but it has no guardGate()... goAttack(robot5, robot2);
// robot6.guardGate();
goAttack(robot6, robotmp1);
//std::cout << "assignement 2:\n"; std::cout << "\nassignement 2 (ScavTrap(ScavTrap)):\n";
// ScavTrap robotmp2("robot7"); ScavTrap robot6(robot2);
// ScavTrap robot8(robotmp2); robot6.guardGate();
// robot8.guardGate(); goAttack(robot6, robot2);
// robot2.takeDamage(robot6.getAttack());
//std::cout << "assignement 3:\n"; robot6 = robot6;
// ClapTrap robotmp3("robot9"); // PBM : assignation doesn't work... goAttack(robot6, robot2);
//// ScavTrap robot10(robotmp3);
//// robot10.guardGate(); std::cout << "\nassignement 3 (ScavTrap(ClapTrap)):\n";
// // ScavTrap robot7(robot1);
//std::cout << "assignement 4:\n";
// ClapTrap robotmp4("robot11"); std::cout << "\nassignement 4 (ClapTrap(ClapTrap)):\n";
// ClapTrap robot12(robotmp4); ClapTrap robot7(robot1);
//// robot12.guardGate(); goAttack(robot7, robot1);
//
std::cout << "\nwar:\n";
// goAttack(robot1, robot2); // goAttack(robot1, robot2);
// goAttack(robot2, robot1); // goAttack(robot2, robot1);
// goAttack(robot1, robot3); // goAttack(robot1, robot3);

Binary file not shown.