Library 1

vector library completed.
list.hpp completed.
This commit is contained in:
Alessandro Ferro 2021-03-31 19:54:40 +02:00
parent 3e73aeb28d
commit 6788a731b3
3 changed files with 116 additions and 56 deletions

View File

@ -1,10 +1,19 @@
namespace lasd { namespace lasd {
// Specific constructor
template <typename Data>
List<Data>::Node::Node(Data newValue){
value = newValue;
}
/* ************************************************************************** */ // Copy constructor
template <typename Data>
List<Data>::Node::Node(const Data& copyFrom){
value = copyFrom.value;
}
// ... // Move constructor
template <typename Data>
/* ************************************************************************** */ List<Data>::Node::Node(Data&& moveFrom){
}
} }

View File

@ -13,150 +13,144 @@ namespace lasd {
/* ************************************************************************** */ /* ************************************************************************** */
template <typename Data> template <typename Data>
class List { // Must extend LinearContainer<Data>, MappableContainer<Data>, and FoldableContainer<Data> class List : virtual public LinearContainer<Data>,
virtual public MappableContainer<Data>,
virtual public FoldableContainer<Data> { // Must extend LinearContainer<Data>, MappableContainer<Data>, and FoldableContainer<Data>
private: private:
// ...
protected: protected:
// using LinearContainer<Data>::???; using LinearContainer<Data>::size;
struct Node struct Node
{ {
Data value;
// Data Node* next = nullptr;
// ...
/* ********************************************************************** */ /* ********************************************************************** */
// Specific constructors // Specific constructors
// ... Node(Data);
/* ********************************************************************** */ /* ********************************************************************** */
// Copy constructor // Copy constructor
// ... Node(const Node&);
// Move constructor // Move constructor
// ... Node(Node&&);
/* ********************************************************************** */ /* ********************************************************************** */
// Destructor // Destructor
// ... ~Node() = default;
/* ********************************************************************** */ /* ********************************************************************** */
// Comparison operators // Comparison operators
// ... bool operator==(const Node&) const noexcept;
bool operator!=(const Node&) const noexcept;
/* ********************************************************************** */
// Specific member functions
// ...
}; };
// ... struct Node* head = nullptr;
struct Node* tail = nullptr;
public: public:
// Default constructor // Default constructor
// List() specifiers; List() = default;
/* ************************************************************************ */ /* ************************************************************************ */
// Specific constructor // Specific constructor
// List(argument) specifiers; // A list obtained from a LinearContainer List(const LinearContainer&); // A list obtained from a LinearContainer
/* ************************************************************************ */ /* ************************************************************************ */
// Copy constructor // Copy constructor
// List(argument) specifiers; List(const List&);
// Move constructor //Move constructor
// List(argument) specifiers; List(List&&);
/* ************************************************************************ */ /* ************************************************************************ */
// Destructor // Destructor
// ~List() specifiers; ~List();
/* ************************************************************************ */ /* ************************************************************************ */
// Copy assignment // Copy assignment
// type operator=(argument) specifiers; List& operator=(const List&);
// Move assignment // Move assignment
// type operator=(argument) specifiers; List& operator=(List&&) noexcept;
/* ************************************************************************ */ /* ************************************************************************ */
// Comparison operators // Comparison operators
// type operator==(argument) specifiers; bool operator==(const List&) const noexcept;
// type operator!=(argument) specifiers; bool operator!=(const List&) const noexcept;
/* ************************************************************************ */ /* ************************************************************************ */
// Specific member functions // Specific member functions
// type InsertAtFront(argument) specifier; // Copy of the value void InsertAtFront(const Data&); // Copy of the value
// type InsertAtFront(argument) specifier; // Move of the value void InsertAtFront(Data&&); // Move of the value
// type RemoveFromFront() specifier; // (must throw std::length_error when empty) void RemoveFromFront(); // (must throw std::length_error when empty)
// type FrontNRemove() specifier; // (must throw std::length_error when empty) Data FrontNRemove(); // (must throw std::length_error when empty)
// type InsertAtBack(argument) specifier; // Copy of the value void InsertAtBack(const Data&); // Copy of the value
// type InsertAtBack(argument) specifier; // Move of the value void InsertAtBack(Data&&); // Move of the value
/* ************************************************************************ */ /* ************************************************************************ */
// Specific member functions (inherited from Container) // Specific member functions (inherited from Container)
// type Clear() specifiers; // Override Container member void Clear() override; // Override Container member
/* ************************************************************************ */ /* ************************************************************************ */
// Specific member functions (inherited from LinearContainer) // Specific member functions (inherited from LinearContainer)
// type Front() specifiers; // Override LinearContainer member (must throw std::length_error when empty) Data& Front() override const; // Override LinearContainer member (must throw std::length_error when empty)
// type Back() specifiers; // Override LinearContainer member (must throw std::length_error when empty) Data& Back() override const; // Override LinearContainer member (must throw std::length_error when empty)
// type operator[](argument) specifiers; // Override LinearContainer member (must throw std::out_of_range when out of range) Data& operator[](const ulong) const override; // Override LinearContainer member (must throw std::out_of_range when out of range)
/* ************************************************************************ */ /* ************************************************************************ */
// Specific member functions (inherited from MappableContainer) // Specific member functions (inherited from MappableContainer)
// using typename MappableContainer<Data>::MapFunctor; using typename MappableContainer<Data>::MapFunctor;
// type MapPreOrder(arguments) specifiers; // Override MappableContainer member void MapPreOrder(const MapFunctor, void*) override; // Override MappableContainer member
// type MapPostOrder(arguments) specifiers; // Override MappableContainer member void MapPostOrder(const MapFunctor, void*) override; // Override MappableContainer member
/* ************************************************************************ */ /* ************************************************************************ */
// Specific member functions (inherited from FoldableContainer) // Specific member functions (inherited from FoldableContainer)
// using typename FoldableContainer<Data>::FoldFunctor; using typename FoldableContainer<Data>::FoldFunctor;
// type FoldPreOrder(arguments) specifiers; // Override FoldableContainer member void FoldPreOrder(const FoldFunctor, const void*, void*) const override; // Override FoldableContainer member
// type FoldPostOrder(arguments) specifiers; // Override FoldableContainer member void FoldPostOrder(const FoldFunctor, const void*, void*) const override; // Override FoldableContainer member
protected: protected:
// Auxiliary member functions (for MappableContainer) // Auxiliary member functions (for MappableContainer)
// type MapPreOrder(arguments) specifiers; // Accessory function executing from one point of the list onwards void MapPreOrder(const MapFunctor, void*, struct Node*); // Accessory function executing from one point of the list onwards
// type MapPostOrder(arguments) specifiers; // Accessory function executing from one point of the list onwards void MapPostOrder(const MapFunctor, void*, struct Node*); // Accessory function executing from one point of the list onwards
/* ************************************************************************ */ /* ************************************************************************ */
// Auxiliary member functions (for FoldableContainer) // Auxiliary member functions (for FoldableContainer)
// type FoldPreOrder(arguments) specifiers; // Accessory function executing from one point of the list onwards void FoldPreOrder(const FoldFunctor, const void*, void*, struct Node*) const; // Accessory function executing from one point of the list onwards
// type FoldPostOrder(arguments) specifiers; // Accessory function executing from one point of the list onwards void FoldPostOrder(const FoldFunctor, const void*, void*, struct Node*) const; // Accessory function executing from one point of the list onwards
}; };

View File

@ -121,3 +121,60 @@ void Vector<Data>::Clear(){
Elements = nullptr; Elements = nullptr;
size = 0; size = 0;
} }
template typename<Data>
Data& Vector<Data>::Front() const{
if(size!=0){
return Elements[0];
}else{
return std::length_error("Access to an empty vector");
}
}
template typename<Data>
Data& Vector<Data>::Back() const{
if(size!=0){
return Elements[size-1];
}else{
return std::length_error("Access to an empty vector");
}
}
template typename<Data>
Data& Vector<Data>::operator[](const ulong index) const{
if(index < size){
return Elements[index];
}else{
throw std::out_of_range("Access at index " + std::to_string(index) + " invalid because the vector size is" + std::to_string(size));
}
}
template typename<Data>
void Vector<Data>::MapPreOrder(const MapFunctor fun, void* par){
for(ulong i = 0 ; i<size ; i++){
fun(Elements[i], par);
}
}
template typename<Data>
void Vector<Data>::MapPostOrder(const MapFunctor fun, void* par){
ulong i = size;
while(i>0){
fun(Elements[--i], par);
}
}
template typename<Data>
void Vector<Data>::FoldPreOrder(const FoldFunctor fun, const void* par, void* acc) const{
for(ulong i = 0 ; i<size ; ++i){
fun(Elements[i], par, acc);
}
}
template typename<Data>
void Vector<Data>::FoldPostOrder(const FoldFunctor fun, const void* par, void* acc) const{
ulong i = size;
while(i>0){
fun(Elements[--i], par, acc);
}
}