Search code examples
c++qtqmap

QMap contains return always true


I have this code for the class IdTask

class IdTask
{
public:
IdTask(QString host, QString id) : _host(host), _id(id) {}
IdTask(const IdTask & idT) : _host(idT._host), _id(idT._id) {}

QString host() const { return _host;}
QString id() const { return _id;}

inline bool operator ==(const IdTask& idT) const { return _host == idT.host() && _id == idT.id();}
inline bool operator <(const IdTask& idT) const { return _host < idT.host() && _id < idT.id();}

private:
QString _host;
QString _id;
};

And the class IdResult

class IdResult
{
public:
IdResult(IdTask idT, QString id) : _idTask(idT), _id(id) {}
IdTask idTask() const { return _idTask;}
QString id() const { return _id;}
bool operator < (const IdResult& idR) const { return _idTask < idR.idTask() && _id < idR.id();}
private:
IdTask _idTask;
QString _id;
};

I create a QMap like this :

QMap<IdResult, QString> mapIdResultInput;
mapIdResultInput.insert(IdResult(IdTask("localhost", "init"), "a"), "_a");

The problem is with the function contains.

mapIdResultInput.contains(IdResult(IdTask("b", "c"), "g"));

It return always true. What is the problem with my code?


Solution

  • I would solve this in the following way: I would sort my IdResults first by IdTask and than, if IdTasks are equal, by id. Here is my implementation of your operators in the classes:

    class IdTask
    {
    public:
        [..]
        bool operator ==(const IdTask& idT) const
        { return _host == idT.host() && _id == idT.id(); }
    
        bool operator <(const IdTask& idT) const 
        { return (_host < idT.host()) || (_host == idT.host() && _id < idT.id()); }
        [..]
    };
    

    And

    class IdResult
    {
        [..]
        bool operator < (const IdResult& idR) const 
        { return (_idTask < idR.idTask()) || (_idTask == idR.idTask() && _id < idR.id()); }
        [..]
    };
    

    And the test

    QMap<IdResult, QString> mapIdResultInput;
    mapIdResultInput.insert(IdResult(IdTask("localhost", "init"), "a"), "_a");
    
    bool b = mapIdResultInput.contains(IdResult(IdTask("b", "c"), "g")); // false
    b = mapIdResultInput.contains(IdResult(IdTask("localhost", "init"), "a")); // true