Skip to content

Commit

Permalink
Merge pull request #28 from skanda890/Patch-1
Browse files Browse the repository at this point in the history
Patch 1
  • Loading branch information
skanda890 committed Aug 7, 2024
2 parents 439bb3c + 10d7577 commit 5cfe361
Show file tree
Hide file tree
Showing 92 changed files with 2,107 additions and 1,630 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# <img src="https://raw.githubusercontent.com/marticliment/UniGetUI/main/media/icon.png" height="40">UniGetUI (formerly WingetUI)
# <img src="https://raw.githubusercontent.com/marticliment/UniGetUI/main/media/icon.png" height="40">UniGetUI (formerly WingetUI)

[![Downloads@latest](https://img.shields.io/github/downloads/marticliment/UniGetUI/3.0.2/total?style=for-the-badge)](https://github.com/marticliment/UniGetUI/releases/latest/download/WingetUI.Installer.exe)
[![Release Version Badge](https://img.shields.io/github/v/release/marticliment/UniGetUI?style=for-the-badge)](https://github.com/marticliment/UniGetUI/releases)
Expand Down
Binary file added src/Debug/WingetUI.exe
Binary file not shown.
Binary file added src/Debug/WingetUI.pdb
Binary file not shown.
Binary file added src/Debug/WingetUIToUniGetUIRedirector.exe
Binary file not shown.
Binary file added src/Debug/WingetUIToUniGetUIRedirector.pdb
Binary file not shown.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using ExternalLibraries.Pickers.Guids;
using System.Runtime.InteropServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Guids;

namespace ExternalLibraries.Pickers.Classes;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using ExternalLibraries.Pickers.Guids;
using System.Runtime.InteropServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Guids;

namespace ExternalLibraries.Pickers.Classes;

Expand Down
4 changes: 2 additions & 2 deletions src/ExternalLibraries.FilePickers/Classes/Helper.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using ExternalLibraries.Pickers.Enums;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Interfaces;
using ExternalLibraries.Pickers.Structures;
using System.Runtime.InteropServices;

namespace ExternalLibraries.Pickers.Classes;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
using ExternalLibraries.Pickers.Classes;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Classes;
using ExternalLibraries.Pickers.Guids;
using System.Runtime.InteropServices;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
using ExternalLibraries.Pickers.Classes;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Classes;
using ExternalLibraries.Pickers.Guids;
using System.Runtime.InteropServices;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
6 changes: 3 additions & 3 deletions src/ExternalLibraries.FilePickers/Interfaces/IFileDialog.cs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
using ExternalLibraries.Pickers.Enums;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Guids;
using ExternalLibraries.Pickers.Structures;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Guids;
using System.Runtime.CompilerServices;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Guids;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using ExternalLibraries.Pickers.Guids;
using ExternalLibraries.Pickers.Structures;
using System.Runtime.CompilerServices;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Guids;
using ExternalLibraries.Pickers.Structures;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
4 changes: 2 additions & 2 deletions src/ExternalLibraries.FilePickers/Interfaces/IModalWindow.cs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
using ExternalLibraries.Pickers.Guids;
using System.Runtime.CompilerServices;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Guids;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
6 changes: 3 additions & 3 deletions src/ExternalLibraries.FilePickers/Interfaces/IShellItem.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Guids;
using System.Runtime.CompilerServices;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Guids;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
using ExternalLibraries.Pickers.Enums;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using ExternalLibraries.Pickers.Enums;
using ExternalLibraries.Pickers.Guids;
using ExternalLibraries.Pickers.Structures;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;

namespace ExternalLibraries.Pickers.Interfaces;

Expand Down
2 changes: 1 addition & 1 deletion src/UniGetUI.Core.LanguageEngine/LanguageEngine.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using Jeffijoe.MessageFormat;
using System.Diagnostics.CodeAnalysis;
using System.Globalization;
using System.Text.Json.Nodes;
using Jeffijoe.MessageFormat;
using UniGetUI.Core.Data;
using UniGetUI.Core.Logging;
using UniGetUI.Core.SettingsEngine;
Expand Down
2 changes: 1 addition & 1 deletion src/UniGetUI.Interface.BackgroundApi/BackgroundApi.cs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
using System.Text;
using Nancy;
using Nancy.Hosting.Self;
using System.Text;
using UniGetUI.Core.Data;
using UniGetUI.Core.Logging;
using UniGetUI.Core.SettingsEngine;
Expand Down
5 changes: 2 additions & 3 deletions src/UniGetUI.PAckageEngine.Interfaces/IPackage.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using System.ComponentModel;
using UniGetUI.Interface.Enums;
using UniGetUI.PackageEngine.Classes.Serializable;
using UniGetUI.PackageEngine.Enums;
using UniGetUI.PackageEngine.Structs;

namespace UniGetUI.PackageEngine.Interfaces
{
Expand All @@ -19,8 +19,7 @@ public interface IPackage : INotifyPropertyChanged, IEquatable<IPackage>
public IPackageManager Manager { get; }
public string NewVersion { get; }
public bool IsUpgradable { get; }
public PackageScope Scope { get; set; }
public string SourceAsString { get; }
public ref OverridenInstallationOptions OverridenOptions { get; }
public string AutomationName { get; }

/// <summary>
Expand Down
2 changes: 0 additions & 2 deletions src/UniGetUI.PAckageEngine.Interfaces/IPackageManager.cs
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
using System.Diagnostics;
using UniGetUI.PackageEngine.Classes.Manager.ManagerHelpers;
using UniGetUI.PackageEngine.Enums;
using UniGetUI.PackageEngine.Interfaces.ManagerProviders;
using UniGetUI.PackageEngine.ManagerClasses.Classes;
using UniGetUI.PackageEngine.ManagerClasses.Manager;
Expand Down
2 changes: 1 addition & 1 deletion src/UniGetUI.PAckageEngine.Interfaces/ManagerProperties.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
using UniGetUI.PackageEngine.Interfaces;
using UniGetUI.Interface.Enums;
using UniGetUI.PackageEngine.Interfaces;

namespace UniGetUI.PackageEngine.ManagerClasses.Manager
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@ OperationType operation
/// </summary>
public abstract OperationVeredict GetOperationResult(
IPackage package,
IInstallationOptions options,
OperationType operation,
IEnumerable<string> processOutput,
int returnCode
Expand Down
14 changes: 14 additions & 0 deletions src/UniGetUI.PackageEngine.Enums/OverridenInstallationOptions.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
using UniGetUI.PackageEngine.Enums;

namespace UniGetUI.PackageEngine.Structs;
public struct OverridenInstallationOptions
{
public PackageScope? Scope;
public bool? RunAsAdministrator;

public OverridenInstallationOptions(PackageScope? scope = null, bool? runAsAdministrator = null)
{
Scope = scope;
RunAsAdministrator = runAsAdministrator;
}
}
5 changes: 2 additions & 3 deletions src/UniGetUI.PackageEngine.Managers.Chocolatey/Chocolatey.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,15 @@
using UniGetUI.Core.Logging;
using UniGetUI.Core.SettingsEngine;
using UniGetUI.Core.Tools;
using UniGetUI.PackageEngine.Classes.Manager;
using UniGetUI.Interface.Enums;
using UniGetUI.PackageEngine.Classes.Manager;
using UniGetUI.PackageEngine.Classes.Manager.ManagerHelpers;
using UniGetUI.PackageEngine.Enums;
using UniGetUI.PackageEngine.Interfaces;
using UniGetUI.PackageEngine.ManagerClasses.Classes;
using UniGetUI.PackageEngine.ManagerClasses.Manager;
using UniGetUI.PackageEngine.Managers.Chocolatey;
using UniGetUI.PackageEngine.Managers.PowerShellManager;
using UniGetUI.PackageEngine.PackageClasses;
using UniGetUI.PackageEngine.ManagerClasses.Classes;

namespace UniGetUI.PackageEngine.Managers.ChocolateyManager
{
Expand Down
Original file line number Diff line number Diff line change
@@ -1,14 +1,7 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading.Tasks;
using UniGetUI.PackageEngine.Classes.Manager.BaseProviders;
using UniGetUI.PackageEngine.Enums;
using UniGetUI.PackageEngine.Interfaces;
using UniGetUI.PackageEngine.Managers.ChocolateyManager;
using UniGetUI.PackageEngine.PackageClasses;

namespace UniGetUI.PackageEngine.Managers.ChocolateyManager;
internal sealed class ChocolateyOperationProvider : BaseOperationProvider<Chocolatey>
Expand Down Expand Up @@ -56,7 +49,6 @@ public override IEnumerable<string> GetOperationParameters(

public override OperationVeredict GetOperationResult(
IPackage package,
IInstallationOptions options,
OperationType operation,
IEnumerable<string> processOutput,
int returnCode)
Expand All @@ -73,12 +65,12 @@ public override OperationVeredict GetOperationResult(


string output_string = string.Join("\n", processOutput);
if (!options.RunAsAdministrator &&
if (!package.OverridenOptions.RunAsAdministrator != true &&
(output_string.Contains("Run as administrator")
|| output_string.Contains("The requested operation requires elevation")
|| output_string.Contains("ERROR: Exception calling \"CreateDirectory\" with \"1\" argument(s): \"Access to the path")) )
{
options.RunAsAdministrator = true;
package.OverridenOptions.RunAsAdministrator = true;
return OperationVeredict.AutoRetry;
}

Expand Down
29 changes: 22 additions & 7 deletions src/UniGetUI.PackageEngine.Managers.Dotnet/DotNet.cs
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,16 @@
using System.Runtime.InteropServices;
using System.Text.RegularExpressions;
using UniGetUI.Core.Tools;
using UniGetUI.PackageEngine.Classes.Manager;
using UniGetUI.Interface.Enums;
using UniGetUI.PackageEngine.Classes.Manager;
using UniGetUI.PackageEngine.Classes.Manager.Classes;
using UniGetUI.PackageEngine.Classes.Manager.ManagerHelpers;
using UniGetUI.PackageEngine.Enums;
using UniGetUI.PackageEngine.Interfaces;
using UniGetUI.PackageEngine.ManagerClasses.Classes;
using UniGetUI.PackageEngine.ManagerClasses.Manager;
using UniGetUI.PackageEngine.Managers.PowerShellManager;
using UniGetUI.PackageEngine.PackageClasses;
using UniGetUI.PackageEngine.ManagerClasses.Classes;
using UniGetUI.PackageEngine.Structs;

namespace UniGetUI.PackageEngine.Managers.DotNetManager
{
Expand Down Expand Up @@ -140,7 +140,15 @@ protected override async Task<Package[]> GetAvailableUpdates_UnSafe()
continue;
}

Packages.Add(new Package(CoreTools.FormatAsName(elements[0]), elements[0], elements[1], elements[2], DefaultSource, this, PackageScope.Global));
Packages.Add(new Package(
CoreTools.FormatAsName(elements[0]),
elements[0],
elements[1],
elements[2],
DefaultSource,
this,
new(PackageScope.Global)
));
}
}
logger.AddToStdErr(await p.StandardError.ReadToEndAsync());
Expand All @@ -153,14 +161,14 @@ protected override async Task<Package[]> GetAvailableUpdates_UnSafe()
protected override async Task<Package[]> GetInstalledPackages_UnSafe()
{
List<Package> Packages = [];
foreach (PackageScope scope in new PackageScope[] { PackageScope.Local, PackageScope.Global })
foreach (var options in new OverridenInstallationOptions[] { new(PackageScope.Local), new(PackageScope.Global) })
{
Process p = new()
{
StartInfo = new ProcessStartInfo
{
FileName = Status.ExecutablePath,
Arguments = Properties.ExecutableCallArgs + " list" + (scope == PackageScope.Global ? " --global" : ""),
Arguments = Properties.ExecutableCallArgs + " list" + (options.Scope == PackageScope.Global ? " --global" : ""),
RedirectStandardOutput = true,
RedirectStandardError = true,
UseShellExecute = false,
Expand Down Expand Up @@ -202,7 +210,14 @@ protected override async Task<Package[]> GetInstalledPackages_UnSafe()
continue;
}

Packages.Add(new Package(CoreTools.FormatAsName(elements[0]), elements[0], elements[1], DefaultSource, this, scope));
Packages.Add(new Package(
CoreTools.FormatAsName(elements[0]),
elements[0],
elements[1],
DefaultSource,
this,
options
));
}
}
logger.AddToStdErr(await p.StandardError.ReadToEndAsync());
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,7 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading.Tasks;
using UniGetUI.PackageEngine.Classes.Manager.BaseProviders;
using UniGetUI.PackageEngine.Enums;
using UniGetUI.PackageEngine.Interfaces;
using UniGetUI.PackageEngine.Managers.DotNetManager;
using UniGetUI.PackageEngine.PackageClasses;
using Windows.ApplicationModel.Appointments;

namespace UniGetUI.PackageEngine.Managers.DotNetManager;
internal sealed class DotNetOperationProvider : BaseOperationProvider<DotNet>
Expand All @@ -35,7 +27,7 @@ public override IEnumerable<string> GetOperationParameters(
if (options.CustomInstallLocation != "")
parameters.AddRange(["--tool-path", "\"" + options.CustomInstallLocation + "\""]);

if (options.InstallationScope == PackageScope.Global || (options.InstallationScope is null && package.Scope == PackageScope.Global))
if(package.OverridenOptions.Scope == PackageScope.Global || (package.OverridenOptions.Scope is null && options.InstallationScope == PackageScope.Global))
parameters.Add("--global");

if (operation is OperationType.Install or OperationType.Update)
Expand All @@ -55,7 +47,6 @@ public override IEnumerable<string> GetOperationParameters(

public override OperationVeredict GetOperationResult(
IPackage package,
IInstallationOptions options,
OperationType operation,
IEnumerable<string> processOutput,
int returnCode)
Expand Down
Loading

0 comments on commit 5cfe361

Please sign in to comment.