jeudi 2 mars 2017

C++ Function Redefinition

I keep getting a function redefinition error, and I'm not sure why. I've looked through similar questions, but I couldn't glean any answers from them -- I've got header guards, and as far as I can tell, I have included the correct files and haven't redefined the functions outside of the header. The errors are as follows:

Contact.cpp:188:2: error: redefinition of ‘communication::Contact::Contact(const communication::Contact&)’
Contact.h:35:3: error: ‘communication::Contact::Contact(const communication::Contact&)’ previously defined here
Contact.cpp:208:18: error: redefinition of ‘communication::Contact& communication::Contact::operator=(const communication::Contact&)’
Contact.h:36:12: error: ‘communication::Contact& communication::Contact::operator=(const communication::Contact&)’ previously defined here

The header and relevant chunk of the CPP file are below. Any help is much appreciated.

Header:

#ifndef CONTACT_H
#define CONTACT_H

namespace communication {
        class Contact
        {
                char m_name[21];
                long long* m_phoneNumbers;
                int m_noOfPhoneNumbers;
        public:
                Contact();
                Contact (const char * c_name, long long contactList[], int numContacts);
                ~Contact();
                void display() const;
                bool isEmpty() const;
                void addPhoneNumber(long long phoneNumber);

                //Definitions of the functions causing problems
                Contact(const Contact& other) = delete;
                Contact& operator=(const Contact& other) = delete;
        };
}

#endif

CPP:

//Copy constructor
        Contact::Contact (const Contact& other) {
                strcpy(m_name,other.m_name);
                m_noOfPhoneNumbers = other.m_noOfPhoneNumbers;

                //Checks to see if the array being copied is empty
                if (other.m_phoneNumbers != nullptr) {
                        //Allocates the appropriate amount of memory to m_phoneNumbers
                        m_phoneNumbers = new long long[m_noOfPhoneNumbers];

                        //Goes through and copies the phone numbers to this.m_phoneNumbers from other.m_Phon$
                        for (int i = 0; i < m_noOfPhoneNumbers; i++) {
                                m_phoneNumbers[i] = other.m_phoneNumbers[i];  
                        }
                }
                else {
                        m_phoneNumbers = nullptr;
                }
        }
        //Copy assignment operator
        Contact& Contact::operator=(const Contact& other) {
                //Checks to make sure that the object is not being assigned to itself
                if (this != &other) {
                        //Copies name and number of phone numbers to the left operand
                        strcpy(m_name,other.m_name);
                        m_noOfPhoneNumbers = other.m_noOfPhoneNumbers;

                        //Deallocates memory that may have been given previously
                        delete [] m_phoneNumbers;

                        //Checks to see if the array being copied is empty
                        if (other.m_phoneNumbers != nullptr) {
                                //Allocates the appropriate amount of memory to m_phoneNumbers
                                m_phoneNumbers = new long long[m_noOfPhoneNumbers];

                                //Goes through and copies the phone numbers to this.m_phoneNumbers from other.m_PhoneNumbers
                                for (int i = 0; i < m_noOfPhoneNumbers; i++) {
                                      m_phoneNumbers[i] = other.m_phoneNumbers[i];
                                }

                        }
                        else {
                                m_phoneNumbers = nullptr;
                        }
                }

                return *this;
        }

Aucun commentaire:

Enregistrer un commentaire