projects
/
quassel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Compute correct height of ChatItems.
[quassel.git]
/
src
/
client
/
messagemodel.cpp
diff --git
a/src/client/messagemodel.cpp
b/src/client/messagemodel.cpp
index
c41ad97
..
76104bd
100644
(file)
--- a/
src/client/messagemodel.cpp
+++ b/
src/client/messagemodel.cpp
@@
-34,8
+34,9
@@
MessageModel::~MessageModel() {
}
QVariant MessageModel::data(const QModelIndex &index, int role) const {
}
QVariant MessageModel::data(const QModelIndex &index, int role) const {
- int row = index.row();
- if(row < 0 || row >= _messageList.count()) return QVariant();
+ int row = index.row(); int column = index.column();
+ if(row < 0 || row >= _messageList.count() || column < 0) return QVariant();
+ if(role == ColumnTypeRole) return column;
return _messageList[row]->data(index.column(), role);
}
return _messageList[row]->data(index.column(), role);
}
@@
-43,7
+44,7
@@
bool MessageModel::setData(const QModelIndex &index, const QVariant &value, int
int row = index.row();
if(row < 0 || row >= _messageList.count()) return false;
if(_messageList[row]->setData(index.column(), value, role)) {
int row = index.row();
if(row < 0 || row >= _messageList.count()) return false;
if(_messageList[row]->setData(index.column(), value, role)) {
- emit dataChanged(index, index);
// FIXME make msg emit this (too)
+ emit dataChanged(index, index);
return true;
}
return false;
return true;
}
return false;
@@
-52,7
+53,7
@@
bool MessageModel::setData(const QModelIndex &index, const QVariant &value, int
void MessageModel::insertMessage(const Message &msg) {
MsgId id = msg.msgId();
int idx = indexForId(id);
void MessageModel::insertMessage(const Message &msg) {
MsgId id = msg.msgId();
int idx = indexForId(id);
- Message
Item *item = createMessage
Item(msg);
+ Message
ModelItem *item = createMessageModel
Item(msg);
beginInsertRows(QModelIndex(), idx, idx);
_messageList.insert(idx, item);
endInsertRows();
beginInsertRows(QModelIndex(), idx, idx);
_messageList.insert(idx, item);
endInsertRows();
@@
-81,7
+82,7
@@
int MessageModel::indexForId(MsgId id) {
/**********************************************************************************/
/**********************************************************************************/
-Message
Item::Message
Item(const Message &msg) {
+Message
ModelItem::MessageModel
Item(const Message &msg) {
_timestamp = msg.timestamp();
_msgId = msg.msgId();
_bufferId = msg.bufferInfo().bufferId();
_timestamp = msg.timestamp();
_msgId = msg.msgId();
_bufferId = msg.bufferInfo().bufferId();
@@
-90,12
+91,12
@@
MessageItem::MessageItem(const Message &msg) {
}
}
-Message
Item::~Message
Item() {
+Message
ModelItem::~MessageModel
Item() {
}
}
-QVariant MessageItem::data(int column, int role) const {
- if(column <
TimestampColumn || column > Text
Column) return QVariant();
+QVariant Message
Model
Item::data(int column, int role) const {
+ if(column <
MessageModel::TimestampColumn || column > MessageModel::Contents
Column) return QVariant();
switch(role) {
case MessageModel::MsgIdRole: return QVariant::fromValue<MsgId>(_msgId);
case MessageModel::BufferIdRole: return QVariant::fromValue<BufferId>(_bufferId);
switch(role) {
case MessageModel::MsgIdRole: return QVariant::fromValue<MsgId>(_msgId);
case MessageModel::BufferIdRole: return QVariant::fromValue<BufferId>(_bufferId);