diff --git a/src/Prism.Core/Common/IParameters.cs b/src/Prism.Core/Common/IParameters.cs index 4fa05b4cc1..4f1d544d9e 100644 --- a/src/Prism.Core/Common/IParameters.cs +++ b/src/Prism.Core/Common/IParameters.cs @@ -1,6 +1,6 @@ -using System.Collections.Generic; using System.Diagnostics.CodeAnalysis; +#nullable enable namespace Prism.Common { /// @@ -65,6 +65,6 @@ public interface IParameters : IEnumerable> /// /// The key of the parameter to get. /// A matching value if it exists. - object this[string key] { get; } + object? this[string key] { get; } } } diff --git a/src/Prism.Core/Common/ListDictionary.cs b/src/Prism.Core/Common/ListDictionary.cs index 4c21b370e9..99d8293f60 100644 --- a/src/Prism.Core/Common/ListDictionary.cs +++ b/src/Prism.Core/Common/ListDictionary.cs @@ -1,6 +1,3 @@ -using System; -using System.Collections.Generic; - namespace Prism.Common { /// diff --git a/src/Prism.Core/Common/ParametersBase.cs b/src/Prism.Core/Common/ParametersBase.cs index 077ff736af..3814e290ce 100644 --- a/src/Prism.Core/Common/ParametersBase.cs +++ b/src/Prism.Core/Common/ParametersBase.cs @@ -1,11 +1,8 @@ -using System; using System.Collections; -using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics.CodeAnalysis; -using System.Linq; using System.Text; - +#nullable enable namespace Prism.Common { /// @@ -13,7 +10,7 @@ namespace Prism.Common /// public abstract class ParametersBase : IParameters { - private readonly List> _entries = []; + private readonly List> _entries = []; /// /// Default constructor. @@ -51,7 +48,7 @@ protected ParametersBase(string query) } i++; } - string key = null; + string? key = null; string value; if (num4 >= 0) { @@ -75,7 +72,7 @@ protected ParametersBase(string query) /// /// The key for the value to be returned. /// The value of the parameter referenced by the key; otherwise null. - public object this[string key] + public object? this[string key] { get { @@ -108,7 +105,7 @@ public object this[string key] /// The key to reference this value in the parameters collection. /// The value of the parameter to store. public void Add(string key, object value) => - _entries.Add(new KeyValuePair(key, value)); + _entries.Add(new KeyValuePair(key, value)); /// /// Checks collection for presence of key. @@ -122,7 +119,7 @@ public bool ContainsKey(string key) => /// Gets an enumerator for the KeyValuePairs in parameter collection. /// /// Enumerator. - public IEnumerator> GetEnumerator() => + public IEnumerator> GetEnumerator() => _entries.GetEnumerator(); /// @@ -181,7 +178,7 @@ public override string ToString() queryBuilder.Append(Uri.EscapeDataString(kvp.Key)); queryBuilder.Append('='); - queryBuilder.Append(Uri.EscapeDataString(kvp.Value?.ToString() is string str ? str : string.Empty)); + queryBuilder.Append(Uri.EscapeDataString(kvp.Value?.ToString() ?? string.Empty)); } } @@ -193,7 +190,7 @@ public override string ToString() /// /// An IEnumerable of KeyValuePairs to add to the current parameter list. [EditorBrowsable(EditorBrowsableState.Never)] - public void FromParameters(IEnumerable> parameters) => + public void FromParameters(IEnumerable> parameters) => _entries.AddRange(parameters); } } diff --git a/src/Prism.Core/Common/ParametersExtensions.cs b/src/Prism.Core/Common/ParametersExtensions.cs index 2f6f56d1e9..c34b45895d 100644 --- a/src/Prism.Core/Common/ParametersExtensions.cs +++ b/src/Prism.Core/Common/ParametersExtensions.cs @@ -1,3 +1,4 @@ +#nullable enable using System; using System.Collections.Generic; using System.ComponentModel; @@ -156,13 +157,6 @@ private static bool TryGetValueInternal(KeyValuePair kvp, Type t public static bool ContainsKey(this IEnumerable> parameters, string key) => parameters.Any(x => string.Compare(x.Key, key, StringComparison.Ordinal) == 0); - private static object GetDefault(Type type) - { - if (type.IsValueType) - { - return Activator.CreateInstance(type); - } - return null; - } + private static object? GetDefault(Type type) => type.IsValueType ? Activator.CreateInstance(type) : null; } } diff --git a/src/Prism.Core/Common/UriParsingHelper.cs b/src/Prism.Core/Common/UriParsingHelper.cs index f768ac1059..e13dbcf7a6 100644 --- a/src/Prism.Core/Common/UriParsingHelper.cs +++ b/src/Prism.Core/Common/UriParsingHelper.cs @@ -1,8 +1,7 @@ -using System; -using System.Collections.Generic; using Prism.Dialogs; using Prism.Navigation; +#nullable enable namespace Prism.Common { /// @@ -10,7 +9,7 @@ namespace Prism.Common /// public static class UriParsingHelper { - private static readonly char[] _pathDelimiter = { '/' }; + private static readonly char[] _pathDelimiter = ['/']; /// /// Gets the Uri segments from a deep linked Navigation Uri @@ -40,10 +39,7 @@ public static Queue GetUriSegments(Uri uri) /// /// A Navigation Segment /// The navigation segment name from the provided segment. - public static string GetSegmentName(string segment) - { - return segment.Split('?')[0]; - } + public static string GetSegmentName(string segment) => segment.Split('?')[0]; /// /// Gets the Segment Parameters from a Navigation Segment that may contain a querystring @@ -72,11 +68,11 @@ public static INavigationParameters GetSegmentParameters(string segment) /// The segment /// The existing . /// The combined . - public static INavigationParameters GetSegmentParameters(string uriSegment, INavigationParameters parameters) + public static INavigationParameters GetSegmentParameters(string uriSegment, INavigationParameters? parameters) { var navParameters = GetSegmentParameters(uriSegment); - if (parameters != null) + if (parameters is not null) { foreach (KeyValuePair navigationParameter in parameters) { @@ -114,7 +110,7 @@ public static IDialogParameters GetSegmentDialogParameters(string segment) /// A navigation segment which may contain a querystring. /// Existing . /// - public static IDialogParameters GetSegmentParameters(string uriSegment, IDialogParameters parameters) + public static IDialogParameters GetSegmentParameters(string uriSegment, IDialogParameters? parameters) { var dialogParameters = GetSegmentDialogParameters(uriSegment); @@ -133,19 +129,13 @@ public static IDialogParameters GetSegmentParameters(string uriSegment, IDialogP /// Gets the query part of . /// /// The Uri. - public static string GetQuery(Uri uri) - { - return EnsureAbsolute(uri).Query; - } + public static string GetQuery(Uri uri) => EnsureAbsolute(uri).Query; /// /// Gets the AbsolutePath part of . /// /// The Uri. - public static string GetAbsolutePath(Uri uri) - { - return EnsureAbsolute(uri).AbsolutePath; - } + public static string GetAbsolutePath(Uri uri) => EnsureAbsolute(uri).AbsolutePath; /// /// Parses the query of into a dictionary. @@ -166,16 +156,14 @@ public static INavigationParameters ParseQuery(Uri uri) /// Throws an when the string is null or empty. public static Uri Parse(string uri) { - if (uri == null) throw new ArgumentNullException(nameof(uri)); - - if (uri.StartsWith("/", StringComparison.Ordinal)) - { - return new Uri("http://localhost" + uri, UriKind.Absolute); - } - else + if (uri == null) { - return new Uri(uri, UriKind.RelativeOrAbsolute); + throw new ArgumentNullException(nameof(uri)); } + + return uri.StartsWith("/", StringComparison.Ordinal) + ? new Uri("http://localhost" + uri, UriKind.Absolute) + : new Uri(uri, UriKind.RelativeOrAbsolute); } /// @@ -191,11 +179,7 @@ public static Uri EnsureAbsolute(Uri uri) return uri; } - if ((uri != null) && !uri.OriginalString.StartsWith("/", StringComparison.Ordinal)) - { - return new Uri("http://localhost/" + uri, UriKind.Absolute); - } - return new Uri("http://localhost" + uri, UriKind.Absolute); + return !uri.OriginalString.StartsWith("/", StringComparison.Ordinal) ? new Uri("http://localhost/" + uri, UriKind.Absolute) : new Uri("http://localhost" + uri, UriKind.Absolute); } } } diff --git a/tests/Maui/Prism.Maui.Tests/Fixtures/Common/UriParsingHelperFixture.cs b/tests/Maui/Prism.Maui.Tests/Fixtures/Common/UriParsingHelperFixture.cs index a39e5d1750..2327ac37fd 100644 --- a/tests/Maui/Prism.Maui.Tests/Fixtures/Common/UriParsingHelperFixture.cs +++ b/tests/Maui/Prism.Maui.Tests/Fixtures/Common/UriParsingHelperFixture.cs @@ -1,8 +1,7 @@ -using System; -using Prism.Common; +using Prism.Common; namespace Prism.Maui.Tests.Fixtures.Common; - +#nullable enable public class UriParsingHelperFixture { const string _relativeUri = "MainPage?id=3&name=dan"; @@ -14,7 +13,7 @@ public class UriParsingHelperFixture [Fact] public void ParametersParsedFromNullSegment() { - var parameters = UriParsingHelper.GetSegmentParameters(null); + var parameters = UriParsingHelper.GetSegmentParameters(null!); Assert.NotNull(parameters); } @@ -62,7 +61,7 @@ public void ParametersParsedFromNavigationParametersInRelativeUri() { "name", "dan" } }; - var parameters = UriParsingHelper.GetSegmentParameters("MainPage" + navParameters.ToString()); + var parameters = UriParsingHelper.GetSegmentParameters("MainPage" + navParameters); Assert.NotEmpty(parameters); @@ -82,7 +81,7 @@ public void ParametersParsedFromNavigationParametersInAbsoluteUri() { "name", "dan" } }; - var parameters = UriParsingHelper.GetSegmentParameters("http://www.dansiegel.net/MainPage" + navParameters.ToString()); + var parameters = UriParsingHelper.GetSegmentParameters("http://www.dansiegel.net/MainPage" + navParameters); Assert.NotEmpty(parameters); @@ -93,6 +92,13 @@ public void ParametersParsedFromNavigationParametersInAbsoluteUri() Assert.Equal("dan", parameters["name"]); } + [Fact] + public void TargetNameParsedFromEmptySegment() + { + var target = UriParsingHelper.GetSegmentName(string.Empty); + Assert.Equal(string.Empty, target); + } + [Fact] public void TargetNameParsedFromSingleSegment() { @@ -177,7 +183,7 @@ public void EnsureAbsoluteUriForAbsoluteUri() [Fact] public void ParseForNull() { - var actual = Assert.Throws(() => UriParsingHelper.Parse(null)); + var actual = Assert.Throws(() => UriParsingHelper.Parse(null!)); Assert.NotNull(actual); Assert.Equal("uri", actual.ParamName); } diff --git a/tests/Prism.Core.Tests/Common/ListDictionaryFixture.cs b/tests/Prism.Core.Tests/Common/ListDictionaryFixture.cs index eb25cc801e..91f4ffb518 100644 --- a/tests/Prism.Core.Tests/Common/ListDictionaryFixture.cs +++ b/tests/Prism.Core.Tests/Common/ListDictionaryFixture.cs @@ -1,9 +1,7 @@ -using System; -using System.Collections.Generic; using Prism.Common; using Xunit; -namespace Prism.Wpf.Tests +namespace Prism.Tests.Common { public class ListDictionaryFixture diff --git a/tests/Prism.Core.Tests/Common/Mocks/MockParameters.cs b/tests/Prism.Core.Tests/Common/Mocks/MockParameters.cs index 671f990144..b59252be1c 100644 --- a/tests/Prism.Core.Tests/Common/Mocks/MockParameters.cs +++ b/tests/Prism.Core.Tests/Common/Mocks/MockParameters.cs @@ -4,7 +4,7 @@ namespace Prism.Tests.Common.Mocks { internal class MockParameters : ParametersBase { - public MockParameters() : base() { } + public MockParameters() { } public MockParameters(string query) : base(query) { } } } diff --git a/tests/Prism.Core.Tests/Common/MulticastExceptionHandlerFixture.cs b/tests/Prism.Core.Tests/Common/MulticastExceptionHandlerFixture.cs index d5b7026fcf..65d756fd48 100644 --- a/tests/Prism.Core.Tests/Common/MulticastExceptionHandlerFixture.cs +++ b/tests/Prism.Core.Tests/Common/MulticastExceptionHandlerFixture.cs @@ -1,10 +1,7 @@ -using System; -using System.IO; -using System.Threading.Tasks; -using Prism.Common; +using Prism.Common; using Xunit; -namespace Prism.Core.Tests.Common; +namespace Prism.Tests.Common; #nullable enable public class MulticastExceptionHandlerFixture diff --git a/tests/Prism.Core.Tests/Common/ParametersFixture.cs b/tests/Prism.Core.Tests/Common/ParametersFixture.cs index abd2aa8cf0..ae629460dd 100644 --- a/tests/Prism.Core.Tests/Common/ParametersFixture.cs +++ b/tests/Prism.Core.Tests/Common/ParametersFixture.cs @@ -1,5 +1,4 @@ -using System.Collections.Generic; -using System.Linq; +#nullable enable using Prism.Tests.Common.Mocks; using Xunit; @@ -28,7 +27,7 @@ public void GetValuesOfT() { var parameters = new MockParameters("mock=Foo&mock=2&mock=Fizz"); - IEnumerable values = default; + IEnumerable values = []; var ex = Record.Exception(() => values = parameters.GetValues("mock")); Assert.Null(ex);