From 002a7dc8c0c87cc00b932e6e0987c405a76becde Mon Sep 17 00:00:00 2001 From: Jade Date: Wed, 18 Dec 2024 10:28:04 +0800 Subject: [PATCH] Add launcher shortcuts on Linux (#458) Doesn't add desktop shortcuts due to complications with how gnome handles desktop files Resolves https://github.com/wpilibsuite/WPILibInstaller-Avalonia/issues/136 Signed-off-by: Jade Turner Co-authored-by: Tyler Veness Co-authored-by: sciencewhiz --- .../ViewModels/InstallPageViewModel.cs | 115 ++++++++++++++---- 1 file changed, 88 insertions(+), 27 deletions(-) diff --git a/WPILibInstaller-Avalonia/ViewModels/InstallPageViewModel.cs b/WPILibInstaller-Avalonia/ViewModels/InstallPageViewModel.cs index c5e19f8..ac4916c 100644 --- a/WPILibInstaller-Avalonia/ViewModels/InstallPageViewModel.cs +++ b/WPILibInstaller-Avalonia/ViewModels/InstallPageViewModel.cs @@ -31,6 +31,52 @@ public class InstallPageViewModel : PageViewModelBase public int ProgressTotal { get; set; } public string TextTotal { get; set; } = ""; + private async void CreateLinuxShortcut(String name, String frcYear, String wmClass, CancellationToken token) + { + var launcherFile = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local/share/applications", $@"{name} {frcYear}.desktop"); + string contents; + if (name.Contains("WPILib")) + { + var nameNoWPILib = name.Remove(name.Length - " (WPILib)".Length); + contents = $@"#!/usr/bin/env xdg-open +[Desktop Entry] +Version=1.0 +Type=Application +Categories=Robotics;Science +Name={name} {frcYear} +Comment={nameNoWPILib} tool for the 2025 FIRST Robotics Competition season +Exec={configurationProvider.InstallDirectory}/tools/{nameNoWPILib}.sh +Icon={configurationProvider.InstallDirectory}/frccode/wpilib-256.ico +Terminal=false +StartupNotify=true +StartupWMClass={wmClass} +"; + + } + else + { + contents = $@"#!/usr/bin/env xdg-open +[Desktop Entry] +Version=1.0 +Type=Application +Categories=Robotics;Science +Name={name} {frcYear} +Comment={name} tool for the 2025 FIRST Robotics Competition season +Exec={configurationProvider.InstallDirectory}/tools/{name}.sh +Icon={configurationProvider.InstallDirectory}/frccode/wpilib-256.ico +Terminal=false +StartupNotify=true +StartupWMClass={wmClass} +"; + } + var launcherPath = Path.GetDirectoryName(launcherFile); + if (launcherPath != null) + { + Directory.CreateDirectory(launcherPath); + } + await File.WriteAllTextAsync(launcherFile, contents, token); + } + public async Task UIUpdateTask(CancellationToken token) { while (!token.IsCancellationRequested) @@ -942,12 +988,14 @@ await MessageBox.Avalonia.MessageBoxManager.GetMessageBoxStandardWindow(new Mess break; } while (true); } - else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux) && vsInstallProvider.Model.InstallingVsCode) + else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux)) { - // Create Linux desktop shortcut - var desktopFile = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), "Desktop", $@"FRC VS Code {frcYear}.desktop"); - var launcherFile = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local/share/applications", $@"FRC VS Code {frcYear}.desktop"); - string contents = $@"#!/usr/bin/env xdg-open + if (vsInstallProvider.Model.InstallingVsCode) + { + // Create Linux desktop shortcut + var desktopFile = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), "Desktop", $@"FRC VS Code {frcYear}.desktop"); + var launcherFile = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".local/share/applications", $@"FRC VS Code {frcYear}.desktop"); + string contents = $@"#!/usr/bin/env xdg-open [Desktop Entry] Version=1.0 Type=Application @@ -961,29 +1009,42 @@ [Desktop Entry] StartupWMClass=Code "; - var desktopPath = Path.GetDirectoryName(desktopFile); - if (desktopPath != null) - { - Directory.CreateDirectory(desktopPath); - } - var launcherPath = Path.GetDirectoryName(launcherFile); - if (launcherPath != null) - { - Directory.CreateDirectory(launcherPath); - } - await File.WriteAllTextAsync(desktopFile, contents, token); - await File.WriteAllTextAsync(launcherFile, contents, token); - await Task.Run(() => - { - var startInfo = new ProcessStartInfo("chmod", $"+x \"{desktopFile}\"") + var desktopPath = Path.GetDirectoryName(desktopFile); + if (desktopPath != null) { - UseShellExecute = false, - WindowStyle = ProcessWindowStyle.Hidden, - CreateNoWindow = true - }; - var proc = Process.Start(startInfo); - proc!.WaitForExit(); - }, token); + Directory.CreateDirectory(desktopPath); + } + var launcherPath = Path.GetDirectoryName(launcherFile); + if (launcherPath != null) + { + Directory.CreateDirectory(launcherPath); + } + await File.WriteAllTextAsync(desktopFile, contents, token); + await File.WriteAllTextAsync(launcherFile, contents, token); + await Task.Run(() => + { + var startInfo = new ProcessStartInfo("chmod", $"+x \"{desktopFile}\"") + { + UseShellExecute = false, + WindowStyle = ProcessWindowStyle.Hidden, + CreateNoWindow = true + }; + var proc = Process.Start(startInfo); + proc!.WaitForExit(); + }, token); + } + + CreateLinuxShortcut("AdvantageScope (WPILib)", frcYear, "AdvantageScope", token); + CreateLinuxShortcut("Elastic (WPILib)", frcYear, "Elastic", token); + CreateLinuxShortcut("Glass", frcYear, "Glass - DISCONNECTED", token); + CreateLinuxShortcut("OutlineViewer", frcYear, "OutlineViewer - DISCONNECTED", token); + CreateLinuxShortcut("DataLogTool", frcYear, "Datalog Tool", token); + CreateLinuxShortcut("SysId", frcYear, "System Identification", token); + CreateLinuxShortcut("SmartDashboard", frcYear, "edu-wpi-first-smartdashboard-SmartDashboard", token); + CreateLinuxShortcut("RobotBuilder", frcYear, "robotbuilder-RobotBuilder", token); + CreateLinuxShortcut("PathWeaver", frcYear, "edu.wpi.first.pathweaver.PathWeaver", token); + CreateLinuxShortcut("roboRIOTeamNumberSetter", frcYear, "roboRIO Team Number Setter", token); + CreateLinuxShortcut("Shuffleboard", frcYear, "edu.wpi.first.shuffleboard.app.Shuffleboard", token); } }