From d161579a2a4ab2d63e5acfd8a1e17c0ecc3de889 Mon Sep 17 00:00:00 2001 From: Raphael Date: Fri, 24 Jan 2025 21:02:57 +0100 Subject: [PATCH] mastring the simple heritage --- cpp03/ex01/FragTrap.cpp | 0 cpp03/ex01/FragTrap.hpp | 0 cpp03/ex01/ScavTrap.cpp | 8 ++- cpp03/ex01/ScavTrap.hpp | 5 +- cpp03/ex01/main.cpp | 5 +- cpp03/ex02/ClapTrap.cpp | 55 ++++++++++++++++++ cpp03/ex02/ClapTrap.hpp | 35 ++++++++++++ cpp03/ex02/FragTrap.cpp | 25 ++++++++ cpp03/ex02/FragTrap.hpp | 29 ++++++++++ cpp03/ex02/Makefile | 124 ++++++++++++++++++++++++++++++++++++++++ cpp03/ex02/ScavTrap.cpp | 27 +++++++++ cpp03/ex02/ScavTrap.hpp | 30 ++++++++++ cpp03/ex02/main.cpp | 37 ++++++++++++ 13 files changed, 376 insertions(+), 4 deletions(-) create mode 100644 cpp03/ex01/FragTrap.cpp create mode 100644 cpp03/ex01/FragTrap.hpp create mode 100644 cpp03/ex02/ClapTrap.cpp create mode 100644 cpp03/ex02/ClapTrap.hpp create mode 100644 cpp03/ex02/FragTrap.cpp create mode 100644 cpp03/ex02/FragTrap.hpp create mode 100644 cpp03/ex02/Makefile create mode 100644 cpp03/ex02/ScavTrap.cpp create mode 100644 cpp03/ex02/ScavTrap.hpp create mode 100644 cpp03/ex02/main.cpp diff --git a/cpp03/ex01/FragTrap.cpp b/cpp03/ex01/FragTrap.cpp new file mode 100644 index 0000000..e69de29 diff --git a/cpp03/ex01/FragTrap.hpp b/cpp03/ex01/FragTrap.hpp new file mode 100644 index 0000000..e69de29 diff --git a/cpp03/ex01/ScavTrap.cpp b/cpp03/ex01/ScavTrap.cpp index cffeba4..13c6c83 100644 --- a/cpp03/ex01/ScavTrap.cpp +++ b/cpp03/ex01/ScavTrap.cpp @@ -6,7 +6,7 @@ /* By: rparodi +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2025/01/24 17:41:01 by rparodi #+# #+# */ -/* Updated: 2025/01/24 18:31:52 by rparodi ### ########.fr */ +/* Updated: 2025/01/24 20:31:45 by rparodi ### ########.fr */ /* */ /* ************************************************************************** */ @@ -17,5 +17,11 @@ ScavTrap::ScavTrap (std::string name) { _hit_point = 100; _energy_point = 50; _attack_damage = 20; + _gateKeeperMode = false; std::cout << "\n[Init] ScavTrap:\n\t" << "Name: " << _name << std::endl; } + +void ScavTrap::guardGate() { + _gateKeeperMode = !_gateKeeperMode; + std::cout << "\n[Mode] ScavTrap:\n\t" << "Name: " << _name << " the mode gate keeper is now: " << (_gateKeeperMode ? "enable" : "disable") << std::endl; +} diff --git a/cpp03/ex01/ScavTrap.hpp b/cpp03/ex01/ScavTrap.hpp index ee90651..2377c84 100644 --- a/cpp03/ex01/ScavTrap.hpp +++ b/cpp03/ex01/ScavTrap.hpp @@ -6,7 +6,7 @@ /* By: rparodi +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2025/01/20 23:13:16 by rparodi #+# #+# */ -/* Updated: 2025/01/24 18:23:14 by rparodi ### ########.fr */ +/* Updated: 2025/01/24 18:46:42 by rparodi ### ########.fr */ /* */ /* ************************************************************************** */ @@ -19,10 +19,11 @@ class ScavTrap : public ClapTrap { public: ScavTrap(std::string name); - + void guardGate(); protected: private: + bool _gateKeeperMode; }; diff --git a/cpp03/ex01/main.cpp b/cpp03/ex01/main.cpp index 115256d..ac67232 100644 --- a/cpp03/ex01/main.cpp +++ b/cpp03/ex01/main.cpp @@ -6,7 +6,7 @@ /* By: rparodi +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2025/01/10 15:50:07 by rparodi #+# #+# */ -/* Updated: 2025/01/24 17:37:56 by rparodi ### ########.fr */ +/* Updated: 2025/01/24 18:51:51 by rparodi ### ########.fr */ /* */ /* ************************************************************************** */ @@ -20,6 +20,9 @@ int main(void) { test.attack("Moulinette"); test.takeDamage(42); test.beRepaired(42); + test.guardGate(); + test.guardGate(); + test.guardGate(); std::cout << "\n\n[Broadcast]\n\tIn the Blue corner the actual cat of the 42 school !" << std::endl; ClapTrap test2("Moulinette"); test2.beRepaired(32); diff --git a/cpp03/ex02/ClapTrap.cpp b/cpp03/ex02/ClapTrap.cpp new file mode 100644 index 0000000..de4937e --- /dev/null +++ b/cpp03/ex02/ClapTrap.cpp @@ -0,0 +1,55 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ClapTrap.cpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/10 13:59:49 by rparodi #+# #+# */ +/* Updated: 2025/01/24 18:32:35 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "ClapTrap.hpp" +#include +#include + +ClapTrap::ClapTrap() { + +} + +ClapTrap::ClapTrap(std::string name) { + _name = name; + _hit_point = 10; + _energy_point = 10; + _attack_damage = 0; + std::cout << "\n[Init] ClapTrap:\n\t" << "Name: " << _name << std::endl; +} + +ClapTrap::~ClapTrap() { + std::cout << "\n[Delete] ClapTrap:\n\t" << "Name: " << _name << std::endl; +} + +void ClapTrap::attack(const std::string& target) { + if (_energy_point <= 0 || _hit_point <= 0) { + std::cerr << "\n[Attack] ClapTrap:\n\t" << "Not enough energy to attack" << std::endl; + return ; + } + _energy_point--; + std::cout << "\n[Attack] ClapTrap:\n\t" << _name << " attacks " << target << ", causing " << _attack_damage << " points of damage!" << std::endl; +} + +void ClapTrap::takeDamage(unsigned int amount) { + _hit_point -= amount; + std::cout << "\n[Hurt] ClapTrap:\n\t" << _name << " take " << amount << " now hit_point are " << _hit_point << std::endl; +} + +void ClapTrap::beRepaired(unsigned int amount) { + if (_energy_point <= 0 || _hit_point <= 0) { + std::cerr << "\n[Repair] ClapTrap:\n\t" << "Not enough energy to repair" << std::endl; + return ; + } + _energy_point--; + _hit_point += amount; + std::cout << "\n[Repair] ClapTrap:\n\t" << _name << " repair, for an amount " << amount << " now hit_point are " << _hit_point << std::endl; +} diff --git a/cpp03/ex02/ClapTrap.hpp b/cpp03/ex02/ClapTrap.hpp new file mode 100644 index 0000000..a6c5d7b --- /dev/null +++ b/cpp03/ex02/ClapTrap.hpp @@ -0,0 +1,35 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ClapTrap.hpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/10 14:54:21 by rparodi #+# #+# */ +/* Updated: 2025/01/24 18:32:41 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef CLAPTRAP_HPP +#define CLAPTRAP_HPP + +#include + +class ClapTrap { + public: + ClapTrap(); + ClapTrap(std::string name); + ~ClapTrap(); + void attack(const std::string& target); + void takeDamage(unsigned int amount); + void beRepaired(unsigned int amount); + protected: + std::string _name; + int _hit_point; + int _energy_point; + int _attack_damage; + private: + +}; + +#endif diff --git a/cpp03/ex02/FragTrap.cpp b/cpp03/ex02/FragTrap.cpp new file mode 100644 index 0000000..57478c5 --- /dev/null +++ b/cpp03/ex02/FragTrap.cpp @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* FragTrap.cpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/24 17:41:01 by rparodi #+# #+# */ +/* Updated: 2025/01/24 21:01:58 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "FragTrap.hpp" + +FragTrap::FragTrap (std::string name) { + _name = name; + _hit_point = 100; + _energy_point = 100; + _attack_damage = 30; + std::cout << "\n[Init] FragTrap:\n\t" << "Name: " << _name << std::endl; +} + +void FragTrap::highFivesGuys() { + std::cout << "\n[Clap] FragTrap:\n\t" << "Name:" << _name << "Hey bro can i get an high five ? Thanks u brother !" << _name << "Hey bro can i get an high five ? Thanks u brother !" << std::endl; +} diff --git a/cpp03/ex02/FragTrap.hpp b/cpp03/ex02/FragTrap.hpp new file mode 100644 index 0000000..4d66b0a --- /dev/null +++ b/cpp03/ex02/FragTrap.hpp @@ -0,0 +1,29 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* FragTrap.hpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/20 23:13:16 by rparodi #+# #+# */ +/* Updated: 2025/01/24 20:54:17 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef FRAGTRAP_HPP +#define FRAGTRAP_HPP + +#include +#include "ClapTrap.hpp" + +class FragTrap: public ClapTrap { + public: + FragTrap(std::string name); + void highFivesGuys(void); + protected: + + private: + +}; + +#endif diff --git a/cpp03/ex02/Makefile b/cpp03/ex02/Makefile new file mode 100644 index 0000000..1b5e259 --- /dev/null +++ b/cpp03/ex02/Makefile @@ -0,0 +1,124 @@ +# **************************************************************************** # +# ::: :::::::: # +# Makefile :+: :+: :+: # +# +:+ +:+ +:+ # +# By: rparodi +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2023/11/12 11:05:05 by rparodi #+# #+# # +# Updated: 2024/12/21 19:50:58 by rparodi ### ########.fr # +# # +# **************************************************************************** # + +# Variables + +# Name +NAME = open + +# Commands +CXX = c++ +RM = rm -rf + +# Flags +# Mandatory flags for 42 CXXFLAGS = -Werror -Wextra -Wall -std=c++98 -I./includes/ +# Flags to debug and have the dependences (can be removed for correction) +CXXFLAGS += -MMD -g3 +# Flag to debug (TO REMOVE) +# CXXFLAGS += -D DEBUG=1 +# Sources +SRC = ClapTrap.cpp \ + FragTrap.cpp \ + ScavTrap.cpp \ + main.cpp + +# Objects +OBJDIRNAME = ./build +OBJ = $(addprefix $(OBJDIRNAME)/,$(SRC:.cpp=.o)) + +# Colors +GREEN = \033[32m +GREY = \033[0;90m +RED = \033[0;31m +GOLD = \033[38;5;220m +END = \033[0m + +# Rules + +# All (make all) +all: header $(NAME) footer + +# Bonus (make bonus) +bonus: header $(OBJ) footer + @mkdir -p $(OBJDIRNAME) + @printf '$(GREY) Creating $(END)$(GREEN)$(OBJDIRNAME)$(END)\n' + @$(CXX) $(CXXFLAGS) -o $(NAME) $(OBJ) + +# Clean (make clean) +clean: + @printf '$(GREY) Removing $(END)$(RED)Objects$(END)\n' + @printf '$(GREY) Removing $(END)$(RED)Objects Folder$(END)\n' + @$(RM) $(OBJDIRNAME) + +# Clean (make fclean) +fclean: clean + @printf '$(GREY) Removing $(END)$(RED)Program$(END)\n' + @$(RM) $(NAME) + @echo "" + +# Restart (make re) +re: header fclean all + +# Dependences for all +$(NAME): $(OBJ) + @mkdir -p $(OBJDIRNAME) + @printf '$(GREY) Creating $(END)$(GREEN)$(OBJDIRNAME)$(END)\n' + @$(CXX) $(CXXFLAGS) -o $(NAME) $(OBJ) + +# Creating the objects +$(OBJDIRNAME)/%.o: %.cpp + @mkdir -p $(dir $@) + @printf '$(GREY) Compiling $(END)$(GREEN)$<$(END)\n' + @$(CXX) $(CXXFLAGS) -o $@ -c $< + +# Header +header: + @clear + @printf '\n\n' + @printf '$(GOLD) ******* ****** ******* $(END)\n' + @printf '$(GOLD) ****** *** ******* $(END)\n' + @printf '$(GOLD) ******* * ******* $(END)\n' + @printf '$(GOLD) ****** ******* $(END)\n' + @printf '$(GOLD) ******* ******* $(END)\n' + @printf '$(GOLD) ******************* ******* * $(END)\n' + @printf '$(GOLD) ******************* ******* *** $(END)\n' + @printf '$(GOLD) ****** ******* ****** $(END)\n' + @printf '$(GOLD) ****** $(END)\n' + @printf '$(GOLD) ****** $(END)\n' + @printf '$(GREY) Made by rparodi$(END)\n\n' + +# Footer +footer: + @printf "\n" + @printf "$(GOLD) ,_ _,$(END)\n" + @printf "$(GOLD) | \\___//|$(END)\n" + @printf "$(GOLD) |=6 6=|$(END)\n" + @printf "$(GOLD) \\=._Y_.=/$(END)\n" + @printf "$(GOLD) ) \` ( ,$(END)\n" + @printf "$(GOLD) / \\ (('$(END)\n" + @printf "$(GOLD) | | ))$(END)\n" + @printf "$(GOLD) /| | | |\\_//$(END)\n" + @printf "$(GOLD) \\| |._.| |/-\`$(END)\n" + @printf "$(GOLD) '\"' '\"'$(END)\n" + @printf ' $(GREY)The compilation is$(END) $(GOLD)finish$(END)\n $(GREY)Have a good $(END)$(GOLD)correction !$(END)\n' + +clangd: + @echo \ + "CompileFlags:\n" \ + " Add:\n" \ + " - \"-std=c++98 -Wall -Wextra -Werror\"\n" \ + " - \"-I"$(shell pwd)"/includes\"\n" \ + " - \"-xc++\"\n" \ + > .clangd + +# Phony +.PHONY: all bonus clean fclean re clangd +-include ${OBJ:.o=.d} diff --git a/cpp03/ex02/ScavTrap.cpp b/cpp03/ex02/ScavTrap.cpp new file mode 100644 index 0000000..1696b88 --- /dev/null +++ b/cpp03/ex02/ScavTrap.cpp @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ScavTrap.cpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/24 17:41:01 by rparodi #+# #+# */ +/* Updated: 2025/01/24 19:24:05 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "ScavTrap.hpp" + +ScavTrap::ScavTrap (std::string name) { + _name = name; + _hit_point = 100; + _energy_point = 50; + _attack_damage = 20; + _gateKeeperMode = false; + std::cout << "\n[Init] ScavTrap:\n\t" << "Name: " << _name << std::endl; +} + +void ScavTrap::guardGate() { +_gateKeeperMode = !_gateKeeperMode; + std::cout << "\n[Mode] ScavTrap:\n\t" << "Name: " << _name << " the mode gate keeper is now: " << (_gateKeeperMode ? "enable" : "disable") << std::endl; +} diff --git a/cpp03/ex02/ScavTrap.hpp b/cpp03/ex02/ScavTrap.hpp new file mode 100644 index 0000000..b8c8b8b --- /dev/null +++ b/cpp03/ex02/ScavTrap.hpp @@ -0,0 +1,30 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ScavTrap.hpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/20 23:13:16 by rparodi #+# #+# */ +/* Updated: 2025/01/24 20:57:35 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef SCAVTRAP_HPP +#define SCAVTRAP_HPP + +#include +#include "ClapTrap.hpp" + +class ScavTrap : public ClapTrap { + public: + ScavTrap(std::string name); + void guardGate(); + protected: + + private: + bool _gateKeeperMode; + +}; + +#endif diff --git a/cpp03/ex02/main.cpp b/cpp03/ex02/main.cpp new file mode 100644 index 0000000..f83c07e --- /dev/null +++ b/cpp03/ex02/main.cpp @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* main.cpp :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rparodi +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2025/01/10 15:50:07 by rparodi #+# #+# */ +/* Updated: 2025/01/24 21:02:23 by rparodi ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "ClapTrap.hpp" +#include "ScavTrap.hpp" +#include "FragTrap.hpp" +#include + +int main(void) { + std::cout << "[Broadcast]\n\tIn the Blue corner the actual cat of the 42 school !" << std::endl; + ClapTrap test("Moulinette"); + test.beRepaired(32); + std::cout << "\n\n[Broadcast]\n\tIn the Red corner the first cat of the 42 school !" << std::endl; + ScavTrap test2("Norminet"); + test2.attack("Moulinette"); + test2.takeDamage(42); + test2.beRepaired(42); + test2.guardGate(); + test2.guardGate(); + test2.guardGate(); + std::cout << "\n\n[Broadcast]\n\t And for the referee of this legendary fight the others cats of Made !" << std::endl; + FragTrap test3("Norminet"); + test3.attack("Moulinette"); + test3.takeDamage(42); + test3.beRepaired(42); + test3.highFivesGuys(); + return (0); +}