Skip to content

Commit

Permalink
Enable code analysis with latest-Recommended (#1681)
Browse files Browse the repository at this point in the history
  • Loading branch information
lahma authored Nov 12, 2023
1 parent 4bff351 commit 088f08f
Show file tree
Hide file tree
Showing 62 changed files with 248 additions and 229 deletions.
15 changes: 15 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,21 @@ indent_size = 2
# IDE0055: Fix formatting
dotnet_diagnostic.IDE0055.severity = warning

# Error CA1051 : Do not declare visible instance fields
dotnet_diagnostic.CA1051.severity = none

# Error CA1720 : Identifiers should not contain type names
dotnet_diagnostic.CA1720.severity = none

# Error CA1711: Identifiers should not have incorrect suffix
dotnet_diagnostic.CA1711.severity = none

# Error CA1710: Identifiers should have correct suffix
dotnet_diagnostic.CA1710.severity = none

# Error CA1716: Identifiers should have correct suffix
dotnet_diagnostic.CA1716.severity = none

# Sort using and Import directives with System.* appearing first
dotnet_sort_system_directives_first = true
dotnet_separate_import_directive_groups = false
Expand Down
7 changes: 4 additions & 3 deletions Jint.Tests/Runtime/EngineTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
using Esprima.Ast;
using Jint.Native;
using Jint.Native.Array;
using Jint.Native.Number;
using Jint.Native.Object;
using Jint.Runtime;
using Jint.Runtime.Debugger;
Expand Down Expand Up @@ -823,8 +824,8 @@ public void ShouldHandleEscapedSlashesInRegex()
[Fact]
public void ShouldComputeFractionInBase()
{
Assert.Equal("011", _engine.Realm.Intrinsics.Number.PrototypeObject.ToFractionBase(0.375, 2));
Assert.Equal("14141414141414141414141414141414141414141414141414", _engine.Realm.Intrinsics.Number.PrototypeObject.ToFractionBase(0.375, 5));
Assert.Equal("011", NumberPrototype.ToFractionBase(0.375, 2));
Assert.Equal("14141414141414141414141414141414141414141414141414", NumberPrototype.ToFractionBase(0.375, 5));
}

[Fact]
Expand Down Expand Up @@ -910,7 +911,7 @@ public void ShouldNotAllowModifyingSharedUndefinedDescriptor()
[InlineData("2qgpckvng1s", 10000000000000000L, 36)]
public void ShouldConvertNumbersToDifferentBase(string expected, long number, int radix)
{
var result = _engine.Realm.Intrinsics.Number.PrototypeObject.ToBase(number, radix);
var result = NumberPrototype.ToBase(number, radix);
Assert.Equal(expected, result);
}

Expand Down
2 changes: 2 additions & 0 deletions Jint/Constraints/TimeConstraint.cs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,9 @@

namespace Jint.Constraints;

#pragma warning disable CA1001
internal sealed class TimeConstraint : Constraint
#pragma warning restore CA1001
{
private readonly TimeSpan _timeout;
private CancellationTokenSource? _cts;
Expand Down
1 change: 1 addition & 0 deletions Jint/Jint.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
<AnalysisLevel>latest-Recommended</AnalysisLevel>
</PropertyGroup>

<PropertyGroup Condition=" '$(TargetFramework)' == 'net6.0' or '$(TargetFramework)' == 'netstandard2.1' ">
Expand Down
2 changes: 2 additions & 0 deletions Jint/Native/ArrayBuffer/JsArrayBuffer.cs
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,9 @@ private byte[] CreateByteDataBlock(ulong byteLength)
internal byte[]? ArrayBufferData => _arrayBufferData;

internal bool IsDetachedBuffer => _arrayBufferData is null;
#pragma warning disable CA1822
internal bool IsSharedArrayBuffer => false; // TODO SharedArrayBuffer
#pragma warning restore CA1822

/// <summary>
/// https://tc39.es/ecma262/#sec-detacharraybuffer
Expand Down
5 changes: 3 additions & 2 deletions Jint/Native/BigInt/BigIntPrototype.cs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
using System.Globalization;
using System.Numerics;
using Jint.Collections;
using Jint.Native.Object;
Expand Down Expand Up @@ -55,7 +56,7 @@ private JsValue ToLocaleString(JsValue thisObject, JsValue[] arguments)
var x = ThisBigIntValue(thisObject);
//var numberFormat = (NumberFormat) Construct(_realm.Intrinsics.NumberFormat, new[] { locales, options });
// numberFormat.FormatNumeric(x);
return x._value.ToString("R");
return x._value.ToString("R", CultureInfo.InvariantCulture);
}

/// <summary>
Expand Down Expand Up @@ -103,7 +104,7 @@ private JsValue ToBigIntString(JsValue thisObject, JsValue[] arguments)

if (radixMV == 10)
{
return value.ToString("R");
return value.ToString("R", CultureInfo.InvariantCulture);
}

var negative = value < 0;
Expand Down
19 changes: 10 additions & 9 deletions Jint/Native/Date/DatePrototype.cs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
using System.Globalization;
using System.Runtime.CompilerServices;
using Jint.Collections;
using Jint.Native.Object;
Expand Down Expand Up @@ -775,9 +776,9 @@ private JsValue ToUtcString(JsValue thisObject, JsValue[] arguments)

var weekday = _dayNames[WeekDay(tv)];
var month = _monthNames[MonthFromTime(tv)];
var day = DateFromTime(tv).ToString("00");
var day = DateFromTime(tv).ToString("00", CultureInfo.InvariantCulture);
var yv = YearFromTime(tv);
var paddedYear = yv.ToString("0000");
var paddedYear = yv.ToString("0000", CultureInfo.InvariantCulture);

return $"{weekday}, {day} {month} {paddedYear} {TimeString(tv)}";
}
Expand Down Expand Up @@ -1355,11 +1356,11 @@ private static string DateString(DatePresentation tv)
var month = _monthNames[MonthFromTime(tv)];

var dateFromTime = DateFromTime(tv);
var day = System.Math.Max(1, dateFromTime).ToString("00");
var day = System.Math.Max(1, dateFromTime).ToString("00", CultureInfo.InvariantCulture);
var yv = YearFromTime(tv);
var yearSign = yv < 0 ? "-" : "";
var year = System.Math.Abs(yv);
var paddedYear = year.ToString("0000");
var paddedYear = year.ToString("0000", CultureInfo.InvariantCulture);

return weekday + " " + month + " " + day + " " + yearSign + paddedYear;
}
Expand All @@ -1369,9 +1370,9 @@ private static string DateString(DatePresentation tv)
/// </summary>
private static string TimeString(DatePresentation t)
{
var hour = HourFromTime(t).ToString("00");
var minute = MinFromTime(t).ToString("00");
var second = SecFromTime(t).ToString("00");
var hour = HourFromTime(t).ToString("00", CultureInfo.InvariantCulture);
var minute = MinFromTime(t).ToString("00", CultureInfo.InvariantCulture);
var second = SecFromTime(t).ToString("00", CultureInfo.InvariantCulture);

return hour + ":" + minute + ":" + second + " GMT";
}
Expand All @@ -1396,8 +1397,8 @@ private string TimeZoneString(DatePresentation tv)
absOffset = -1 * offset;
}

var offsetMin = MinFromTime(absOffset).ToString("00");
var offsetHour = HourFromTime(absOffset).ToString("00");
var offsetMin = MinFromTime(absOffset).ToString("00", CultureInfo.InvariantCulture);
var offsetHour = HourFromTime(absOffset).ToString("00", CultureInfo.InvariantCulture);

var tzName = " (" + _timeSystem.DefaultTimeZone.StandardName + ")";

Expand Down
8 changes: 7 additions & 1 deletion Jint/Native/Date/MimeKit.cs
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,7 @@ static DateUtils()
any[1] = (char) c;
}

#pragma warning disable CA2249
if (NumericZoneCharacters.IndexOf((char) c) == -1)
datetok[c] |= DateTokenFlags.NonNumericZone;
if (AlphaZoneCharacters.IndexOf((char) c) == -1)
Expand All @@ -192,6 +193,7 @@ static DateUtils()
datetok[c] |= DateTokenFlags.NonMonth;
if (TimeCharacters.IndexOf((char) c) == -1)
datetok[c] |= DateTokenFlags.NonTime;
#pragma warning restore CA2249
}

datetok[':'] |= DateTokenFlags.HasColon;
Expand Down Expand Up @@ -518,7 +520,9 @@ private static bool TryParseUnknownDateFormat(IList<DateToken> tokens, byte[] te
int endIndex = tokens[i].Start + tokens[i].Length;
int index = tokens[i].Start;

#pragma warning disable CA1806
ParseUtils.TryParseInt32(text, ref index, endIndex, out value);
#pragma warning restore CA1806

if (month == null && value > 0 && value <= 12)
{
Expand Down Expand Up @@ -727,7 +731,9 @@ public static bool SkipCommentsAndWhiteSpace(byte[] text, ref int index, int end
if (!SkipComment(text, ref index, endIndex))
{
if (throwOnError)
throw new Exception($"Incomplete comment token at offset {startIndex}");
{
throw new ArgumentException($"Incomplete comment token at offset {startIndex}");
}

return false;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ public FinalizationRegistryInstance(Engine engine, Realm realm, ICallable cleanu
_callable = engine._host.MakeJobCallBack(cleanupCallback);
}

public void CleanupFinalizationRegistry(ICallable? callback)
public static void CleanupFinalizationRegistry(ICallable? callback)
{
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ private JsValue CleanupSome(JsValue thisObject, JsValue[] arguments)
ExceptionHelper.ThrowTypeError(_realm, callback + " must be callable");
}

finalizationRegistry.CleanupFinalizationRegistry(callback as ICallable);
FinalizationRegistryInstance.CleanupFinalizationRegistry(callback as ICallable);

return Undefined;
}
Expand Down
2 changes: 1 addition & 1 deletion Jint/Native/Function/ClassDefinition.cs
Original file line number Diff line number Diff line change
Expand Up @@ -276,7 +276,7 @@ private static ClassFieldDefinition ClassFieldDefinitionEvaluation(Engine engine

private sealed class ClassFieldFunction : Node, IFunction
{
private readonly NodeList<Node> _nodeList = new();
private readonly NodeList<Node> _nodeList;
private readonly BlockStatement _statement;

public ClassFieldFunction(Expression expression) : base(Nodes.ExpressionStatement)
Expand Down
4 changes: 2 additions & 2 deletions Jint/Native/Function/ScriptFunctionInstance.cs
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ internal ScriptFunctionInstance(
/// <summary>
/// https://tc39.es/ecma262/#sec-ecmascript-function-objects-call-thisargument-argumentslist
/// </summary>
protected internal override JsValue Call(JsValue thisArgument, JsValue[] arguments)
protected internal override JsValue Call(JsValue thisObject, JsValue[] arguments)
{
var strict = _functionDefinition.Strict || _thisMode == FunctionThisMode.Strict;
using (new StrictModeScope(strict, true))
Expand All @@ -71,7 +71,7 @@ protected internal override JsValue Call(JsValue thisArgument, JsValue[] argumen
ExceptionHelper.ThrowTypeError(calleeContext.Realm, $"Class constructor {_functionDefinition.Name} cannot be invoked without 'new'");
}

OrdinaryCallBindThis(calleeContext, thisArgument);
OrdinaryCallBindThis(calleeContext, thisObject);

// actual call
var context = _engine._activeEvaluationContext ?? new EvaluationContext(_engine);
Expand Down
30 changes: 15 additions & 15 deletions Jint/Native/Global/GlobalObject.cs
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,7 @@ public static JsValue ParseFloat(JsValue thisObject, JsValue[] arguments)
if (trimmedString[0] == '-')
{
i++;
if (trimmedString.Length > 1 && trimmedString[1] == 'I' && trimmedString.StartsWith("-Infinity"))
if (trimmedString.Length > 1 && trimmedString[1] == 'I' && trimmedString.StartsWith("-Infinity", StringComparison.Ordinal))
{
return JsNumber.DoubleNegativeInfinity;
}
Expand All @@ -147,18 +147,18 @@ public static JsValue ParseFloat(JsValue thisObject, JsValue[] arguments)
if (trimmedString[0] == '+')
{
i++;
if (trimmedString.Length > 1 && trimmedString[1] == 'I' && trimmedString.StartsWith("+Infinity"))
if (trimmedString.Length > 1 && trimmedString[1] == 'I' && trimmedString.StartsWith("+Infinity", StringComparison.Ordinal))
{
return JsNumber.DoublePositiveInfinity;
}
}

if (trimmedString.StartsWith("Infinity"))
if (trimmedString.StartsWith("Infinity", StringComparison.Ordinal))
{
return JsNumber.DoublePositiveInfinity;
}

if (trimmedString.StartsWith("NaN"))
if (trimmedString.StartsWith("NaN", StringComparison.Ordinal))
{
return JsNumber.DoubleNaN;
}
Expand Down Expand Up @@ -462,7 +462,9 @@ private JsValue Decode(string uriString, string? reservedSet)
if ((B & 0x80) == 0)
{
C = (char)B;
#pragma warning disable CA2249
if (reservedSet == null || reservedSet.IndexOf(C) == -1)
#pragma warning restore CA2249
{
_stringBuilder.Append(C);
}
Expand Down Expand Up @@ -590,7 +592,7 @@ private static bool IsDigit(char c, int radix, out int result)
/// </summary>
public JsValue Escape(JsValue thisObject, JsValue[] arguments)
{
const string whiteList = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789@*_ + -./";
const string WhiteList = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789@*_ + -./";
var uriString = TypeConverter.ToString(arguments.At(0));

var strLen = uriString.Length;
Expand All @@ -601,17 +603,17 @@ public JsValue Escape(JsValue thisObject, JsValue[] arguments)
for (var k = 0; k < strLen; k++)
{
var c = uriString[k];
if (whiteList.IndexOf(c) != -1)
if (WhiteList.IndexOf(c) != -1)
{
_stringBuilder.Append(c);
}
else if (c < 256)
{
_stringBuilder.Append($"%{((int) c):X2}");
_stringBuilder.Append('%').AppendFormat(CultureInfo.InvariantCulture, "{0:X2}", (int) c);
}
else
{
_stringBuilder.Append($"%u{((int) c):X4}");
_stringBuilder.Append("%u").AppendFormat(CultureInfo.InvariantCulture, "{0:X4}", (int) c);
}
}

Expand Down Expand Up @@ -639,18 +641,16 @@ public JsValue Unescape(JsValue thisObject, JsValue[] arguments)
&& uriString[k + 1] == 'u'
&& uriString.Skip(k + 2).Take(4).All(IsValidHexaChar))
{
c = (char)int.Parse(
string.Join(string.Empty, uriString.Skip(k + 2).Take(4)),
NumberStyles.AllowHexSpecifier);
var joined = string.Join(string.Empty, uriString.Skip(k + 2).Take(4));
c = (char) int.Parse(joined, NumberStyles.AllowHexSpecifier, CultureInfo.InvariantCulture);

k += 5;
}
else if (k <= strLen - 3
&& uriString.Skip(k + 1).Take(2).All(IsValidHexaChar))
&& uriString.Skip(k + 1).Take(2).All(IsValidHexaChar))
{
c = (char)int.Parse(
string.Join(string.Empty, uriString.Skip(k + 1).Take(2)),
NumberStyles.AllowHexSpecifier);
var joined = string.Join(string.Empty, uriString.Skip(k + 1).Take(2));
c = (char) int.Parse(joined, NumberStyles.AllowHexSpecifier, CultureInfo.InvariantCulture);

k += 2;
}
Expand Down
2 changes: 1 addition & 1 deletion Jint/Native/Intl/DateTimeFormatConstructor.cs
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ public override ObjectInstance Construct(JsValue[] arguments, JsValue newTarget)
/// <summary>
/// https://tc39.es/ecma402/#sec-initializedatetimeformat
/// </summary>
private void InitializeDateTimeFormat(JsObject dateTimeFormat, JsValue locales, JsValue options)
private static void InitializeDateTimeFormat(JsObject dateTimeFormat, JsValue locales, JsValue options)
{
// TODO
}
Expand Down
6 changes: 3 additions & 3 deletions Jint/Native/Intl/NumberFormatConstructor.cs
Original file line number Diff line number Diff line change
Expand Up @@ -201,16 +201,16 @@ private void SetNumberFormatUnitOptions(JsObject intlObj, JsValue options)
/// <summary>
/// https://tc39.es/ecma402/#sec-iswellformedunitidentifier
/// </summary>
private bool IsWellFormedUnitIdentifier(JsValue unitIdentifier)
private static bool IsWellFormedUnitIdentifier(JsValue unitIdentifier)
{
var value = unitIdentifier.ToString();
if (IsSanctionedSingleUnitIdentifier(value))
{
return true;
}

var i = value.IndexOf("-per-");
if (i == -1 || value.IndexOf("-per-", i + 1) != -1)
var i = value.IndexOf("-per-", StringComparison.Ordinal);
if (i == -1 || value.IndexOf("-per-", i + 1, StringComparison.Ordinal) != -1)
{
return false;
}
Expand Down
2 changes: 1 addition & 1 deletion Jint/Native/Intl/PluralRulesConstructor.cs
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ public override ObjectInstance Construct(JsValue[] arguments, JsValue newTarget)
/// <summary>
/// https://tc39.es/ecma402/#sec-initializepluralrules
/// </summary>
private void InitializePluralRules(JsObject pluralRules, JsValue locales, JsValue options)
private static void InitializePluralRules(JsObject pluralRules, JsValue locales, JsValue options)
{
// TODO
}
Expand Down
2 changes: 1 addition & 1 deletion Jint/Native/Intl/RelativeTimeFormatConstructor.cs
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ public override ObjectInstance Construct(JsValue[] arguments, JsValue newTarget)
/// <summary>
/// https://tc39.es/ecma402/#sec-InitializeRelativeTimeFormat
/// </summary>
private void InitializeRelativeTimeFormat(JsObject relativeTimeFormat, JsValue locales, JsValue options)
private static void InitializeRelativeTimeFormat(JsObject relativeTimeFormat, JsValue locales, JsValue options)
{
// TODO
}
Expand Down
Loading

0 comments on commit 088f08f

Please sign in to comment.