Welcome to Spice Routes
def check_dependencies(self): """Check if required tools are installed""" deps = ['wbfs-tool', 'dd', 'parted'] missing = [] for dep in deps: if not shutil.which(dep) and dep != 'wbfs-tool': missing.append(dep) if missing: print(f"⚠️ Missing dependencies: {', '.join(missing)}") print("Install with: sudo apt install wbfs-tools parted coreutils")
def extract_game(self, device, game_id, output_file): """Extract a game from WBFS to ISO/WBFS file""" print(f"Extracting {game_id} to {output_file}...") try: subprocess.run(['sudo', 'wbfs-tool', device, 'extract', game_id, output_file], check=True) print(f"✅ Game extracted to {output_file}") except subprocess.CalledProcessError: print(f"❌ Extraction failed.")
def check_usage(self, device): """Show used/free space on WBFS partition""" try: result = subprocess.run(['sudo', 'wbfs-tool', device, 'df'], capture_output=True, text=True, check=True) print("\n💾 Disk Usage:") print(result.stdout) except: print("❌ Could not read disk usage.")
def list_games(self, device): """List all games on WBFS partition""" try: result = subprocess.run(['sudo', 'wbfs-tool', device, 'ls'], capture_output=True, text=True, check=True) print("\n📀 Games on WBFS drive:") print("-" * 50) print(result.stdout) except subprocess.CalledProcessError: print("❌ No WBFS partition found or unable to read.")
manager = WBFSManager() manager.interactive_menu() if == " main ": main() 📦 Installation & Usage # Install dependencies (Ubuntu/Debian) sudo apt update sudo apt install wbfs-tools parted coreutils Download the script nano wbfs_manager.py (paste the code above) Make it executable chmod +x wbfs_manager.py Run as root (needed for disk operations) sudo python3 wbfs_manager.py 🚀 Advanced Feature: Auto-Mount & Game Organizer Here's an bonus feature - an auto-organizer for WBFS games: