A simple POSIX-based operating system for 64-bit computers
Go to file
apio 9c4f20790f
All checks were successful
Build and test / build (push) Successful in 1m55s
CI: Undo artifact stuff
Doesn't seem to be really supported on Gitea for now.
2024-09-07 16:35:59 +02:00
.gitea/workflows CI: Undo artifact stuff 2024-09-07 16:35:59 +02:00
.vscode libos: Document it entirely using Doxygen comments =D 2023-06-09 22:45:06 +02:00
base gui: Add a login UI and support the os::IPC::Notifier API 2024-07-31 19:50:20 +02:00
docs all: Reorder directory structure 2024-07-21 13:24:46 +02:00
gui gui: Add a login UI and support the os::IPC::Notifier API 2024-07-31 19:50:20 +02:00
initrd/sys initrd: Remove unused stray script file 2023-10-13 22:12:18 +02:00
kernel kernel: Make StorageCache have a reference to its parent BlockDevice 2024-08-09 18:52:56 +02:00
libc libc+libluna: Add endianness-dependent functions and use them in SHA256 2024-07-20 16:26:06 +02:00
libluna libluna: Add a reference-counted immutable string type 2024-09-01 12:40:20 +02:00
libos libos+init: Add a standard API for config file access 2024-09-01 12:40:37 +02:00
ports ports: Add doomgeneric port 2024-03-31 13:40:43 +02:00
shell shell: Split code into multiple files, add the "echo" builtin, and add support for a .shellrc file 2024-04-20 17:17:31 +02:00
system libos+init: Add a standard API for config file access 2024-09-01 12:40:37 +02:00
tests tests: Add tests for SHA256 2024-07-20 16:34:31 +02:00
tools tools+libluna: Make new and delete weak to avoid conflicts with libstdc++ 2024-09-01 12:39:55 +02:00
utils all: Reorder directory structure 2024-07-21 13:24:46 +02:00
.clang-format Update .clang-format 2022-12-21 20:22:44 +01:00
.gdbconf Make GDB use the correct kernel file 2022-12-03 17:34:14 +01:00
.gitignore taskbar: Make taskbar entries configurable 2024-04-10 21:42:21 +02:00
CMakeLists.txt all: Reorder directory structure 2024-07-21 13:24:46 +02:00
LICENSE Update LICENSE 2024-01-04 11:24:48 +01:00
luna.json tools: Make the Ext2 partition bigger (32M) 2023-07-22 16:11:34 +02:00
README.md gui: Add a login UI and support the os::IPC::Notifier API 2024-07-31 19:50:20 +02:00

Luna

A simple POSIX-based operating system for 64-bit computers, written in C++.

Another UNIX clone?

Yes, another UNIX clone.

Features

Screenshot

Screenshot as of 0.6.0

Setup

To build and run Luna, you will need to build a cross-compiler and cross-binutils for x86_64-luna.

For this, you should start by installing the required dependencies.

Then, run tools/setup.sh to build the toolchain.

Please beware that building GCC and Binutils can take some time, depending on your machine.

Running

To run Luna in a virtual machine, you should have QEMU installed.

Additionally, the build process needs some extra dependencies to run: cmake, ninja, nasm, fakeroot and genext2fs.

tools/run.sh is the script you should use in most cases. It will build changed files, install, make an ISO image, and run Luna in QEMU.

If you have no toolchain set up, run.sh will build it automatically, which means that you don't necessarily have to run setup.sh manually since run.sh does it for you.

Login UI

For development convenience, the system automatically starts a GUI session as the default user, without prompting for a password.

Despite this, Luna does have a login window built-in. If you'd like to try this feature out or start a GUI session as a different user, you'll need to edit base/etc/init/99-login and change the line that says Command=/usr/bin/loginui --autologin=selene to Command=/usr/bin/loginui.

Prebuilt images

Prebuilt ISO images for every release version can be found at pub.cloudapio.eu.

Is there third-party software I can use on Luna?

Yes! A ports system is in place, and you can use the build scripts to add some ports to your image. More information in the Ports page.

License

Luna is open-source and free software under the BSD-2-Clause License.