A simple POSIX-based operating system for 64-bit computers
Go to file
2024-11-23 20:02:34 +01: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 base: Add taskbar entry for the editor 2024-09-14 15:40:27 +02:00
docs all: Reorder directory structure 2024-07-21 13:24:46 +02:00
gui editor: Avoid showing an error dialog when pressing Ctrl+S 2024-10-26 14:00:57 +02:00
initrd/sys initrd: Remove unused stray script file 2023-10-13 22:12:18 +02:00
kernel kernel: Use a mutex to allocate new posix timers for a thread 2024-11-23 20:02:34 +01:00
libc libc+libluna: Add endianness-dependent functions and use them in SHA256 2024-07-20 16:26:06 +02:00
libluna libluna+libos+libui: Move Action to libluna and make it usable in the kernel 2024-10-19 21:25:17 +02:00
libos libluna+libos+libui: Move Action to libluna and make it usable in the kernel 2024-10-19 21:25:17 +02:00
ports ports: Add cbench port 2024-09-23 19:51:42 +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 startui: Remove /tmp/launch.sock as root 2024-09-07 17:33:38 +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 utils: Add a hackish "logout" command 2024-09-07 17:40:39 +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: Update release to 0.7.0 "Pulsar" 2024-09-07 17:17:08 +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 base+gui: Move autologin configuration to /etc/loginui.conf 2024-09-14 15:05:05 +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/loginui.conf and change the line that says Autologin=true to Autologin=false.

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.