Sync a declarative package list with the pacman package manager
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

4.4 KiB

1. Project Setup

  • 1.1 Initialize Go module with proper imports
  • 1.2 Add required dependencies (dyalpm wrapper, Jguer/aur)
  • 1.3 Set up project structure (cmd/declpac/main.go, pkg/ subdirectory)
  • 1.4 Add libalpm initialization and handle

2. Input Parsing

  • 2.1 Implement stdin reader to collect package names
  • 2.2 Implement state file reader for text-list format
  • 2.3 Add whitespace normalization for package names
  • 2.4 Create package name set data structure

3. Input Merging

  • 3.1 Implement additive merging of stdin and state file packages
  • 3.2 Handle multiple --state flags with last-writer-wins per file
  • 3.3 Implement duplicate package handling (no deduplication)

4. State Validation

  • 4.1 Implement empty state detection (no packages found)
  • 4.2 Add stderr error output for empty state
  • 4.3 Set exit code 1 for empty state case (abort, not proceed)
  • 4.4 Check pacman DB freshness (db.lock timestamp)
  • 4.5 Run pacman -Syy if DB older than 1 day
  • 4.6 Validate packages via libalpm (pacman repos)
  • 4.7 Validate packages via Jguer/aur (AUR)
  • 4.8 Fail fast with error if package not found

5. Pacman Integration (Hybrid: query via libalpm, modify via exec)

  • 5.1 Initialize libalpm handle for queries
  • 5.2 Implement libalpm query for installed packages
  • 5.3 Implement libalpm query for available packages
  • 5.4 Implement pacman -Syy command execution (DB refresh)
  • 5.5 Implement pacman -Syu command execution wrapper
  • 5.6 Add command-line argument construction with package list
  • 5.7 Capture pacman stdout and stderr output
  • 5.8 Implement pacman error message parsing
  • 5.9 Handle pacman exit codes for success/failure detection
  • 5.10 Verify pacman automatically resolves transitive dependencies

6. Explicit Marking & Orphan Cleanup

  • 6.1 Get list of currently installed packages before sync
  • 6.2 Mark declared state packages as explicitly installed via pacman -D --explicit
  • 6.3 Run pacman sync operation (5.x series)
  • 6.4 Run pacman -Rsu to remove orphaned packages
  • 6.5 Capture and report number of packages removed
  • 6.6 Handle case where no orphans exist (no packages removed)

7. AUR Integration

  • 7.1 Implement AUR package lookup via Jguer/aur library
  • 7.2 Check package not in pacman repos first (via libalpm)
  • 7.3 Query AUR for missing packages
  • 7.4 Implement AUR fallback using makepkg (direct build, not AUR helper)
  • 7.5 Clone AUR package git repo to temp directory
  • 7.6 Run makepkg -si in temp directory for installation
  • 7.7 Upgrade existing AUR packages to latest (makepkg rebuild)
  • 7.8 Add stderr error reporting for packages not in pacman or AUR
  • 7.9 Capture makepkg stdout and stderr for output parsing
  • 7.10 Handle makepkg exit codes for success/failure detection

8. Output Generation

  • 8.1 Parse pacman output for installed package count
  • 8.2 Parse pacman output for removed package count (orphan cleanup)
  • 8.3 Generate output: Installed X packages, removed Y packages
  • 8.4 Handle 0 packages case: Installed 0 packages, removed 0 packages
  • 8.5 Print errors to stderr
  • 8.6 Set exit code 0 for success, 1 for errors

9. CLI Interface

  • 9.1 Implement --state flag argument parsing
  • 9.2 Implement stdin input handling from /dev/stdin
  • 9.3 Set up correct CLI usage/help message
  • 9.4 Implement flag order validation

10. Integration & Testing

  • 10.1 Wire together stdin -> state files -> merging -> validation -> pacman sync -> orphan cleanup -> output
  • 10.2 Test empty state error output and exit code 1
  • 10.3 Test single state file parsing
  • 10.4 Test multiple state file merging
  • 10.5 Test stdin input parsing
  • 10.6 Test explicit marking before sync
  • 10.7 Test pacman command execution with real packages
  • 10.8 Test orphan cleanup removes unneeded packages
  • 10.9 Test AUR fallback with makepkg for AUR package
  • 10.10 Test error handling for missing packages
  • 10.11 Generate final binary

11. Dry-Run Mode

  • 11.1 Add --dry-run flag to CLI argument parsing
  • 11.2 Implement DryRun function to query current state
  • 11.3 Compare declared packages to current installations
  • 11.4 Identify packages to install (not currently installed)
  • 11.5 Identify orphans to remove via pacman -Qdtq
  • 11.6 Output "Would install:" and "Would remove:" sections