diff --git a/.github/dependabot.yaml b/.github/dependabot.yaml index 36ce6698414..9eb25702544 100644 --- a/.github/dependabot.yaml +++ b/.github/dependabot.yaml @@ -154,12 +154,6 @@ updates: interval: "daily" labels: - "autosubmit" - - package-ecosystem: "pub" - directory: "experimental/linting_tool/" - schedule: - interval: "daily" - labels: - - "autosubmit" - package-ecosystem: "pub" directory: "experimental/material_3_demo/" schedule: diff --git a/experimental/linting_tool/.gitignore b/experimental/linting_tool/.gitignore deleted file mode 100644 index a1345d017cf..00000000000 --- a/experimental/linting_tool/.gitignore +++ /dev/null @@ -1,45 +0,0 @@ -# Miscellaneous -*.class -*.log -*.pyc -*.swp -.DS_Store -.atom/ -.buildlog/ -.history -.svn/ - -# IntelliJ related -*.iml -*.ipr -*.iws -.idea/ - -# The .vscode folder contains launch configuration and tasks you configure in -# VS Code which you may wish to be included in version control, so this line -# is commented out by default. -#.vscode/ - -# Flutter/Dart/Pub related -**/doc/api/ -**/ios/Flutter/.last_build_id -.dart_tool/ -.flutter-plugins -.flutter-plugins-dependencies -.packages -.pub-cache/ -.pub/ -/build/ - -# Web related - -# Symbolication related -app.*.symbols - -# Obfuscation related -app.*.map.json - -# Android Studio will place build artifacts here -/android/app/debug -/android/app/profile -/android/app/release diff --git a/experimental/linting_tool/.metadata b/experimental/linting_tool/.metadata deleted file mode 100644 index ec98142da0b..00000000000 --- a/experimental/linting_tool/.metadata +++ /dev/null @@ -1,10 +0,0 @@ -# This file tracks properties of this Flutter project. -# Used by Flutter tool to assess capabilities and perform upgrades etc. -# -# This file should be version controlled and should not be manually edited. - -version: - revision: d79295af24c3ed621c33713ecda14ad196fd9c31 - channel: stable - -project_type: app diff --git a/experimental/linting_tool/README.md b/experimental/linting_tool/README.md index 0d1d8704528..38706e9949a 100644 --- a/experimental/linting_tool/README.md +++ b/experimental/linting_tool/README.md @@ -1,21 +1,34 @@ -# linting_tool +# Sample retired -A desktop tool that helps you manage [linter rules](https://dart.dev/guides/language/analysis-options#enabling-linter-rules) -for your Flutter project. +The `linting_tool` sample has been retired. +Flutter's desktop support has evolved over the years and +the underlying data that this tool surfaced is no longer supported. -## Goals for this sample +`linting_tool` was a successful sample of using Flutter to build desktop apps, +written by Abdullah Deshmukh ([X][], [GitHub][]) for Google Summer of Code 2021. +You can learn about Abdullah's experience creating the sample +by reading [GSoC '21: Creating a desktop sample for Flutter][medium]. -* Show how to read and write files on Desktop -* Show how to create, parse and use yaml files -* Show how to implement basic navigation in Desktop apps -* Show how to implement right-click popup menus +[X]: https://x.com/abdullahzakir99 +[GitHub]: https://github.com/abd99 +[medium]: https://medium.com/flutter/gsoc-21-creating-a-desktop-sample-for-flutter-7d77e74812d6 -## Questions/issues +## Flutter on Desktop -If you have a general question about Flutter, the best places to go are: +Flutter supports creating desktop apps for Windows, macOS, and Linux. +To set up platform support or learn more about [Flutter on Desktop][], +check out the [platform integration docs][] for each desktop platform. -* [The FlutterDev Google Group](https://groups.google.com/forum/#!forum/flutter-dev) -* [The Flutter Gitter channel](https://gitter.im/flutter/flutter) -* [StackOverflow](https://stackoverflow.com/questions/tagged/flutter) +[Flutter on Desktop]: https://flutter.dev/multi-platform/desktop +[platform integration docs]: https://docs.flutter.dev/platform-integration/desktop -If you run into an issue with the sample itself, please [file an issue](https://github.com/flutter/samples/issues). +## Analyzing and linting Dart projects + +To learn more about configuring analysis of your Dart and Flutter projects, +check out [Customizing static analysis][]. + +For information about the various lints you can configure, +reference the [Linter rules][] index. + +[Customizing static analysis]: https://dart.dev/tools/analysis +[Linter rules]: https://dart.dev/lints diff --git a/experimental/linting_tool/analysis_options.yaml b/experimental/linting_tool/analysis_options.yaml deleted file mode 100644 index 39271ef9df9..00000000000 --- a/experimental/linting_tool/analysis_options.yaml +++ /dev/null @@ -1,6 +0,0 @@ -include: package:analysis_defaults/flutter.yaml - -analyzer: - exclude: - - lib/model/rule.g.dart - - test/widget_test.mocks.dart diff --git a/experimental/linting_tool/lib/app.dart b/experimental/linting_tool/lib/app.dart deleted file mode 100644 index 60781e03ab8..00000000000 --- a/experimental/linting_tool/lib/app.dart +++ /dev/null @@ -1,56 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:http/http.dart' as http; -import 'package:linting_tool/model/profiles_store.dart'; -import 'package:linting_tool/model/rules_store.dart'; -import 'package:linting_tool/routes.dart' as routes; -import 'package:linting_tool/theme/app_theme.dart'; -import 'package:linting_tool/widgets/adaptive_nav.dart'; -import 'package:provider/provider.dart'; - -final client = http.Client(); - -class LintingTool extends StatefulWidget { - const LintingTool({super.key}); - - static const String homeRoute = routes.homeRoute; - - @override - State createState() => _LintingToolState(); -} - -class _LintingToolState extends State { - @override - Widget build(BuildContext context) { - return MultiProvider( - providers: [ - ChangeNotifierProvider( - create: (context) => RuleStore(client), - ), - ChangeNotifierProvider( - create: (context) => ProfilesStore(client), - ), - ], - child: MaterialApp( - title: 'Flutter Linting Tool', - theme: AppTheme.buildReplyLightTheme(context), - darkTheme: AppTheme.buildReplyDarkTheme(context), - themeMode: ThemeMode.light, - initialRoute: LintingTool.homeRoute, - onGenerateRoute: (settings) { - switch (settings.name) { - case LintingTool.homeRoute: - return MaterialPageRoute( - builder: (context) => const AdaptiveNav(), - settings: settings, - ); - } - return null; - }, - ), - ); - } -} diff --git a/experimental/linting_tool/lib/layout/adaptive.dart b/experimental/linting_tool/lib/layout/adaptive.dart deleted file mode 100644 index 5daa08986c1..00000000000 --- a/experimental/linting_tool/lib/layout/adaptive.dart +++ /dev/null @@ -1,21 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:adaptive_breakpoints/adaptive_breakpoints.dart'; -import 'package:flutter/material.dart'; - -/// Returns a boolean value whether the window is considered medium or large size. -/// Used to build adaptive and responsive layouts. -bool isDisplayLarge(BuildContext context) => - getWindowType(context) >= AdaptiveWindowType.medium; - -/// Returns boolean value whether the window is considered medium size. -/// Used to build adaptive and responsive layouts. -bool isDisplayMedium(BuildContext context) => - getWindowType(context) == AdaptiveWindowType.medium; - -/// Returns boolean value whether the window is considered small size. -/// Used to build adaptive and responsive layouts. -bool isDisplaySmall(BuildContext context) => - getWindowType(context) <= AdaptiveWindowType.small; diff --git a/experimental/linting_tool/lib/main.dart b/experimental/linting_tool/lib/main.dart deleted file mode 100644 index ec45d8660ca..00000000000 --- a/experimental/linting_tool/lib/main.dart +++ /dev/null @@ -1,27 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:hive_flutter/hive_flutter.dart'; -import 'package:linting_tool/app.dart'; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/model/rule.dart'; -import 'package:window_size/window_size.dart'; - -Future main() async { - /// Initialize Hive DB. - await Hive.initFlutter(); - - /// Register adapters for [Rule] and [RulesProfile] - /// so that their objects can be directly saved to the DB. - Hive.registerAdapter(RuleAdapter()); - Hive.registerAdapter(RulesProfileAdapter()); - - /// Open a [LazyBox] to retrieve data from it - await Hive.openLazyBox('rules_profile'); - - setWindowMinSize(const Size(600, 600)); - - runApp(const LintingTool()); -} diff --git a/experimental/linting_tool/lib/model/editing_controller.dart b/experimental/linting_tool/lib/model/editing_controller.dart deleted file mode 100644 index 4575c705e48..00000000000 --- a/experimental/linting_tool/lib/model/editing_controller.dart +++ /dev/null @@ -1,50 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/model/profiles_store.dart'; -import 'package:linting_tool/model/rule.dart'; - -/// Used to control editing of the saved profiles on the RulesPage. -class EditingController extends ChangeNotifier { - bool _isEditing; - - EditingController({bool isEditing = false}) : _isEditing = isEditing; - - bool get isEditing => _isEditing; - - set isEditing(bool enabled) { - _selectedRules.clear(); - _isEditing = enabled; - notifyListeners(); - } - - final Set _selectedRules = {}; - - Set get selectedRules => _selectedRules; - - void selectRule(Rule rule) { - _selectedRules.add(rule); - notifyListeners(); - } - - void deselectRule(Rule rule) { - _selectedRules.remove(rule); - notifyListeners(); - } - - Future deleteSelected( - RulesProfile profile, ProfilesStore profilesStore) async { - final rules = profile.rules; - rules.removeWhere((rule) => _selectedRules.contains(rule)); - - final newProfile = RulesProfile(name: profile.name, rules: rules); - - await profilesStore.updateProfile(profile, newProfile); - - isEditing = false; - notifyListeners(); - } -} diff --git a/experimental/linting_tool/lib/model/profile.dart b/experimental/linting_tool/lib/model/profile.dart deleted file mode 100644 index c9acc51a0ad..00000000000 --- a/experimental/linting_tool/lib/model/profile.dart +++ /dev/null @@ -1,26 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:equatable/equatable.dart'; -import 'package:hive/hive.dart'; -import 'package:linting_tool/model/rule.dart'; - -part 'profile.g.dart'; - -@HiveType(typeId: 1) -class RulesProfile extends Equatable { - @HiveField(0) - final String name; - - @HiveField(1) - final List rules; - - const RulesProfile({ - required this.name, - required this.rules, - }); - - @override - List get props => [name]; -} diff --git a/experimental/linting_tool/lib/model/profile.g.dart b/experimental/linting_tool/lib/model/profile.g.dart deleted file mode 100644 index 85d776f09a8..00000000000 --- a/experimental/linting_tool/lib/model/profile.g.dart +++ /dev/null @@ -1,44 +0,0 @@ -// GENERATED CODE - DO NOT MODIFY BY HAND - -part of 'profile.dart'; - -// ************************************************************************** -// TypeAdapterGenerator -// ************************************************************************** - -class RulesProfileAdapter extends TypeAdapter { - @override - final int typeId = 1; - - @override - RulesProfile read(BinaryReader reader) { - final numOfFields = reader.readByte(); - final fields = { - for (int i = 0; i < numOfFields; i++) reader.readByte(): reader.read(), - }; - return RulesProfile( - name: fields[0] as String, - rules: (fields[1] as List).cast(), - ); - } - - @override - void write(BinaryWriter writer, RulesProfile obj) { - writer - ..writeByte(2) - ..writeByte(0) - ..write(obj.name) - ..writeByte(1) - ..write(obj.rules); - } - - @override - int get hashCode => typeId.hashCode; - - @override - bool operator ==(Object other) => - identical(this, other) || - other is RulesProfileAdapter && - runtimeType == other.runtimeType && - typeId == other.typeId; -} diff --git a/experimental/linting_tool/lib/model/profiles_store.dart b/experimental/linting_tool/lib/model/profiles_store.dart deleted file mode 100644 index e19edff9b11..00000000000 --- a/experimental/linting_tool/lib/model/profiles_store.dart +++ /dev/null @@ -1,184 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'dart:convert'; -import 'dart:developer'; -import 'dart:io'; -import 'dart:typed_data'; - -import 'package:file_selector/file_selector.dart' as file_selector; -import 'package:flutter/material.dart'; -import 'package:http/http.dart' as http; -import 'package:json2yaml/json2yaml.dart'; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/model/rule.dart'; -import 'package:linting_tool/repository/hive_service.dart'; -import 'package:linting_tool/repository/repository.dart'; -import 'package:yaml/yaml.dart'; - -const _boxName = 'rules_profile'; - -class ProfilesStore extends ChangeNotifier { - final Repository repository; - - ProfilesStore(http.Client httpClient) : repository = Repository(httpClient) { - fetchSavedProfiles(); - } - - bool _isLoading = true; - - bool get isLoading => _isLoading; - - List _savedProfiles = []; - - List get savedProfiles => _savedProfiles; - - String? _error; - - String? get error => _error; - - Future fetchSavedProfiles() async { - if (!_isLoading) _isLoading = true; - notifyListeners(); - try { - _savedProfiles = await HiveService.getBoxes(_boxName); - } on Exception catch (e) { - log(e.toString()); - } - _isLoading = false; - - notifyListeners(); - } - - Future addToNewProfile(RulesProfile profile) async { - await HiveService.addBox(profile, _boxName); - - await Future.delayed(const Duration(milliseconds: 100), () async { - await fetchSavedProfiles(); - }); - } - - Future addToExistingProfile(RulesProfile profile, Rule rule) async { - // ignore: todo - // TODO(abd99): Consider refactoring to LinkedHashSet/SplayTreeSet to avoid - // duplication automatically. - // ref: https://github.com/flutter/samples/pull/870#discussion_r685666792 - final rules = profile.rules; - - // If rule is already in profile, skip updating profile - if (rules.contains(rule)) { - return; - } - - rules.add(rule); - - final newProfile = RulesProfile(name: profile.name, rules: rules); - - await HiveService.updateBox(profile, newProfile, _boxName); - - await Future.delayed(const Duration(milliseconds: 100), () async { - await fetchSavedProfiles(); - }); - } - - Future updateProfile( - RulesProfile oldProfile, RulesProfile newProfile) async { - await HiveService.updateBox(oldProfile, newProfile, _boxName); - - await Future.delayed(const Duration(milliseconds: 100), () async { - await fetchSavedProfiles(); - }); - } - - Future removeRuleFromProfile(RulesProfile profile, Rule rule) async { - final newProfile = - RulesProfile(name: profile.name, rules: profile.rules..remove(rule)); - await updateProfile(profile, newProfile); - } - - Future deleteProfile(RulesProfile profile) async { - await HiveService.deleteBox(profile, _boxName); - - await Future.delayed(const Duration(milliseconds: 100), () async { - await fetchSavedProfiles(); - }); - } - - Future exportProfileFile( - RulesProfile profile, { - RulesStyle rulesStyle = RulesStyle.booleanMap, - }) async { - _isLoading = true; - notifyListeners(); - - var resultSaved = false; - - try { - final templateFileData = await repository.getTemplateFile(); - - /// Fetch formatted data to create new YamlFile. - final newYamlFile = - _prepareYamlFile(profile, templateFileData, rulesStyle); - - resultSaved = await _saveFileToDisk(newYamlFile); - } on SocketException catch (e) { - log(e.toString()); - _error = 'Check internet connection.'; - resultSaved = false; - } on Exception catch (e) { - log(e.toString()); - } - - _isLoading = false; - notifyListeners(); - - return resultSaved; - } - - Future _saveFileToDisk(String newYamlFile) async { - const name = 'analysis_options.yaml'; - - /// Get file path using file picker. - final saveLocation = await file_selector.getSaveLocation( - suggestedName: name, - ); - - final data = Uint8List.fromList(newYamlFile.codeUnits); - final file = file_selector.XFile.fromData(data, name: name); - - /// Save file to disk if path was provided. - if (saveLocation != null) { - await file.saveTo(saveLocation.path); - return true; - } - - const errorMessage = 'File path not found.'; - _error = errorMessage; - throw Exception(errorMessage); - } - - String _prepareYamlFile( - RulesProfile profile, YamlMap templateFile, RulesStyle rulesStyle) { - final rules = profile.rules.map((e) => e.name); - - final rulesData = - json.decode(json.encode(templateFile)) as Map; - - /// Add rules to existing template according to formatting style. - if (rulesStyle == RulesStyle.booleanMap) { - final rulesMap = {for (final rule in rules) rule: true}; - rulesData.update('linter', (dynamic value) => {'rules': rulesMap}); - } else { - rulesData.update('linter', (dynamic value) => {'rules': rules}); - } - - return json2yaml(rulesData, yamlStyle: YamlStyle.pubspecYaml); - } -} - -/// Formatting style for rules. -enum RulesStyle { - list, - booleanMap, -} diff --git a/experimental/linting_tool/lib/model/rule.dart b/experimental/linting_tool/lib/model/rule.dart deleted file mode 100644 index 224bdfbec65..00000000000 --- a/experimental/linting_tool/lib/model/rule.dart +++ /dev/null @@ -1,45 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:equatable/equatable.dart'; -import 'package:hive/hive.dart'; -import 'package:json_annotation/json_annotation.dart'; - -part 'rule.g.dart'; - -@JsonSerializable() -@HiveType(typeId: 0) -class Rule extends Equatable { - @HiveField(0) - final String name; - @HiveField(1) - final String description; - @HiveField(2) - final String group; - @HiveField(3) - final String state; - @HiveField(4) - final List incompatible; - @HiveField(5) - final List sets; - @HiveField(6) - final String details; - - const Rule({ - required this.name, - required this.description, - required this.group, - required this.state, - required this.incompatible, - required this.sets, - required this.details, - }); - - factory Rule.fromJson(Map json) => _$RuleFromJson(json); - - Map toJson() => _$RuleToJson(this); - - @override - List get props => [name]; -} diff --git a/experimental/linting_tool/lib/model/rule.g.dart b/experimental/linting_tool/lib/model/rule.g.dart deleted file mode 100644 index bc9e8f8af7d..00000000000 --- a/experimental/linting_tool/lib/model/rule.g.dart +++ /dev/null @@ -1,85 +0,0 @@ -// GENERATED CODE - DO NOT MODIFY BY HAND - -part of 'rule.dart'; - -// ************************************************************************** -// TypeAdapterGenerator -// ************************************************************************** - -class RuleAdapter extends TypeAdapter { - @override - final int typeId = 0; - - @override - Rule read(BinaryReader reader) { - final numOfFields = reader.readByte(); - final fields = { - for (int i = 0; i < numOfFields; i++) reader.readByte(): reader.read(), - }; - return Rule( - name: fields[0] as String, - description: fields[1] as String, - group: fields[2] as String, - state: fields[3] as String, - incompatible: (fields[4] as List).cast(), - sets: (fields[5] as List).cast(), - details: fields[6] as String, - ); - } - - @override - void write(BinaryWriter writer, Rule obj) { - writer - ..writeByte(7) - ..writeByte(0) - ..write(obj.name) - ..writeByte(1) - ..write(obj.description) - ..writeByte(2) - ..write(obj.group) - ..writeByte(3) - ..write(obj.state) - ..writeByte(4) - ..write(obj.incompatible) - ..writeByte(5) - ..write(obj.sets) - ..writeByte(6) - ..write(obj.details); - } - - @override - int get hashCode => typeId.hashCode; - - @override - bool operator ==(Object other) => - identical(this, other) || - other is RuleAdapter && - runtimeType == other.runtimeType && - typeId == other.typeId; -} - -// ************************************************************************** -// JsonSerializableGenerator -// ************************************************************************** - -Rule _$RuleFromJson(Map json) => Rule( - name: json['name'] as String, - description: json['description'] as String, - group: json['group'] as String, - state: json['state'] as String, - incompatible: (json['incompatible'] as List) - .map((e) => e as String) - .toList(), - sets: (json['sets'] as List).map((e) => e as String).toList(), - details: json['details'] as String, - ); - -Map _$RuleToJson(Rule instance) => { - 'name': instance.name, - 'description': instance.description, - 'group': instance.group, - 'state': instance.state, - 'incompatible': instance.incompatible, - 'sets': instance.sets, - 'details': instance.details, - }; diff --git a/experimental/linting_tool/lib/model/rules_store.dart b/experimental/linting_tool/lib/model/rules_store.dart deleted file mode 100644 index 66ef06f4934..00000000000 --- a/experimental/linting_tool/lib/model/rules_store.dart +++ /dev/null @@ -1,70 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'dart:developer'; -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:http/http.dart' as http; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/model/rule.dart'; -import 'package:linting_tool/repository/repository.dart'; - -/// Manages fetching rules from the web. -class RuleStore extends ChangeNotifier { - final Repository repository; - - RuleStore(http.Client httpClient) : repository = Repository(httpClient) { - fetchRules(); - } - - bool _isLoading = true; - - bool get isLoading => _isLoading; - - List _rules = []; - - List get rules => _rules; - - String? _error; - - String? get error => _error; - - List get defaultProfiles { - if (isLoading || rules.isEmpty) { - return const []; - } - - final Map setsToProfiles = {}; - - for (final rule in rules) { - for (final setName in rule.sets) { - final profile = setsToProfiles[setName]; - if (profile == null) { - setsToProfiles[setName] = RulesProfile(name: setName, rules: [rule]); - } else { - profile.rules.add(rule); - } - } - } - - return setsToProfiles.values.toList(growable: false); - } - - Future fetchRules() async { - if (!_isLoading) _isLoading = true; - notifyListeners(); - try { - _rules = await repository.getRulesList(); - } on SocketException catch (e) { - log(e.toString()); - _error = 'Check internet connection.'; - } on Exception catch (e) { - log(e.toString()); - } - _isLoading = false; - - notifyListeners(); - } -} diff --git a/experimental/linting_tool/lib/pages/default_lints_page.dart b/experimental/linting_tool/lib/pages/default_lints_page.dart deleted file mode 100644 index 3c356c9cb9e..00000000000 --- a/experimental/linting_tool/lib/pages/default_lints_page.dart +++ /dev/null @@ -1,84 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:linting_tool/layout/adaptive.dart'; -import 'package:linting_tool/model/rules_store.dart'; -import 'package:linting_tool/pages/default_rules_page.dart'; -import 'package:linting_tool/theme/colors.dart'; -import 'package:provider/provider.dart'; - -class DefaultLintsPage extends StatelessWidget { - const DefaultLintsPage({super.key}); - - @override - Widget build(BuildContext context) { - return Consumer( - builder: (context, rulesStore, child) { - if (rulesStore.isLoading) { - return const CircularProgressIndicator.adaptive(); - } - - final defaultSets = rulesStore.defaultProfiles; - if (defaultSets.isNotEmpty) { - final isDesktop = isDisplayLarge(context); - final isTablet = isDisplayMedium(context); - final startPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - final endPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - - return ListView.separated( - padding: EdgeInsetsDirectional.only( - start: startPadding, - end: endPadding, - top: isDesktop ? 28 : 16, - bottom: isDesktop ? kToolbarHeight : 16, - ), - cacheExtent: 5, - itemCount: defaultSets.length, - itemBuilder: (context, index) { - final profile = defaultSets[index]; - return ListTile( - title: Text( - profile.name, - ), - tileColor: AppColors.white50, - onTap: () { - Navigator.push( - context, - MaterialPageRoute( - builder: (context) => DefaultRulesPage(profile: profile), - ), - ); - }, - ); - }, - separatorBuilder: (context, index) => const SizedBox(height: 4), - ); - } - - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - Text(rulesStore.error ?? 'Failed to load rules.'), - const SizedBox( - height: 16.0, - ), - IconButton( - onPressed: () => rulesStore.fetchRules(), - icon: const Icon(Icons.refresh), - ), - ], - ); - }, - ); - } -} diff --git a/experimental/linting_tool/lib/pages/default_rules_page.dart b/experimental/linting_tool/lib/pages/default_rules_page.dart deleted file mode 100644 index 6e411d36119..00000000000 --- a/experimental/linting_tool/lib/pages/default_rules_page.dart +++ /dev/null @@ -1,75 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:flutter/services.dart' show SystemUiOverlayStyle; -import 'package:linting_tool/layout/adaptive.dart'; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/widgets/lint_expansion_tile.dart'; - -class DefaultRulesPage extends StatelessWidget { - final RulesProfile profile; - - const DefaultRulesPage({ - required this.profile, - super.key, - }); - - @override - Widget build(BuildContext context) { - final isDesktop = isDisplayLarge(context); - final isTablet = isDisplayMedium(context); - final textTheme = Theme.of(context).textTheme; - final startPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - final endPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - return Scaffold( - appBar: AppBar( - title: Text( - profile.name, - style: textTheme.titleSmall!.copyWith( - color: textTheme.bodyLarge!.color, - ), - ), - leading: Padding( - padding: const EdgeInsets.only(left: 80.0), - child: TextButton.icon( - onPressed: () { - Navigator.pop(context); - }, - icon: const Icon(Icons.arrow_back_ios_new), - label: const Text('Back'), - ), - ), - leadingWidth: 160.0, - toolbarHeight: 38.0, - backgroundColor: Colors.white, - systemOverlayStyle: SystemUiOverlayStyle.dark, - ), - body: ListView.separated( - padding: EdgeInsetsDirectional.only( - start: startPadding, - end: endPadding, - top: isDesktop ? 28 : 16, - bottom: isDesktop ? kToolbarHeight : 16, - ), - itemCount: profile.rules.length, - cacheExtent: 5, - itemBuilder: (context, index) { - return LintExpansionTile( - rule: profile.rules[index], - ); - }, - separatorBuilder: (context, index) => const SizedBox(height: 4), - ), - ); - } -} diff --git a/experimental/linting_tool/lib/pages/home_page.dart b/experimental/linting_tool/lib/pages/home_page.dart deleted file mode 100644 index 2dc63a96f87..00000000000 --- a/experimental/linting_tool/lib/pages/home_page.dart +++ /dev/null @@ -1,70 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:linting_tool/layout/adaptive.dart'; -import 'package:linting_tool/model/rules_store.dart'; -import 'package:linting_tool/widgets/lint_expansion_tile.dart'; -import 'package:provider/provider.dart'; - -class HomePage extends StatelessWidget { - const HomePage({super.key}); - - @override - Widget build(BuildContext context) { - return Consumer( - builder: (context, rulesStore, child) { - if (rulesStore.isLoading) { - return const CircularProgressIndicator.adaptive(); - } - - if (rulesStore.rules.isNotEmpty) { - final isDesktop = isDisplayLarge(context); - final isTablet = isDisplayMedium(context); - final startPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - final endPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - - return ListView.separated( - padding: EdgeInsetsDirectional.only( - start: startPadding, - end: endPadding, - top: isDesktop ? 28 : 16, - bottom: isDesktop ? kToolbarHeight : 16, - ), - itemCount: rulesStore.rules.length, - cacheExtent: 5, - itemBuilder: (context, index) { - return LintExpansionTile( - rule: rulesStore.rules[index], - ); - }, - separatorBuilder: (context, index) => const SizedBox(height: 4), - ); - } - - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - Text(rulesStore.error ?? 'Failed to load rules.'), - const SizedBox( - height: 16.0, - ), - IconButton( - onPressed: () => rulesStore.fetchRules(), - icon: const Icon(Icons.refresh), - ), - ], - ); - }, - ); - } -} diff --git a/experimental/linting_tool/lib/pages/rules_page.dart b/experimental/linting_tool/lib/pages/rules_page.dart deleted file mode 100644 index 77ca1ab1da7..00000000000 --- a/experimental/linting_tool/lib/pages/rules_page.dart +++ /dev/null @@ -1,167 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:context_menus/context_menus.dart'; -import 'package:flutter/material.dart'; -import 'package:flutter/services.dart' show SystemUiOverlayStyle; -import 'package:linting_tool/layout/adaptive.dart'; -import 'package:linting_tool/model/editing_controller.dart'; -import 'package:linting_tool/model/profiles_store.dart'; -import 'package:linting_tool/widgets/saved_rule_tile.dart'; -import 'package:provider/provider.dart'; - -class RulesPage extends StatelessWidget { - final int selectedProfileIndex; - - const RulesPage({ - required this.selectedProfileIndex, - super.key, - }); - - @override - Widget build(BuildContext context) { - final isDesktop = isDisplayLarge(context); - final isTablet = isDisplayMedium(context); - final textTheme = Theme.of(context).textTheme; - final startPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - final endPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 4.0; - return Scaffold( - appBar: AppBar( - title: Text( - context - .read() - .savedProfiles[selectedProfileIndex] - .name, - style: textTheme.titleSmall!.copyWith( - color: textTheme.bodyLarge!.color, - ), - ), - leading: Padding( - padding: const EdgeInsets.only(left: 80.0), - child: TextButton.icon( - onPressed: () { - Navigator.pop(context); - }, - icon: const Icon(Icons.arrow_back_ios_new), - label: const Text('Back'), - ), - ), - leadingWidth: 160.0, - toolbarHeight: 38.0, - backgroundColor: Colors.white, - systemOverlayStyle: SystemUiOverlayStyle.dark, - ), - - /// ContextMenuOverlay is required to show - /// right-click context menus using ContextMenuRegion. - body: ContextMenuOverlay( - child: Consumer( - builder: (context, profilesStore, child) { - var profile = profilesStore.savedProfiles[selectedProfileIndex]; - return profile.rules.isEmpty - ? const Center( - child: Text('There are no rules added to the profile.'), - ) - : Row( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Expanded( - child: ListView.separated( - padding: EdgeInsetsDirectional.only( - start: startPadding, - end: endPadding, - top: isDesktop ? 28 : 16, - bottom: isDesktop ? kToolbarHeight : 16, - ), - itemCount: profile.rules.length, - cacheExtent: 5, - itemBuilder: (context, index) { - /// Show right-click context menu to delete rule. - return ContextMenuRegion( - contextMenu: GenericContextMenu( - buttonConfigs: [ - ContextMenuButtonConfig( - 'Remove rule from profile', - onPressed: () { - context - .read() - .removeRuleFromProfile( - profile, profile.rules[index]); - }, - ), - ], - ), - child: SavedRuleTile( - rule: profile.rules[index], - ), - ); - }, - separatorBuilder: (context, index) => - const SizedBox(height: 4), - ), - ), - Padding( - padding: const EdgeInsetsDirectional.only(top: 28), - child: Row( - children: [ - Consumer( - builder: (context, editingController, child) { - var isEditing = editingController.isEditing; - return isEditing - ? Column( - children: [ - IconButton( - icon: const Icon(Icons.done), - onPressed: () { - editingController.isEditing = - false; - }, - ), - if (editingController - .selectedRules.isNotEmpty) - IconButton( - icon: const Icon(Icons.delete), - onPressed: () { - editingController - .deleteSelected( - profile, - profilesStore, - ); - }, - ), - ], - ) - : IconButton( - icon: const Icon(Icons.edit), - onPressed: () { - editingController.isEditing = true; - }, - ); - }, - ), - SizedBox( - width: isTablet - ? 30 - : isDesktop - ? 60 - : 16), - ], - ), - ), - ], - ); - }, - ), - ), - ); - } -} diff --git a/experimental/linting_tool/lib/pages/saved_lints_page.dart b/experimental/linting_tool/lib/pages/saved_lints_page.dart deleted file mode 100644 index d7f2639a34c..00000000000 --- a/experimental/linting_tool/lib/pages/saved_lints_page.dart +++ /dev/null @@ -1,164 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:linting_tool/layout/adaptive.dart'; -import 'package:linting_tool/model/editing_controller.dart'; -import 'package:linting_tool/model/profiles_store.dart'; -import 'package:linting_tool/pages/rules_page.dart'; -import 'package:linting_tool/theme/colors.dart'; -import 'package:provider/provider.dart'; - -class SavedLintsPage extends StatefulWidget { - const SavedLintsPage({super.key}); - - @override - State createState() => _SavedLintsPageState(); -} - -class _SavedLintsPageState extends State { - @override - Widget build(BuildContext context) { - return Consumer( - builder: (context, profilesStore, child) { - if (profilesStore.isLoading) { - return const CircularProgressIndicator.adaptive(); - } - - if (!profilesStore.isLoading) { - if (profilesStore.savedProfiles.isNotEmpty) { - final isDesktop = isDisplayLarge(context); - final isTablet = isDisplayMedium(context); - final startPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - final endPadding = isTablet - ? 60.0 - : isDesktop - ? 120.0 - : 16.0; - - return ListView.separated( - padding: EdgeInsetsDirectional.only( - start: startPadding, - end: endPadding, - top: isDesktop ? 28 : 16, - bottom: isDesktop ? kToolbarHeight : 16, - ), - itemCount: profilesStore.savedProfiles.length, - cacheExtent: 5, - itemBuilder: (itemBuilderContext, index) { - var profile = profilesStore.savedProfiles[index]; - return ListTile( - title: Text( - profile.name, - ), - tileColor: AppColors.white50, - onTap: () { - Navigator.push( - context, - MaterialPageRoute( - builder: (context) => ChangeNotifierProvider( - create: (context) => EditingController(), - child: RulesPage(selectedProfileIndex: index), - ), - ), - ); - }, - trailing: Row( - mainAxisSize: MainAxisSize.min, - children: [ - IconButton( - icon: const Icon(Icons.edit), - onPressed: () { - Navigator.push( - context, - MaterialPageRoute( - builder: (context) => ChangeNotifierProvider( - create: (context) => EditingController( - isEditing: true, - ), - child: RulesPage(selectedProfileIndex: index), - ), - ), - ); - }, - ), - const SizedBox( - width: 8.0, - ), - PopupMenuButton( - icon: const Icon(Icons.more_vert), - onSelected: (value) async { - switch (value) { - case 'Export file': - // ignore: todo - // TODO(abd99): Add option to select formatting style. - - var saved = await profilesStore - .exportProfileFile(profile); - - if (!context.mounted) return; - - if (!saved) { - _showSnackBar( - context, - profilesStore.error ?? 'Failed to save file.', - ); - } - - case 'Delete': - await profilesStore.deleteProfile(profile); - default: - } - }, - itemBuilder: (context) { - return [ - const PopupMenuItem( - value: 'Export file', - child: Text('Export file'), - ), - const PopupMenuItem( - value: 'Delete', - child: Text('Delete'), - ), - ]; - }, - ), - ], - ), - ); - }, - separatorBuilder: (context, index) => const SizedBox(height: 4), - ); - } - } - - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - Text(profilesStore.error ?? 'No saved profiles found.'), - const SizedBox( - height: 16.0, - ), - IconButton( - onPressed: () => profilesStore.fetchSavedProfiles(), - icon: const Icon(Icons.refresh), - ), - ], - ); - }, - ); - } - - void _showSnackBar(BuildContext context, String data) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(data), - ), - ); - } -} diff --git a/experimental/linting_tool/lib/repository/api_provider.dart b/experimental/linting_tool/lib/repository/api_provider.dart deleted file mode 100644 index 76d2349a902..00000000000 --- a/experimental/linting_tool/lib/repository/api_provider.dart +++ /dev/null @@ -1,40 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'dart:convert'; -import 'package:http/http.dart' as http; -import 'package:linting_tool/model/rule.dart'; -import 'package:yaml/yaml.dart'; - -class APIProvider { - final http.Client httpClient; - - APIProvider(this.httpClient); - - Future> getRulesList() async { - final response = await httpClient.get(Uri.parse( - 'https://raw.githubusercontent.com/dart-lang/site-www/main/src/_data/linter_rules.json', - )); - - if (response.statusCode == 200) { - final data = json.decode(response.body) as List; - final rulesList = [ - for (final item in data) Rule.fromJson(item as Map) - ]; - return rulesList; - } else { - throw Exception('Failed to load rules'); - } - } - - Future getTemplateFile() async { - final response = await httpClient.get(Uri.parse( - 'https://raw.githubusercontent.com/flutter/flutter/main/packages/flutter_tools/templates/app_shared/analysis_options.yaml.tmpl')); - if (response.statusCode == 200) { - return loadYaml(response.body) as YamlMap; - } else { - throw Exception('Failed to load template file'); - } - } -} diff --git a/experimental/linting_tool/lib/repository/hive_service.dart b/experimental/linting_tool/lib/repository/hive_service.dart deleted file mode 100644 index 3fdc75d0ea2..00000000000 --- a/experimental/linting_tool/lib/repository/hive_service.dart +++ /dev/null @@ -1,75 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:hive/hive.dart'; - -class HiveService { - static Future addBox(T item, String boxName) async { - final openBox = await Hive.openLazyBox( - boxName, - ); - - final List existingProducts = await getBoxes(boxName); - - if (!existingProducts.contains(item)) { - await openBox.add(item); - return true; - } - return false; - } - - static Future addBoxes(List items, String boxName) async { - final openBox = await Hive.openLazyBox( - boxName, - ); - - final Set existingProducts = Set.unmodifiable(await getBoxes(boxName)); - - for (final item in items) { - if (!existingProducts.contains(item)) { - await openBox.add(item); - } - } - } - - static Future deleteBox(T item, String boxName) async { - final openBox = await Hive.openLazyBox( - boxName, - ); - - final List boxes = await getBoxes(boxName); - - for (final box in boxes) { - if (box == item) { - await openBox.deleteAt(boxes.indexOf(item)); - } - } - } - - static Future updateBox(T item, T newItem, String boxName) async { - final openBox = await Hive.openLazyBox( - boxName, - ); - - final List boxes = await getBoxes(boxName); - - for (final box in boxes) { - if (box == item) { - await openBox.putAt(boxes.indexOf(item), newItem); - } - } - } - - static Future> getBoxes(String boxName, [String? query]) async { - final openBox = await Hive.openLazyBox(boxName); - - final length = openBox.length; - - final boxList = [ - for (int i = 0; i < length; i++) await openBox.getAt(i) as T - ]; - - return boxList; - } -} diff --git a/experimental/linting_tool/lib/repository/repository.dart b/experimental/linting_tool/lib/repository/repository.dart deleted file mode 100644 index eadd8f4093f..00000000000 --- a/experimental/linting_tool/lib/repository/repository.dart +++ /dev/null @@ -1,18 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:http/http.dart' as http; -import 'package:linting_tool/model/rule.dart'; -import 'package:linting_tool/repository/api_provider.dart'; -import 'package:yaml/yaml.dart'; - -class Repository { - final APIProvider _apiProvider; - - Repository(http.Client httpClient) : _apiProvider = APIProvider(httpClient); - - Future> getRulesList() => _apiProvider.getRulesList(); - - Future getTemplateFile() => _apiProvider.getTemplateFile(); -} diff --git a/experimental/linting_tool/lib/routes.dart b/experimental/linting_tool/lib/routes.dart deleted file mode 100644 index 184c9a69492..00000000000 --- a/experimental/linting_tool/lib/routes.dart +++ /dev/null @@ -1,6 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -const String homeRoute = '/home'; -// TODO(abd99): Add new routes. diff --git a/experimental/linting_tool/lib/theme/app_theme.dart b/experimental/linting_tool/lib/theme/app_theme.dart deleted file mode 100644 index fc1339e7925..00000000000 --- a/experimental/linting_tool/lib/theme/app_theme.dart +++ /dev/null @@ -1,234 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:flutter_markdown/flutter_markdown.dart'; -import 'package:google_fonts/google_fonts.dart'; -import 'package:linting_tool/theme/colors.dart'; - -abstract class AppTheme { - static ThemeData buildReplyLightTheme(BuildContext context) { - final base = ThemeData.light(); - return base.copyWith( - bottomSheetTheme: BottomSheetThemeData( - backgroundColor: AppColors.blue700, - modalBackgroundColor: Colors.white.withAlpha(179), - ), - navigationRailTheme: NavigationRailThemeData( - backgroundColor: AppColors.blue700, - selectedIconTheme: const IconThemeData( - color: AppColors.orange500, - ), - selectedLabelTextStyle: - GoogleFonts.workSansTextTheme().headlineSmall!.copyWith( - color: AppColors.orange500, - ), - unselectedIconTheme: const IconThemeData( - color: AppColors.blue200, - ), - unselectedLabelTextStyle: - GoogleFonts.workSansTextTheme().headlineSmall!.copyWith( - color: AppColors.blue200, - ), - ), - canvasColor: AppColors.white50, - cardColor: AppColors.white50, - chipTheme: _buildChipTheme( - AppColors.blue700, - AppColors.lightChipBackground, - Brightness.light, - ), - colorScheme: ColorScheme.fromSwatch( - primarySwatch: Colors.blueGrey, - ), - textTheme: _buildReplyLightTextTheme(base.textTheme), - scaffoldBackgroundColor: AppColors.blue50, - bottomAppBarTheme: const BottomAppBarTheme(color: AppColors.blue700), - ); - } - - static ThemeData buildReplyDarkTheme(BuildContext context) { - final base = ThemeData.dark(); - return base.copyWith( - bottomSheetTheme: BottomSheetThemeData( - backgroundColor: AppColors.darkDrawerBackground, - modalBackgroundColor: Colors.black.withAlpha(179), - ), - navigationRailTheme: NavigationRailThemeData( - backgroundColor: AppColors.darkBottomAppBarBackground, - selectedIconTheme: const IconThemeData( - color: AppColors.orange300, - ), - selectedLabelTextStyle: - GoogleFonts.workSansTextTheme().headlineSmall!.copyWith( - color: AppColors.orange300, - ), - unselectedIconTheme: const IconThemeData( - color: AppColors.greyLabel, - ), - unselectedLabelTextStyle: - GoogleFonts.workSansTextTheme().headlineSmall!.copyWith( - color: AppColors.greyLabel, - ), - ), - canvasColor: AppColors.black900, - cardColor: AppColors.darkCardBackground, - chipTheme: _buildChipTheme( - AppColors.blue200, - AppColors.darkChipBackground, - Brightness.dark, - ), - colorScheme: const ColorScheme.dark( - primary: AppColors.blue200, - secondary: AppColors.orange300, - surface: AppColors.black800, - error: AppColors.red200, - onPrimary: AppColors.black900, - onSecondary: AppColors.black900, - onSurface: AppColors.white50, - onError: AppColors.black900, - ), - textTheme: _buildReplyDarkTextTheme(base.textTheme), - scaffoldBackgroundColor: AppColors.black900, - bottomAppBarTheme: - const BottomAppBarTheme(color: AppColors.darkBottomAppBarBackground), - ); - } - - static ChipThemeData _buildChipTheme( - Color primaryColor, - Color chipBackground, - Brightness brightness, - ) { - return ChipThemeData( - backgroundColor: primaryColor.withAlpha(31), - disabledColor: primaryColor.withAlpha(222), - selectedColor: primaryColor.withAlpha(12), - secondarySelectedColor: chipBackground, - padding: const EdgeInsets.all(4), - shape: const StadiumBorder(), - labelStyle: GoogleFonts.workSansTextTheme().bodyMedium!.copyWith( - color: brightness == Brightness.dark - ? AppColors.white50 - : AppColors.black900, - ), - secondaryLabelStyle: GoogleFonts.workSansTextTheme().bodyMedium!, - brightness: brightness, - ); - } - - static TextTheme _buildReplyLightTextTheme(TextTheme base) { - return base.copyWith( - headlineMedium: GoogleFonts.workSans( - fontWeight: FontWeight.w600, - fontSize: 34, - letterSpacing: 0.4, - height: 0.9, - color: AppColors.black900, - ), - headlineSmall: GoogleFonts.workSans( - fontWeight: FontWeight.bold, - fontSize: 24, - letterSpacing: 0.27, - color: AppColors.black900, - ), - titleLarge: GoogleFonts.workSans( - fontWeight: FontWeight.w600, - fontSize: 20, - letterSpacing: 0.18, - color: AppColors.black900, - ), - titleSmall: GoogleFonts.workSans( - fontWeight: FontWeight.w600, - fontSize: 14, - letterSpacing: -0.04, - color: AppColors.black900, - ), - bodyLarge: GoogleFonts.workSans( - fontWeight: FontWeight.normal, - fontSize: 18, - letterSpacing: 0.2, - color: AppColors.black900, - ), - bodyMedium: GoogleFonts.workSans( - fontWeight: FontWeight.normal, - fontSize: 14, - letterSpacing: -0.05, - color: AppColors.black900, - ), - bodySmall: GoogleFonts.workSans( - fontWeight: FontWeight.normal, - fontSize: 12, - letterSpacing: 0.2, - color: AppColors.black900, - ), - ); - } - - static TextTheme _buildReplyDarkTextTheme(TextTheme base) { - return base.copyWith( - headlineMedium: GoogleFonts.workSans( - fontWeight: FontWeight.w600, - fontSize: 34, - letterSpacing: 0.4, - height: 0.9, - color: AppColors.white50, - ), - headlineSmall: GoogleFonts.workSans( - fontWeight: FontWeight.bold, - fontSize: 24, - letterSpacing: 0.27, - color: AppColors.white50, - ), - titleLarge: GoogleFonts.workSans( - fontWeight: FontWeight.w600, - fontSize: 20, - letterSpacing: 0.18, - color: AppColors.white50, - ), - titleSmall: GoogleFonts.workSans( - fontWeight: FontWeight.w600, - fontSize: 14, - letterSpacing: -0.04, - color: AppColors.white50, - ), - bodyLarge: GoogleFonts.workSans( - fontWeight: FontWeight.normal, - fontSize: 18, - letterSpacing: 0.2, - color: AppColors.white50, - ), - bodyMedium: GoogleFonts.workSans( - fontWeight: FontWeight.normal, - fontSize: 14, - letterSpacing: -0.05, - color: AppColors.white50, - ), - bodySmall: GoogleFonts.workSans( - fontWeight: FontWeight.normal, - fontSize: 12, - letterSpacing: 0.2, - color: AppColors.white50, - ), - ); - } - - static MarkdownStyleSheet buildMarkDownTheme(ThemeData theme) { - final textTheme = theme.textTheme; - return MarkdownStyleSheet.largeFromTheme(theme).copyWith( - strong: textTheme.titleSmall!, - em: textTheme.bodyMedium!.copyWith( - fontWeight: FontWeight.w900, - fontStyle: FontStyle.italic, - ), - codeblockPadding: const EdgeInsets.all(8), - codeblockDecoration: BoxDecoration( - color: Colors.grey.shade100, - ), - code: TextStyle( - backgroundColor: Colors.grey.shade100, - ), - ); - } -} diff --git a/experimental/linting_tool/lib/theme/colors.dart b/experimental/linting_tool/lib/theme/colors.dart deleted file mode 100644 index 2166ea19b33..00000000000 --- a/experimental/linting_tool/lib/theme/colors.dart +++ /dev/null @@ -1,42 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; - -abstract class AppColors { - static const Color white50 = Color(0xFFFFFFFF); - - static const Color black800 = Color(0xFF121212); - static const Color black900 = Color(0xFF000000); - - static const Color blue50 = Color(0xFFEEF0F2); - static const Color blue100 = Color(0xFFD2DBE0); - static const Color blue200 = Color(0xFFADBBC4); - static const Color blue300 = Color(0xFF8CA2AE); - static const Color blue600 = Color(0xFF4A6572); - static const Color blue700 = Color(0xFF344955); - static const Color blue800 = Color(0xFF232F34); - - static const Color orange300 = Color(0xFFFBD790); - static const Color orange400 = Color(0xFFF9BE64); - static const Color orange500 = Color(0xFFF9AA33); - - static const Color red200 = Color(0xFFCF7779); - static const Color red400 = Color(0xFFFF4C5D); - - static const Color white50Alpha060 = Color(0x99FFFFFF); - - static const Color blue50Alpha060 = Color(0x99EEF0F2); - - static const Color black900Alpha020 = Color(0x33000000); - static const Color black900Alpha087 = Color(0xDE000000); - static const Color black900Alpha060 = Color(0x99000000); - - static const Color greyLabel = Color(0xFFAEAEAE); - static const Color darkBottomAppBarBackground = Color(0xFF2D2D2D); - static const Color darkDrawerBackground = Color(0xFF353535); - static const Color darkCardBackground = Color(0xFF1E1E1E); - static const Color darkChipBackground = Color(0xFF2A2A2A); - static const Color lightChipBackground = Color(0xFFE5E5E5); -} diff --git a/experimental/linting_tool/lib/widgets/adaptive_nav.dart b/experimental/linting_tool/lib/widgets/adaptive_nav.dart deleted file mode 100644 index 0a45f096e01..00000000000 --- a/experimental/linting_tool/lib/widgets/adaptive_nav.dart +++ /dev/null @@ -1,352 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'dart:math' as math; - -import 'package:flutter/material.dart'; -import 'package:flutter/services.dart' show SystemUiOverlayStyle; -import 'package:linting_tool/layout/adaptive.dart'; -import 'package:linting_tool/pages/default_lints_page.dart'; -import 'package:linting_tool/pages/home_page.dart'; -import 'package:linting_tool/pages/saved_lints_page.dart'; -import 'package:linting_tool/theme/colors.dart'; - -final navKey = GlobalKey(); - -class AdaptiveNav extends StatefulWidget { - const AdaptiveNav({super.key}); - - @override - State createState() => _AdaptiveNavState(); -} - -class _AdaptiveNavState extends State { - @override - Widget build(BuildContext context) { - final isDesktop = isDisplayLarge(context); - const navigationDestinations = <_Destination>[ - _Destination( - textLabel: 'Home', - icon: Icons.home_outlined, - selectedIcon: Icons.home, - destination: HomePage(), - ), - _Destination( - textLabel: 'Saved Profiles', - icon: Icons.save_outlined, - selectedIcon: Icons.save, - destination: SavedLintsPage(), - ), - _Destination( - textLabel: 'Default Profiles', - icon: Icons.featured_play_list_outlined, - selectedIcon: Icons.featured_play_list, - destination: DefaultLintsPage(), - ), - ]; - - const trailing = { - 'About': Icons.info_outline, - }; - - return _NavView( - extended: isDesktop, - destinations: navigationDestinations, - trailing: trailing, - ); - } -} - -class _NavView extends StatefulWidget { - const _NavView({ - required this.extended, - required this.destinations, - this.trailing = const {}, - }); - - final bool extended; - final List<_Destination> destinations; - final Map trailing; - - @override - _NavViewState createState() => _NavViewState(); -} - -class _NavViewState extends State<_NavView> { - late final ValueNotifier _isExtended; - var _selectedIndex = 0; - - @override - void initState() { - super.initState(); - _isExtended = ValueNotifier(widget.extended); - } - - void _onDestinationSelected(int index) { - setState(() { - _selectedIndex = index; - }); - } - - @override - Widget build(BuildContext context) { - final textTheme = Theme.of(context).textTheme; - return Scaffold( - appBar: AppBar( - title: Text( - 'Flutter Linting Tool', - style: textTheme.titleSmall!.copyWith( - color: textTheme.bodyLarge!.color, - ), - ), - toolbarHeight: 38.0, - backgroundColor: Colors.white, - systemOverlayStyle: SystemUiOverlayStyle.dark, - ), - body: Row( - children: [ - LayoutBuilder( - builder: (context, constraints) { - return SingleChildScrollView( - clipBehavior: Clip.antiAlias, - child: ConstrainedBox( - constraints: BoxConstraints( - minHeight: constraints.maxHeight, - ), - child: IntrinsicHeight( - child: ValueListenableBuilder( - valueListenable: _isExtended, - builder: (context, value, child) { - var isSmallDisplay = isDisplaySmall(context); - return NavigationRail( - destinations: [ - for (var destination in widget.destinations) - NavigationRailDestination( - icon: Icon(destination.icon), - selectedIcon: destination.selectedIcon != null - ? Icon(destination.selectedIcon) - : null, - label: Text(destination.textLabel), - ), - ], - extended: _isExtended.value && !isSmallDisplay, - labelType: NavigationRailLabelType.none, - leading: _NavigationRailHeader( - extended: _isExtended, - ), - trailing: _NavigationRailTrailingSection( - trailingDestinations: widget.trailing, - ), - selectedIndex: _selectedIndex, - onDestinationSelected: _onDestinationSelected, - ); - }, - ), - ), - ), - ); - }, - ), - const VerticalDivider(thickness: 1, width: 1), - Expanded( - child: Center( - child: ConstrainedBox( - constraints: const BoxConstraints(maxWidth: 1340), - child: AnimatedSwitcher( - duration: const Duration(milliseconds: 300), - switchOutCurve: Curves.easeOut, - switchInCurve: Curves.easeIn, - child: widget.destinations[_selectedIndex].destination, - ), - ), - ), - ), - ], - ), - ); - } -} - -class _NavigationRailHeader extends StatelessWidget { - const _NavigationRailHeader({ - required this.extended, - }); - - final ValueNotifier extended; - - @override - Widget build(BuildContext context) { - final textTheme = Theme.of(context).textTheme; - final animation = NavigationRail.extendedAnimation(context); - - return AnimatedBuilder( - animation: animation, - builder: (context, child) { - return Align( - alignment: AlignmentDirectional.centerStart, - widthFactor: animation.value, - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - SizedBox( - height: 56, - child: Row( - children: [ - const SizedBox(width: 6), - InkWell( - borderRadius: const BorderRadius.all(Radius.circular(16)), - onTap: () { - extended.value = !extended.value!; - }, - child: Row( - children: [ - Transform.rotate( - angle: animation.value * math.pi, - child: const Icon( - Icons.arrow_left, - color: AppColors.white50, - size: 16, - ), - ), - const FlutterLogo(), - const SizedBox(width: 10), - Align( - alignment: AlignmentDirectional.centerStart, - widthFactor: animation.value, - child: Opacity( - opacity: animation.value, - child: Text( - 'Linting Tool', - style: textTheme.bodyLarge!.copyWith( - color: AppColors.white50, - ), - ), - ), - ), - SizedBox(width: 18 * animation.value), - ], - ), - ), - ], - ), - ), - const SizedBox(height: 8), - ], - ), - ); - }, - ); - } -} - -class _NavigationRailTrailingSection extends StatelessWidget { - const _NavigationRailTrailingSection({ - required this.trailingDestinations, - }); - - final Map trailingDestinations; - - @override - Widget build(BuildContext context) { - final theme = Theme.of(context); - final textTheme = theme.textTheme; - final navigationRailTheme = theme.navigationRailTheme; - final animation = NavigationRail.extendedAnimation(context); - - return AnimatedBuilder( - animation: animation, - builder: (context, child) { - return Visibility( - maintainAnimation: true, - maintainState: true, - visible: animation.value > 0, - child: Opacity( - opacity: animation.value, - child: Align( - widthFactor: animation.value, - alignment: AlignmentDirectional.centerStart, - child: SizedBox( - height: 485, - width: 256, - child: ListView( - padding: const EdgeInsets.all(12), - physics: const NeverScrollableScrollPhysics(), - children: [ - const Divider( - color: AppColors.blue200, - thickness: 0.4, - indent: 14, - endIndent: 16, - ), - const SizedBox(height: 8), - for (var item in trailingDestinations.keys) - InkWell( - borderRadius: const BorderRadius.all( - Radius.circular(36), - ), - onTap: () => _onTapped(context, item), - child: Column( - children: [ - Row( - children: [ - const SizedBox(width: 12), - Icon( - trailingDestinations[item], - color: AppColors.blue300, - ), - const SizedBox(width: 24), - Text( - item, - style: textTheme.bodyLarge!.copyWith( - color: navigationRailTheme - .unselectedLabelTextStyle!.color, - ), - ), - const SizedBox(height: 72), - ], - ), - ], - ), - ), - ], - ), - ), - ), - ), - ); - }, - ); - } - - void _onTapped(BuildContext context, String key) { - switch (key) { - case 'About': - showAboutDialog( - context: context, - applicationIcon: const FlutterLogo(), - children: [ - const Text( - 'A tool that helps you manage linter rules for your Flutter projects.', - ), - ], - ); - default: - break; - } - } -} - -class _Destination { - const _Destination({ - required this.destination, - required this.textLabel, - required this.icon, - this.selectedIcon, - }); - - final String textLabel; - final IconData icon; - final IconData? selectedIcon; - final Widget destination; -} diff --git a/experimental/linting_tool/lib/widgets/lint_expansion_tile.dart b/experimental/linting_tool/lib/widgets/lint_expansion_tile.dart deleted file mode 100644 index 0663203ad48..00000000000 --- a/experimental/linting_tool/lib/widgets/lint_expansion_tile.dart +++ /dev/null @@ -1,324 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:flutter_markdown/flutter_markdown.dart'; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/model/profiles_store.dart'; -import 'package:linting_tool/model/rule.dart'; -import 'package:linting_tool/theme/app_theme.dart'; -import 'package:linting_tool/theme/colors.dart'; -import 'package:provider/provider.dart'; - -class LintExpansionTile extends StatefulWidget { - final Rule rule; - - const LintExpansionTile({ - required this.rule, - super.key, - }); - - @override - State createState() => _LintExpansionTileState(); -} - -class _LintExpansionTileState extends State { - var isExpanded = false; - - @override - Widget build(BuildContext context) { - final theme = Theme.of(context); - final textTheme = theme.textTheme; - final rule = widget.rule; - final incompatibleString = - rule.incompatible.isNotEmpty ? rule.incompatible.join(', ') : 'none'; - final setsString = rule.sets.isNotEmpty ? rule.sets.join(', ') : 'none'; - return ExpansionTile( - collapsedBackgroundColor: AppColors.white50, - title: Text( - rule.name, - style: textTheme.titleMedium!.copyWith( - fontWeight: FontWeight.w700, - ), - ), - subtitle: Text( - rule.description, - style: textTheme.bodySmall!, - ), - initiallyExpanded: isExpanded, - onExpansionChanged: (value) { - setState(() { - isExpanded = value; - }); - }, - expandedAlignment: Alignment.centerLeft, - childrenPadding: const EdgeInsets.symmetric( - horizontal: 16.0, - vertical: 8.0, - ), - backgroundColor: AppColors.white50, - maintainState: true, - expandedCrossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'Group:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' ${rule.group}', - ), - ], - ), - textAlign: TextAlign.left, - ), - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'State:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' ${rule.state}', - ), - ], - ), - textAlign: TextAlign.left, - ), - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'Incompatible:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' $incompatibleString', - ), - ], - ), - textAlign: TextAlign.left, - ), - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'Sets:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' $setsString', - ), - ], - ), - textAlign: TextAlign.left, - ), - const SizedBox( - height: 16.0, - ), - MarkdownBody( - data: rule.details, - selectable: true, - styleSheet: AppTheme.buildMarkDownTheme(theme), - ), - const SizedBox( - height: 8.0, - ), - Align( - alignment: Alignment.centerRight, - child: ElevatedButton( - child: const Text('Add to profile'), - onPressed: () async { - ProfileType? destinationProfileType = - await showDialog( - context: context, - builder: (context) { - return const _ProfileTypeDialog(); - }, - ); - if (!context.mounted) return; - if (destinationProfileType == ProfileType.newProfile) { - await showDialog( - context: context, - builder: (context) { - return NewProfileDialog(rule: rule); - }, - ); - } else if (destinationProfileType == - ProfileType.existingProfile) { - await showDialog( - context: context, - builder: (context) { - return ExistingProfileDialog(rule: rule); - }, - ); - } - }, - ), - ), - const SizedBox( - height: 16.0, - ), - ], - ); - } -} - -enum ProfileType { - newProfile, - existingProfile, -} - -class _ProfileTypeDialog extends StatelessWidget { - const _ProfileTypeDialog(); - - @override - Widget build(BuildContext context) { - var profilesStore = context.watch(); - - return AlertDialog( - actionsPadding: const EdgeInsets.only( - left: 16.0, - right: 16.0, - bottom: 16.0, - ), - title: const Text('Select Profile Type'), - actions: [ - if (profilesStore.savedProfiles.isNotEmpty) - ElevatedButton( - onPressed: () { - Navigator.pop(context, ProfileType.existingProfile); - }, - child: const Text('Existing'), - ), - TextButton( - onPressed: () { - Navigator.pop(context, ProfileType.newProfile); - }, - child: const Text('New'), - ), - ], - ); - } -} - -class NewProfileDialog extends StatefulWidget { - final Rule rule; - const NewProfileDialog({ - required this.rule, - super.key, - }); - - @override - State createState() => _NewProfileDialogState(); -} - -class _NewProfileDialogState extends State { - @override - Widget build(BuildContext context) { - String name = ''; - final formKey = GlobalKey(); - - return AlertDialog( - title: const Text('Create new lint profile'), - content: Form( - key: formKey, - autovalidateMode: AutovalidateMode.onUserInteraction, - child: Column( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - const Text('Profile Name'), - TextFormField( - onChanged: (value) { - name = value; - }, - validator: (value) { - if (value == null || value.isEmpty) { - return 'Name cannot be empty.'; - } - return null; - }, - ), - ], - ), - ), - actionsPadding: const EdgeInsets.all(16.0), - actions: [ - TextButton( - onPressed: () { - Navigator.pop(context); - }, - child: const Text('Cancel'), - ), - ElevatedButton( - onPressed: () async { - if (formKey.currentState!.validate()) { - var newProfile = RulesProfile( - name: name, - rules: [widget.rule], - ); - await Provider.of(context, listen: false) - .addToNewProfile(newProfile); - if (!context.mounted) return; - Navigator.pop(context); - } - }, - child: const Text('Save'), - ), - ], - ); - } -} - -class ExistingProfileDialog extends StatefulWidget { - const ExistingProfileDialog({ - super.key, - required this.rule, - }); - - final Rule rule; - - @override - State createState() => _ExistingProfileDialogState(); -} - -class _ExistingProfileDialogState extends State { - @override - Widget build(BuildContext context) { - final profilesStore = Provider.of(context); - final savedProfiles = profilesStore.savedProfiles; - return AlertDialog( - title: const Text('Select a lint profile'), - content: Column( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: CrossAxisAlignment.start, - children: List.generate( - savedProfiles.length, - (index) => ListTile( - title: Text(savedProfiles[index].name), - onTap: () async { - await profilesStore.addToExistingProfile( - savedProfiles[index], widget.rule); - if (!context.mounted) return; - Navigator.pop(context); - }, - ), - ), - ), - actionsPadding: const EdgeInsets.all(16.0), - actions: [ - TextButton( - onPressed: () { - Navigator.pop(context); - }, - child: const Text('Cancel'), - ), - ], - ); - } -} diff --git a/experimental/linting_tool/lib/widgets/saved_rule_tile.dart b/experimental/linting_tool/lib/widgets/saved_rule_tile.dart deleted file mode 100644 index 79c92702563..00000000000 --- a/experimental/linting_tool/lib/widgets/saved_rule_tile.dart +++ /dev/null @@ -1,158 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'package:flutter/material.dart'; -import 'package:flutter_markdown/flutter_markdown.dart'; -import 'package:linting_tool/model/editing_controller.dart'; -import 'package:linting_tool/model/rule.dart'; -import 'package:linting_tool/theme/app_theme.dart'; -import 'package:linting_tool/theme/colors.dart'; -import 'package:provider/provider.dart'; - -class SavedRuleTile extends StatefulWidget { - final Rule rule; - - const SavedRuleTile({ - required this.rule, - super.key, - }); - - @override - State createState() => _SavedRuleTileState(); -} - -class _SavedRuleTileState extends State { - var isExpanded = false; - var isSelected = false; - - @override - Widget build(BuildContext context) { - final theme = Theme.of(context); - final textTheme = theme.textTheme; - final rule = widget.rule; - final incompatibleString = - rule.incompatible.isNotEmpty ? rule.incompatible.join(', ') : 'none'; - final setsString = rule.sets.isNotEmpty ? rule.sets.join(', ') : 'none'; - - return Consumer( - builder: (context, editingController, child) { - return ExpansionTile( - collapsedBackgroundColor: AppColors.white50, - leading: editingController.isEditing - ? Checkbox( - value: isSelected && - editingController.selectedRules.contains(rule), - onChanged: (value) { - if (value!) { - editingController.selectRule(rule); - setState(() { - isSelected = value; - }); - } else { - editingController.deselectRule(rule); - setState(() { - isSelected = value; - }); - } - }, - ) - : null, - title: Text( - rule.name, - style: textTheme.titleMedium!.copyWith( - fontWeight: FontWeight.w700, - ), - ), - subtitle: Text( - rule.description, - style: textTheme.bodySmall!, - ), - initiallyExpanded: isExpanded, - onExpansionChanged: (value) { - setState(() { - isExpanded = value; - }); - }, - expandedAlignment: Alignment.centerLeft, - childrenPadding: const EdgeInsets.symmetric( - horizontal: 16.0, - vertical: 8.0, - ), - backgroundColor: AppColors.white50, - maintainState: true, - expandedCrossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'Group:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' ${rule.group}', - ), - ], - ), - textAlign: TextAlign.left, - ), - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'State:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' ${rule.state}', - ), - ], - ), - textAlign: TextAlign.left, - ), - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'Incompatible:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' $incompatibleString', - ), - ], - ), - textAlign: TextAlign.left, - ), - Text.rich( - TextSpan( - children: [ - TextSpan( - text: 'Sets:', - style: textTheme.titleSmall, - ), - TextSpan( - text: ' $setsString', - ), - ], - ), - textAlign: TextAlign.left, - ), - const SizedBox( - height: 16.0, - ), - MarkdownBody( - data: rule.details, - selectable: true, - styleSheet: AppTheme.buildMarkDownTheme(theme), - ), - const SizedBox( - height: 16.0, - ), - ], - ); - }, - ); - } -} diff --git a/experimental/linting_tool/linux/.gitignore b/experimental/linting_tool/linux/.gitignore deleted file mode 100644 index d3896c98444..00000000000 --- a/experimental/linting_tool/linux/.gitignore +++ /dev/null @@ -1 +0,0 @@ -flutter/ephemeral diff --git a/experimental/linting_tool/linux/CMakeLists.txt b/experimental/linting_tool/linux/CMakeLists.txt deleted file mode 100644 index 868809639b3..00000000000 --- a/experimental/linting_tool/linux/CMakeLists.txt +++ /dev/null @@ -1,116 +0,0 @@ -cmake_minimum_required(VERSION 3.10) -project(runner LANGUAGES CXX) - -set(BINARY_NAME "linting_tool") -set(APPLICATION_ID "dev.flutter.linting_tool") - -cmake_policy(SET CMP0063 NEW) - -set(CMAKE_INSTALL_RPATH "$ORIGIN/lib") - -# Root filesystem for cross-building. -if(FLUTTER_TARGET_PLATFORM_SYSROOT) - set(CMAKE_SYSROOT ${FLUTTER_TARGET_PLATFORM_SYSROOT}) - set(CMAKE_FIND_ROOT_PATH ${CMAKE_SYSROOT}) - set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) - set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY) - set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) - set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) -endif() - -# Configure build options. -if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) - set(CMAKE_BUILD_TYPE "Debug" CACHE - STRING "Flutter build mode" FORCE) - set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS - "Debug" "Profile" "Release") -endif() - -# Compilation settings that should be applied to most targets. -function(APPLY_STANDARD_SETTINGS TARGET) - target_compile_features(${TARGET} PUBLIC cxx_std_14) - target_compile_options(${TARGET} PRIVATE -Wall -Werror) - target_compile_options(${TARGET} PRIVATE "$<$>:-O3>") - target_compile_definitions(${TARGET} PRIVATE "$<$>:NDEBUG>") -endfunction() - -set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter") - -# Flutter library and tool build rules. -add_subdirectory(${FLUTTER_MANAGED_DIR}) - -# System-level dependencies. -find_package(PkgConfig REQUIRED) -pkg_check_modules(GTK REQUIRED IMPORTED_TARGET gtk+-3.0) - -add_definitions(-DAPPLICATION_ID="${APPLICATION_ID}") - -# Application build -add_executable(${BINARY_NAME} - "main.cc" - "my_application.cc" - "${FLUTTER_MANAGED_DIR}/generated_plugin_registrant.cc" -) -apply_standard_settings(${BINARY_NAME}) -target_link_libraries(${BINARY_NAME} PRIVATE flutter) -target_link_libraries(${BINARY_NAME} PRIVATE PkgConfig::GTK) -add_dependencies(${BINARY_NAME} flutter_assemble) -# Only the install-generated bundle's copy of the executable will launch -# correctly, since the resources must in the right relative locations. To avoid -# people trying to run the unbundled copy, put it in a subdirectory instead of -# the default top-level location. -set_target_properties(${BINARY_NAME} - PROPERTIES - RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/intermediates_do_not_run" -) - -# Generated plugin build rules, which manage building the plugins and adding -# them to the application. -include(flutter/generated_plugins.cmake) - - -# === Installation === -# By default, "installing" just makes a relocatable bundle in the build -# directory. -set(BUILD_BUNDLE_DIR "${PROJECT_BINARY_DIR}/bundle") -if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) - set(CMAKE_INSTALL_PREFIX "${BUILD_BUNDLE_DIR}" CACHE PATH "..." FORCE) -endif() - -# Start with a clean build bundle directory every time. -install(CODE " - file(REMOVE_RECURSE \"${BUILD_BUNDLE_DIR}/\") - " COMPONENT Runtime) - -set(INSTALL_BUNDLE_DATA_DIR "${CMAKE_INSTALL_PREFIX}/data") -set(INSTALL_BUNDLE_LIB_DIR "${CMAKE_INSTALL_PREFIX}/lib") - -install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}" - COMPONENT Runtime) - -install(FILES "${FLUTTER_ICU_DATA_FILE}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" - COMPONENT Runtime) - -install(FILES "${FLUTTER_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" - COMPONENT Runtime) - -if(PLUGIN_BUNDLED_LIBRARIES) - install(FILES "${PLUGIN_BUNDLED_LIBRARIES}" - DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" - COMPONENT Runtime) -endif() - -# Fully re-copy the assets directory on each build to avoid having stale files -# from a previous install. -set(FLUTTER_ASSET_DIR_NAME "flutter_assets") -install(CODE " - file(REMOVE_RECURSE \"${INSTALL_BUNDLE_DATA_DIR}/${FLUTTER_ASSET_DIR_NAME}\") - " COMPONENT Runtime) -install(DIRECTORY "${PROJECT_BUILD_DIR}/${FLUTTER_ASSET_DIR_NAME}" - DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" COMPONENT Runtime) - -# Install the AOT library on non-Debug builds only. -if(NOT CMAKE_BUILD_TYPE MATCHES "Debug") - install(FILES "${AOT_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" - COMPONENT Runtime) -endif() diff --git a/experimental/linting_tool/linux/flutter/CMakeLists.txt b/experimental/linting_tool/linux/flutter/CMakeLists.txt deleted file mode 100644 index 33fd5801e71..00000000000 --- a/experimental/linting_tool/linux/flutter/CMakeLists.txt +++ /dev/null @@ -1,87 +0,0 @@ -cmake_minimum_required(VERSION 3.10) - -set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral") - -# Configuration provided via flutter tool. -include(${EPHEMERAL_DIR}/generated_config.cmake) - -# TODO: Move the rest of this into files in ephemeral. See -# https://github.com/flutter/flutter/issues/57146. - -# Serves the same purpose as list(TRANSFORM ... PREPEND ...), -# which isn't available in 3.10. -function(list_prepend LIST_NAME PREFIX) - set(NEW_LIST "") - foreach(element ${${LIST_NAME}}) - list(APPEND NEW_LIST "${PREFIX}${element}") - endforeach(element) - set(${LIST_NAME} "${NEW_LIST}" PARENT_SCOPE) -endfunction() - -# === Flutter Library === -# System-level dependencies. -find_package(PkgConfig REQUIRED) -pkg_check_modules(GTK REQUIRED IMPORTED_TARGET gtk+-3.0) -pkg_check_modules(GLIB REQUIRED IMPORTED_TARGET glib-2.0) -pkg_check_modules(GIO REQUIRED IMPORTED_TARGET gio-2.0) - -set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/libflutter_linux_gtk.so") - -# Published to parent scope for install step. -set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE) -set(FLUTTER_ICU_DATA_FILE "${EPHEMERAL_DIR}/icudtl.dat" PARENT_SCOPE) -set(PROJECT_BUILD_DIR "${PROJECT_DIR}/build/" PARENT_SCOPE) -set(AOT_LIBRARY "${PROJECT_DIR}/build/lib/libapp.so" PARENT_SCOPE) - -list(APPEND FLUTTER_LIBRARY_HEADERS - "fl_basic_message_channel.h" - "fl_binary_codec.h" - "fl_binary_messenger.h" - "fl_dart_project.h" - "fl_engine.h" - "fl_json_message_codec.h" - "fl_json_method_codec.h" - "fl_message_codec.h" - "fl_method_call.h" - "fl_method_channel.h" - "fl_method_codec.h" - "fl_method_response.h" - "fl_plugin_registrar.h" - "fl_plugin_registry.h" - "fl_standard_message_codec.h" - "fl_standard_method_codec.h" - "fl_string_codec.h" - "fl_value.h" - "fl_view.h" - "flutter_linux.h" -) -list_prepend(FLUTTER_LIBRARY_HEADERS "${EPHEMERAL_DIR}/flutter_linux/") -add_library(flutter INTERFACE) -target_include_directories(flutter INTERFACE - "${EPHEMERAL_DIR}" -) -target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}") -target_link_libraries(flutter INTERFACE - PkgConfig::GTK - PkgConfig::GLIB - PkgConfig::GIO -) -add_dependencies(flutter flutter_assemble) - -# === Flutter tool backend === -# _phony_ is a non-existent file to force this command to run every time, -# since currently there's no way to get a full input/output list from the -# flutter tool. -add_custom_command( - OUTPUT ${FLUTTER_LIBRARY} ${FLUTTER_LIBRARY_HEADERS} - ${CMAKE_CURRENT_BINARY_DIR}/_phony_ - COMMAND ${CMAKE_COMMAND} -E env - ${FLUTTER_TOOL_ENVIRONMENT} - "${FLUTTER_ROOT}/packages/flutter_tools/bin/tool_backend.sh" - ${FLUTTER_TARGET_PLATFORM} ${CMAKE_BUILD_TYPE} - VERBATIM -) -add_custom_target(flutter_assemble DEPENDS - "${FLUTTER_LIBRARY}" - ${FLUTTER_LIBRARY_HEADERS} -) diff --git a/experimental/linting_tool/linux/flutter/generated_plugin_registrant.cc b/experimental/linting_tool/linux/flutter/generated_plugin_registrant.cc deleted file mode 100644 index c259cda910a..00000000000 --- a/experimental/linting_tool/linux/flutter/generated_plugin_registrant.cc +++ /dev/null @@ -1,23 +0,0 @@ -// -// Generated file. Do not edit. -// - -// clang-format off - -#include "generated_plugin_registrant.h" - -#include -#include -#include - -void fl_register_plugins(FlPluginRegistry* registry) { - g_autoptr(FlPluginRegistrar) file_selector_linux_registrar = - fl_plugin_registry_get_registrar_for_plugin(registry, "FileSelectorPlugin"); - file_selector_plugin_register_with_registrar(file_selector_linux_registrar); - g_autoptr(FlPluginRegistrar) url_launcher_linux_registrar = - fl_plugin_registry_get_registrar_for_plugin(registry, "UrlLauncherPlugin"); - url_launcher_plugin_register_with_registrar(url_launcher_linux_registrar); - g_autoptr(FlPluginRegistrar) window_size_registrar = - fl_plugin_registry_get_registrar_for_plugin(registry, "WindowSizePlugin"); - window_size_plugin_register_with_registrar(window_size_registrar); -} diff --git a/experimental/linting_tool/linux/flutter/generated_plugin_registrant.h b/experimental/linting_tool/linux/flutter/generated_plugin_registrant.h deleted file mode 100644 index e0f0a47bc08..00000000000 --- a/experimental/linting_tool/linux/flutter/generated_plugin_registrant.h +++ /dev/null @@ -1,15 +0,0 @@ -// -// Generated file. Do not edit. -// - -// clang-format off - -#ifndef GENERATED_PLUGIN_REGISTRANT_ -#define GENERATED_PLUGIN_REGISTRANT_ - -#include - -// Registers Flutter plugins. -void fl_register_plugins(FlPluginRegistry* registry); - -#endif // GENERATED_PLUGIN_REGISTRANT_ diff --git a/experimental/linting_tool/linux/flutter/generated_plugins.cmake b/experimental/linting_tool/linux/flutter/generated_plugins.cmake deleted file mode 100644 index 7c9fef0b892..00000000000 --- a/experimental/linting_tool/linux/flutter/generated_plugins.cmake +++ /dev/null @@ -1,26 +0,0 @@ -# -# Generated file, do not edit. -# - -list(APPEND FLUTTER_PLUGIN_LIST - file_selector_linux - url_launcher_linux - window_size -) - -list(APPEND FLUTTER_FFI_PLUGIN_LIST -) - -set(PLUGIN_BUNDLED_LIBRARIES) - -foreach(plugin ${FLUTTER_PLUGIN_LIST}) - add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/linux plugins/${plugin}) - target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin) - list(APPEND PLUGIN_BUNDLED_LIBRARIES $) - list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries}) -endforeach(plugin) - -foreach(ffi_plugin ${FLUTTER_FFI_PLUGIN_LIST}) - add_subdirectory(flutter/ephemeral/.plugin_symlinks/${ffi_plugin}/linux plugins/${ffi_plugin}) - list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${ffi_plugin}_bundled_libraries}) -endforeach(ffi_plugin) diff --git a/experimental/linting_tool/linux/main.cc b/experimental/linting_tool/linux/main.cc deleted file mode 100644 index e7c5c543703..00000000000 --- a/experimental/linting_tool/linux/main.cc +++ /dev/null @@ -1,6 +0,0 @@ -#include "my_application.h" - -int main(int argc, char** argv) { - g_autoptr(MyApplication) app = my_application_new(); - return g_application_run(G_APPLICATION(app), argc, argv); -} diff --git a/experimental/linting_tool/linux/my_application.cc b/experimental/linting_tool/linux/my_application.cc deleted file mode 100644 index 440d21dfd87..00000000000 --- a/experimental/linting_tool/linux/my_application.cc +++ /dev/null @@ -1,105 +0,0 @@ -#include "my_application.h" - -#include -#ifdef GDK_WINDOWING_X11 -#include -#endif - -#include "flutter/generated_plugin_registrant.h" - -struct _MyApplication { - GtkApplication parent_instance; - char** dart_entrypoint_arguments; -}; - -G_DEFINE_TYPE(MyApplication, my_application, GTK_TYPE_APPLICATION) - -// Implements GApplication::activate. -static void my_application_activate(GApplication* application) { - MyApplication* self = MY_APPLICATION(application); - GtkWindow* window = - GTK_WINDOW(gtk_application_window_new(GTK_APPLICATION(application))); - - // Use a header bar when running in GNOME as this is the common style used - // by applications and is the setup most users will be using (e.g. Ubuntu - // desktop). - // If running on X and not using GNOME then just use a traditional title bar - // in case the window manager does more exotic layout, e.g. tiling. - // If running on Wayland assume the header bar will work (may need changing - // if future cases occur). - gboolean use_header_bar = TRUE; -#ifdef GDK_WINDOWING_X11 - GdkScreen *screen = gtk_window_get_screen(window); - if (GDK_IS_X11_SCREEN(screen)) { - const gchar* wm_name = gdk_x11_screen_get_window_manager_name(screen); - if (g_strcmp0(wm_name, "GNOME Shell") != 0) { - use_header_bar = FALSE; - } - } -#endif - if (use_header_bar) { - GtkHeaderBar *header_bar = GTK_HEADER_BAR(gtk_header_bar_new()); - gtk_widget_show(GTK_WIDGET(header_bar)); - gtk_header_bar_set_title(header_bar, "linting_tool"); - gtk_header_bar_set_show_close_button(header_bar, TRUE); - gtk_window_set_titlebar(window, GTK_WIDGET(header_bar)); - } - else { - gtk_window_set_title(window, "linting_tool"); - } - - gtk_window_set_default_size(window, 1280, 720); - gtk_widget_show(GTK_WIDGET(window)); - - g_autoptr(FlDartProject) project = fl_dart_project_new(); - fl_dart_project_set_dart_entrypoint_arguments(project, self->dart_entrypoint_arguments); - - FlView* view = fl_view_new(project); - gtk_widget_show(GTK_WIDGET(view)); - gtk_container_add(GTK_CONTAINER(window), GTK_WIDGET(view)); - - fl_register_plugins(FL_PLUGIN_REGISTRY(view)); - - gtk_widget_grab_focus(GTK_WIDGET(view)); -} - -// Implements GApplication::local_command_line. -static gboolean my_application_local_command_line(GApplication* application, gchar ***arguments, int *exit_status) { - MyApplication* self = MY_APPLICATION(application); - // Strip out the first argument as it is the binary name. - self->dart_entrypoint_arguments = g_strdupv(*arguments + 1); - - g_autoptr(GError) error = nullptr; - if (!g_application_register(application, nullptr, &error)) { - g_warning("Failed to register: %s", error->message); - *exit_status = 1; - return TRUE; - } - - g_application_activate(application); - *exit_status = 0; - - return TRUE; -} - -// Implements GObject::dispose. -static void my_application_dispose(GObject *object) { - MyApplication* self = MY_APPLICATION(object); - g_clear_pointer(&self->dart_entrypoint_arguments, g_strfreev); - G_OBJECT_CLASS(my_application_parent_class)->dispose(object); -} - -static void my_application_class_init(MyApplicationClass* klass) { - G_APPLICATION_CLASS(klass)->activate = my_application_activate; - G_APPLICATION_CLASS(klass)->local_command_line = my_application_local_command_line; - G_OBJECT_CLASS(klass)->dispose = my_application_dispose; -} - -static void my_application_init(MyApplication* self) {} - -MyApplication* my_application_new() { - return MY_APPLICATION(g_object_new(my_application_get_type(), - "application-id", APPLICATION_ID, - "flags", G_APPLICATION_NON_UNIQUE, - nullptr)); -} diff --git a/experimental/linting_tool/linux/my_application.h b/experimental/linting_tool/linux/my_application.h deleted file mode 100644 index 72271d5e417..00000000000 --- a/experimental/linting_tool/linux/my_application.h +++ /dev/null @@ -1,18 +0,0 @@ -#ifndef FLUTTER_MY_APPLICATION_H_ -#define FLUTTER_MY_APPLICATION_H_ - -#include - -G_DECLARE_FINAL_TYPE(MyApplication, my_application, MY, APPLICATION, - GtkApplication) - -/** - * my_application_new: - * - * Creates a new Flutter-based application. - * - * Returns: a new #MyApplication. - */ -MyApplication* my_application_new(); - -#endif // FLUTTER_MY_APPLICATION_H_ diff --git a/experimental/linting_tool/macos/.gitignore b/experimental/linting_tool/macos/.gitignore deleted file mode 100644 index d2fd3772308..00000000000 --- a/experimental/linting_tool/macos/.gitignore +++ /dev/null @@ -1,6 +0,0 @@ -# Flutter-related -**/Flutter/ephemeral/ -**/Pods/ - -# Xcode-related -**/xcuserdata/ diff --git a/experimental/linting_tool/macos/Flutter/Flutter-Debug.xcconfig b/experimental/linting_tool/macos/Flutter/Flutter-Debug.xcconfig deleted file mode 100644 index 4b81f9b2d20..00000000000 --- a/experimental/linting_tool/macos/Flutter/Flutter-Debug.xcconfig +++ /dev/null @@ -1,2 +0,0 @@ -#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig" -#include "ephemeral/Flutter-Generated.xcconfig" diff --git a/experimental/linting_tool/macos/Flutter/Flutter-Release.xcconfig b/experimental/linting_tool/macos/Flutter/Flutter-Release.xcconfig deleted file mode 100644 index 5caa9d1579e..00000000000 --- a/experimental/linting_tool/macos/Flutter/Flutter-Release.xcconfig +++ /dev/null @@ -1,2 +0,0 @@ -#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig" -#include "ephemeral/Flutter-Generated.xcconfig" diff --git a/experimental/linting_tool/macos/Flutter/GeneratedPluginRegistrant.swift b/experimental/linting_tool/macos/Flutter/GeneratedPluginRegistrant.swift deleted file mode 100644 index 87d00ec0290..00000000000 --- a/experimental/linting_tool/macos/Flutter/GeneratedPluginRegistrant.swift +++ /dev/null @@ -1,18 +0,0 @@ -// -// Generated file. Do not edit. -// - -import FlutterMacOS -import Foundation - -import file_selector_macos -import path_provider_foundation -import url_launcher_macos -import window_size - -func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) { - FileSelectorPlugin.register(with: registry.registrar(forPlugin: "FileSelectorPlugin")) - PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin")) - UrlLauncherPlugin.register(with: registry.registrar(forPlugin: "UrlLauncherPlugin")) - WindowSizePlugin.register(with: registry.registrar(forPlugin: "WindowSizePlugin")) -} diff --git a/experimental/linting_tool/macos/Podfile b/experimental/linting_tool/macos/Podfile deleted file mode 100644 index dade8dfad0d..00000000000 --- a/experimental/linting_tool/macos/Podfile +++ /dev/null @@ -1,40 +0,0 @@ -platform :osx, '10.11' - -# CocoaPods analytics sends network stats synchronously affecting flutter build latency. -ENV['COCOAPODS_DISABLE_STATS'] = 'true' - -project 'Runner', { - 'Debug' => :debug, - 'Profile' => :release, - 'Release' => :release, -} - -def flutter_root - generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'ephemeral', 'Flutter-Generated.xcconfig'), __FILE__) - unless File.exist?(generated_xcode_build_settings_path) - raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure \"flutter pub get\" is executed first" - end - - File.foreach(generated_xcode_build_settings_path) do |line| - matches = line.match(/FLUTTER_ROOT\=(.*)/) - return matches[1].strip if matches - end - raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Flutter-Generated.xcconfig, then run \"flutter pub get\"" -end - -require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root) - -flutter_macos_podfile_setup - -target 'Runner' do - use_frameworks! - use_modular_headers! - - flutter_install_all_macos_pods File.dirname(File.realpath(__FILE__)) -end - -post_install do |installer| - installer.pods_project.targets.each do |target| - flutter_additional_macos_build_settings(target) - end -end diff --git a/experimental/linting_tool/macos/Runner.xcodeproj/project.pbxproj b/experimental/linting_tool/macos/Runner.xcodeproj/project.pbxproj deleted file mode 100644 index 5eac5b098a5..00000000000 --- a/experimental/linting_tool/macos/Runner.xcodeproj/project.pbxproj +++ /dev/null @@ -1,632 +0,0 @@ -// !$*UTF8*$! -{ - archiveVersion = 1; - classes = { - }; - objectVersion = 51; - objects = { - -/* Begin PBXAggregateTarget section */ - 33CC111A2044C6BA0003C045 /* Flutter Assemble */ = { - isa = PBXAggregateTarget; - buildConfigurationList = 33CC111B2044C6BA0003C045 /* Build configuration list for PBXAggregateTarget "Flutter Assemble" */; - buildPhases = ( - 33CC111E2044C6BF0003C045 /* ShellScript */, - ); - dependencies = ( - ); - name = "Flutter Assemble"; - productName = FLX; - }; -/* End PBXAggregateTarget section */ - -/* Begin PBXBuildFile section */ - 263EC21EDDA79B90E36D3AF2 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 4BA99C65F70358A600BD0DB9 /* Pods_Runner.framework */; }; - 335BBD1B22A9A15E00E9071D /* GeneratedPluginRegistrant.swift in Sources */ = {isa = PBXBuildFile; fileRef = 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */; }; - 33CC10F12044A3C60003C045 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33CC10F02044A3C60003C045 /* AppDelegate.swift */; }; - 33CC10F32044A3C60003C045 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 33CC10F22044A3C60003C045 /* Assets.xcassets */; }; - 33CC10F62044A3C60003C045 /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 33CC10F42044A3C60003C045 /* MainMenu.xib */; }; - 33CC11132044BFA00003C045 /* MainFlutterWindow.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */; }; -/* End PBXBuildFile section */ - -/* Begin PBXContainerItemProxy section */ - 33CC111F2044C79F0003C045 /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = 33CC10E52044A3C60003C045 /* Project object */; - proxyType = 1; - remoteGlobalIDString = 33CC111A2044C6BA0003C045; - remoteInfo = FLX; - }; -/* End PBXContainerItemProxy section */ - -/* Begin PBXCopyFilesBuildPhase section */ - 33CC110E2044A8840003C045 /* Bundle Framework */ = { - isa = PBXCopyFilesBuildPhase; - buildActionMask = 2147483647; - dstPath = ""; - dstSubfolderSpec = 10; - files = ( - ); - name = "Bundle Framework"; - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXCopyFilesBuildPhase section */ - -/* Begin PBXFileReference section */ - 1FF9829B1C25BAA5E9CFD6F7 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; }; - 333000ED22D3DE5D00554162 /* Warnings.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Warnings.xcconfig; sourceTree = ""; }; - 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = GeneratedPluginRegistrant.swift; sourceTree = ""; }; - 33CC10ED2044A3C60003C045 /* linting_tool.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = linting_tool.app; sourceTree = BUILT_PRODUCTS_DIR; }; - 33CC10F02044A3C60003C045 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; - 33CC10F22044A3C60003C045 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Assets.xcassets; path = Runner/Assets.xcassets; sourceTree = ""; }; - 33CC10F52044A3C60003C045 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/MainMenu.xib; sourceTree = ""; }; - 33CC10F72044A3C60003C045 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; name = Info.plist; path = Runner/Info.plist; sourceTree = ""; }; - 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MainFlutterWindow.swift; sourceTree = ""; }; - 33CEB47222A05771004F2AC0 /* Flutter-Debug.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = "Flutter-Debug.xcconfig"; sourceTree = ""; }; - 33CEB47422A05771004F2AC0 /* Flutter-Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = "Flutter-Release.xcconfig"; sourceTree = ""; }; - 33CEB47722A0578A004F2AC0 /* Flutter-Generated.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = "Flutter-Generated.xcconfig"; path = "ephemeral/Flutter-Generated.xcconfig"; sourceTree = ""; }; - 33E51913231747F40026EE4D /* DebugProfile.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = DebugProfile.entitlements; sourceTree = ""; }; - 33E51914231749380026EE4D /* Release.entitlements */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.entitlements; path = Release.entitlements; sourceTree = ""; }; - 33E5194F232828860026EE4D /* AppInfo.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = AppInfo.xcconfig; sourceTree = ""; }; - 4BA99C65F70358A600BD0DB9 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - 66D130ED505BEFC4C780F92C /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; }; - 7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Release.xcconfig; sourceTree = ""; }; - 7E301E068432A8A69757147C /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = ""; }; - 9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; path = Debug.xcconfig; sourceTree = ""; }; -/* End PBXFileReference section */ - -/* Begin PBXFrameworksBuildPhase section */ - 33CC10EA2044A3C60003C045 /* Frameworks */ = { - isa = PBXFrameworksBuildPhase; - buildActionMask = 2147483647; - files = ( - 263EC21EDDA79B90E36D3AF2 /* Pods_Runner.framework in Frameworks */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXFrameworksBuildPhase section */ - -/* Begin PBXGroup section */ - 33BA886A226E78AF003329D5 /* Configs */ = { - isa = PBXGroup; - children = ( - 33E5194F232828860026EE4D /* AppInfo.xcconfig */, - 9740EEB21CF90195004384FC /* Debug.xcconfig */, - 7AFA3C8E1D35360C0083082E /* Release.xcconfig */, - 333000ED22D3DE5D00554162 /* Warnings.xcconfig */, - ); - path = Configs; - sourceTree = ""; - }; - 33CC10E42044A3C60003C045 = { - isa = PBXGroup; - children = ( - 33FAB671232836740065AC1E /* Runner */, - 33CEB47122A05771004F2AC0 /* Flutter */, - 33CC10EE2044A3C60003C045 /* Products */, - D73912EC22F37F3D000D13A0 /* Frameworks */, - 51EE2FAB634AFBA8448DB770 /* Pods */, - ); - sourceTree = ""; - }; - 33CC10EE2044A3C60003C045 /* Products */ = { - isa = PBXGroup; - children = ( - 33CC10ED2044A3C60003C045 /* linting_tool.app */, - ); - name = Products; - sourceTree = ""; - }; - 33CC11242044D66E0003C045 /* Resources */ = { - isa = PBXGroup; - children = ( - 33CC10F22044A3C60003C045 /* Assets.xcassets */, - 33CC10F42044A3C60003C045 /* MainMenu.xib */, - 33CC10F72044A3C60003C045 /* Info.plist */, - ); - name = Resources; - path = ..; - sourceTree = ""; - }; - 33CEB47122A05771004F2AC0 /* Flutter */ = { - isa = PBXGroup; - children = ( - 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */, - 33CEB47222A05771004F2AC0 /* Flutter-Debug.xcconfig */, - 33CEB47422A05771004F2AC0 /* Flutter-Release.xcconfig */, - 33CEB47722A0578A004F2AC0 /* Flutter-Generated.xcconfig */, - ); - path = Flutter; - sourceTree = ""; - }; - 33FAB671232836740065AC1E /* Runner */ = { - isa = PBXGroup; - children = ( - 33CC10F02044A3C60003C045 /* AppDelegate.swift */, - 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */, - 33E51913231747F40026EE4D /* DebugProfile.entitlements */, - 33E51914231749380026EE4D /* Release.entitlements */, - 33CC11242044D66E0003C045 /* Resources */, - 33BA886A226E78AF003329D5 /* Configs */, - ); - path = Runner; - sourceTree = ""; - }; - 51EE2FAB634AFBA8448DB770 /* Pods */ = { - isa = PBXGroup; - children = ( - 66D130ED505BEFC4C780F92C /* Pods-Runner.debug.xcconfig */, - 1FF9829B1C25BAA5E9CFD6F7 /* Pods-Runner.release.xcconfig */, - 7E301E068432A8A69757147C /* Pods-Runner.profile.xcconfig */, - ); - name = Pods; - path = Pods; - sourceTree = ""; - }; - D73912EC22F37F3D000D13A0 /* Frameworks */ = { - isa = PBXGroup; - children = ( - 4BA99C65F70358A600BD0DB9 /* Pods_Runner.framework */, - ); - name = Frameworks; - sourceTree = ""; - }; -/* End PBXGroup section */ - -/* Begin PBXNativeTarget section */ - 33CC10EC2044A3C60003C045 /* Runner */ = { - isa = PBXNativeTarget; - buildConfigurationList = 33CC10FB2044A3C60003C045 /* Build configuration list for PBXNativeTarget "Runner" */; - buildPhases = ( - FA1FF96E71045A62F03992DA /* [CP] Check Pods Manifest.lock */, - 33CC10E92044A3C60003C045 /* Sources */, - 33CC10EA2044A3C60003C045 /* Frameworks */, - 33CC10EB2044A3C60003C045 /* Resources */, - 33CC110E2044A8840003C045 /* Bundle Framework */, - 3399D490228B24CF009A79C7 /* ShellScript */, - A7CF0EFBD867541ADB9884D5 /* [CP] Embed Pods Frameworks */, - ); - buildRules = ( - ); - dependencies = ( - 33CC11202044C79F0003C045 /* PBXTargetDependency */, - ); - name = Runner; - productName = Runner; - productReference = 33CC10ED2044A3C60003C045 /* linting_tool.app */; - productType = "com.apple.product-type.application"; - }; -/* End PBXNativeTarget section */ - -/* Begin PBXProject section */ - 33CC10E52044A3C60003C045 /* Project object */ = { - isa = PBXProject; - attributes = { - LastSwiftUpdateCheck = 0920; - LastUpgradeCheck = 0930; - ORGANIZATIONNAME = ""; - TargetAttributes = { - 33CC10EC2044A3C60003C045 = { - CreatedOnToolsVersion = 9.2; - LastSwiftMigration = 1100; - ProvisioningStyle = Automatic; - SystemCapabilities = { - com.apple.Sandbox = { - enabled = 1; - }; - }; - }; - 33CC111A2044C6BA0003C045 = { - CreatedOnToolsVersion = 9.2; - ProvisioningStyle = Manual; - }; - }; - }; - buildConfigurationList = 33CC10E82044A3C60003C045 /* Build configuration list for PBXProject "Runner" */; - compatibilityVersion = "Xcode 9.3"; - developmentRegion = en; - hasScannedForEncodings = 0; - knownRegions = ( - en, - Base, - ); - mainGroup = 33CC10E42044A3C60003C045; - productRefGroup = 33CC10EE2044A3C60003C045 /* Products */; - projectDirPath = ""; - projectRoot = ""; - targets = ( - 33CC10EC2044A3C60003C045 /* Runner */, - 33CC111A2044C6BA0003C045 /* Flutter Assemble */, - ); - }; -/* End PBXProject section */ - -/* Begin PBXResourcesBuildPhase section */ - 33CC10EB2044A3C60003C045 /* Resources */ = { - isa = PBXResourcesBuildPhase; - buildActionMask = 2147483647; - files = ( - 33CC10F32044A3C60003C045 /* Assets.xcassets in Resources */, - 33CC10F62044A3C60003C045 /* MainMenu.xib in Resources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXResourcesBuildPhase section */ - -/* Begin PBXShellScriptBuildPhase section */ - 3399D490228B24CF009A79C7 /* ShellScript */ = { - isa = PBXShellScriptBuildPhase; - buildActionMask = 2147483647; - files = ( - ); - inputFileListPaths = ( - ); - inputPaths = ( - ); - outputFileListPaths = ( - ); - outputPaths = ( - ); - runOnlyForDeploymentPostprocessing = 0; - shellPath = /bin/sh; - shellScript = "echo \"$PRODUCT_NAME.app\" > \"$PROJECT_DIR\"/Flutter/ephemeral/.app_filename && \"$FLUTTER_ROOT\"/packages/flutter_tools/bin/macos_assemble.sh embed\n"; - }; - 33CC111E2044C6BF0003C045 /* ShellScript */ = { - isa = PBXShellScriptBuildPhase; - buildActionMask = 2147483647; - files = ( - ); - inputFileListPaths = ( - Flutter/ephemeral/FlutterInputs.xcfilelist, - ); - inputPaths = ( - Flutter/ephemeral/tripwire, - ); - outputFileListPaths = ( - Flutter/ephemeral/FlutterOutputs.xcfilelist, - ); - outputPaths = ( - ); - runOnlyForDeploymentPostprocessing = 0; - shellPath = /bin/sh; - shellScript = "\"$FLUTTER_ROOT\"/packages/flutter_tools/bin/macos_assemble.sh && touch Flutter/ephemeral/tripwire"; - }; - A7CF0EFBD867541ADB9884D5 /* [CP] Embed Pods Frameworks */ = { - isa = PBXShellScriptBuildPhase; - buildActionMask = 2147483647; - files = ( - ); - inputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist", - ); - name = "[CP] Embed Pods Frameworks"; - outputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist", - ); - runOnlyForDeploymentPostprocessing = 0; - shellPath = /bin/sh; - shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n"; - showEnvVarsInLog = 0; - }; - FA1FF96E71045A62F03992DA /* [CP] Check Pods Manifest.lock */ = { - isa = PBXShellScriptBuildPhase; - buildActionMask = 2147483647; - files = ( - ); - inputFileListPaths = ( - ); - inputPaths = ( - "${PODS_PODFILE_DIR_PATH}/Podfile.lock", - "${PODS_ROOT}/Manifest.lock", - ); - name = "[CP] Check Pods Manifest.lock"; - outputFileListPaths = ( - ); - outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt", - ); - runOnlyForDeploymentPostprocessing = 0; - shellPath = /bin/sh; - shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; - showEnvVarsInLog = 0; - }; -/* End PBXShellScriptBuildPhase section */ - -/* Begin PBXSourcesBuildPhase section */ - 33CC10E92044A3C60003C045 /* Sources */ = { - isa = PBXSourcesBuildPhase; - buildActionMask = 2147483647; - files = ( - 33CC11132044BFA00003C045 /* MainFlutterWindow.swift in Sources */, - 33CC10F12044A3C60003C045 /* AppDelegate.swift in Sources */, - 335BBD1B22A9A15E00E9071D /* GeneratedPluginRegistrant.swift in Sources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXSourcesBuildPhase section */ - -/* Begin PBXTargetDependency section */ - 33CC11202044C79F0003C045 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = 33CC111A2044C6BA0003C045 /* Flutter Assemble */; - targetProxy = 33CC111F2044C79F0003C045 /* PBXContainerItemProxy */; - }; -/* End PBXTargetDependency section */ - -/* Begin PBXVariantGroup section */ - 33CC10F42044A3C60003C045 /* MainMenu.xib */ = { - isa = PBXVariantGroup; - children = ( - 33CC10F52044A3C60003C045 /* Base */, - ); - name = MainMenu.xib; - path = Runner; - sourceTree = ""; - }; -/* End PBXVariantGroup section */ - -/* Begin XCBuildConfiguration section */ - 338D0CE9231458BD00FA5F75 /* Profile */ = { - isa = XCBuildConfiguration; - baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; - CLANG_CXX_LIBRARY = "libc++"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CODE_SIGN_IDENTITY = "-"; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - ENABLE_NS_ASSERTIONS = NO; - ENABLE_STRICT_OBJC_MSGSEND = YES; - GCC_C_LANGUAGE_STANDARD = gnu11; - GCC_NO_COMMON_BLOCKS = YES; - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - MACOSX_DEPLOYMENT_TARGET = 10.11; - MTL_ENABLE_DEBUG_INFO = NO; - SDKROOT = macosx; - SWIFT_COMPILATION_MODE = wholemodule; - SWIFT_OPTIMIZATION_LEVEL = "-O"; - }; - name = Profile; - }; - 338D0CEA231458BD00FA5F75 /* Profile */ = { - isa = XCBuildConfiguration; - baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - CLANG_ENABLE_MODULES = YES; - CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements; - CODE_SIGN_STYLE = Automatic; - COMBINE_HIDPI_IMAGES = YES; - INFOPLIST_FILE = Runner/Info.plist; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/../Frameworks", - ); - PROVISIONING_PROFILE_SPECIFIER = ""; - SWIFT_VERSION = 5.0; - }; - name = Profile; - }; - 338D0CEB231458BD00FA5F75 /* Profile */ = { - isa = XCBuildConfiguration; - buildSettings = { - CODE_SIGN_STYLE = Manual; - PRODUCT_NAME = "$(TARGET_NAME)"; - }; - name = Profile; - }; - 33CC10F92044A3C60003C045 /* Debug */ = { - isa = XCBuildConfiguration; - baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; - CLANG_CXX_LIBRARY = "libc++"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CODE_SIGN_IDENTITY = "-"; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = dwarf; - ENABLE_STRICT_OBJC_MSGSEND = YES; - ENABLE_TESTABILITY = YES; - GCC_C_LANGUAGE_STANDARD = gnu11; - GCC_DYNAMIC_NO_PIC = NO; - GCC_NO_COMMON_BLOCKS = YES; - GCC_OPTIMIZATION_LEVEL = 0; - GCC_PREPROCESSOR_DEFINITIONS = ( - "DEBUG=1", - "$(inherited)", - ); - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - MACOSX_DEPLOYMENT_TARGET = 10.11; - MTL_ENABLE_DEBUG_INFO = YES; - ONLY_ACTIVE_ARCH = YES; - SDKROOT = macosx; - SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; - SWIFT_OPTIMIZATION_LEVEL = "-Onone"; - }; - name = Debug; - }; - 33CC10FA2044A3C60003C045 /* Release */ = { - isa = XCBuildConfiguration; - baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; - CLANG_CXX_LIBRARY = "libc++"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CODE_SIGN_IDENTITY = "-"; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - ENABLE_NS_ASSERTIONS = NO; - ENABLE_STRICT_OBJC_MSGSEND = YES; - GCC_C_LANGUAGE_STANDARD = gnu11; - GCC_NO_COMMON_BLOCKS = YES; - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - MACOSX_DEPLOYMENT_TARGET = 10.11; - MTL_ENABLE_DEBUG_INFO = NO; - SDKROOT = macosx; - SWIFT_COMPILATION_MODE = wholemodule; - SWIFT_OPTIMIZATION_LEVEL = "-O"; - }; - name = Release; - }; - 33CC10FC2044A3C60003C045 /* Debug */ = { - isa = XCBuildConfiguration; - baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - CLANG_ENABLE_MODULES = YES; - CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements; - CODE_SIGN_STYLE = Automatic; - COMBINE_HIDPI_IMAGES = YES; - INFOPLIST_FILE = Runner/Info.plist; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/../Frameworks", - ); - PROVISIONING_PROFILE_SPECIFIER = ""; - SWIFT_OPTIMIZATION_LEVEL = "-Onone"; - SWIFT_VERSION = 5.0; - }; - name = Debug; - }; - 33CC10FD2044A3C60003C045 /* Release */ = { - isa = XCBuildConfiguration; - baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - CLANG_ENABLE_MODULES = YES; - CODE_SIGN_ENTITLEMENTS = Runner/Release.entitlements; - CODE_SIGN_STYLE = Automatic; - COMBINE_HIDPI_IMAGES = YES; - INFOPLIST_FILE = Runner/Info.plist; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/../Frameworks", - ); - PROVISIONING_PROFILE_SPECIFIER = ""; - SWIFT_VERSION = 5.0; - }; - name = Release; - }; - 33CC111C2044C6BA0003C045 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - CODE_SIGN_STYLE = Manual; - PRODUCT_NAME = "$(TARGET_NAME)"; - }; - name = Debug; - }; - 33CC111D2044C6BA0003C045 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - CODE_SIGN_STYLE = Automatic; - PRODUCT_NAME = "$(TARGET_NAME)"; - }; - name = Release; - }; -/* End XCBuildConfiguration section */ - -/* Begin XCConfigurationList section */ - 33CC10E82044A3C60003C045 /* Build configuration list for PBXProject "Runner" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - 33CC10F92044A3C60003C045 /* Debug */, - 33CC10FA2044A3C60003C045 /* Release */, - 338D0CE9231458BD00FA5F75 /* Profile */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - 33CC10FB2044A3C60003C045 /* Build configuration list for PBXNativeTarget "Runner" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - 33CC10FC2044A3C60003C045 /* Debug */, - 33CC10FD2044A3C60003C045 /* Release */, - 338D0CEA231458BD00FA5F75 /* Profile */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - 33CC111B2044C6BA0003C045 /* Build configuration list for PBXAggregateTarget "Flutter Assemble" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - 33CC111C2044C6BA0003C045 /* Debug */, - 33CC111D2044C6BA0003C045 /* Release */, - 338D0CEB231458BD00FA5F75 /* Profile */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; -/* End XCConfigurationList section */ - }; - rootObject = 33CC10E52044A3C60003C045 /* Project object */; -} diff --git a/experimental/linting_tool/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/experimental/linting_tool/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist deleted file mode 100644 index 18d981003d6..00000000000 --- a/experimental/linting_tool/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +++ /dev/null @@ -1,8 +0,0 @@ - - - - - IDEDidComputeMac32BitWarning - - - diff --git a/experimental/linting_tool/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/experimental/linting_tool/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme deleted file mode 100644 index be7701b216e..00000000000 --- a/experimental/linting_tool/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +++ /dev/null @@ -1,89 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/experimental/linting_tool/macos/Runner.xcworkspace/contents.xcworkspacedata b/experimental/linting_tool/macos/Runner.xcworkspace/contents.xcworkspacedata deleted file mode 100644 index 21a3cc14c74..00000000000 --- a/experimental/linting_tool/macos/Runner.xcworkspace/contents.xcworkspacedata +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - diff --git a/experimental/linting_tool/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/experimental/linting_tool/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist deleted file mode 100644 index 18d981003d6..00000000000 --- a/experimental/linting_tool/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +++ /dev/null @@ -1,8 +0,0 @@ - - - - - IDEDidComputeMac32BitWarning - - - diff --git a/experimental/linting_tool/macos/Runner/AppDelegate.swift b/experimental/linting_tool/macos/Runner/AppDelegate.swift deleted file mode 100644 index d53ef643772..00000000000 --- a/experimental/linting_tool/macos/Runner/AppDelegate.swift +++ /dev/null @@ -1,9 +0,0 @@ -import Cocoa -import FlutterMacOS - -@NSApplicationMain -class AppDelegate: FlutterAppDelegate { - override func applicationShouldTerminateAfterLastWindowClosed(_ sender: NSApplication) -> Bool { - return true - } -} diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json deleted file mode 100644 index a2ec33f19f1..00000000000 --- a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json +++ /dev/null @@ -1,68 +0,0 @@ -{ - "images" : [ - { - "size" : "16x16", - "idiom" : "mac", - "filename" : "app_icon_16.png", - "scale" : "1x" - }, - { - "size" : "16x16", - "idiom" : "mac", - "filename" : "app_icon_32.png", - "scale" : "2x" - }, - { - "size" : "32x32", - "idiom" : "mac", - "filename" : "app_icon_32.png", - "scale" : "1x" - }, - { - "size" : "32x32", - "idiom" : "mac", - "filename" : "app_icon_64.png", - "scale" : "2x" - }, - { - "size" : "128x128", - "idiom" : "mac", - "filename" : "app_icon_128.png", - "scale" : "1x" - }, - { - "size" : "128x128", - "idiom" : "mac", - "filename" : "app_icon_256.png", - "scale" : "2x" - }, - { - "size" : "256x256", - "idiom" : "mac", - "filename" : "app_icon_256.png", - "scale" : "1x" - }, - { - "size" : "256x256", - "idiom" : "mac", - "filename" : "app_icon_512.png", - "scale" : "2x" - }, - { - "size" : "512x512", - "idiom" : "mac", - "filename" : "app_icon_512.png", - "scale" : "1x" - }, - { - "size" : "512x512", - "idiom" : "mac", - "filename" : "app_icon_1024.png", - "scale" : "2x" - } - ], - "info" : { - "version" : 1, - "author" : "xcode" - } -} diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png deleted file mode 100644 index 3c4935a7ca8..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png deleted file mode 100644 index ed4cc164216..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png deleted file mode 100644 index 483be613897..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png deleted file mode 100644 index bcbf36df2f2..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png deleted file mode 100644 index 9c0a6528647..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png deleted file mode 100644 index e71a726136a..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png b/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png deleted file mode 100644 index 8a31fe2dd3f..00000000000 Binary files a/experimental/linting_tool/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png and /dev/null differ diff --git a/experimental/linting_tool/macos/Runner/Base.lproj/MainMenu.xib b/experimental/linting_tool/macos/Runner/Base.lproj/MainMenu.xib deleted file mode 100644 index d196364b96c..00000000000 --- a/experimental/linting_tool/macos/Runner/Base.lproj/MainMenu.xib +++ /dev/null @@ -1,340 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/experimental/linting_tool/macos/Runner/Configs/AppInfo.xcconfig b/experimental/linting_tool/macos/Runner/Configs/AppInfo.xcconfig deleted file mode 100644 index 8c9702b7668..00000000000 --- a/experimental/linting_tool/macos/Runner/Configs/AppInfo.xcconfig +++ /dev/null @@ -1,14 +0,0 @@ -// Application-level settings for the Runner target. -// -// This may be replaced with something auto-generated from metadata (e.g., pubspec.yaml) in the -// future. If not, the values below would default to using the project name when this becomes a -// 'flutter create' template. - -// The application's name. By default this is also the title of the Flutter window. -PRODUCT_NAME = linting_tool - -// The application's bundle identifier -PRODUCT_BUNDLE_IDENTIFIER = dev.flutter.lintingTool - -// The copyright displayed in application information -PRODUCT_COPYRIGHT = Copyright © 2021 dev.flutter. All rights reserved. diff --git a/experimental/linting_tool/macos/Runner/Configs/Debug.xcconfig b/experimental/linting_tool/macos/Runner/Configs/Debug.xcconfig deleted file mode 100644 index 36b0fd9464f..00000000000 --- a/experimental/linting_tool/macos/Runner/Configs/Debug.xcconfig +++ /dev/null @@ -1,2 +0,0 @@ -#include "../../Flutter/Flutter-Debug.xcconfig" -#include "Warnings.xcconfig" diff --git a/experimental/linting_tool/macos/Runner/Configs/Release.xcconfig b/experimental/linting_tool/macos/Runner/Configs/Release.xcconfig deleted file mode 100644 index dff4f49561c..00000000000 --- a/experimental/linting_tool/macos/Runner/Configs/Release.xcconfig +++ /dev/null @@ -1,2 +0,0 @@ -#include "../../Flutter/Flutter-Release.xcconfig" -#include "Warnings.xcconfig" diff --git a/experimental/linting_tool/macos/Runner/Configs/Warnings.xcconfig b/experimental/linting_tool/macos/Runner/Configs/Warnings.xcconfig deleted file mode 100644 index 42bcbf4780b..00000000000 --- a/experimental/linting_tool/macos/Runner/Configs/Warnings.xcconfig +++ /dev/null @@ -1,13 +0,0 @@ -WARNING_CFLAGS = -Wall -Wconditional-uninitialized -Wnullable-to-nonnull-conversion -Wmissing-method-return-type -Woverlength-strings -GCC_WARN_UNDECLARED_SELECTOR = YES -CLANG_UNDEFINED_BEHAVIOR_SANITIZER_NULLABILITY = YES -CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE -CLANG_WARN__DUPLICATE_METHOD_MATCH = YES -CLANG_WARN_PRAGMA_PACK = YES -CLANG_WARN_STRICT_PROTOTYPES = YES -CLANG_WARN_COMMA = YES -GCC_WARN_STRICT_SELECTOR_MATCH = YES -CLANG_WARN_OBJC_REPEATED_USE_OF_WEAK = YES -CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES -GCC_WARN_SHADOW = YES -CLANG_WARN_UNREACHABLE_CODE = YES diff --git a/experimental/linting_tool/macos/Runner/DebugProfile.entitlements b/experimental/linting_tool/macos/Runner/DebugProfile.entitlements deleted file mode 100644 index 9158f3eb1ce..00000000000 --- a/experimental/linting_tool/macos/Runner/DebugProfile.entitlements +++ /dev/null @@ -1,16 +0,0 @@ - - - - - com.apple.security.app-sandbox - - com.apple.security.cs.allow-jit - - com.apple.security.network.client - - com.apple.security.network.server - - com.apple.security.files.user-selected.read-write - - - diff --git a/experimental/linting_tool/macos/Runner/Info.plist b/experimental/linting_tool/macos/Runner/Info.plist deleted file mode 100644 index 485f6f47999..00000000000 --- a/experimental/linting_tool/macos/Runner/Info.plist +++ /dev/null @@ -1,32 +0,0 @@ - - - - - CFBundleDevelopmentRegion - $(DEVELOPMENT_LANGUAGE) - CFBundleExecutable - $(EXECUTABLE_NAME) - CFBundleIconFile - - CFBundleIdentifier - $(PRODUCT_BUNDLE_IDENTIFIER) - CFBundleInfoDictionaryVersion - 6.0 - CFBundleName - Flutter Linting Tool - CFBundlePackageType - APPL - CFBundleShortVersionString - $(FLUTTER_BUILD_NAME) - CFBundleVersion - $(FLUTTER_BUILD_NUMBER) - LSMinimumSystemVersion - $(MACOSX_DEPLOYMENT_TARGET) - NSHumanReadableCopyright - $(PRODUCT_COPYRIGHT) - NSMainNibFile - MainMenu - NSPrincipalClass - NSApplication - - diff --git a/experimental/linting_tool/macos/Runner/MainFlutterWindow.swift b/experimental/linting_tool/macos/Runner/MainFlutterWindow.swift deleted file mode 100644 index 2722837ec91..00000000000 --- a/experimental/linting_tool/macos/Runner/MainFlutterWindow.swift +++ /dev/null @@ -1,15 +0,0 @@ -import Cocoa -import FlutterMacOS - -class MainFlutterWindow: NSWindow { - override func awakeFromNib() { - let flutterViewController = FlutterViewController.init() - let windowFrame = self.frame - self.contentViewController = flutterViewController - self.setFrame(windowFrame, display: true) - - RegisterGeneratedPlugins(registry: flutterViewController) - - super.awakeFromNib() - } -} diff --git a/experimental/linting_tool/macos/Runner/Release.entitlements b/experimental/linting_tool/macos/Runner/Release.entitlements deleted file mode 100644 index c1a22b8a084..00000000000 --- a/experimental/linting_tool/macos/Runner/Release.entitlements +++ /dev/null @@ -1,14 +0,0 @@ - - - - - com.apple.security.app-sandbox - - com.apple.security.network.client - - com.apple.security.network.server - - com.apple.security.files.user-selected.read-write - - - diff --git a/experimental/linting_tool/pubspec.yaml b/experimental/linting_tool/pubspec.yaml deleted file mode 100644 index 625476f51a1..00000000000 --- a/experimental/linting_tool/pubspec.yaml +++ /dev/null @@ -1,44 +0,0 @@ -name: linting_tool -description: A new Flutter project. - -version: 1.0.0+1 - -publish_to: "none" - -environment: - sdk: ^3.5.0 - -dependencies: - flutter: - sdk: flutter - adaptive_breakpoints: ^0.1.1 - cupertino_icons: ^1.0.2 - equatable: ^2.0.3 - file_selector: ^1.0.0 - flutter_markdown: ^0.7.3 - google_fonts: ^6.0.0 - hive: ^2.0.4 - hive_flutter: ^1.1.0 - http: ^1.2.1 - json2yaml: ^3.0.0 - json_annotation: ^4.8.1 - mockito: ^5.0.13 - provider: ^6.0.2 - yaml: ^3.1.0 - context_menus: ^1.0.1 - window_size: - git: - url: https://github.com/google/flutter-desktop-embedding.git - path: plugins/window_size - -dev_dependencies: - analysis_defaults: - path: ../../analysis_defaults - flutter_test: - sdk: flutter - build_runner: ^2.4.6 - hive_generator: ^2.0.0 - json_serializable: ^6.7.1 - -flutter: - uses-material-design: true diff --git a/experimental/linting_tool/test/widget_test.dart b/experimental/linting_tool/test/widget_test.dart deleted file mode 100644 index f32e5cb64f0..00000000000 --- a/experimental/linting_tool/test/widget_test.dart +++ /dev/null @@ -1,104 +0,0 @@ -// Copyright 2021 The Flutter team. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:hive_flutter/hive_flutter.dart'; -import 'package:http/http.dart' as http; -import 'package:linting_tool/app.dart'; -import 'package:linting_tool/model/profile.dart'; -import 'package:linting_tool/model/profiles_store.dart'; -import 'package:linting_tool/model/rule.dart'; -import 'package:linting_tool/model/rules_store.dart'; -import 'package:linting_tool/pages/default_lints_page.dart'; -import 'package:linting_tool/pages/home_page.dart'; -import 'package:linting_tool/pages/saved_lints_page.dart'; -import 'package:linting_tool/theme/app_theme.dart'; -import 'package:linting_tool/widgets/adaptive_nav.dart'; -import 'package:mockito/annotations.dart'; -import 'package:mockito/mockito.dart'; -import 'package:provider/provider.dart'; - -import 'widget_test.mocks.dart'; - -late MockClient _mockClient; - -class _TestApp extends StatelessWidget { - const _TestApp(); - - @override - Widget build(BuildContext context) { - return MultiProvider( - providers: [ - ChangeNotifierProvider( - create: (context) => RuleStore(_mockClient), - ), - ChangeNotifierProvider( - create: (context) => ProfilesStore(_mockClient), - ), - ], - child: MaterialApp( - title: 'Flutter Linting Tool', - initialRoute: LintingTool.homeRoute, - theme: AppTheme.buildReplyLightTheme(context), - onGenerateRoute: (settings) { - switch (settings.name) { - case LintingTool.homeRoute: - return MaterialPageRoute( - builder: (context) => const AdaptiveNav(), - settings: settings, - ); - } - return null; - }, - ), - ); - } -} - -@GenerateMocks([http.Client]) -void main() { - setUp(() async { - final tempDir = await Directory.systemTemp.createTemp(); - Hive.init(tempDir.path); - Hive.registerAdapter(RuleAdapter()); - Hive.registerAdapter(RulesProfileAdapter()); - await Hive.openLazyBox('rules_profile'); - _mockClient = MockClient(); - }); - - testWidgets('NavigationRail smoke test', (tester) async { - var responseBody = - '''[{"name": "always_use_package_imports","description": "Avoid relative imports for files in `lib/`.","group": "errors","state": "stable","incompatible": [],"sets": [],"details": "*DO* avoid relative imports for files in `lib/`.\n\nWhen mixing relative and absolute imports it's possible to create confusion\nwhere the same member gets imported in two different ways. One way to avoid\nthat is to ensure you consistently use absolute imports for files withing the\n`lib/` directory.\n\nThis is the opposite of 'prefer_relative_imports'.\nMight be used with 'avoid_relative_lib_imports' to avoid relative imports of\nfiles within `lib/` directory outside of it. (for example `test/`)\n\n**GOOD:**\n\n```dart\nimport 'package:foo/bar.dart';\n\nimport 'package:foo/baz.dart';\n\nimport 'package:foo/src/baz.dart';\n...\n```\n\n**BAD:**\n\n```dart\nimport 'baz.dart';\n\nimport 'src/bag.dart'\n\nimport '../lib/baz.dart';\n\n...\n```\n\n"}]'''; - - when(_mockClient.get(Uri.parse( - 'https://raw.githubusercontent.com/dart-lang/site-www/main/src/_data/linter_rules.json', - ))).thenAnswer( - (_) async => http.Response(responseBody, 400), - ); - - await tester.pumpWidget(const _TestApp()); - expect(find.byType(HomePage), findsOneWidget); - expect(find.byType(SavedLintsPage), findsNothing); - - var offset = tester.getCenter(find.text('Saved Profiles').first); - await tester.tapAt(offset); - await tester.pumpAndSettle(); - expect(find.byType(SavedLintsPage), findsOneWidget); - expect(find.byType(DefaultLintsPage), findsNothing); - - offset = tester.getCenter(find.text('Default Profiles').first); - await tester.tapAt(offset); - await tester.pumpAndSettle(); - expect(find.byType(DefaultLintsPage), findsOneWidget); - expect(find.byType(HomePage), findsNothing); - - offset = tester.getCenter(find.text('Home').first); - await tester.tapAt(offset); - await tester.pumpAndSettle(); - expect(find.byType(HomePage), findsOneWidget); - }); -} diff --git a/experimental/linting_tool/test/widget_test.mocks.dart b/experimental/linting_tool/test/widget_test.mocks.dart deleted file mode 100644 index c3b2fb95d2e..00000000000 --- a/experimental/linting_tool/test/widget_test.mocks.dart +++ /dev/null @@ -1,263 +0,0 @@ -// Mocks generated by Mockito 5.4.2 from annotations -// in linting_tool/test/widget_test.dart. -// Do not manually edit this file. - -// ignore_for_file: no_leading_underscores_for_library_prefixes -import 'dart:async' as _i3; -import 'dart:convert' as _i4; -import 'dart:typed_data' as _i5; - -import 'package:http/http.dart' as _i2; -import 'package:mockito/mockito.dart' as _i1; - -// ignore_for_file: type=lint -// ignore_for_file: avoid_redundant_argument_values -// ignore_for_file: avoid_setters_without_getters -// ignore_for_file: comment_references -// ignore_for_file: implementation_imports -// ignore_for_file: invalid_use_of_visible_for_testing_member -// ignore_for_file: prefer_const_constructors -// ignore_for_file: unnecessary_parenthesis -// ignore_for_file: camel_case_types -// ignore_for_file: subtype_of_sealed_class - -class _FakeResponse_0 extends _i1.SmartFake implements _i2.Response { - _FakeResponse_0( - Object parent, - Invocation parentInvocation, - ) : super( - parent, - parentInvocation, - ); -} - -class _FakeStreamedResponse_1 extends _i1.SmartFake - implements _i2.StreamedResponse { - _FakeStreamedResponse_1( - Object parent, - Invocation parentInvocation, - ) : super( - parent, - parentInvocation, - ); -} - -/// A class which mocks [Client]. -/// -/// See the documentation for Mockito's code generation for more information. -class MockClient extends _i1.Mock implements _i2.Client { - MockClient() { - _i1.throwOnMissingStub(this); - } - - @override - _i3.Future<_i2.Response> head( - Uri? url, { - Map? headers, - }) => - (super.noSuchMethod( - Invocation.method( - #head, - [url], - {#headers: headers}, - ), - returnValue: _i3.Future<_i2.Response>.value(_FakeResponse_0( - this, - Invocation.method( - #head, - [url], - {#headers: headers}, - ), - )), - ) as _i3.Future<_i2.Response>); - @override - _i3.Future<_i2.Response> get( - Uri? url, { - Map? headers, - }) => - (super.noSuchMethod( - Invocation.method( - #get, - [url], - {#headers: headers}, - ), - returnValue: _i3.Future<_i2.Response>.value(_FakeResponse_0( - this, - Invocation.method( - #get, - [url], - {#headers: headers}, - ), - )), - ) as _i3.Future<_i2.Response>); - @override - _i3.Future<_i2.Response> post( - Uri? url, { - Map? headers, - Object? body, - _i4.Encoding? encoding, - }) => - (super.noSuchMethod( - Invocation.method( - #post, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - returnValue: _i3.Future<_i2.Response>.value(_FakeResponse_0( - this, - Invocation.method( - #post, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - )), - ) as _i3.Future<_i2.Response>); - @override - _i3.Future<_i2.Response> put( - Uri? url, { - Map? headers, - Object? body, - _i4.Encoding? encoding, - }) => - (super.noSuchMethod( - Invocation.method( - #put, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - returnValue: _i3.Future<_i2.Response>.value(_FakeResponse_0( - this, - Invocation.method( - #put, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - )), - ) as _i3.Future<_i2.Response>); - @override - _i3.Future<_i2.Response> patch( - Uri? url, { - Map? headers, - Object? body, - _i4.Encoding? encoding, - }) => - (super.noSuchMethod( - Invocation.method( - #patch, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - returnValue: _i3.Future<_i2.Response>.value(_FakeResponse_0( - this, - Invocation.method( - #patch, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - )), - ) as _i3.Future<_i2.Response>); - @override - _i3.Future<_i2.Response> delete( - Uri? url, { - Map? headers, - Object? body, - _i4.Encoding? encoding, - }) => - (super.noSuchMethod( - Invocation.method( - #delete, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - returnValue: _i3.Future<_i2.Response>.value(_FakeResponse_0( - this, - Invocation.method( - #delete, - [url], - { - #headers: headers, - #body: body, - #encoding: encoding, - }, - ), - )), - ) as _i3.Future<_i2.Response>); - @override - _i3.Future read( - Uri? url, { - Map? headers, - }) => - (super.noSuchMethod( - Invocation.method( - #read, - [url], - {#headers: headers}, - ), - returnValue: _i3.Future.value(''), - ) as _i3.Future); - @override - _i3.Future<_i5.Uint8List> readBytes( - Uri? url, { - Map? headers, - }) => - (super.noSuchMethod( - Invocation.method( - #readBytes, - [url], - {#headers: headers}, - ), - returnValue: _i3.Future<_i5.Uint8List>.value(_i5.Uint8List(0)), - ) as _i3.Future<_i5.Uint8List>); - @override - _i3.Future<_i2.StreamedResponse> send(_i2.BaseRequest? request) => - (super.noSuchMethod( - Invocation.method( - #send, - [request], - ), - returnValue: - _i3.Future<_i2.StreamedResponse>.value(_FakeStreamedResponse_1( - this, - Invocation.method( - #send, - [request], - ), - )), - ) as _i3.Future<_i2.StreamedResponse>); - @override - void close() => super.noSuchMethod( - Invocation.method( - #close, - [], - ), - returnValueForMissingStub: null, - ); -} diff --git a/experimental/linting_tool/web/favicon.png b/experimental/linting_tool/web/favicon.png deleted file mode 100644 index 8aaa46ac1ae..00000000000 Binary files a/experimental/linting_tool/web/favicon.png and /dev/null differ diff --git a/experimental/linting_tool/web/icons/Icon-192.png b/experimental/linting_tool/web/icons/Icon-192.png deleted file mode 100644 index b749bfef074..00000000000 Binary files a/experimental/linting_tool/web/icons/Icon-192.png and /dev/null differ diff --git a/experimental/linting_tool/web/icons/Icon-512.png b/experimental/linting_tool/web/icons/Icon-512.png deleted file mode 100644 index 88cfd48dff1..00000000000 Binary files a/experimental/linting_tool/web/icons/Icon-512.png and /dev/null differ diff --git a/experimental/linting_tool/web/index.html b/experimental/linting_tool/web/index.html deleted file mode 100644 index 6749182c3de..00000000000 --- a/experimental/linting_tool/web/index.html +++ /dev/null @@ -1,98 +0,0 @@ - - - - - - - - - - - - - - - - - linting_tool - - - - - - - diff --git a/experimental/linting_tool/web/manifest.json b/experimental/linting_tool/web/manifest.json deleted file mode 100644 index ef17815cc55..00000000000 --- a/experimental/linting_tool/web/manifest.json +++ /dev/null @@ -1,23 +0,0 @@ -{ - "name": "linting_tool", - "short_name": "linting_tool", - "start_url": ".", - "display": "standalone", - "background_color": "#0175C2", - "theme_color": "#0175C2", - "description": "A new Flutter project.", - "orientation": "portrait-primary", - "prefer_related_applications": false, - "icons": [ - { - "src": "icons/Icon-192.png", - "sizes": "192x192", - "type": "image/png" - }, - { - "src": "icons/Icon-512.png", - "sizes": "512x512", - "type": "image/png" - } - ] -} diff --git a/experimental/linting_tool/windows/.gitignore b/experimental/linting_tool/windows/.gitignore deleted file mode 100644 index d492d0d98c8..00000000000 --- a/experimental/linting_tool/windows/.gitignore +++ /dev/null @@ -1,17 +0,0 @@ -flutter/ephemeral/ - -# Visual Studio user-specific files. -*.suo -*.user -*.userosscache -*.sln.docstates - -# Visual Studio build-related files. -x64/ -x86/ - -# Visual Studio cache files -# files ending in .cache can be ignored -*.[Cc]ache -# but keep track of directories ending in .cache -!*.[Cc]ache/ diff --git a/experimental/linting_tool/windows/CMakeLists.txt b/experimental/linting_tool/windows/CMakeLists.txt deleted file mode 100644 index f85a4a0c25e..00000000000 --- a/experimental/linting_tool/windows/CMakeLists.txt +++ /dev/null @@ -1,95 +0,0 @@ -cmake_minimum_required(VERSION 3.15) -project(linting_tool LANGUAGES CXX) - -set(BINARY_NAME "linting_tool") - -cmake_policy(SET CMP0063 NEW) - -set(CMAKE_INSTALL_RPATH "$ORIGIN/lib") - -# Configure build options. -get_property(IS_MULTICONFIG GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG) -if(IS_MULTICONFIG) - set(CMAKE_CONFIGURATION_TYPES "Debug;Profile;Release" - CACHE STRING "" FORCE) -else() - if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) - set(CMAKE_BUILD_TYPE "Debug" CACHE - STRING "Flutter build mode" FORCE) - set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS - "Debug" "Profile" "Release") - endif() -endif() - -set(CMAKE_EXE_LINKER_FLAGS_PROFILE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}") -set(CMAKE_SHARED_LINKER_FLAGS_PROFILE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE}") -set(CMAKE_C_FLAGS_PROFILE "${CMAKE_C_FLAGS_RELEASE}") -set(CMAKE_CXX_FLAGS_PROFILE "${CMAKE_CXX_FLAGS_RELEASE}") - -# Use Unicode for all projects. -add_definitions(-DUNICODE -D_UNICODE) - -# Compilation settings that should be applied to most targets. -function(APPLY_STANDARD_SETTINGS TARGET) - target_compile_features(${TARGET} PUBLIC cxx_std_17) - target_compile_options(${TARGET} PRIVATE /W4 /WX /wd"4100") - target_compile_options(${TARGET} PRIVATE /EHsc) - target_compile_definitions(${TARGET} PRIVATE "_HAS_EXCEPTIONS=0") - target_compile_definitions(${TARGET} PRIVATE "$<$:_DEBUG>") -endfunction() - -set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter") - -# Flutter library and tool build rules. -add_subdirectory(${FLUTTER_MANAGED_DIR}) - -# Application build -add_subdirectory("runner") - -# Generated plugin build rules, which manage building the plugins and adding -# them to the application. -include(flutter/generated_plugins.cmake) - - -# === Installation === -# Support files are copied into place next to the executable, so that it can -# run in place. This is done instead of making a separate bundle (as on Linux) -# so that building and running from within Visual Studio will work. -set(BUILD_BUNDLE_DIR "$") -# Make the "install" step default, as it's required to run. -set(CMAKE_VS_INCLUDE_INSTALL_TO_DEFAULT_BUILD 1) -if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) - set(CMAKE_INSTALL_PREFIX "${BUILD_BUNDLE_DIR}" CACHE PATH "..." FORCE) -endif() - -set(INSTALL_BUNDLE_DATA_DIR "${CMAKE_INSTALL_PREFIX}/data") -set(INSTALL_BUNDLE_LIB_DIR "${CMAKE_INSTALL_PREFIX}") - -install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}" - COMPONENT Runtime) - -install(FILES "${FLUTTER_ICU_DATA_FILE}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" - COMPONENT Runtime) - -install(FILES "${FLUTTER_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" - COMPONENT Runtime) - -if(PLUGIN_BUNDLED_LIBRARIES) - install(FILES "${PLUGIN_BUNDLED_LIBRARIES}" - DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" - COMPONENT Runtime) -endif() - -# Fully re-copy the assets directory on each build to avoid having stale files -# from a previous install. -set(FLUTTER_ASSET_DIR_NAME "flutter_assets") -install(CODE " - file(REMOVE_RECURSE \"${INSTALL_BUNDLE_DATA_DIR}/${FLUTTER_ASSET_DIR_NAME}\") - " COMPONENT Runtime) -install(DIRECTORY "${PROJECT_BUILD_DIR}/${FLUTTER_ASSET_DIR_NAME}" - DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" COMPONENT Runtime) - -# Install the AOT library on non-Debug builds only. -install(FILES "${AOT_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" - CONFIGURATIONS Profile;Release - COMPONENT Runtime) diff --git a/experimental/linting_tool/windows/flutter/CMakeLists.txt b/experimental/linting_tool/windows/flutter/CMakeLists.txt deleted file mode 100644 index b02c5485c95..00000000000 --- a/experimental/linting_tool/windows/flutter/CMakeLists.txt +++ /dev/null @@ -1,103 +0,0 @@ -cmake_minimum_required(VERSION 3.15) - -set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral") - -# Configuration provided via flutter tool. -include(${EPHEMERAL_DIR}/generated_config.cmake) - -# TODO: Move the rest of this into files in ephemeral. See -# https://github.com/flutter/flutter/issues/57146. -set(WRAPPER_ROOT "${EPHEMERAL_DIR}/cpp_client_wrapper") - -# === Flutter Library === -set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/flutter_windows.dll") - -# Published to parent scope for install step. -set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE) -set(FLUTTER_ICU_DATA_FILE "${EPHEMERAL_DIR}/icudtl.dat" PARENT_SCOPE) -set(PROJECT_BUILD_DIR "${PROJECT_DIR}/build/" PARENT_SCOPE) -set(AOT_LIBRARY "${PROJECT_DIR}/build/windows/app.so" PARENT_SCOPE) - -list(APPEND FLUTTER_LIBRARY_HEADERS - "flutter_export.h" - "flutter_windows.h" - "flutter_messenger.h" - "flutter_plugin_registrar.h" - "flutter_texture_registrar.h" -) -list(TRANSFORM FLUTTER_LIBRARY_HEADERS PREPEND "${EPHEMERAL_DIR}/") -add_library(flutter INTERFACE) -target_include_directories(flutter INTERFACE - "${EPHEMERAL_DIR}" -) -target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}.lib") -add_dependencies(flutter flutter_assemble) - -# === Wrapper === -list(APPEND CPP_WRAPPER_SOURCES_CORE - "core_implementations.cc" - "standard_codec.cc" -) -list(TRANSFORM CPP_WRAPPER_SOURCES_CORE PREPEND "${WRAPPER_ROOT}/") -list(APPEND CPP_WRAPPER_SOURCES_PLUGIN - "plugin_registrar.cc" -) -list(TRANSFORM CPP_WRAPPER_SOURCES_PLUGIN PREPEND "${WRAPPER_ROOT}/") -list(APPEND CPP_WRAPPER_SOURCES_APP - "flutter_engine.cc" - "flutter_view_controller.cc" -) -list(TRANSFORM CPP_WRAPPER_SOURCES_APP PREPEND "${WRAPPER_ROOT}/") - -# Wrapper sources needed for a plugin. -add_library(flutter_wrapper_plugin STATIC - ${CPP_WRAPPER_SOURCES_CORE} - ${CPP_WRAPPER_SOURCES_PLUGIN} -) -apply_standard_settings(flutter_wrapper_plugin) -set_target_properties(flutter_wrapper_plugin PROPERTIES - POSITION_INDEPENDENT_CODE ON) -set_target_properties(flutter_wrapper_plugin PROPERTIES - CXX_VISIBILITY_PRESET hidden) -target_link_libraries(flutter_wrapper_plugin PUBLIC flutter) -target_include_directories(flutter_wrapper_plugin PUBLIC - "${WRAPPER_ROOT}/include" -) -add_dependencies(flutter_wrapper_plugin flutter_assemble) - -# Wrapper sources needed for the runner. -add_library(flutter_wrapper_app STATIC - ${CPP_WRAPPER_SOURCES_CORE} - ${CPP_WRAPPER_SOURCES_APP} -) -apply_standard_settings(flutter_wrapper_app) -target_link_libraries(flutter_wrapper_app PUBLIC flutter) -target_include_directories(flutter_wrapper_app PUBLIC - "${WRAPPER_ROOT}/include" -) -add_dependencies(flutter_wrapper_app flutter_assemble) - -# === Flutter tool backend === -# _phony_ is a non-existent file to force this command to run every time, -# since currently there's no way to get a full input/output list from the -# flutter tool. -set(PHONY_OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/_phony_") -set_source_files_properties("${PHONY_OUTPUT}" PROPERTIES SYMBOLIC TRUE) -add_custom_command( - OUTPUT ${FLUTTER_LIBRARY} ${FLUTTER_LIBRARY_HEADERS} - ${CPP_WRAPPER_SOURCES_CORE} ${CPP_WRAPPER_SOURCES_PLUGIN} - ${CPP_WRAPPER_SOURCES_APP} - ${PHONY_OUTPUT} - COMMAND ${CMAKE_COMMAND} -E env - ${FLUTTER_TOOL_ENVIRONMENT} - "${FLUTTER_ROOT}/packages/flutter_tools/bin/tool_backend.bat" - windows-x64 $ - VERBATIM -) -add_custom_target(flutter_assemble DEPENDS - "${FLUTTER_LIBRARY}" - ${FLUTTER_LIBRARY_HEADERS} - ${CPP_WRAPPER_SOURCES_CORE} - ${CPP_WRAPPER_SOURCES_PLUGIN} - ${CPP_WRAPPER_SOURCES_APP} -) diff --git a/experimental/linting_tool/windows/flutter/generated_plugin_registrant.cc b/experimental/linting_tool/windows/flutter/generated_plugin_registrant.cc deleted file mode 100644 index cd2d5c19834..00000000000 --- a/experimental/linting_tool/windows/flutter/generated_plugin_registrant.cc +++ /dev/null @@ -1,20 +0,0 @@ -// -// Generated file. Do not edit. -// - -// clang-format off - -#include "generated_plugin_registrant.h" - -#include -#include -#include - -void RegisterPlugins(flutter::PluginRegistry* registry) { - FileSelectorWindowsRegisterWithRegistrar( - registry->GetRegistrarForPlugin("FileSelectorWindows")); - UrlLauncherWindowsRegisterWithRegistrar( - registry->GetRegistrarForPlugin("UrlLauncherWindows")); - WindowSizePluginRegisterWithRegistrar( - registry->GetRegistrarForPlugin("WindowSizePlugin")); -} diff --git a/experimental/linting_tool/windows/flutter/generated_plugin_registrant.h b/experimental/linting_tool/windows/flutter/generated_plugin_registrant.h deleted file mode 100644 index dc139d85a93..00000000000 --- a/experimental/linting_tool/windows/flutter/generated_plugin_registrant.h +++ /dev/null @@ -1,15 +0,0 @@ -// -// Generated file. Do not edit. -// - -// clang-format off - -#ifndef GENERATED_PLUGIN_REGISTRANT_ -#define GENERATED_PLUGIN_REGISTRANT_ - -#include - -// Registers Flutter plugins. -void RegisterPlugins(flutter::PluginRegistry* registry); - -#endif // GENERATED_PLUGIN_REGISTRANT_ diff --git a/experimental/linting_tool/windows/flutter/generated_plugins.cmake b/experimental/linting_tool/windows/flutter/generated_plugins.cmake deleted file mode 100644 index a22fdb08d37..00000000000 --- a/experimental/linting_tool/windows/flutter/generated_plugins.cmake +++ /dev/null @@ -1,26 +0,0 @@ -# -# Generated file, do not edit. -# - -list(APPEND FLUTTER_PLUGIN_LIST - file_selector_windows - url_launcher_windows - window_size -) - -list(APPEND FLUTTER_FFI_PLUGIN_LIST -) - -set(PLUGIN_BUNDLED_LIBRARIES) - -foreach(plugin ${FLUTTER_PLUGIN_LIST}) - add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/windows plugins/${plugin}) - target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin) - list(APPEND PLUGIN_BUNDLED_LIBRARIES $) - list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries}) -endforeach(plugin) - -foreach(ffi_plugin ${FLUTTER_FFI_PLUGIN_LIST}) - add_subdirectory(flutter/ephemeral/.plugin_symlinks/${ffi_plugin}/windows plugins/${ffi_plugin}) - list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${ffi_plugin}_bundled_libraries}) -endforeach(ffi_plugin) diff --git a/experimental/linting_tool/windows/runner/CMakeLists.txt b/experimental/linting_tool/windows/runner/CMakeLists.txt deleted file mode 100644 index 977e38b5d1d..00000000000 --- a/experimental/linting_tool/windows/runner/CMakeLists.txt +++ /dev/null @@ -1,18 +0,0 @@ -cmake_minimum_required(VERSION 3.15) -project(runner LANGUAGES CXX) - -add_executable(${BINARY_NAME} WIN32 - "flutter_window.cpp" - "main.cpp" - "run_loop.cpp" - "utils.cpp" - "win32_window.cpp" - "${FLUTTER_MANAGED_DIR}/generated_plugin_registrant.cc" - "Runner.rc" - "runner.exe.manifest" -) -apply_standard_settings(${BINARY_NAME}) -target_compile_definitions(${BINARY_NAME} PRIVATE "NOMINMAX") -target_link_libraries(${BINARY_NAME} PRIVATE flutter flutter_wrapper_app) -target_include_directories(${BINARY_NAME} PRIVATE "${CMAKE_SOURCE_DIR}") -add_dependencies(${BINARY_NAME} flutter_assemble) diff --git a/experimental/linting_tool/windows/runner/Runner.rc b/experimental/linting_tool/windows/runner/Runner.rc deleted file mode 100644 index c1ee378ef88..00000000000 --- a/experimental/linting_tool/windows/runner/Runner.rc +++ /dev/null @@ -1,121 +0,0 @@ -// Microsoft Visual C++ generated resource script. -// -#pragma code_page(65001) -#include "resource.h" - -#define APSTUDIO_READONLY_SYMBOLS -///////////////////////////////////////////////////////////////////////////// -// -// Generated from the TEXTINCLUDE 2 resource. -// -#include "winres.h" - -///////////////////////////////////////////////////////////////////////////// -#undef APSTUDIO_READONLY_SYMBOLS - -///////////////////////////////////////////////////////////////////////////// -// English (United States) resources - -#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU) -LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US - -#ifdef APSTUDIO_INVOKED -///////////////////////////////////////////////////////////////////////////// -// -// TEXTINCLUDE -// - -1 TEXTINCLUDE -BEGIN - "resource.h\0" -END - -2 TEXTINCLUDE -BEGIN - "#include ""winres.h""\r\n" - "\0" -END - -3 TEXTINCLUDE -BEGIN - "\r\n" - "\0" -END - -#endif // APSTUDIO_INVOKED - - -///////////////////////////////////////////////////////////////////////////// -// -// Icon -// - -// Icon with lowest ID value placed first to ensure application icon -// remains consistent on all systems. -IDI_APP_ICON ICON "resources\\app_icon.ico" - - -///////////////////////////////////////////////////////////////////////////// -// -// Version -// - -#ifdef FLUTTER_BUILD_NUMBER -#define VERSION_AS_NUMBER FLUTTER_BUILD_NUMBER -#else -#define VERSION_AS_NUMBER 1,0,0 -#endif - -#ifdef FLUTTER_BUILD_NAME -#define VERSION_AS_STRING #FLUTTER_BUILD_NAME -#else -#define VERSION_AS_STRING "1.0.0" -#endif - -VS_VERSION_INFO VERSIONINFO - FILEVERSION VERSION_AS_NUMBER - PRODUCTVERSION VERSION_AS_NUMBER - FILEFLAGSMASK VS_FFI_FILEFLAGSMASK -#ifdef _DEBUG - FILEFLAGS VS_FF_DEBUG -#else - FILEFLAGS 0x0L -#endif - FILEOS VOS__WINDOWS32 - FILETYPE VFT_APP - FILESUBTYPE 0x0L -BEGIN - BLOCK "StringFileInfo" - BEGIN - BLOCK "040904e4" - BEGIN - VALUE "CompanyName", "dev.flutter" "\0" - VALUE "FileDescription", "A new Flutter project." "\0" - VALUE "FileVersion", VERSION_AS_STRING "\0" - VALUE "InternalName", "linting_tool" "\0" - VALUE "LegalCopyright", "Copyright (C) 2021 dev.flutter. All rights reserved." "\0" - VALUE "OriginalFilename", "linting_tool.exe" "\0" - VALUE "ProductName", "linting_tool" "\0" - VALUE "ProductVersion", VERSION_AS_STRING "\0" - END - END - BLOCK "VarFileInfo" - BEGIN - VALUE "Translation", 0x409, 1252 - END -END - -#endif // English (United States) resources -///////////////////////////////////////////////////////////////////////////// - - - -#ifndef APSTUDIO_INVOKED -///////////////////////////////////////////////////////////////////////////// -// -// Generated from the TEXTINCLUDE 3 resource. -// - - -///////////////////////////////////////////////////////////////////////////// -#endif // not APSTUDIO_INVOKED diff --git a/experimental/linting_tool/windows/runner/flutter_window.cpp b/experimental/linting_tool/windows/runner/flutter_window.cpp deleted file mode 100644 index 41bbc5e0342..00000000000 --- a/experimental/linting_tool/windows/runner/flutter_window.cpp +++ /dev/null @@ -1,64 +0,0 @@ -#include "flutter_window.h" - -#include - -#include "flutter/generated_plugin_registrant.h" - -FlutterWindow::FlutterWindow(RunLoop* run_loop, - const flutter::DartProject& project) - : run_loop_(run_loop), project_(project) {} - -FlutterWindow::~FlutterWindow() {} - -bool FlutterWindow::OnCreate() { - if (!Win32Window::OnCreate()) { - return false; - } - - RECT frame = GetClientArea(); - - // The size here must match the window dimensions to avoid unnecessary surface - // creation / destruction in the startup path. - flutter_controller_ = std::make_unique( - frame.right - frame.left, frame.bottom - frame.top, project_); - // Ensure that basic setup of the controller was successful. - if (!flutter_controller_->engine() || !flutter_controller_->view()) { - return false; - } - RegisterPlugins(flutter_controller_->engine()); - run_loop_->RegisterFlutterInstance(flutter_controller_->engine()); - SetChildContent(flutter_controller_->view()->GetNativeWindow()); - return true; -} - -void FlutterWindow::OnDestroy() { - if (flutter_controller_) { - run_loop_->UnregisterFlutterInstance(flutter_controller_->engine()); - flutter_controller_ = nullptr; - } - - Win32Window::OnDestroy(); -} - -LRESULT -FlutterWindow::MessageHandler(HWND hwnd, UINT const message, - WPARAM const wparam, - LPARAM const lparam) noexcept { - // Give Flutter, including plugins, an opportunity to handle window messages. - if (flutter_controller_) { - std::optional result = - flutter_controller_->HandleTopLevelWindowProc(hwnd, message, wparam, - lparam); - if (result) { - return *result; - } - } - - switch (message) { - case WM_FONTCHANGE: - flutter_controller_->engine()->ReloadSystemFonts(); - break; - } - - return Win32Window::MessageHandler(hwnd, message, wparam, lparam); -} diff --git a/experimental/linting_tool/windows/runner/flutter_window.h b/experimental/linting_tool/windows/runner/flutter_window.h deleted file mode 100644 index b663ddd5012..00000000000 --- a/experimental/linting_tool/windows/runner/flutter_window.h +++ /dev/null @@ -1,39 +0,0 @@ -#ifndef RUNNER_FLUTTER_WINDOW_H_ -#define RUNNER_FLUTTER_WINDOW_H_ - -#include -#include - -#include - -#include "run_loop.h" -#include "win32_window.h" - -// A window that does nothing but host a Flutter view. -class FlutterWindow : public Win32Window { - public: - // Creates a new FlutterWindow driven by the |run_loop|, hosting a - // Flutter view running |project|. - explicit FlutterWindow(RunLoop* run_loop, - const flutter::DartProject& project); - virtual ~FlutterWindow(); - - protected: - // Win32Window: - bool OnCreate() override; - void OnDestroy() override; - LRESULT MessageHandler(HWND window, UINT const message, WPARAM const wparam, - LPARAM const lparam) noexcept override; - - private: - // The run loop driving events for this window. - RunLoop* run_loop_; - - // The project to run. - flutter::DartProject project_; - - // The Flutter instance hosted by this window. - std::unique_ptr flutter_controller_; -}; - -#endif // RUNNER_FLUTTER_WINDOW_H_ diff --git a/experimental/linting_tool/windows/runner/main.cpp b/experimental/linting_tool/windows/runner/main.cpp deleted file mode 100644 index 51bd7dad4f7..00000000000 --- a/experimental/linting_tool/windows/runner/main.cpp +++ /dev/null @@ -1,42 +0,0 @@ -#include -#include -#include - -#include "flutter_window.h" -#include "run_loop.h" -#include "utils.h" - -int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev, - _In_ wchar_t *command_line, _In_ int show_command) { - // Attach to console when present (e.g., 'flutter run') or create a - // new console when running with a debugger. - if (!::AttachConsole(ATTACH_PARENT_PROCESS) && ::IsDebuggerPresent()) { - CreateAndAttachConsole(); - } - - // Initialize COM, so that it is available for use in the library and/or - // plugins. - ::CoInitializeEx(nullptr, COINIT_APARTMENTTHREADED); - - RunLoop run_loop; - - flutter::DartProject project(L"data"); - - std::vector command_line_arguments = - GetCommandLineArguments(); - - project.set_dart_entrypoint_arguments(std::move(command_line_arguments)); - - FlutterWindow window(&run_loop, project); - Win32Window::Point origin(10, 10); - Win32Window::Size size(1280, 720); - if (!window.CreateAndShow(L"linting_tool", origin, size)) { - return EXIT_FAILURE; - } - window.SetQuitOnClose(true); - - run_loop.Run(); - - ::CoUninitialize(); - return EXIT_SUCCESS; -} diff --git a/experimental/linting_tool/windows/runner/resource.h b/experimental/linting_tool/windows/runner/resource.h deleted file mode 100644 index 66a65d1e4a7..00000000000 --- a/experimental/linting_tool/windows/runner/resource.h +++ /dev/null @@ -1,16 +0,0 @@ -//{{NO_DEPENDENCIES}} -// Microsoft Visual C++ generated include file. -// Used by Runner.rc -// -#define IDI_APP_ICON 101 - -// Next default values for new objects -// -#ifdef APSTUDIO_INVOKED -#ifndef APSTUDIO_READONLY_SYMBOLS -#define _APS_NEXT_RESOURCE_VALUE 102 -#define _APS_NEXT_COMMAND_VALUE 40001 -#define _APS_NEXT_CONTROL_VALUE 1001 -#define _APS_NEXT_SYMED_VALUE 101 -#endif -#endif diff --git a/experimental/linting_tool/windows/runner/resources/app_icon.ico b/experimental/linting_tool/windows/runner/resources/app_icon.ico deleted file mode 100644 index c04e20caf63..00000000000 Binary files a/experimental/linting_tool/windows/runner/resources/app_icon.ico and /dev/null differ diff --git a/experimental/linting_tool/windows/runner/run_loop.cpp b/experimental/linting_tool/windows/runner/run_loop.cpp deleted file mode 100644 index 2d6636ab6bc..00000000000 --- a/experimental/linting_tool/windows/runner/run_loop.cpp +++ /dev/null @@ -1,66 +0,0 @@ -#include "run_loop.h" - -#include - -#include - -RunLoop::RunLoop() {} - -RunLoop::~RunLoop() {} - -void RunLoop::Run() { - bool keep_running = true; - TimePoint next_flutter_event_time = TimePoint::clock::now(); - while (keep_running) { - std::chrono::nanoseconds wait_duration = - std::max(std::chrono::nanoseconds(0), - next_flutter_event_time - TimePoint::clock::now()); - ::MsgWaitForMultipleObjects( - 0, nullptr, FALSE, static_cast(wait_duration.count() / 1000), - QS_ALLINPUT); - bool processed_events = false; - MSG message; - // All pending Windows messages must be processed; MsgWaitForMultipleObjects - // won't return again for items left in the queue after PeekMessage. - while (::PeekMessage(&message, nullptr, 0, 0, PM_REMOVE)) { - processed_events = true; - if (message.message == WM_QUIT) { - keep_running = false; - break; - } - ::TranslateMessage(&message); - ::DispatchMessage(&message); - // Allow Flutter to process messages each time a Windows message is - // processed, to prevent starvation. - next_flutter_event_time = - std::min(next_flutter_event_time, ProcessFlutterMessages()); - } - // If the PeekMessage loop didn't run, process Flutter messages. - if (!processed_events) { - next_flutter_event_time = - std::min(next_flutter_event_time, ProcessFlutterMessages()); - } - } -} - -void RunLoop::RegisterFlutterInstance( - flutter::FlutterEngine* flutter_instance) { - flutter_instances_.insert(flutter_instance); -} - -void RunLoop::UnregisterFlutterInstance( - flutter::FlutterEngine* flutter_instance) { - flutter_instances_.erase(flutter_instance); -} - -RunLoop::TimePoint RunLoop::ProcessFlutterMessages() { - TimePoint next_event_time = TimePoint::max(); - for (auto instance : flutter_instances_) { - std::chrono::nanoseconds wait_duration = instance->ProcessMessages(); - if (wait_duration != std::chrono::nanoseconds::max()) { - next_event_time = - std::min(next_event_time, TimePoint::clock::now() + wait_duration); - } - } - return next_event_time; -} diff --git a/experimental/linting_tool/windows/runner/run_loop.h b/experimental/linting_tool/windows/runner/run_loop.h deleted file mode 100644 index 000d3624638..00000000000 --- a/experimental/linting_tool/windows/runner/run_loop.h +++ /dev/null @@ -1,40 +0,0 @@ -#ifndef RUNNER_RUN_LOOP_H_ -#define RUNNER_RUN_LOOP_H_ - -#include - -#include -#include - -// A runloop that will service events for Flutter instances as well -// as native messages. -class RunLoop { - public: - RunLoop(); - ~RunLoop(); - - // Prevent copying - RunLoop(RunLoop const&) = delete; - RunLoop& operator=(RunLoop const&) = delete; - - // Runs the run loop until the application quits. - void Run(); - - // Registers the given Flutter instance for event servicing. - void RegisterFlutterInstance( - flutter::FlutterEngine* flutter_instance); - - // Unregisters the given Flutter instance from event servicing. - void UnregisterFlutterInstance( - flutter::FlutterEngine* flutter_instance); - - private: - using TimePoint = std::chrono::steady_clock::time_point; - - // Processes all currently pending messages for registered Flutter instances. - TimePoint ProcessFlutterMessages(); - - std::set flutter_instances_; -}; - -#endif // RUNNER_RUN_LOOP_H_ diff --git a/experimental/linting_tool/windows/runner/runner.exe.manifest b/experimental/linting_tool/windows/runner/runner.exe.manifest deleted file mode 100644 index c977c4a4258..00000000000 --- a/experimental/linting_tool/windows/runner/runner.exe.manifest +++ /dev/null @@ -1,20 +0,0 @@ - - - - - PerMonitorV2 - - - - - - - - - - - - - - - diff --git a/experimental/linting_tool/windows/runner/utils.cpp b/experimental/linting_tool/windows/runner/utils.cpp deleted file mode 100644 index d19bdbbcc32..00000000000 --- a/experimental/linting_tool/windows/runner/utils.cpp +++ /dev/null @@ -1,64 +0,0 @@ -#include "utils.h" - -#include -#include -#include -#include - -#include - -void CreateAndAttachConsole() { - if (::AllocConsole()) { - FILE *unused; - if (freopen_s(&unused, "CONOUT$", "w", stdout)) { - _dup2(_fileno(stdout), 1); - } - if (freopen_s(&unused, "CONOUT$", "w", stderr)) { - _dup2(_fileno(stdout), 2); - } - std::ios::sync_with_stdio(); - FlutterDesktopResyncOutputStreams(); - } -} - -std::vector GetCommandLineArguments() { - // Convert the UTF-16 command line arguments to UTF-8 for the Engine to use. - int argc; - wchar_t** argv = ::CommandLineToArgvW(::GetCommandLineW(), &argc); - if (argv == nullptr) { - return std::vector(); - } - - std::vector command_line_arguments; - - // Skip the first argument as it's the binary name. - for (int i = 1; i < argc; i++) { - command_line_arguments.push_back(Utf8FromUtf16(argv[i])); - } - - ::LocalFree(argv); - - return command_line_arguments; -} - -std::string Utf8FromUtf16(const wchar_t* utf16_string) { - if (utf16_string == nullptr) { - return std::string(); - } - int target_length = ::WideCharToMultiByte( - CP_UTF8, WC_ERR_INVALID_CHARS, utf16_string, - -1, nullptr, 0, nullptr, nullptr); - if (target_length == 0) { - return std::string(); - } - std::string utf8_string; - utf8_string.resize(target_length); - int converted_length = ::WideCharToMultiByte( - CP_UTF8, WC_ERR_INVALID_CHARS, utf16_string, - -1, utf8_string.data(), - target_length, nullptr, nullptr); - if (converted_length == 0) { - return std::string(); - } - return utf8_string; -} diff --git a/experimental/linting_tool/windows/runner/utils.h b/experimental/linting_tool/windows/runner/utils.h deleted file mode 100644 index 3879d547557..00000000000 --- a/experimental/linting_tool/windows/runner/utils.h +++ /dev/null @@ -1,19 +0,0 @@ -#ifndef RUNNER_UTILS_H_ -#define RUNNER_UTILS_H_ - -#include -#include - -// Creates a console for the process, and redirects stdout and stderr to -// it for both the runner and the Flutter library. -void CreateAndAttachConsole(); - -// Takes a null-terminated wchar_t* encoded in UTF-16 and returns a std::string -// encoded in UTF-8. Returns an empty std::string on failure. -std::string Utf8FromUtf16(const wchar_t* utf16_string); - -// Gets the command line arguments passed in as a std::vector, -// encoded in UTF-8. Returns an empty std::vector on failure. -std::vector GetCommandLineArguments(); - -#endif // RUNNER_UTILS_H_ diff --git a/experimental/linting_tool/windows/runner/win32_window.cpp b/experimental/linting_tool/windows/runner/win32_window.cpp deleted file mode 100644 index c10f08dc7da..00000000000 --- a/experimental/linting_tool/windows/runner/win32_window.cpp +++ /dev/null @@ -1,245 +0,0 @@ -#include "win32_window.h" - -#include - -#include "resource.h" - -namespace { - -constexpr const wchar_t kWindowClassName[] = L"FLUTTER_RUNNER_WIN32_WINDOW"; - -// The number of Win32Window objects that currently exist. -static int g_active_window_count = 0; - -using EnableNonClientDpiScaling = BOOL __stdcall(HWND hwnd); - -// Scale helper to convert logical scaler values to physical using passed in -// scale factor -int Scale(int source, double scale_factor) { - return static_cast(source * scale_factor); -} - -// Dynamically loads the |EnableNonClientDpiScaling| from the User32 module. -// This API is only needed for PerMonitor V1 awareness mode. -void EnableFullDpiSupportIfAvailable(HWND hwnd) { - HMODULE user32_module = LoadLibraryA("User32.dll"); - if (!user32_module) { - return; - } - auto enable_non_client_dpi_scaling = - reinterpret_cast( - GetProcAddress(user32_module, "EnableNonClientDpiScaling")); - if (enable_non_client_dpi_scaling != nullptr) { - enable_non_client_dpi_scaling(hwnd); - FreeLibrary(user32_module); - } -} - -} // namespace - -// Manages the Win32Window's window class registration. -class WindowClassRegistrar { - public: - ~WindowClassRegistrar() = default; - - // Returns the singleton registar instance. - static WindowClassRegistrar* GetInstance() { - if (!instance_) { - instance_ = new WindowClassRegistrar(); - } - return instance_; - } - - // Returns the name of the window class, registering the class if it hasn't - // previously been registered. - const wchar_t* GetWindowClass(); - - // Unregisters the window class. Should only be called if there are no - // instances of the window. - void UnregisterWindowClass(); - - private: - WindowClassRegistrar() = default; - - static WindowClassRegistrar* instance_; - - bool class_registered_ = false; -}; - -WindowClassRegistrar* WindowClassRegistrar::instance_ = nullptr; - -const wchar_t* WindowClassRegistrar::GetWindowClass() { - if (!class_registered_) { - WNDCLASS window_class{}; - window_class.hCursor = LoadCursor(nullptr, IDC_ARROW); - window_class.lpszClassName = kWindowClassName; - window_class.style = CS_HREDRAW | CS_VREDRAW; - window_class.cbClsExtra = 0; - window_class.cbWndExtra = 0; - window_class.hInstance = GetModuleHandle(nullptr); - window_class.hIcon = - LoadIcon(window_class.hInstance, MAKEINTRESOURCE(IDI_APP_ICON)); - window_class.hbrBackground = 0; - window_class.lpszMenuName = nullptr; - window_class.lpfnWndProc = Win32Window::WndProc; - RegisterClass(&window_class); - class_registered_ = true; - } - return kWindowClassName; -} - -void WindowClassRegistrar::UnregisterWindowClass() { - UnregisterClass(kWindowClassName, nullptr); - class_registered_ = false; -} - -Win32Window::Win32Window() { - ++g_active_window_count; -} - -Win32Window::~Win32Window() { - --g_active_window_count; - Destroy(); -} - -bool Win32Window::CreateAndShow(const std::wstring& title, - const Point& origin, - const Size& size) { - Destroy(); - - const wchar_t* window_class = - WindowClassRegistrar::GetInstance()->GetWindowClass(); - - const POINT target_point = {static_cast(origin.x), - static_cast(origin.y)}; - HMONITOR monitor = MonitorFromPoint(target_point, MONITOR_DEFAULTTONEAREST); - UINT dpi = FlutterDesktopGetDpiForMonitor(monitor); - double scale_factor = dpi / 96.0; - - HWND window = CreateWindow( - window_class, title.c_str(), WS_OVERLAPPEDWINDOW | WS_VISIBLE, - Scale(origin.x, scale_factor), Scale(origin.y, scale_factor), - Scale(size.width, scale_factor), Scale(size.height, scale_factor), - nullptr, nullptr, GetModuleHandle(nullptr), this); - - if (!window) { - return false; - } - - return OnCreate(); -} - -// static -LRESULT CALLBACK Win32Window::WndProc(HWND const window, - UINT const message, - WPARAM const wparam, - LPARAM const lparam) noexcept { - if (message == WM_NCCREATE) { - auto window_struct = reinterpret_cast(lparam); - SetWindowLongPtr(window, GWLP_USERDATA, - reinterpret_cast(window_struct->lpCreateParams)); - - auto that = static_cast(window_struct->lpCreateParams); - EnableFullDpiSupportIfAvailable(window); - that->window_handle_ = window; - } else if (Win32Window* that = GetThisFromHandle(window)) { - return that->MessageHandler(window, message, wparam, lparam); - } - - return DefWindowProc(window, message, wparam, lparam); -} - -LRESULT -Win32Window::MessageHandler(HWND hwnd, - UINT const message, - WPARAM const wparam, - LPARAM const lparam) noexcept { - switch (message) { - case WM_DESTROY: - window_handle_ = nullptr; - Destroy(); - if (quit_on_close_) { - PostQuitMessage(0); - } - return 0; - - case WM_DPICHANGED: { - auto newRectSize = reinterpret_cast(lparam); - LONG newWidth = newRectSize->right - newRectSize->left; - LONG newHeight = newRectSize->bottom - newRectSize->top; - - SetWindowPos(hwnd, nullptr, newRectSize->left, newRectSize->top, newWidth, - newHeight, SWP_NOZORDER | SWP_NOACTIVATE); - - return 0; - } - case WM_SIZE: { - RECT rect = GetClientArea(); - if (child_content_ != nullptr) { - // Size and position the child window. - MoveWindow(child_content_, rect.left, rect.top, rect.right - rect.left, - rect.bottom - rect.top, TRUE); - } - return 0; - } - - case WM_ACTIVATE: - if (child_content_ != nullptr) { - SetFocus(child_content_); - } - return 0; - } - - return DefWindowProc(window_handle_, message, wparam, lparam); -} - -void Win32Window::Destroy() { - OnDestroy(); - - if (window_handle_) { - DestroyWindow(window_handle_); - window_handle_ = nullptr; - } - if (g_active_window_count == 0) { - WindowClassRegistrar::GetInstance()->UnregisterWindowClass(); - } -} - -Win32Window* Win32Window::GetThisFromHandle(HWND const window) noexcept { - return reinterpret_cast( - GetWindowLongPtr(window, GWLP_USERDATA)); -} - -void Win32Window::SetChildContent(HWND content) { - child_content_ = content; - SetParent(content, window_handle_); - RECT frame = GetClientArea(); - - MoveWindow(content, frame.left, frame.top, frame.right - frame.left, - frame.bottom - frame.top, true); - - SetFocus(child_content_); -} - -RECT Win32Window::GetClientArea() { - RECT frame; - GetClientRect(window_handle_, &frame); - return frame; -} - -HWND Win32Window::GetHandle() { - return window_handle_; -} - -void Win32Window::SetQuitOnClose(bool quit_on_close) { - quit_on_close_ = quit_on_close; -} - -bool Win32Window::OnCreate() { - // No-op; provided for subclasses. - return true; -} - -void Win32Window::OnDestroy() { - // No-op; provided for subclasses. -} diff --git a/experimental/linting_tool/windows/runner/win32_window.h b/experimental/linting_tool/windows/runner/win32_window.h deleted file mode 100644 index 17ba431125b..00000000000 --- a/experimental/linting_tool/windows/runner/win32_window.h +++ /dev/null @@ -1,98 +0,0 @@ -#ifndef RUNNER_WIN32_WINDOW_H_ -#define RUNNER_WIN32_WINDOW_H_ - -#include - -#include -#include -#include - -// A class abstraction for a high DPI-aware Win32 Window. Intended to be -// inherited from by classes that wish to specialize with custom -// rendering and input handling -class Win32Window { - public: - struct Point { - unsigned int x; - unsigned int y; - Point(unsigned int x, unsigned int y) : x(x), y(y) {} - }; - - struct Size { - unsigned int width; - unsigned int height; - Size(unsigned int width, unsigned int height) - : width(width), height(height) {} - }; - - Win32Window(); - virtual ~Win32Window(); - - // Creates and shows a win32 window with |title| and position and size using - // |origin| and |size|. New windows are created on the default monitor. Window - // sizes are specified to the OS in physical pixels, hence to ensure a - // consistent size to will treat the width height passed in to this function - // as logical pixels and scale to appropriate for the default monitor. Returns - // true if the window was created successfully. - bool CreateAndShow(const std::wstring& title, - const Point& origin, - const Size& size); - - // Release OS resources associated with window. - void Destroy(); - - // Inserts |content| into the window tree. - void SetChildContent(HWND content); - - // Returns the backing Window handle to enable clients to set icon and other - // window properties. Returns nullptr if the window has been destroyed. - HWND GetHandle(); - - // If true, closing this window will quit the application. - void SetQuitOnClose(bool quit_on_close); - - // Return a RECT representing the bounds of the current client area. - RECT GetClientArea(); - - protected: - // Processes and route salient window messages for mouse handling, - // size change and DPI. Delegates handling of these to member overloads that - // inheriting classes can handle. - virtual LRESULT MessageHandler(HWND window, - UINT const message, - WPARAM const wparam, - LPARAM const lparam) noexcept; - - // Called when CreateAndShow is called, allowing subclass window-related - // setup. Subclasses should return false if setup fails. - virtual bool OnCreate(); - - // Called when Destroy is called. - virtual void OnDestroy(); - - private: - friend class WindowClassRegistrar; - - // OS callback called by message pump. Handles the WM_NCCREATE message which - // is passed when the non-client area is being created and enables automatic - // non-client DPI scaling so that the non-client area automatically - // responsponds to changes in DPI. All other messages are handled by - // MessageHandler. - static LRESULT CALLBACK WndProc(HWND const window, - UINT const message, - WPARAM const wparam, - LPARAM const lparam) noexcept; - - // Retrieves a class instance pointer for |window| - static Win32Window* GetThisFromHandle(HWND const window) noexcept; - - bool quit_on_close_ = false; - - // window handle for top level window. - HWND window_handle_ = nullptr; - - // window handle for hosted content. - HWND child_content_ = nullptr; -}; - -#endif // RUNNER_WIN32_WINDOW_H_