One fix is in the runner, which is part of the completion
engine itself. The other is specific for C++.
Task-number: QTCREATORBUG-5947
Change-Id: Ib8fff1eb5adad1ffb2a11da66c50b545e1457df8
Reviewed-on: http://codereview.qt.nokia.com/4355
Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com>
Reviewed-by: Fawzi Mohamed <fawzi.mohamed@nokia.com>
}
}
} else {
+ delete *it;
it = m_completions.erase(it);
}
}
#include "iassistprocessor.h"
#include "iassistproposal.h"
#include "iassistinterface.h"
+#include "iassistproposalmodel.h"
using namespace TextEditor;
using namespace Internal;
ProcessorRunner::~ProcessorRunner()
{
delete m_processor;
- if (m_discardProposal)
+ if (m_discardProposal && m_proposal) {
+ // Proposal doesn't own the model, so we need to delete both.
+ delete m_proposal->model();
delete m_proposal;
+ }
}
void ProcessorRunner::setProcessor(IAssistProcessor *computer)