Files
RedBear-OS/local/recipes/qt/qtdeclarative/source/examples/quick/positioners/positioners-transitions.qml
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

383 lines
9.1 KiB
QML

// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQml
import QtQuick
Item {
id: page
property real effectiveOpacity: 1.0
property real ratio: width / 320 < height / 440 ? width / 320 : height / 440
property int smallSize: 45 * ratio
property int bigSize: 2 * smallSize
property int elementSpacing: 0.14 * smallSize
anchors.fill: parent
Timer {
interval: 2000
running: true
repeat: true
onTriggered: page.effectiveOpacity = (page.effectiveOpacity == 1.0 ? 0.0 : 1.0)
}
Column {
anchors {
left: parent.left
leftMargin: page.width / 32
top: parent.top
topMargin: page.height / 48
}
spacing: page.elementSpacing
populate: Transition {
NumberAnimation {
properties: "x,y"
from: 200
duration: 100
easing.type: Easing.OutBounce
}
}
add: Transition {
NumberAnimation {
properties: "y"
easing.type: Easing.OutQuad
}
}
move: Transition {
NumberAnimation {
properties: "y"
easing.type: Easing.OutBounce
}
}
Rectangle {
color: "#80c342"
width: page.bigSize
height: page.smallSize
}
Rectangle {
id: greenV1
visible: opacity != 0
width: page.bigSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#14aaff"
width: page.bigSize
height: page.smallSize
}
Rectangle {
id: greenV2
visible: opacity != 0
width: page.bigSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#6400aa"
width: page.bigSize
height: page.smallSize
}
Rectangle {
color: "#80c342"
width: page.bigSize
height: page.smallSize
}
}
Row {
anchors {
left: page.left
leftMargin: page.width / 32
bottom: page.bottom
bottomMargin: page.height / 48
}
spacing: page.elementSpacing
populate: Transition {
NumberAnimation {
properties: "x,y"
from: 200
duration: 100
easing.type: Easing.OutBounce
}
}
add: Transition {
NumberAnimation {
properties: "x"
easing.type: Easing.OutQuad
}
}
move: Transition {
NumberAnimation {
properties: "x"
easing.type: Easing.OutBounce
}
}
Rectangle {
color: "#80c342"
width: page.smallSize
height: page.bigSize
}
Rectangle {
id: blueH1
visible: opacity != 0
width: page.smallSize
height: page.bigSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#14aaff"
width: page.smallSize
height: page.bigSize
}
Rectangle {
id: greenH2
visible: opacity != 0
width: page.smallSize
height: page.bigSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#6400aa"
width: page.smallSize
height: page.bigSize
}
Rectangle {
color: "#80c342"
width: page.smallSize
height: page.bigSize
}
}
Grid {
anchors.top: parent.top
anchors.topMargin: page.height / 48
anchors.left: flowItem.left
columns: 3
spacing: page.elementSpacing
populate: Transition {
NumberAnimation {
properties: "x,y"
from: 200
duration: 100
easing.type: Easing.OutBounce
}
}
add: Transition {
NumberAnimation {
properties: "x,y"
easing.type: Easing.OutBounce
}
}
move: Transition {
NumberAnimation {
properties: "x,y"
easing.type: Easing.OutBounce
}
}
Rectangle {
color: "#80c342"
width: page.smallSize
height: page.smallSize
}
Rectangle {
id: greenG1
visible: opacity != 0
width: page.smallSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#14aaff"
width: page.smallSize
height: page.smallSize
}
Rectangle {
id: greenG2
visible: opacity != 0
width: page.smallSize
height:page. smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#6400aa"
width: page.smallSize
height: page.smallSize
}
Rectangle {
id: greenG3
visible: opacity != 0
width: page.smallSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#80c342"
width: page.smallSize
height: page.smallSize
}
Rectangle {
color: "#14aaff"
width: page.smallSize
height: page.smallSize
}
Rectangle {
color: "#6400aa"
width: page.smallSize
height: page.smallSize
}
}
Flow {
id: flowItem
anchors.right: page.right
anchors.rightMargin: page.width / 32
y: 2 * page.bigSize
width: 1.8 * page.bigSize
spacing: page.elementSpacing
//! [move]
move: Transition {
NumberAnimation {
properties: "x,y"
easing.type: Easing.OutBounce
}
}
//! [move]
//! [add]
add: Transition {
NumberAnimation {
properties: "x,y"
easing.type: Easing.OutBounce
}
}
//! [add]
//! [populate]
populate: Transition {
NumberAnimation {
properties: "x,y"
from: 200
duration: 100
easing.type: Easing.OutBounce
}
}
//! [populate]
Rectangle {
color: "#80c342"
width: page.smallSize
height: page.smallSize
}
Rectangle {
id: greenF1
visible: opacity != 0
width: 0.6 * page.bigSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#14aaff"
width: 0.3 * page.bigSize
height: page.smallSize
}
Rectangle {
id: greenF2
visible: opacity != 0
width: 0.6 * page.bigSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#6400aa"
width: page.smallSize
height: page.smallSize
}
Rectangle {
id: greenF3
visible: opacity != 0
width: 0.4 * page.bigSize
height: page.smallSize
color: "#006325"
border.color: "transparent"
Behavior on opacity { NumberAnimation {} }
opacity: page.effectiveOpacity
}
Rectangle {
color: "#80c342"
width: 0.8 * page.bigSize
height: page.smallSize
}
}
}