Merge pull request #2597 from krille-chan/krille/stricter-linting-rules

refactor: Add more stricter lints
This commit is contained in:
Krille-chan 2026-02-20 14:40:38 +01:00 committed by GitHub
commit 84993dec59
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
27 changed files with 85 additions and 92 deletions

View file

@ -2,7 +2,6 @@ include: package:flutter_lints/flutter.yaml
linter:
rules:
- camel_case_types
- avoid_print
- constant_identifier_names
- prefer_final_locals
@ -10,6 +9,16 @@ linter:
- sort_pub_dependencies
- require_trailing_commas
- omit_local_variable_types
- cancel_subscriptions
- always_declare_return_types
- no_adjacent_strings_in_list
- test_types_in_equals
- throw_in_finally
- unnecessary_statements
- avoid_bool_literals_in_conditional_expressions
- prefer_single_quotes
- prefer_const_declarations
- unnecessary_lambdas
analyzer:
plugins:

View file

@ -1,5 +1,5 @@
// ignore: constant_identifier_names
const String ISRG_X1 = """-----BEGIN CERTIFICATE-----
const String ISRG_X1 = '''-----BEGIN CERTIFICATE-----
MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw
TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh
cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4
@ -29,4 +29,4 @@ oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq
4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA
mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d
emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc=
-----END CERTIFICATE-----""";
-----END CERTIFICATE-----''';

View file

@ -155,8 +155,7 @@ class ChatEventList extends StatelessWidget {
highlightMarker:
controller.scrollToEventIdMarker == event.eventId,
onSelect: controller.onSelectMessage,
scrollToEventId: (String eventId) =>
controller.scrollToEventId(eventId),
scrollToEventId: controller.scrollToEventId,
longPressSelect: controller.selectedEvents.isNotEmpty,
selected: controller.selectedEvents.any(
(e) => e.eventId == event.eventId,
@ -164,7 +163,7 @@ class ChatEventList extends StatelessWidget {
singleSelected:
controller.selectedEvents.singleOrNull?.eventId ==
event.eventId,
onEdit: () => controller.editSelectedEventAction(),
onEdit: controller.editSelectedEventAction,
timeline: timeline,
displayReadMarker:
i > 0 && controller.readMarkerEventId == event.eventId,

View file

@ -26,41 +26,41 @@ String commandExample(String command) {
String commandHint(L10n l10n, String command) {
switch (command) {
case "ban":
case 'ban':
return l10n.commandHint_ban;
case "clearcache":
case 'clearcache':
return l10n.commandHint_clearcache;
case "create":
case 'create':
return l10n.commandHint_create;
case "discardsession":
case 'discardsession':
return l10n.commandHint_discardsession;
case "dm":
case 'dm':
return l10n.commandHint_dm;
case "html":
case 'html':
return l10n.commandHint_html;
case "invite":
case 'invite':
return l10n.commandHint_invite;
case "join":
case 'join':
return l10n.commandHint_join;
case "kick":
case 'kick':
return l10n.commandHint_kick;
case "leave":
case 'leave':
return l10n.commandHint_leave;
case "me":
case 'me':
return l10n.commandHint_me;
case "myroomavatar":
case 'myroomavatar':
return l10n.commandHint_myroomavatar;
case "myroomnick":
case 'myroomnick':
return l10n.commandHint_myroomnick;
case "op":
case 'op':
return l10n.commandHint_op;
case "plain":
case 'plain':
return l10n.commandHint_plain;
case "react":
case 'react':
return l10n.commandHint_react;
case "send":
case 'send':
return l10n.commandHint_send;
case "unban":
case 'unban':
return l10n.commandHint_unban;
case 'markasdm':
return l10n.commandHint_markasdm;
@ -85,6 +85,6 @@ String commandHint(L10n l10n, String command) {
case 'logoutall':
return l10n.commandHint_logoutall;
default:
return "";
return '';
}
}

View file

@ -253,9 +253,8 @@ class HtmlMessage extends StatelessWidget {
: checkboxCheckedEvents?.firstWhereOrNull(
(event) => event.checkedCheckboxId == checkboxIndex,
);
final staticallyChecked = !isCheckbox
? false
: node.children.first.attributes['checked'] == 'true';
final staticallyChecked =
isCheckbox && node.children.first.attributes['checked'] == 'true';
return WidgetSpan(
child: Padding(

View file

@ -207,7 +207,7 @@ class MessageContent extends StatelessWidget {
.split(';')
.first
.split(',')
.map((s) => double.tryParse(s))
.map(double.tryParse)
.toList();
if (latlong.length == 2 &&
latlong.first != null &&

View file

@ -66,7 +66,7 @@ class MessageReactions extends StatelessWidget {
if (evt != null) {
showFutureLoadingDialog(
context: context,
future: () => evt.redactEvent(),
future: evt.redactEvent,
);
}
} else {

View file

@ -25,7 +25,7 @@ class PollWidget extends StatelessWidget {
});
void _endPoll(BuildContext context) =>
showFutureLoadingDialog(context: context, future: () => event.endPoll());
showFutureLoadingDialog(context: context, future: event.endPoll);
void _toggleVote(BuildContext context, String answerId, int maxSelection) {
final userId = event.room.client.userID!;

View file

@ -145,9 +145,7 @@ class RecordingViewModelState extends State<RecordingViewModel> {
}
void cancel() {
setState(() {
_reset();
});
setState(_reset);
}
void pause() {

View file

@ -181,9 +181,7 @@ class ChatAccessSettingsPageView extends StatelessWidget {
return const SizedBox.shrink();
}
localAddresses.remove(room.canonicalAlias);
localAddresses.removeWhere(
(alias) => altAliases.contains(alias),
);
localAddresses.removeWhere(altAliases.contains);
return Column(
mainAxisSize: .min,
children: localAddresses

View file

@ -35,7 +35,7 @@ class ChatListViewBody extends StatelessWidget {
key: ValueKey(activeSpace),
spaceId: activeSpace,
onBack: controller.clearActiveSpace,
onChatTab: (room) => controller.onChatTap(room),
onChatTab: controller.onChatTap,
activeChat: controller.activeChat,
);
}
@ -123,7 +123,7 @@ class ChatListViewBody extends StatelessWidget {
if (!controller.isSearchMode &&
AppSettings.showPresences.value)
GestureDetector(
onLongPress: () => controller.dismissStatusList(),
onLongPress: controller.dismissStatusList,
child: StatusMessageList(
onStatusEdit: controller.setStatus,
),

View file

@ -56,9 +56,9 @@ class ChatListItem extends StatelessWidget {
return const SizedBox.shrink();
}
final needLastEventSender = lastEvent == null
? false
: room.getState(EventTypes.RoomMember, lastEvent.senderId) == null;
final needLastEventSender =
lastEvent != null &&
room.getState(EventTypes.RoomMember, lastEvent.senderId) == null;
final space = this.space;
return Padding(

View file

@ -55,9 +55,9 @@ class ChatSearchFilesTab extends StatelessWidget {
'UNKNOWN');
final sizeString = event.sizeString;
final prevEvent = i > 0 ? events[i - 1] : null;
final sameEnvironment = prevEvent == null
? false
: prevEvent.originServerTs.sameEnvironment(event.originServerTs);
final sameEnvironment =
prevEvent != null &&
prevEvent.originServerTs.sameEnvironment(event.originServerTs);
return Padding(
padding: const EdgeInsets.all(8.0),
child: Column(

View file

@ -194,9 +194,7 @@ class MyCallingPage extends State<Calling> {
call.onCallStateChanged.stream.listen(_handleCallState);
call.onCallEventChanged.stream.listen((event) {
if (event == CallStateChange.kFeedsChanged) {
setState(() {
call.tryRemoveStopedStreams();
});
setState(call.tryRemoveStopedStreams);
} else if (event == CallStateChange.kLocalHoldUnhold ||
event == CallStateChange.kRemoteHoldUnhold) {
setState(() {});

View file

@ -207,7 +207,7 @@ class LoginController extends State<Login> {
final data = <String, dynamic>{
'new_password': password,
'logout_devices': false,
"auth": AuthenticationThreePidCreds(
'auth': AuthenticationThreePidCreds(
type: AuthenticationTypes.emailIdentity,
threepidCreds: ThreepidCreds(
sid: response.result!.sid,

View file

@ -234,9 +234,9 @@ class EmotesSettingsController extends State<EmotesSettings> {
?.tryGetMap<String, Object?>(stateKey ?? '') !=
null;
bool get readonly => room == null
? false
: room?.canChangeStateEvent('im.ponies.room_emotes') == false;
bool get readonly =>
room != null &&
room?.canChangeStateEvent('im.ponies.room_emotes') == false;
void resetAction() {
setState(() {

View file

@ -117,6 +117,6 @@ extension PushRuleKindLocal on PushRuleKind {
extension on String {
String capitalize() {
return "${this[0].toUpperCase()}${substring(1).toLowerCase()}";
return '${this[0].toUpperCase()}${substring(1).toLowerCase()}';
}
}

View file

@ -32,7 +32,7 @@ Future<void> ssoLoginFlow(
final urlScheme =
(PlatformInfos.isMobile || PlatformInfos.isWeb || PlatformInfos.isMacOS)
? Uri.parse(redirectUrl).scheme
: "http://localhost:3001";
: 'http://localhost:3001';
final result = await FlutterWebAuth2.authenticate(
url: url.toString(),
callbackUrlScheme: urlScheme,

View file

@ -231,7 +231,7 @@ class BackgroundPush {
currentPushers.first.data.format ==
AppSettings.pushNotificationsPusherFormat.value &&
mapEquals(currentPushers.single.data.additionalProperties, {
"data_message": pusherDataMessageFormat,
'data_message': pusherDataMessageFormat,
})) {
Logs().i('[Push] Pusher already set');
} else {
@ -269,7 +269,7 @@ class BackgroundPush {
data: PusherData(
url: Uri.parse(gatewayUrl!),
format: AppSettings.pushNotificationsPusherFormat.value,
additionalProperties: {"data_message": pusherDataMessageFormat},
additionalProperties: {'data_message': pusherDataMessageFormat},
),
kind: 'http',
),
@ -290,7 +290,7 @@ class BackgroundPush {
static bool _wentToRoomOnStartup = false;
Future<void> setupPush() async {
Logs().d("SetupPush");
Logs().d('SetupPush');
if (client.onLoginStateChanged.value != LoginState.loggedIn ||
!PlatformInfos.isMobile ||
matrix == null) {
@ -371,7 +371,7 @@ class BackgroundPush {
Future<void> setupUp() async {
await UnifiedPushUi(
context: matrix!.context,
instances: ["default"],
instances: ['default'],
unifiedPushFunctions: UPFunctions(),
showNoDistribDialog: false,
onNoDistribDialogDismissed: () {}, // TODO: Implement me

View file

@ -15,11 +15,11 @@ class ErrorReporter {
const ErrorReporter(this.context, [this.message]);
static const Set<String> ingoredTypes = {
"IOException",
"ClientException",
"SocketException",
"TlsException",
"HandshakeException",
'IOException',
'ClientException',
'SocketException',
'TlsException',
'HandshakeException',
};
void onErrorCallback(Object error, [StackTrace? stackTrace]) {

View file

@ -4,10 +4,10 @@ import 'package:matrix/matrix.dart';
IconData _getIconFromName(String displayname) {
final name = displayname.toLowerCase();
if ({'android'}.any((s) => name.contains(s))) {
if ({'android'}.any(name.contains)) {
return Icons.phone_android_outlined;
}
if ({'ios', 'ipad', 'iphone', 'ipod'}.any((s) => name.contains(s))) {
if ({'ios', 'ipad', 'iphone', 'ipod'}.any(name.contains)) {
return Icons.phone_iphone_outlined;
}
if ({
@ -19,16 +19,10 @@ IconData _getIconFromName(String displayname) {
'/_matrix',
'safari',
'opera',
}.any((s) => name.contains(s))) {
}.any(name.contains)) {
return Icons.web_outlined;
}
if ({
'desktop',
'windows',
'macos',
'linux',
'ubuntu',
}.any((s) => name.contains(s))) {
if ({'desktop', 'windows', 'macos', 'linux', 'ubuntu'}.any(name.contains)) {
return Icons.desktop_mac_outlined;
}
return Icons.device_unknown_outlined;

View file

@ -35,7 +35,7 @@ extension StreamExtension on Stream {
};
final subscription = listen(
(_) => onMessage?.call(),
onDone: () => controller.close(),
onDone: controller.close,
onError: (e, s) => controller.addError(e, s),
);
// add proper cleanup to the subscription and the controller, to not memory leak

View file

@ -105,9 +105,7 @@ extension UiaRequestManager on MatrixState {
launchUrl(url, mode: LaunchMode.inAppBrowserView);
final completer = Completer();
final listener = AppLifecycleListener(
onResume: () => completer.complete(),
);
final listener = AppLifecycleListener(onResume: completer.complete);
await completer.future;
listener.dispose();

View file

@ -66,7 +66,7 @@ class UrlLauncher {
.split(';')
.first
.split(',')
.map((s) => double.tryParse(s))
.map(double.tryParse)
.toList();
if (latlong.length == 2 &&
latlong.first != null &&

View file

@ -141,7 +141,7 @@ class VoipPlugin with WidgetsBindingObserver implements WebRTCDelegate {
FlutterForegroundTask.setOnLockScreenVisibility(false);
FlutterForegroundTask.stopService();
final wasForeground = matrix.store.getString('wasForeground');
wasForeground == 'false' ? FlutterForegroundTask.minimizeApp() : null;
if (wasForeground == 'false') FlutterForegroundTask.minimizeApp();
}
}
}

View file

@ -135,7 +135,7 @@ extension LocalNotificationsExtension on MatrixState {
var action = DesktopNotificationActions.values.singleWhereOrNull(
(a) => a.name == actionStr,
);
if (action == null && actionStr == "default") {
if (action == null && actionStr == 'default') {
action = DesktopNotificationActions.openChat;
}
switch (action!) {

View file

@ -165,10 +165,10 @@ packages:
dependency: transitive
description:
name: characters
sha256: faf38497bda5ead2a8c7615f4f7939df04333478bf32e4173fcb06d428b5716b
sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803
url: "https://pub.dev"
source: hosted
version: "1.4.1"
version: "1.4.0"
charcode:
dependency: transitive
description:
@ -1112,18 +1112,18 @@ packages:
dependency: transitive
description:
name: matcher
sha256: "12956d0ad8390bbcc63ca2e1469c0619946ccb52809807067a7020d57e647aa6"
sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2
url: "https://pub.dev"
source: hosted
version: "0.12.18"
version: "0.12.17"
material_color_utilities:
dependency: transitive
description:
name: material_color_utilities
sha256: "9c337007e82b1889149c82ed242ed1cb24a66044e30979c44912381e9be4c48b"
sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec
url: "https://pub.dev"
source: hosted
version: "0.13.0"
version: "0.11.1"
matrix:
dependency: "direct main"
description:
@ -1869,26 +1869,26 @@ packages:
dependency: transitive
description:
name: test
sha256: "54c516bbb7cee2754d327ad4fca637f78abfc3cbcc5ace83b3eda117e42cd71a"
sha256: "75906bf273541b676716d1ca7627a17e4c4070a3a16272b7a3dc7da3b9f3f6b7"
url: "https://pub.dev"
source: hosted
version: "1.29.0"
version: "1.26.3"
test_api:
dependency: transitive
description:
name: test_api
sha256: "93167629bfc610f71560ab9312acdda4959de4df6fac7492c89ff0d3886f6636"
sha256: ab2726c1a94d3176a45960b6234466ec367179b87dd74f1611adb1f3b5fb9d55
url: "https://pub.dev"
source: hosted
version: "0.7.9"
version: "0.7.7"
test_core:
dependency: transitive
description:
name: test_core
sha256: "394f07d21f0f2255ec9e3989f21e54d3c7dc0e6e9dbce160e5a9c1a6be0e2943"
sha256: "0cc24b5ff94b38d2ae73e1eb43cc302b77964fbf67abad1e296025b78deb53d0"
url: "https://pub.dev"
source: hosted
version: "0.6.15"
version: "0.6.12"
timezone:
dependency: transitive
description: