Files
omnixy/CLAUDE.md
theArctesian d8947e67b7 documentation
2025-09-25 07:50:48 -07:00

249 lines
8.7 KiB
Markdown

# CLAUDE.md
This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
## Project Notes
- **Repository**: https://github.com/TheArctesian/omnixy
- **System Name**: The system uses "omnixy" for flake names and commands
- **Git Setup**: The installation process requires users to set up their GitHub account manually before initializing the git repository
## Overview
This repository contains OmniXY NixOS (https://github.com/TheArctesian/omnixy), a declarative system configuration that transforms NixOS into a beautiful, modern development environment based on Hyprland. This version uses Nix's declarative configuration management for reproducible systems.
## Key Commands
### System Management
```bash
# Rebuild system configuration
sudo nixos-rebuild switch --flake /etc/nixos#omnixy
omnixy-rebuild # Convenience wrapper
# Update system and flake inputs
omnixy update
omnixy-update # Direct command
# Clean and optimize Nix store
omnixy clean
omnixy-clean # Direct command
# Search for packages
omnixy search <package-name>
omnixy-search <package-name> # Direct command
# Show system information
omnixy info
omnixy-info # Direct command
# Get help
omnixy help
omnixy-help # Direct command
```
### Development Workflows
```bash
# Test configuration changes
nixos-rebuild build --flake .#omnixy # Build without switching
# Enter development shell
nix develop # Uses flake.nix devShell
nix develop .#python # Language-specific shell
nix develop .#node # Node.js development
nix develop .#rust # Rust development
# Alternative: Use omnixy development shells
omnixy-dev-shell rust # Rust development shell
omnixy-dev-shell python # Python development shell
omnixy-dev-shell go # Go development shell
omnixy-dev-shell js # JavaScript/Node.js shell
omnixy-dev-shell c # C/C++ development shell
# Format Nix code
nixpkgs-fmt *.nix
alejandra *.nix # Alternative formatter
# Check Nix code
statix check . # Static analysis
deadnix . # Dead code elimination
```
### Theme Development
```bash
# Available themes in modules/themes/
ls modules/themes/
# List available themes
omnixy theme
omnixy-theme-list
# Switch theme
omnixy theme tokyo-night
omnixy-theme-set tokyo-night
# Available themes: tokyo-night, catppuccin, gruvbox, nord,
# everforest, rose-pine, kanagawa, catppuccin-latte, matte-black,
# osaka-jade, ristretto
# Create new theme
cp modules/themes/tokyo-night.nix modules/themes/my-theme.nix
# Edit color values and application configs, then rebuild
```
## Architecture
### Flake Structure
- **flake.nix** - Main flake definition with inputs and outputs
- **configuration.nix** - Main NixOS configuration entry point
- **home.nix** - Home-manager configuration for user environment
### Module System
The configuration is split into focused modules:
- **modules/core.nix** - Base system settings and OmniXY options
- **modules/packages.nix** - Package collections with feature flags
- **modules/development.nix** - Development tools and environments
- **modules/services.nix** - System services and daemons
- **modules/users.nix** - User account management
- **modules/boot.nix** - Boot configuration and kernel parameters
- **modules/security.nix** - Security settings and authentication
- **modules/menus.nix** - Application menus and launchers
- **modules/walker.nix** - Walker application launcher configuration
- **modules/fastfetch.nix** - System information display
- **modules/scripts.nix** - OmniXY utility scripts
- **modules/themes/** - Complete theme system with multiple themes
- **modules/hardware/** - Hardware-specific configurations (Intel, AMD, NVIDIA, Audio, etc.)
- **modules/lib.nix** - Helper functions and utilities
- **modules/colors.nix** - Color palette definitions
- **modules/helpers.nix** - Additional helper functions
### Configuration Management
1. **Declarative** - Everything defined in Nix expressions
2. **Modular** - Features can be enabled/disabled via options
3. **Reproducible** - Same configuration produces identical systems
4. **Version Controlled** - All changes tracked in git
### Theme System
- Each theme is a complete Nix module in `modules/themes/`
- Themes configure: terminals, editors, GTK, Qt, desktop components
- Theme switching updates configuration.nix and rebuilds system
- Colors defined as variables for consistency
### Package Management
- **System packages** in `modules/packages.nix` with feature categories
- **User packages** in home.nix via home-manager
- **Development environments** via flake devShells
- **Custom packages** in packages/ directory
## Development Guidelines
### Adding Packages
1. **System packages**: Add to `modules/packages.nix` in appropriate category
2. **User packages**: Add to `home.nix` home.packages
3. **Development only**: Add to devShell in flake.nix
4. Always rebuild/test: `nixos-rebuild build --flake .#omnixy`
### Creating Modules
1. Follow NixOS module structure with options and config sections
2. Use `lib.mkEnableOption` and `lib.mkOption` for configuration
3. Implement feature flags for optional functionality
4. Document options and provide sensible defaults
### Theme Development
1. Copy existing theme as template
2. Define color palette as environment variables
3. Configure all supported applications consistently
4. Test theme switching functionality
### Custom Packages
1. Create derivations in packages/ directory
2. Use `pkgs.writeShellScriptBin` for simple scripts
3. Add to flake outputs for external use
4. Follow Nix packaging guidelines
### Flake Management
- Pin inputs for stability: `nix flake update --commit-lock-file`
- Use follows for input deduplication
- Provide multiple devShells for different workflows
- Export packages and apps for external consumption
### Testing Changes
- Build configuration: `nixos-rebuild build --flake .#omnixy`
- Test in VM: `nixos-rebuild build-vm --flake .#omnixy`
- Run VM: `./result/bin/run-omnixy-vm` or use the linked script in /nix/store
- Check evaluation: `nix flake check`
- Format code: `nixpkgs-fmt .` or `alejandra .`
### Home Manager Integration
- User-specific configuration in home.nix
- Theme integration via home-manager modules
- Dotfile management through Nix expressions
- Service management via systemd user units
## Common Tasks
### Adding New Service
1. Define in `modules/services.nix`
2. Use systemd service configuration
3. Add necessary packages
4. Configure firewalls/permissions as needed
### Hardware Support
1. Add hardware-specific modules in `modules/hardware/`
2. Use conditional configuration based on hardware detection
3. Include necessary firmware and drivers
4. Test on target hardware
### Installation and Bootstrap
- Bootstrap script: `./boot.sh` - Downloads and runs installer on fresh NixOS
- Interactive installer: `./install.sh` - Full styled installer with theme selection
- Simple installer: `./install-simple.sh` - Unix-philosophy compliant, scriptable installer
- Manual flake install: `sudo nixos-rebuild switch --flake github:TheArctesian/omnixy#omnixy`
### Unix Philosophy Tools (scripts/ directory)
Focused, composable tools following "do one thing well":
- `scripts/omnixy-check-system` - Just check system requirements
- `scripts/omnixy-backup-config` - Just backup configuration
- `scripts/omnixy-install-files` - Just copy files
- `scripts/omnixy-configure-user` - Just update user configuration
- `scripts/omnixy-build-system` - Just build/switch system
### Scriptable Usage Examples
```bash
# Quiet installation
./install-simple.sh --quiet --user alice --theme gruvbox
# Test configuration without applying
./install-simple.sh --dry-run
# Automated installation
OMNIXY_USER=bob OMNIXY_THEME=nord ./install-simple.sh --quiet
# Use individual tools for custom workflows
scripts/omnixy-check-system --nixos-only
backup_path=$(scripts/omnixy-backup-config)
scripts/omnixy-install-files
scripts/omnixy-configure-user alice
scripts/omnixy-build-system --dry-run
# Scriptable omnixy command with clean output
omnixy --quiet theme set gruvbox
omnixy --json info | jq .system.theme
omnixy --quiet update && echo "Update complete"
```
### Screenshots and Utilities
- Take screenshots: `omnixy-screenshot` (region by default)
- Screenshot modes: `omnixy-screenshot region|full|window`
- Screenshots saved to `~/Pictures/Screenshots/` and copied to clipboard
### Development Containers
The install.sh script mentions but doesn't implement:
- `dev-postgres` - PostgreSQL container
- `dev-redis` - Redis container
- `dev-mysql` - MySQL container
- `dev-mongodb` - MongoDB container
### Debugging Issues
- Check system logs: `journalctl -xe`
- Nix build logs: `nix log /nix/store/...`
- Configuration evaluation: `nix show-config`
- Module option documentation: `man configuration.nix`
- System information: `omnixy info` or `omnixy-info`