Files
RedBear-OS/local/recipes/qt/qtdeclarative/source/examples/quickcontrols/eventcalendar/eventmodel.cpp
T
vasilito f31522130f fix: comprehensive boot warnings and exceptions — fixable silenced, unfixable diagnosed
Build system (5 gaps hardened):
- COOKBOOK_OFFLINE defaults to true (fork-mode)
- normalize_patch handles diff -ruN format
- New 'repo validate-patches' command (25/25 relibc patches)
- 14 patched Qt/Wayland/display recipes added to protected list
- relibc archive regenerated with current patch chain

Boot fixes (fixable):
- Full ISO EFI partition: 16 MiB → 1 MiB (matches mini, BIOS hardcoded 2 MiB offset)
- D-Bus system bus: absolute /usr/bin/dbus-daemon path (was skipped)
- redbear-sessiond: absolute /usr/bin/redbear-sessiond path (was skipped)
- daemon framework: silenced spurious INIT_NOTIFY warnings for oneshot_async services (P0-daemon-silence-init-notify.patch)
- udev-shim: demoted INIT_NOTIFY warning to INFO (expected for oneshot_async)
- relibc: comprehensive named semaphores (sem_open/close/unlink) replacing upstream todo!() stubs
- greeterd: Wayland socket timeout 15s → 30s (compositor DRM wait)
- greeter-ui: built and linked (header guard unification, sem_compat stubs removed)
- mc: un-ignored in both configs, fixed glib/libiconv/pcre2 transitive deps
- greeter config: removed stale keymapd dependency from display/greeter services
- prefix toolchain: relibc headers synced, _RELIBC_STDLIB_H guard unified

Unfixable (diagnosed, upstream):
- i2c-hidd: abort on no-I2C-hardware (QEMU) — process::exit → relibc abort
- kded6/greeter-ui: page fault 0x8 — Qt library null deref
- Thread panics fd != -1 — Rust std library on Redox
- DHCP timeout / eth0 MAC — QEMU user-mode networking
- hwrngd/thermald — no hardware RNG/thermal in VM
- live preload allocation — BIOS memory fragmentation, continues on demand
2026-05-05 20:20:37 +01:00

89 lines
1.8 KiB
C++

// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
#include "eventmodel.h"
#include "sqleventdatabase.h"
#include <QtCore/QScopeGuard>
EventModel::EventModel(QObject *parent)
: QAbstractListModel(parent)
{
}
SqlEventDatabase *EventModel::eventDatabase()
{
return m_eventDatabase;
}
void EventModel::setEventDatabase(SqlEventDatabase *eventDatabase)
{
if (eventDatabase == m_eventDatabase)
return;
m_eventDatabase = eventDatabase;
repopulate();
emit eventDatabaseChanged();
}
QDate EventModel::date() const
{
return m_date;
}
void EventModel::setDate(QDate date)
{
if (date == m_date)
return;
m_date = date;
repopulate();
emit dateChanged();
}
int EventModel::rowCount(const QModelIndex &) const
{
return m_events.size();
}
QVariant EventModel::data(const QModelIndex &index, int role) const
{
if (!checkIndex(index, CheckIndexOption::IndexIsValid))
return QVariant();
switch (role) {
case NameRole: return m_events.at(index.row()).name;
case StartDateRole: return m_events.at(index.row()).startDate;
case EndDateRole: return m_events.at(index.row()).endDate;
default: return QVariant();
}
}
QHash<int, QByteArray> EventModel::roleNames() const
{
static const QHash<int, QByteArray> roles {
{ NameRole, "name" },
{ StartDateRole, "startDate" },
{ EndDateRole, "endDate" }
};
return roles;
}
bool EventModel::isValid() const
{
return m_eventDatabase && !m_date.isNull();
}
void EventModel::repopulate()
{
beginResetModel();
auto endReset = qScopeGuard([this]{ endResetModel(); });
if (!m_eventDatabase || m_date.isNull()) {
m_events.clear();
return;
}
m_events = m_eventDatabase->eventsForDate(m_date);
}