refactor: Add more stricter lints

This commit is contained in:
Christian Kußowski 2026-02-20 14:03:46 +01:00
parent c59031c44c
commit 5283d0fcc8
No known key found for this signature in database
GPG key ID: E067ECD60F1A0652
15 changed files with 66 additions and 60 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,14 @@ 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
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

@ -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

@ -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

@ -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

@ -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: