save to move to e3
This commit is contained in:
@@ -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++;}
|
||||||
|
|
||||||
/*********************************************
|
/*********************************************
|
||||||
|
|||||||
@@ -29,6 +29,8 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
int getTotalNumber() const;
|
||||||
|
|
||||||
std::string _name;
|
std::string _name;
|
||||||
std::string _class;
|
std::string _class;
|
||||||
int _hit;
|
int _hit;
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|
||||||
|
|||||||
@@ -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";
|
||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************
|
/*********************************************
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
BIN
d03/ex01/robots
BIN
d03/ex01/robots
Binary file not shown.
Reference in New Issue
Block a user