A simple POSIX-based operating system for 64-bit computers
Go to file
apio 3021fffb07
All checks were successful
continuous-integration/drone/pr Build is passing
kernel: Store FD_CLOEXEC in the file descriptor itself
Closes #39.
2023-08-03 17:46:45 +02:00
.vscode libos: Document it entirely using Doxygen comments =D 2023-06-09 22:45:06 +02:00
apps libc+init+shmem-test: Add POSIX shared memory objects 2023-08-03 10:32:52 +02:00
base base: Remove startup items not necessary for GUI startup 2023-08-03 17:39:49 +02:00
initrd kernel+apps+base+tools: Use Ext2 for the root partition file system 2023-07-10 13:05:06 +02:00
kernel kernel: Store FD_CLOEXEC in the file descriptor itself 2023-08-03 17:46:45 +02:00
libc libc+init+shmem-test: Add POSIX shared memory objects 2023-08-03 10:32:52 +02:00
libluna kernel: Support listening sockets in poll() 2023-08-03 16:28:14 +02:00
libos libos: Add a new LocalServer class for local domain sockets 2023-08-03 16:39:30 +02:00
libui libui+wind: (Draggable) windows 2023-08-03 17:38:49 +02:00
ports ports+tools: Add bc port 2023-07-24 19:14:22 +02:00
shell sh: Use input_file instead of hardcoding stdin everywhere in tcsetpgrp() 2023-07-21 21:08:27 +02:00
tests libluna: Store SharedPtr's ref count in the object itself 2023-07-30 11:32:46 +02:00
tools libui: Add a GUI and graphics library 2023-08-03 12:21:29 +02:00
wind libui+wind: (Draggable) windows 2023-08-03 17:38:49 +02:00
.clang-format Update .clang-format 2022-12-21 20:22:44 +01:00
.drone.yml Update drone.yml 2023-07-21 14:11:44 +02:00
.gdbconf Make GDB use the correct kernel file 2022-12-03 17:34:14 +01:00
.gitignore ports: Basic ports system + nasm port 2023-07-24 17:07:49 +02:00
CMakeLists.txt wind: Add a simple display server skeleton using libui 2023-08-03 12:21:29 +02:00
LICENSE Update year range in LICENSE :) 2023-01-02 13:08:42 +01:00
luna.json tools: Make the Ext2 partition bigger (32M) 2023-07-22 16:11:34 +02:00
README.md Update README.md 2023-07-30 11:55:20 +02:00

Luna

A very basic POSIX-based operating system for personal computers, written in C++. Build Status

Another UNIX clone?

Yes, another UNIX clone.

Features

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 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 since run.sh does it for you.

Prebuilt images

Prebuilt ISO images (numbered) for every version can be found at pub.cloudapio.eu.

These images are built manually whenever a new release is created, and thus don't reflect the latest changes on the main branch.

Every hour, this server pulls the latest commits on main and builds an hourly ISO image. The ten most recent ones can be found in the hourly directory, and Luna-latest.iso should always be symlinked to the newest one.

These images do reflect the latest changes on the main branch, but are obviously less stable. Additionally, an hourly image will be skipped if building the latest commit of the project fails.

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.