mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 07:23:14 +08:00
Merge pull request #21763 from turbedi/argumentnullexception_throwhelper
Use new ArgumentNullException.ThrowIfNull throw-helper API
This commit is contained in:
commit
d31b649ed7
@ -35,8 +35,8 @@ namespace osu.Game.Rulesets.Mania.Beatmaps.Patterns.Legacy
|
|||||||
protected PatternGenerator(LegacyRandom random, HitObject hitObject, ManiaBeatmap beatmap, Pattern previousPattern, IBeatmap originalBeatmap)
|
protected PatternGenerator(LegacyRandom random, HitObject hitObject, ManiaBeatmap beatmap, Pattern previousPattern, IBeatmap originalBeatmap)
|
||||||
: base(hitObject, beatmap, previousPattern)
|
: base(hitObject, beatmap, previousPattern)
|
||||||
{
|
{
|
||||||
if (random == null) throw new ArgumentNullException(nameof(random));
|
ArgumentNullException.ThrowIfNull(random);
|
||||||
if (originalBeatmap == null) throw new ArgumentNullException(nameof(originalBeatmap));
|
ArgumentNullException.ThrowIfNull(originalBeatmap);
|
||||||
|
|
||||||
Random = random;
|
Random = random;
|
||||||
OriginalBeatmap = originalBeatmap;
|
OriginalBeatmap = originalBeatmap;
|
||||||
|
@ -33,9 +33,9 @@ namespace osu.Game.Rulesets.Mania.Beatmaps.Patterns
|
|||||||
|
|
||||||
protected PatternGenerator(HitObject hitObject, ManiaBeatmap beatmap, Pattern previousPattern)
|
protected PatternGenerator(HitObject hitObject, ManiaBeatmap beatmap, Pattern previousPattern)
|
||||||
{
|
{
|
||||||
if (hitObject == null) throw new ArgumentNullException(nameof(hitObject));
|
ArgumentNullException.ThrowIfNull(hitObject);
|
||||||
if (beatmap == null) throw new ArgumentNullException(nameof(beatmap));
|
ArgumentNullException.ThrowIfNull(beatmap);
|
||||||
if (previousPattern == null) throw new ArgumentNullException(nameof(previousPattern));
|
ArgumentNullException.ThrowIfNull(previousPattern);
|
||||||
|
|
||||||
HitObject = hitObject;
|
HitObject = hitObject;
|
||||||
Beatmap = beatmap;
|
Beatmap = beatmap;
|
||||||
|
@ -22,8 +22,7 @@ namespace osu.Game.Rulesets.Mania.MathUtils
|
|||||||
|
|
||||||
public static void Sort(T[] keys, IComparer<T> comparer)
|
public static void Sort(T[] keys, IComparer<T> comparer)
|
||||||
{
|
{
|
||||||
if (keys == null)
|
ArgumentNullException.ThrowIfNull(keys);
|
||||||
throw new ArgumentNullException(nameof(keys));
|
|
||||||
|
|
||||||
if (keys.Length == 0)
|
if (keys.Length == 0)
|
||||||
return;
|
return;
|
||||||
|
@ -29,8 +29,7 @@ namespace osu.Game.Rulesets.Mania.UI
|
|||||||
|
|
||||||
public ManiaPlayfield(List<StageDefinition> stageDefinitions)
|
public ManiaPlayfield(List<StageDefinition> stageDefinitions)
|
||||||
{
|
{
|
||||||
if (stageDefinitions == null)
|
ArgumentNullException.ThrowIfNull(stageDefinitions);
|
||||||
throw new ArgumentNullException(nameof(stageDefinitions));
|
|
||||||
|
|
||||||
if (stageDefinitions.Count <= 0)
|
if (stageDefinitions.Count <= 0)
|
||||||
throw new ArgumentException("Can't have zero or fewer stages.");
|
throw new ArgumentException("Can't have zero or fewer stages.");
|
||||||
|
@ -84,8 +84,8 @@ namespace osu.Game.Rulesets.Osu.Replays
|
|||||||
{
|
{
|
||||||
public int Compare(ReplayFrame? f1, ReplayFrame? f2)
|
public int Compare(ReplayFrame? f1, ReplayFrame? f2)
|
||||||
{
|
{
|
||||||
if (f1 == null) throw new ArgumentNullException(nameof(f1));
|
ArgumentNullException.ThrowIfNull(f1);
|
||||||
if (f2 == null) throw new ArgumentNullException(nameof(f2));
|
ArgumentNullException.ThrowIfNull(f2);
|
||||||
|
|
||||||
return f1.Time.CompareTo(f2.Time);
|
return f1.Time.CompareTo(f2.Time);
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@ namespace osu.Game.Tournament.Components
|
|||||||
|
|
||||||
public TournamentBeatmapPanel(TournamentBeatmap beatmap, string mod = null)
|
public TournamentBeatmapPanel(TournamentBeatmap beatmap, string mod = null)
|
||||||
{
|
{
|
||||||
if (beatmap == null) throw new ArgumentNullException(nameof(beatmap));
|
ArgumentNullException.ThrowIfNull(beatmap);
|
||||||
|
|
||||||
Beatmap = beatmap;
|
Beatmap = beatmap;
|
||||||
this.mod = mod;
|
this.mod = mod;
|
||||||
|
@ -211,8 +211,7 @@ namespace osu.Game.Beatmaps.ControlPoints
|
|||||||
public static T BinarySearch<T>(IReadOnlyList<T> list, double time)
|
public static T BinarySearch<T>(IReadOnlyList<T> list, double time)
|
||||||
where T : class, IControlPoint
|
where T : class, IControlPoint
|
||||||
{
|
{
|
||||||
if (list == null)
|
ArgumentNullException.ThrowIfNull(list);
|
||||||
throw new ArgumentNullException(nameof(list));
|
|
||||||
|
|
||||||
if (list.Count == 0)
|
if (list.Count == 0)
|
||||||
return null;
|
return null;
|
||||||
|
@ -15,8 +15,7 @@ namespace osu.Game.Beatmaps.Drawables
|
|||||||
|
|
||||||
public BeatmapBackgroundSprite(IWorkingBeatmap working)
|
public BeatmapBackgroundSprite(IWorkingBeatmap working)
|
||||||
{
|
{
|
||||||
if (working == null)
|
ArgumentNullException.ThrowIfNull(working);
|
||||||
throw new ArgumentNullException(nameof(working));
|
|
||||||
|
|
||||||
this.working = working;
|
this.working = working;
|
||||||
}
|
}
|
||||||
|
@ -18,8 +18,7 @@ namespace osu.Game.Beatmaps.Drawables
|
|||||||
|
|
||||||
public OnlineBeatmapSetCover(IBeatmapSetOnlineInfo set, BeatmapSetCoverType type = BeatmapSetCoverType.Cover)
|
public OnlineBeatmapSetCover(IBeatmapSetOnlineInfo set, BeatmapSetCoverType type = BeatmapSetCoverType.Cover)
|
||||||
{
|
{
|
||||||
if (set == null)
|
ArgumentNullException.ThrowIfNull(set);
|
||||||
throw new ArgumentNullException(nameof(set));
|
|
||||||
|
|
||||||
this.set = set;
|
this.set = set;
|
||||||
this.type = type;
|
this.type = type;
|
||||||
|
@ -57,8 +57,7 @@ namespace osu.Game.Beatmaps.Formats
|
|||||||
public static Decoder<T> GetDecoder<T>(LineBufferedReader stream)
|
public static Decoder<T> GetDecoder<T>(LineBufferedReader stream)
|
||||||
where T : new()
|
where T : new()
|
||||||
{
|
{
|
||||||
if (stream == null)
|
ArgumentNullException.ThrowIfNull(stream);
|
||||||
throw new ArgumentNullException(nameof(stream));
|
|
||||||
|
|
||||||
if (!decoders.TryGetValue(typeof(T), out var typedDecoders))
|
if (!decoders.TryGetValue(typeof(T), out var typedDecoders))
|
||||||
throw new IOException(@"Unknown decoder type");
|
throw new IOException(@"Unknown decoder type");
|
||||||
|
@ -36,8 +36,7 @@ namespace osu.Game.Graphics.Containers
|
|||||||
/// <param name="easing">The easing type of the initial transform.</param>
|
/// <param name="easing">The easing type of the initial transform.</param>
|
||||||
public void StartTracking(OsuLogo logo, double duration = 0, Easing easing = Easing.None)
|
public void StartTracking(OsuLogo logo, double duration = 0, Easing easing = Easing.None)
|
||||||
{
|
{
|
||||||
if (logo == null)
|
ArgumentNullException.ThrowIfNull(logo);
|
||||||
throw new ArgumentNullException(nameof(logo));
|
|
||||||
|
|
||||||
if (logo.IsTracking && Logo == null)
|
if (logo.IsTracking && Logo == null)
|
||||||
throw new InvalidOperationException($"Cannot track an instance of {typeof(OsuLogo)} to multiple {typeof(LogoTrackingContainer)}s");
|
throw new InvalidOperationException($"Cannot track an instance of {typeof(OsuLogo)} to multiple {typeof(LogoTrackingContainer)}s");
|
||||||
|
@ -114,8 +114,7 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
get => current;
|
get => current;
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value == null)
|
ArgumentNullException.ThrowIfNull(value);
|
||||||
throw new ArgumentNullException(nameof(value));
|
|
||||||
|
|
||||||
current.UnbindBindings();
|
current.UnbindBindings();
|
||||||
current.BindTo(value);
|
current.BindTo(value);
|
||||||
|
@ -23,8 +23,7 @@ namespace osu.Game.IO.FileAbstraction
|
|||||||
|
|
||||||
public void CloseStream(Stream stream)
|
public void CloseStream(Stream stream)
|
||||||
{
|
{
|
||||||
if (stream == null)
|
ArgumentNullException.ThrowIfNull(stream);
|
||||||
throw new ArgumentNullException(nameof(stream));
|
|
||||||
|
|
||||||
stream.Close();
|
stream.Close();
|
||||||
}
|
}
|
||||||
|
@ -118,8 +118,7 @@ namespace osu.Game.Online.Chat
|
|||||||
/// <param name="name"></param>
|
/// <param name="name"></param>
|
||||||
public void OpenChannel(string name)
|
public void OpenChannel(string name)
|
||||||
{
|
{
|
||||||
if (name == null)
|
ArgumentNullException.ThrowIfNull(name);
|
||||||
throw new ArgumentNullException(nameof(name));
|
|
||||||
|
|
||||||
CurrentChannel.Value = AvailableChannels.FirstOrDefault(c => c.Name == name) ?? throw new ChannelNotFoundException(name);
|
CurrentChannel.Value = AvailableChannels.FirstOrDefault(c => c.Name == name) ?? throw new ChannelNotFoundException(name);
|
||||||
}
|
}
|
||||||
@ -130,8 +129,7 @@ namespace osu.Game.Online.Chat
|
|||||||
/// <param name="user">The user the private channel is opened with.</param>
|
/// <param name="user">The user the private channel is opened with.</param>
|
||||||
public void OpenPrivateChannel(APIUser user)
|
public void OpenPrivateChannel(APIUser user)
|
||||||
{
|
{
|
||||||
if (user == null)
|
ArgumentNullException.ThrowIfNull(user);
|
||||||
throw new ArgumentNullException(nameof(user));
|
|
||||||
|
|
||||||
if (user.Id == api.LocalUser.Value.Id)
|
if (user.Id == api.LocalUser.Value.Id)
|
||||||
return;
|
return;
|
||||||
|
@ -70,7 +70,7 @@ namespace osu.Game.Overlays
|
|||||||
/// <see cref="APIChangelogBuild.DisplayVersion"/> are specified, the header will instantly display them.</param>
|
/// <see cref="APIChangelogBuild.DisplayVersion"/> are specified, the header will instantly display them.</param>
|
||||||
public void ShowBuild([NotNull] APIChangelogBuild build)
|
public void ShowBuild([NotNull] APIChangelogBuild build)
|
||||||
{
|
{
|
||||||
if (build == null) throw new ArgumentNullException(nameof(build));
|
ArgumentNullException.ThrowIfNull(build);
|
||||||
|
|
||||||
Current.Value = build;
|
Current.Value = build;
|
||||||
Show();
|
Show();
|
||||||
@ -78,8 +78,8 @@ namespace osu.Game.Overlays
|
|||||||
|
|
||||||
public void ShowBuild([NotNull] string updateStream, [NotNull] string version)
|
public void ShowBuild([NotNull] string updateStream, [NotNull] string version)
|
||||||
{
|
{
|
||||||
if (updateStream == null) throw new ArgumentNullException(nameof(updateStream));
|
ArgumentNullException.ThrowIfNull(updateStream);
|
||||||
if (version == null) throw new ArgumentNullException(nameof(version));
|
ArgumentNullException.ThrowIfNull(version);
|
||||||
|
|
||||||
performAfterFetch(() =>
|
performAfterFetch(() =>
|
||||||
{
|
{
|
||||||
|
@ -58,7 +58,7 @@ namespace osu.Game.Overlays
|
|||||||
/// <exception cref="InvalidOperationException">If <paramref name="configManager"/> is already being tracked from the same <paramref name="source"/>.</exception>
|
/// <exception cref="InvalidOperationException">If <paramref name="configManager"/> is already being tracked from the same <paramref name="source"/>.</exception>
|
||||||
public void BeginTracking(object source, ITrackableConfigManager configManager)
|
public void BeginTracking(object source, ITrackableConfigManager configManager)
|
||||||
{
|
{
|
||||||
if (configManager == null) throw new ArgumentNullException(nameof(configManager));
|
ArgumentNullException.ThrowIfNull(configManager);
|
||||||
|
|
||||||
if (trackedConfigManagers.ContainsKey((source, configManager)))
|
if (trackedConfigManagers.ContainsKey((source, configManager)))
|
||||||
throw new InvalidOperationException($"{nameof(configManager)} is already registered.");
|
throw new InvalidOperationException($"{nameof(configManager)} is already registered.");
|
||||||
@ -82,7 +82,7 @@ namespace osu.Game.Overlays
|
|||||||
/// <exception cref="InvalidOperationException">If <paramref name="configManager"/> is not being tracked from the same <paramref name="source"/>.</exception>
|
/// <exception cref="InvalidOperationException">If <paramref name="configManager"/> is not being tracked from the same <paramref name="source"/>.</exception>
|
||||||
public void StopTracking(object source, ITrackableConfigManager configManager)
|
public void StopTracking(object source, ITrackableConfigManager configManager)
|
||||||
{
|
{
|
||||||
if (configManager == null) throw new ArgumentNullException(nameof(configManager));
|
ArgumentNullException.ThrowIfNull(configManager);
|
||||||
|
|
||||||
if (!trackedConfigManagers.TryGetValue((source, configManager), out var existing))
|
if (!trackedConfigManagers.TryGetValue((source, configManager), out var existing))
|
||||||
return;
|
return;
|
||||||
|
@ -28,8 +28,7 @@ namespace osu.Game.Overlays.Volume
|
|||||||
get => current;
|
get => current;
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value == null)
|
ArgumentNullException.ThrowIfNull(value);
|
||||||
throw new ArgumentNullException(nameof(value));
|
|
||||||
|
|
||||||
current.UnbindBindings();
|
current.UnbindBindings();
|
||||||
current.BindTo(value);
|
current.BindTo(value);
|
||||||
|
@ -126,8 +126,7 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
get => this;
|
get => this;
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value == null)
|
ArgumentNullException.ThrowIfNull(value);
|
||||||
throw new ArgumentNullException(nameof(value));
|
|
||||||
|
|
||||||
if (currentBound != null) UnbindFrom(currentBound);
|
if (currentBound != null) UnbindFrom(currentBound);
|
||||||
BindTo(currentBound = value);
|
BindTo(currentBound = value);
|
||||||
|
@ -208,8 +208,7 @@ namespace osu.Game.Rulesets.Objects.Drawables
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public void Apply([NotNull] HitObject hitObject)
|
public void Apply([NotNull] HitObject hitObject)
|
||||||
{
|
{
|
||||||
if (hitObject == null)
|
ArgumentNullException.ThrowIfNull(hitObject);
|
||||||
throw new ArgumentNullException($"Cannot apply a null {nameof(HitObject)}.");
|
|
||||||
|
|
||||||
Apply(new SyntheticHitObjectEntry(hitObject));
|
Apply(new SyntheticHitObjectEntry(hitObject));
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,7 @@ namespace osu.Game.Rulesets.UI
|
|||||||
{
|
{
|
||||||
public override void Add(T judgement)
|
public override void Add(T judgement)
|
||||||
{
|
{
|
||||||
if (judgement == null) throw new ArgumentNullException(nameof(judgement));
|
ArgumentNullException.ThrowIfNull(judgement);
|
||||||
|
|
||||||
// remove any existing judgements for the judged object.
|
// remove any existing judgements for the judged object.
|
||||||
// this can be the case when rewinding.
|
// this can be the case when rewinding.
|
||||||
|
@ -71,8 +71,8 @@ namespace osu.Game.Scoring
|
|||||||
|
|
||||||
// These properties are known to be non-null, but these final checks ensure a null hasn't come from somewhere (or the refetch has failed).
|
// These properties are known to be non-null, but these final checks ensure a null hasn't come from somewhere (or the refetch has failed).
|
||||||
// Under no circumstance do we want these to be written to realm as null.
|
// Under no circumstance do we want these to be written to realm as null.
|
||||||
if (model.BeatmapInfo == null) throw new ArgumentNullException(nameof(model.BeatmapInfo));
|
ArgumentNullException.ThrowIfNull(model.BeatmapInfo);
|
||||||
if (model.Ruleset == null) throw new ArgumentNullException(nameof(model.Ruleset));
|
ArgumentNullException.ThrowIfNull(model.Ruleset);
|
||||||
|
|
||||||
PopulateMaximumStatistics(model);
|
PopulateMaximumStatistics(model);
|
||||||
|
|
||||||
|
@ -147,7 +147,7 @@ namespace osu.Game.Screens.Menu
|
|||||||
|
|
||||||
private void addAmplitudesFromSource(IHasAmplitudes source)
|
private void addAmplitudesFromSource(IHasAmplitudes source)
|
||||||
{
|
{
|
||||||
if (source == null) throw new ArgumentNullException(nameof(source));
|
ArgumentNullException.ThrowIfNull(source);
|
||||||
|
|
||||||
var amplitudes = source.CurrentAmplitudes.FrequencyAmplitudes.Span;
|
var amplitudes = source.CurrentAmplitudes.FrequencyAmplitudes.Span;
|
||||||
|
|
||||||
|
@ -33,8 +33,7 @@ namespace osu.Game.Screens.Play.HUD
|
|||||||
get => current.Current;
|
get => current.Current;
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value == null)
|
ArgumentNullException.ThrowIfNull(value);
|
||||||
throw new ArgumentNullException(nameof(value));
|
|
||||||
|
|
||||||
current.Current = value;
|
current.Current = value;
|
||||||
}
|
}
|
||||||
|
@ -30,8 +30,7 @@ namespace osu.Game.Screens.Play.HUD
|
|||||||
get => current.Current;
|
get => current.Current;
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
if (value == null)
|
ArgumentNullException.ThrowIfNull(value);
|
||||||
throw new ArgumentNullException(nameof(value));
|
|
||||||
|
|
||||||
current.Current = value;
|
current.Current = value;
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,7 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
public override void Add(KeyCounter key)
|
public override void Add(KeyCounter key)
|
||||||
{
|
{
|
||||||
if (key == null) throw new ArgumentNullException(nameof(key));
|
ArgumentNullException.ThrowIfNull(key);
|
||||||
|
|
||||||
base.Add(key);
|
base.Add(key);
|
||||||
key.IsCounting = IsCounting;
|
key.IsCounting = IsCounting;
|
||||||
|
@ -27,8 +27,7 @@ namespace osu.Game.Users.Drawables
|
|||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(TextureStore ts)
|
private void load(TextureStore ts)
|
||||||
{
|
{
|
||||||
if (ts == null)
|
ArgumentNullException.ThrowIfNull(ts);
|
||||||
throw new ArgumentNullException(nameof(ts));
|
|
||||||
|
|
||||||
string textureName = countryCode == CountryCode.Unknown ? "__" : countryCode.ToString();
|
string textureName = countryCode == CountryCode.Unknown ? "__" : countryCode.ToString();
|
||||||
Texture = ts.Get($@"Flags/{textureName}") ?? ts.Get(@"Flags/__");
|
Texture = ts.Get($@"Flags/{textureName}") ?? ts.Get(@"Flags/__");
|
||||||
|
@ -36,8 +36,7 @@ namespace osu.Game.Users
|
|||||||
protected UserPanel(APIUser user)
|
protected UserPanel(APIUser user)
|
||||||
: base(HoverSampleSet.Button)
|
: base(HoverSampleSet.Button)
|
||||||
{
|
{
|
||||||
if (user == null)
|
ArgumentNullException.ThrowIfNull(user);
|
||||||
throw new ArgumentNullException(nameof(user));
|
|
||||||
|
|
||||||
User = user;
|
User = user;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user