Files
RedBear-OS/local/recipes/qt/qtbase/source/util/includemocs/includemocs.pl
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

114 lines
3.1 KiB
Perl
Executable File

#!/usr/bin/perl
# Copyright (C) 2017 Intel Corporation.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
use strict;
MAKEFILE: while ($_ = shift @ARGV) {
chdir($ENV{PWD});
open MAKEFILE, "<", $_
or die("Could not open Makefile");
print "includemocs.pl: Processing $_\n";
my $srcdir;
my $sourcesline;
# Find "SOURCES =" line
while (<MAKEFILE>) {
$srcdir = $1 if m,^# Project:\s+(.*)/[^/]+.pro,;
if (/^# Template:\s+(\w+)/) {
next MAKEFILE if $1 eq "subdirs";
}
if (/^SOURCES\s*=\s*(.*)/) {
$sourcesline = $1;
last;
}
}
if ($sourcesline =~ s/\s+\\//) {
# continuation
while (<MAKEFILE>) {
chomp;
/^\s*([^ ]+)/;
$sourcesline .= " $1";
last unless m/\\$/;
}
}
close MAKEFILE;
# Now parse the sources
my @mocs;
my @sources;
for (split(/ /, $sourcesline)) {
if (/\.moc\/(moc_.*\.cpp)/) {
push @mocs, $1;
} elsif (/^\.(rcc|uic)/) {
# ignore
} else {
push @sources, $_;
}
}
chdir($srcdir) or die("Where's $srcdir? $!");
for my $moc (@mocs) {
my $include = "#include \"$moc\"\n";
# Find a corresponding .cpp file to host the new #include
my $basename = ($moc =~ s/^moc_//r);
$basename =~ s/\.[^.]+//;
my @candidates = grep { m,\Q/$basename.\E, } @sources;
if (scalar @candidates == 0) {
# Try without a _p suffix
$basename =~ s/_p$//;
@candidates = grep { m,\Q/$basename.\E, } @sources;
}
if (scalar @candidates == 0) {
print STDERR "includemocs.pl: Cannot find .cpp file for $moc\n";
next;
}
my $cpp = $candidates[0];
undef @candidates;
#print "$moc -> $cpp\n";
open CPP, "<", $cpp
or die("Cannot open source $cpp: $!");
my @lines;
while (<CPP>) {
push @lines, $_;
next unless defined($include);
# Print the new include next to a pre-existing moc include
if (/#include \"moc_/ || /#include ".*\.moc"/) {
push @lines, $include;
undef $include;
}
}
close CPP;
if (defined($include)) {
# Try to insert the new #include between QT_END_NAMESPACE and any #endif lines
my $n = 0;
my $extrablank = "";
while (defined($include)) {
--$n;
$_ = $lines[$n];
if (/^#endif/) {
$extrablank = "\n";
next;
}
$_ .= "\n" unless /^$/;
splice @lines, $n, 1, ($_, $include, $extrablank);
undef $include;
}
}
# Write the file again
open CPP, ">", $cpp
or die("Cannot open source $cpp for writing: $!");
map { print CPP $_; } @lines;
close CPP;
}
}