Truly independent web browser
Find a file
Andreas Kling 33d0916d29 WindowServer: Add support for fullscreen windows.
Fullscreen windows are rendered alone and above everything else when they
are active, and as part of the regular window stack order when something
else is active.

Currently windows cannot be made fullscreen after-the-fact, but must have
the fullscreen flag included in their CreateWindow message.

It should not possible to interact with the menu, taskbar or window frame
while the active window is fullscreened. :^)
2019-05-17 22:33:19 +02:00
AK Build: Install most headers to Root (and libcore.a/libgui.a) 2019-05-17 21:59:48 +02:00
Applications Terminal: Uh, also change the one caller of beep() to sysbeep().. 2019-05-17 14:34:07 +02:00
Base RetroFetch: Add a silly neofetch-like program. 2019-05-13 04:54:48 +02:00
Demos Fix "make clean" not deleting app binaries. 2019-05-13 14:56:18 +02:00
DevTools/VisualBuilder Fix "make clean" not deleting app binaries. 2019-05-13 14:56:18 +02:00
Documentation Documentation: Add a brief description of Serenity's smart pointer types. 2019-05-15 14:07:14 +02:00
Games Fix "make clean" not deleting app binaries. 2019-05-13 14:56:18 +02:00
Kernel Build: Install most headers to Root (and libcore.a/libgui.a) 2019-05-17 21:59:48 +02:00
LibC LibC: Implement clock() and add CLOCKS_PER_SEC define. 2019-05-17 20:19:03 +02:00
LibCore Build: Install most headers to Root (and libcore.a/libgui.a) 2019-05-17 21:59:48 +02:00
LibGUI WindowServer: Add support for fullscreen windows. 2019-05-17 22:33:19 +02:00
LibM Toolchain: Make sure everything ends up in the right place in Root/ 2019-05-08 15:50:24 +02:00
Meta Meta: Tweak ReadMe and add a new screenshot. 2019-04-30 15:27:35 +02:00
Servers WindowServer: Add support for fullscreen windows. 2019-05-17 22:33:19 +02:00
SharedGraphics Build: Install most headers to Root (and libcore.a/libgui.a) 2019-05-17 21:59:48 +02:00
Shell LibC/Shell: Add unsetenv(), and unset builtin calling it in Shell. 2019-05-16 14:32:09 +02:00
Toolchain Build: Install most headers to Root (and libcore.a/libgui.a) 2019-05-17 21:59:48 +02:00
Userland LibCore: Move AK/ArgsParser to LibCore/CArgsParser 2019-05-17 15:49:37 +02:00
.gitignore Meta: forgot to gitignore Toolchain/Local 2019-04-29 13:12:20 +02:00
LICENSE Let's go with a 2-clause BSD license. 2019-04-15 14:04:23 +02:00
Makefile.common Only the kernel needs to build with default includes disabled. 2019-05-16 13:40:43 +02:00
ReadMe.md ReadMe: Add build/run instructions from "old" wiki 2019-05-15 21:14:09 +02:00

Serenity

Graphical Unix-like operating system for x86 computers.

About

I always wondered what it would be like to write my own operating system, but I never took it seriously. Until now.

Serenity is a love letter to '90s user interfaces, with a custom Unix-like core. It flatters with sincerity by stealing beautiful ideas from various other systems.

Roughly speaking, the goal is a marriage between the aesthetic of late-1990s productivity software and the power-user accessibility of late-2000s *nix. This is a system by me, for me, based on the things I like.

If you like some of the same things, you are welcome to join the project. It would be great to one day change the above to say "this is a system by us, for us, based on the things we like." :^)

I regularly post raw hacking sessions and demos on my YouTube channel.

There's also a Patreon if you would like to show some support that way.

Screenshot

Screenshot as of d727005

Current features

  • Pre-emptive multitasking
  • Multithreading
  • Compositing window server
  • IPv4 networking with ARP, TCP, UDP and ICMP
  • ext2 filesystem
  • Unix-like libc and userland
  • Shell with pipes and I/O redirection
  • mmap()
  • /proc filesystem
  • Local sockets
  • Pseudoterminals (with /dev/pts filesystem)
  • Event loop library (LibCore)
  • High-level GUI library (LibGUI)
  • Visual GUI design tool
  • PNG format support
  • Text editor
  • IRC client
  • DNS lookup
  • Desktop games: Minesweeper and Snake
  • Other stuff I can't think of right now...

How do I build and run this?

Go into the Toolchain/ directory and run the BuildIt.sh script. Then source the UseIt.sh script to put the i686-pc-serenity toolchain in your $PATH.

Once you've done both of those, go into the Kernel directory, then run makeall.sh, and if nothing breaks too much, take it for a spin by using run.

Otherwise, see the older step-by-step guide to building Serenity

IRC

Come chat in #serenityos on the Freenode IRC network.

Author

License

Serenity is licensed under a 2-clause BSD license.