#include "ece250.h" #include "Double_list.h" #include "Exception.h" template Double_list::Double_list(): list_head( nullptr ), list_tail( nullptr ), list_size( 0 ) { // empty constructor } template Double_list::Double_list( Double_list const &list ): list_head( nullptr ), list_tail( nullptr ), list_size( 0 ) { // enter your implementation here } template Double_list::~Double_list() { } template int Double_list::size() const { return 0; } template bool Double_list::empty() const { return true; } template Type Double_list::front() const { return Type(); } template Type Double_list::back() const { return Type(); } template Double_node *Double_list::head() const { return nullptr; } template Double_node *Double_list::tail() const { return nullptr; } template int Double_list::count( Type const &obj ) const { return 0; } template void Double_list::swap( Double_list &list ) { std::swap( list_head, list.list_head ); std::swap( list_tail, list.list_tail ); std::swap( list_size, list.list_size ); } template Double_list &Double_list::operator=( Double_list const &rhs ) { Double_list copy( rhs ); swap( copy ); return *this; } template void Double_list::push_front( Type const &obj ) { } template void Double_list::push_back( Type const &obj ) { } template Type Double_list::pop_front() { return Type(); } template Type Double_list::pop_back() { return Type(); } template int Double_list::erase( Type const &obj ) { return 0; } // You can modify this function however you want: it will not be tested template std::ostream &operator<<( std::ostream &out, Double_list const &list ) { out << "head"; for ( Double_node *ptr = list.head(); ptr != nullptr; ptr = ptr->next() ) { out << "->" << ptr->retrieve(); } out << "->0" << std::endl << "tail"; for ( Double_node *ptr = list.tail(); ptr != nullptr; ptr = ptr->previous() ) { out << "->" << ptr->retrieve(); } out << "->0"; return out; } // Is an error showing up in ece250.h or elsewhere? // Did you forget a closing '}' ?