f31522130f
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
86 lines
2.6 KiB
C++
86 lines
2.6 KiB
C++
// Copyright (C) 2016 The Qt Company Ltd.
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
|
|
|
|
#include <testhttpserver.h>
|
|
|
|
#include <QCoreApplication>
|
|
#include <QCommandLineParser>
|
|
#include <QCommandLineOption>
|
|
#include <QDebug>
|
|
#include <QDir>
|
|
#include <QFileInfo>
|
|
|
|
#include <iostream>
|
|
#include <iterator>
|
|
#include <algorithm>
|
|
|
|
inline std::wostream &operator<<(std::wostream &str, const QString &s)
|
|
{
|
|
#ifdef Q_OS_WIN
|
|
str << reinterpret_cast<const wchar_t *>(s.utf16());
|
|
#else
|
|
str << s.toStdWString();
|
|
#endif
|
|
return str;
|
|
}
|
|
|
|
enum { defaultPort = 14457 };
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
QCoreApplication a(argc, argv);
|
|
QCoreApplication::setApplicationName("HttpServer");
|
|
QCoreApplication::setApplicationVersion(QT_VERSION_STR);
|
|
|
|
QCommandLineParser commandLineParser;
|
|
commandLineParser.setSingleDashWordOptionMode(QCommandLineParser::ParseAsLongOptions);
|
|
commandLineParser.setApplicationDescription(QStringLiteral("HTTP Test server"));
|
|
commandLineParser.addHelpOption();
|
|
commandLineParser.addVersionOption();
|
|
|
|
QCommandLineOption portOption(QStringLiteral("p"),
|
|
QStringLiteral("Port (default: ") + QString::number(defaultPort) + QLatin1Char(')'),
|
|
QStringLiteral("port"));
|
|
|
|
commandLineParser.addOption(portOption);
|
|
|
|
commandLineParser.addPositionalArgument(QStringLiteral("[directory]"),
|
|
QStringLiteral("Directory to serve."));
|
|
|
|
commandLineParser.process(a);
|
|
|
|
const QStringList args = commandLineParser.positionalArguments();
|
|
if (args.size() != 1)
|
|
commandLineParser.showHelp(1);
|
|
|
|
const QString directory = QDir::cleanPath(args.front());
|
|
if (!QFileInfo(directory).isDir()) {
|
|
std::wcerr << '"' << QDir::toNativeSeparators(directory) << "\" is not a directory.\n";
|
|
return -1;
|
|
}
|
|
|
|
unsigned short port = defaultPort;
|
|
if (commandLineParser.isSet(portOption)) {
|
|
const QString portV = commandLineParser.value(portOption);
|
|
bool ok;
|
|
port = portV.toUShort(&ok);
|
|
if (!ok) {
|
|
std::wcerr << portV << " is not a valid port number.\n";
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
std::wcout << "Serving \"" << QDir::toNativeSeparators(directory)
|
|
<< "\":\n\n" << QDir(directory).entryList(QDir::Files).join(QLatin1Char('\n'))
|
|
<< "\n\non http://localhost:" << port << '\n';
|
|
|
|
TestHTTPServer server;
|
|
if (!server.listen(port)) {
|
|
std::wcout << "Couldn't listen on port " << port << server.errorString().toLocal8Bit();
|
|
exit(-1);
|
|
}
|
|
server.serveDirectory(directory);
|
|
|
|
return a.exec();
|
|
}
|