Pregunta

Im trying to create a very simple VCard but im getting a non-const lvalue reference to type cannot bind error in my main.cpp and can't figure this out. the problem line is.....

vc->createVCard("JasonSteindorf.vcf", &p1);

//Person.h

#ifndef JASONSTEINDORF_PERSON_H
#define JASONSTEINDORF_PERSON_H

#include <string>
using std::string;

namespace JasonSteindorf{

    class Person{
    public:
        Person();
        Person(string firstName,string lastName,string phoneNumber,string email)
            : firstName(firstName), lastName(lastName), phoneNumber(phoneNumber), email(email){}

        inline string getFirstName(){ return firstName; }
        inline string getLastName(){ return lastName; }
        inline string getPhoneNumber(){ return phoneNumber; }
        inline string getEmail(){ return email; }

    private:
        string firstName, lastName, phoneNumber, email;
    };
}

#endif

//VCard.h

#ifndef JASONSTEINDORF_VCARD_H
#define JASONSTEINDORF_VCARD_H


#include "Person.h"

#include <string>
using std::string;

namespace JasonSteindorf{

    class VCard{

    public:
        void createVCard(string fileName, Person &p);
        string getVCard(Person &p);
    };
}

#endif 

//VCard.cpp

#include "VCard.h"

#include <fstream>
using std::ofstream;

#include <string>
using std::string;

#include <sstream>
#include <iostream>
using std::ostringstream;


using namespace JasonSteindorf;

//Writes the VCard to a file
string getVCard(Person &p){
    ostringstream os;

    os << "BEGIN:VCARD\n"
       << "VERSION:3.0\n"
       << "N:" << p.getLastName() << ";" << p.getFirstName() << "\n"
       << "FN:" << p.getFirstName() <<" " << p.getLastName() << "\n"
       << "TEL:TYPE=CELL:" << p.getPhoneNumber() << "\n"
       << "EMAIL:" << p.getEmail() << "\n"
       << "URL:" << "http://sorcerer.ucsd.edu/html/people/jason.html" << "\n"
       << "REV:20110719T195243Z" << "\n"
       << "END:VCARD\n";

    return os.str();
}

//Returns a string containing the VCard format
void createVCard(string fileName, Person &p){
    string vCard = getVCard(p);

    ofstream outputFile("/Users/jsteindorf/Desktop/" + fileName);
    outputFile << vCard;
}

//main.cpp

#include "Person.h"
#include "VCard.h"

#include <iostream>

using namespace JasonSteindorf;

int main(int argc, const char * argv[])
{

    VCard *vc = new VCard();
    Person *p1 = new Person ("Jason", "S", "858-555-5555", "js@ucsd.edu");

    vc->createVCard("JS.vcf", &p1);

    return 0;
}
¿Fue útil?

Solución

You haven't defined the functions createVCard and getCard as member functions of VCard class.

Those are global functions. Use the scope resolution operator :: to define them as member functions of the class like

  void Vcard::createVCard(string fileName,Person &p)
  {
    ....
    ....
  }
  string Vcard::getVCard(Person &p)
  {
    ....
    ....
  }

And also your createVCard function accepts a reference to Person hence you will have to pass the object to the person not the address of pointer to the object (&p) nor address of the object (p) instead pass the object by de-referencing it like *p, hence the call would look like vc->createVCard("JS.vcf", *p1)

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top