Development guide
This guide covers everything you need to contribute to ProzillaOS or create your own virtual operating system. For instructions on deploying the project to a server, see the Self-hosting guide.
Prerequisites
Getting started
# Clone the repository
git clone https://github.com/prozilla-os/ProzillaOS.git
cd ProzillaOS
# Install dependencies
pnpm install
# Start the demo development server
pnpm run start
# Or open the interactive task menu
pnpm run menuAfter starting the development server, the demo website will be available at localhost:3000.
Project structure
ProzillaOS is a monorepo managed with pnpm workspaces. See packages/README.md for a full overview of the package structure.
Tech stack
- Vite - Building packages and websites
- TypeScript - Type safety
- React - UI
- ESLint - Code linting
- pnpm - Package management
- Turborepo - Build system
- VitePress - Documentation
- Vitest - Testing
Commands
| Command | Description |
|---|---|
pnpm run build | Build all packages, demo and docs |
pnpm run packages:build | Build only packages (not websites) |
pnpm run libs:build | Build only libraries (no app packages or websites) |
pnpm run start | Start the demo development server |
pnpm run lint | Lint all files with ESLint (auto-fix) |
pnpm run lint:nofix | Lint all files with ESLint (no auto-fix) |
pnpm run test | Run all tests with Vitest |
pnpm run deploy | Deploy the built site to GitHub Pages |
pnpm run deploy:dry | Preview deployment without publishing |
pnpm run clean | Remove all build artifacts |
pnpm run demo:start | Start the demo development server |
pnpm run demo:build | Build the demo website for production |
pnpm run docs:start | Start the docs development server |
pnpm run docs:build | Build the docs website for production |
pnpm run docs:api | Generate API reference docs via TypeDoc |
pnpm run docs:api:libs | Generate API docs for libraries only |
pnpm run docs:api:apps | Generate API docs for apps only |
Thanks to Turborepo, all tasks will automatically run in the correct order, run in parallel whenever possible and cache their builds to save time.
Code style
Most conventions are enforced by ESLint. ESLint is configured with TypeScript-aware rules. Run pnpm run lint to check and auto-fix all files. The configuration is in eslint.config.js at the project root.
Naming conventions
| Category | Case | Example | Name should match |
|---|---|---|---|
| Folders | kebab-case | virtual-drive | |
.ts files | camelCase | virtualRoot.ts | |
.tsx files | PascalCase | Desktop.tsx | React component |
.css files & static assets | kebab-case | global.css | |
Local .module.css files | PascalCase | Desktop.module.css | React component |
Global .module.css files | kebab-case | utils.module.css | |
| CSS class names | PascalCase | .WindowsView | React component |
| Variables | camelCase | const fooBar = true; | |
| Global constant variables | MACRO_CASE | export const NAME = "ProzillaOS"; | |
| Classes | PascalCase | class WindowsManager { } | |
| React components | PascalCase | export function WindowsView({ }) { } | |
| Functions | camelCase | function focusWindow() { } | |
| Types | PascalCase | type FooBar = boolean; |
Other conventions
- Indentation: Tabs
- Quotes: Double quotes
- Semicolons: Required
- Imports: Use
typeprefix for type-only imports (import type { Foo } from "...") - React components: One component per file, no other exports
- JSDoc: Checked by
eslint-plugin-jsdoc, complete sentences and hyphens before parameter descriptions
Branching
feat/feature-name- New featuresfix/bug-description- Bug fixesrelease- Release preparation
Commits
Commit messages use descriptive English sentences in the present tense. An optional scope prefix (the package name) can be used for clarity. The scope of the package itself (e.g., @prozilla-os/) is omitted for brevity. Commit message subjects should be at most 50 characters long, unless that is not enough to cover all the changes, in which case it might be worth considering splitting up your commit.
Examples
core: Add virtual drive support
demo: Update wordle
Fix build error
Refactor shell + update documentationPull requests
- PRs should target the
mainbranch. - The title should clearly describe the change.
- Keep PRs focused on a single concern when possible.
- PRs should link to any relevant issues.
- All checks must pass before the PR is merged.
Testing
Tests use Vitest. Run the following command to execute all test suites across the monorepo:
pnpm run testThe @prozilla-os/dev-tools package provides some utility functions built on top of Vitest's API to make writing tests easier. You can get access to these functions by using extend().
Documentation
The documentation is built with VitePress and lives in the docs/ directory.
Running locally
pnpm run docs:startThe documentation website will be available at localhost:3000/docs.
API reference
The API reference pages under docs/src/reference/ are auto-generated by TypeDoc using typedoc-plugin-markdown. To regenerate them:
pnpm run docs:api # All packages
pnpm run docs:api:libs # Libraries only (core, shared, skins, dev-tools)
pnpm run docs:api:apps # Applications onlyAPI reference generation runs automatically before the docs:build task.
Contribution workflow
- Find or create an issue to work on.
- Fork the repository and clone your fork.
- Set up your local development environment and get started.
- Follow the conventions described in this guide.
- Make sure all tests pass and there are no linting issues.
- Commit and push to your fork.
- Open a pull request and describe your changes and motivation.
- Request a review from Prozilla.
Testing and documentation
If you are adding to the public API surface (e.g., a new exported function or class), make sure you also add new tests and some documentation.
Support
If you have questions or need help, reach out to the community on Discord.