diff --git a/src/Package.props b/src/Package.props index f93943b..4580111 100644 --- a/src/Package.props +++ b/src/Package.props @@ -7,6 +7,11 @@ MIT true https://github.com/irihitech/Ursa.Avalonia + + + IDE0130;IDE00056;IDE0306;IDE0305;IDE0300;IDE0290;IDE0251;IDE0090;IDE0079;IDE0066;IDE0062;IDE0060;IDE0057;IDE0056;IDE0044;IDE0042;IDE0039;IDE0031;IDE0028;IDE0017; + CA2208;CA1866;CA1861;CA1859;CA1847;CA1845;CA1822;CA1041; + diff --git a/src/Ursa/Controls/ElasticWrapPanel.cs b/src/Ursa/Controls/ElasticWrapPanel.cs index 6fb71b6..346e875 100644 --- a/src/Ursa/Controls/ElasticWrapPanel.cs +++ b/src/Ursa/Controls/ElasticWrapPanel.cs @@ -319,9 +319,19 @@ public class ElasticWrapPanel : WrapPanel { if (itemSetSize.U > 0) { - int maxElementCount = lineUVCollection - .Max(uiSet => uiSet.UICollection - .Sum(p => p.Value.ULengthCount)); + // 用 foreach 替换嵌套 LINQ,彻底避免类型推断和绑定压力 + // 修复 C29236 编译时需要绑定 lambda 表达式至少 100 次。请考虑使用显式参数类型声明 lambda 表达式,如果包含的方法调用是泛型的,请考虑使用显式类型参数。 + int maxElementCount = 0; + foreach (var uiSet in lineUVCollection) + { + int sum = 0; + foreach (var p in uiSet.UICollection) + { + sum += p.Value.ULengthCount; + } + if (sum > maxElementCount) + maxElementCount = sum; + } adaptULength = (uvFinalSize.U - maxElementCount * itemSetSize.U) / maxElementCount; adaptULength = Max(adaptULength, 0); } diff --git a/src/Ursa/Controls/Panels/WrapPanelWithTrailingItem.cs b/src/Ursa/Controls/Panels/WrapPanelWithTrailingItem.cs index f26d193..7b551d1 100644 --- a/src/Ursa/Controls/Panels/WrapPanelWithTrailingItem.cs +++ b/src/Ursa/Controls/Panels/WrapPanelWithTrailingItem.cs @@ -53,7 +53,7 @@ public class WrapPanelWithTrailingItem : Panel } } - WrapPanel p = new WrapPanel(); + // WrapPanel p = new WrapPanel(); } protected override Size MeasureOverride(Size availableSize) diff --git a/src/Ursa/Controls/SelectionList/SelectionList.cs b/src/Ursa/Controls/SelectionList/SelectionList.cs index 045421c..b0d4e63 100644 --- a/src/Ursa/Controls/SelectionList/SelectionList.cs +++ b/src/Ursa/Controls/SelectionList/SelectionList.cs @@ -159,7 +159,7 @@ public class SelectionList : SelectingItemsControl protected override void OnKeyDown(KeyEventArgs e) { - var hotkeys = Application.Current!.PlatformSettings?.HotkeyConfiguration; + // var hotkeys = Application.Current!.PlatformSettings?.HotkeyConfiguration; if (e.Key.ToNavigationDirection() is { } direction && direction.IsDirectional()) e.Handled |= MoveSelection(direction, WrapSelection);