12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- #include "IRCLogBufferModel.h"
- #include "IRCLogBuffer.h"
- #include <stdio.h>
- #include <time.h>
- #include <SharedGraphics/Font.h>
- IRCLogBufferModel::IRCLogBufferModel(Retained<IRCLogBuffer>&& log_buffer)
- : m_log_buffer(move(log_buffer))
- {
- }
- IRCLogBufferModel::~IRCLogBufferModel()
- {
- }
- int IRCLogBufferModel::row_count() const
- {
- return m_log_buffer->count();
- }
- int IRCLogBufferModel::column_count() const
- {
- return Column::__Count;
- }
- String IRCLogBufferModel::column_name(int column) const
- {
- switch (column) {
- case Column::Timestamp: return "Time";
- case Column::Name: return "Name";
- case Column::Text: return "Text";
- }
- ASSERT_NOT_REACHED();
- }
- GTableModel::ColumnMetadata IRCLogBufferModel::column_metadata(int column) const
- {
- switch (column) {
- case Column::Timestamp: return { 60, TextAlignment::CenterLeft };
- case Column::Name: return { 70, TextAlignment::CenterRight, &Font::default_bold_font() };
- case Column::Text: return { 800, TextAlignment::CenterLeft };
- }
- ASSERT_NOT_REACHED();
- }
- GVariant IRCLogBufferModel::data(const GModelIndex& index, Role) const
- {
- auto& entry = m_log_buffer->at(index.row());
- switch (index.column()) {
- case Column::Timestamp: {
- auto* tm = localtime(&entry.timestamp);
- return String::format("%02u:%02u:%02u", tm->tm_hour, tm->tm_min, tm->tm_sec);
- }
- case Column::Name:
- if (entry.sender.is_empty())
- return String::empty();
- return String::format("<%c%s>", entry.prefix ? entry.prefix : ' ', entry.sender.characters());
- case Column::Text: return entry.text;
- }
- ASSERT_NOT_REACHED();
- }
- void IRCLogBufferModel::update()
- {
- did_update();
- }
- void IRCLogBufferModel::activate(const GModelIndex&)
- {
- }
|