rpcsx/rpcsx-os/iodev/stdout.cpp

54 lines
1.5 KiB
C++
Raw Normal View History

2023-06-23 02:28:14 +02:00
#include "io-device.hpp"
2023-07-04 18:19:17 +02:00
#include "orbis/KernelAllocator.hpp"
2023-06-23 02:28:14 +02:00
#include <cstdio>
struct StdoutInstance : public IoDeviceInstance {};
struct StdoutDevice : public IoDevice {
StdoutInstance *instance = nullptr;
};
static std::int64_t stdout_instance_write(IoDeviceInstance *instance,
const void *data,
std::uint64_t size) {
2023-07-26 17:36:32 +02:00
if (size)
std::fprintf(stdout, "\e[30;1m");
2023-06-23 02:28:14 +02:00
auto result = std::fwrite(data, 1, size, stdout);
2023-07-26 17:36:32 +02:00
if (size)
std::fprintf(stdout, "\e[0m");
2023-06-23 02:28:14 +02:00
std::fflush(stdout);
return result;
}
static std::int64_t stdout_instance_close(IoDeviceInstance *instance) {
instance->device->decRef();
return 0;
}
static std::int32_t stdout_device_open(IoDevice *device,
orbis::Ref<IoDeviceInstance> *instance,
const char *path, std::uint32_t flags,
std::uint32_t mode) {
auto stdoutDevice = static_cast<StdoutDevice *>(device);
if (stdoutDevice->instance == nullptr) {
2023-07-04 18:19:17 +02:00
auto *newInstance = orbis::knew<StdoutInstance>();
2023-06-23 02:28:14 +02:00
newInstance->write = stdout_instance_write;
newInstance->close = stdout_instance_close;
io_device_instance_init(device, newInstance);
*instance = newInstance;
} else {
device->incRef();
*instance = stdoutDevice->instance;
}
return 0;
}
IoDevice *createStdoutCharacterDevice() {
2023-07-04 18:19:17 +02:00
auto *newDevice = orbis::knew<StdoutDevice>();
2023-06-23 02:28:14 +02:00
newDevice->open = stdout_device_open;
return newDevice;
}