2022-07-21 17:17:01 +03:00
# SerenityOS Documentation
Serenity development moves quickly, so some of these might be out of date. Please let us know if something here is wrong, or submit a PR with any additions or corrections! If you have any questions that are not answered here or in the [FAQ ](FAQ.md ), you are welcome to ask on [Discord ](../README.md#get-in-touch-and-participate ).
2023-01-21 02:01:44 +03:00
A list of useful pages across the web can be found on [the link list ](Links.md ).
2022-07-21 17:17:01 +03:00
## Building and Running
* [Build Instructions ](BuildInstructions.md )
* [Advanced Build Instructions ](AdvancedBuildInstructions.md )
* [Troubleshooting ](Troubleshooting.md )
* [Running in VirtualBox ](VirtualBox.md )
* [Running in VMware ](VMware.md )
* [Running Tests ](RunningTests.md )
* [Setting Up Self-Hosted Runners ](SelfHostedRunners.md )
* [Profiling the Build ](BuildProfilingInstructions.md )
2023-07-31 22:01:25 +03:00
* [Spice Integration ](SpiceIntegration.md )
2022-07-21 17:17:01 +03:00
### OS-specific
Make sure to read the basic [Build Instructions ](BuildInstructions.md ) first.
* [Building on Windows ](BuildInstructionsWindows.md )
* [Building on macOS ](BuildInstructionsMacOS.md )
* [Building on Linux ](BuildInstructionsOther.md )
### Running on Hardware
* [Bare Metal Installation ](BareMetalInstallation.md )
* [Running On Raspberry Pi ](RunningOnRaspberryPi.md )
* [Known Hardware Compatibility ](HardwareCompatibility.md )
* [Network Booting ](NetworkBoot.md )
## Configuring Editors
* [CLion ](CLionConfiguration.md )
* [Emacs ](EmacsConfiguration.md )
2023-07-15 13:41:13 +03:00
* [Helix ](HelixConfiguration.md )
* [NVim ](NvimConfiguration.md )
2022-07-21 17:17:01 +03:00
* [Qt Creator ](QtCreatorConfiguration.md )
2023-07-15 13:41:13 +03:00
* [Vim ](VimConfiguration.md )
2022-07-21 17:17:01 +03:00
* [VS Code ](VSCodeConfiguration.md )
## Development
* [How to Contribute ](../CONTRIBUTING.md )
* [Coding Style ](CodingStyle.md )
* [Common Patterns ](Patterns.md )
2023-07-15 13:41:13 +03:00
* [Guidelines for Text in UI ](HumanInterfaceGuidelines/Text.md )
2024-01-25 15:32:58 +03:00
* [Guidelines for writing manual pages ](WritingManPages.md )
2022-07-21 17:17:01 +03:00
* [EventLoop ](EventLoop.md )
* [High DPI Support ](HighDPI.md )
* [Smart Pointers ](SmartPointers.md )
* [String Formatting ](StringFormatting.md )
* [How to Transfer Files Out of Serenity ](TransferringFiles.md )
### File and Data Formats
* [Application Files (.af) ](../Base/usr/share/man/man5/af.md )
* [Bitmap Fonts (.font) ](../Base/usr/share/man/man5/font.md )
* [Clipboard data ](../Base/usr/share/man/man5/clipboard.md )
* [Drag-and-drop data ](../Base/usr/share/man/man5/drag-and-drop.md )
* [GUI Markup Language (.gml) ](../Base/usr/share/man/man5/GML.md )
* [HackStudio Post-Create Scripts (.postcreate) ](../Base/usr/share/man/man5/postcreate.md )
* [Inter-Process Communication protocol (.ipc) ](../Base/usr/share/man/man4/ipc.md )
## Browser/LibWeb
2023-07-15 13:41:13 +03:00
* [Ladybird Browser Build Instructions ](BuildInstructionsLadybird.md )
2022-07-21 17:17:01 +03:00
* [General Architecture ](Browser/ProcessArchitecture.md )
* [LibWeb: From Loading to Painting ](Browser/LibWebFromLoadingToPainting.md )
* [How to Add an IDL File ](Browser/AddNewIDLFile.md )
2023-03-12 23:03:00 +03:00
* [LibWeb Code Style & Patterns ](Browser/Patterns.md )
2022-07-21 17:17:01 +03:00
## Kernel
* [AHCI Locking ](Kernel/AHCILocking.md )
* [ProcFS Indexing ](Kernel/ProcFSIndexing.md )
2023-07-15 13:41:13 +03:00
* [RAMFS ](Kernel/RAMFS.md )
* [IOWindow ](Kernel/IOWindow.md )
* [Graphics Subsystem ](Kernel/GraphicsSubsystem.md )
* [Kernel Development Patterns & Guidelines ](Kernel/DevelopmentGuidelines.md )
2022-07-21 17:17:01 +03:00
## Applications
Documentation for SerenityOS applications and utilities can be found in [the man pages ](https://man.serenityos.org/ ).