flutter_rb 1.0.0 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CODE_OF_CONDUCT.md +76 -0
- data/COMMIT_CONVENTION.md +58 -0
- data/README.md +24 -27
- data/lib/checkstyle_report/checkstyle_report.rb +25 -1
- data/lib/flutter_rb/checks/check.rb +9 -1
- data/lib/flutter_rb/checks/plugin_directories_check.rb +5 -0
- data/lib/flutter_rb/checks/plugin_gradle_check.rb +10 -0
- data/lib/flutter_rb/checks/plugin_podspec_check.rb +35 -16
- data/lib/flutter_rb/checks/plugin_pubspec_check.rb +54 -25
- data/lib/flutter_rb/config/flutter_rb_config.rb +4 -5
- data/lib/flutter_rb/config/flutter_rb_config_initializer.rb +20 -5
- data/lib/flutter_rb/project/project.rb +7 -0
- data/lib/flutter_rb/project/specs/android/android_folder.rb +1 -0
- data/lib/flutter_rb/project/specs/android/gradle.rb +4 -0
- data/lib/flutter_rb/project/specs/flutter/dev_dependency.rb +2 -0
- data/lib/flutter_rb/project/specs/flutter/platform_plugin.rb +3 -0
- data/lib/flutter_rb/project/specs/flutter/pubspec.rb +13 -0
- data/lib/flutter_rb/project/specs/flutter/pubspec_info.rb +5 -0
- data/lib/flutter_rb/project/specs/ios/ios_folder.rb +2 -0
- data/lib/flutter_rb/project/specs/ios/podspec.rb +7 -0
- data/lib/flutter_rb/report/check_report.rb +10 -0
- data/lib/flutter_rb.rb +36 -10
- metadata +18 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 8fd9ab4300d4125491e760985c8d40ffc3fa5f96991591e175f944841982328f
|
4
|
+
data.tar.gz: b1458595c0f9f9ffdd6f288acb6ef38a2e008a6d692bdacfc1c91afb9512c193
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 44ee511a8e2f5537d14eaa0097fcb0ba22e61fdfcb9b9300814b5b793cc23617a7017dd413384069f95cbd7f6ebd7a1cf3330a0011aa942318bc4224bdc5b2db
|
7
|
+
data.tar.gz: 42eb043999a521b44ec7a9950e6cb9e1fc8fb8fecf2f8d59cc0b9c6e0c369a69d43a071be6970bcac8780e3caa734f7c2ea9468b098e40d52daed92b6be43d29
|
data/CODE_OF_CONDUCT.md
ADDED
@@ -0,0 +1,76 @@
|
|
1
|
+
# Contributor Covenant Code of Conduct
|
2
|
+
|
3
|
+
## Our Pledge
|
4
|
+
|
5
|
+
In the interest of fostering an open and welcoming environment, we as
|
6
|
+
contributors and maintainers pledge to making participation in our project and
|
7
|
+
our community a harassment-free experience for everyone, regardless of age, body
|
8
|
+
size, disability, ethnicity, sex characteristics, gender identity and expression,
|
9
|
+
level of experience, education, socio-economic status, nationality, personal
|
10
|
+
appearance, race, religion, or sexual identity and orientation.
|
11
|
+
|
12
|
+
## Our Standards
|
13
|
+
|
14
|
+
Examples of behavior that contributes to creating a positive environment
|
15
|
+
include:
|
16
|
+
|
17
|
+
* Using welcoming and inclusive language
|
18
|
+
* Being respectful of differing viewpoints and experiences
|
19
|
+
* Gracefully accepting constructive criticism
|
20
|
+
* Focusing on what is best for the community
|
21
|
+
* Showing empathy towards other community members
|
22
|
+
|
23
|
+
Examples of unacceptable behavior by participants include:
|
24
|
+
|
25
|
+
* The use of sexualized language or imagery and unwelcome sexual attention or
|
26
|
+
advances
|
27
|
+
* Trolling, insulting/derogatory comments, and personal or political attacks
|
28
|
+
* Public or private harassment
|
29
|
+
* Publishing others' private information, such as a physical or electronic
|
30
|
+
address, without explicit permission
|
31
|
+
* Other conduct which could reasonably be considered inappropriate in a
|
32
|
+
professional setting
|
33
|
+
|
34
|
+
## Our Responsibilities
|
35
|
+
|
36
|
+
Project maintainers are responsible for clarifying the standards of acceptable
|
37
|
+
behavior and are expected to take appropriate and fair corrective action in
|
38
|
+
response to any instances of unacceptable behavior.
|
39
|
+
|
40
|
+
Project maintainers have the right and responsibility to remove, edit, or
|
41
|
+
reject comments, commits, code, wiki edits, issues, and other contributions
|
42
|
+
that are not aligned to this Code of Conduct, or to ban temporarily or
|
43
|
+
permanently any contributor for other behaviors that they deem inappropriate,
|
44
|
+
threatening, offensive, or harmful.
|
45
|
+
|
46
|
+
## Scope
|
47
|
+
|
48
|
+
This Code of Conduct applies both within project spaces and in public spaces
|
49
|
+
when an individual is representing the project or its community. Examples of
|
50
|
+
representing a project or community include using an official project e-mail
|
51
|
+
address, posting via an official social media account, or acting as an appointed
|
52
|
+
representative at an online or offline event. Representation of a project may be
|
53
|
+
further defined and clarified by project maintainers.
|
54
|
+
|
55
|
+
## Enforcement
|
56
|
+
|
57
|
+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
|
58
|
+
reported by contacting the project team at jaman.smlnsk@gmail.com. All
|
59
|
+
complaints will be reviewed and investigated and will result in a response that
|
60
|
+
is deemed necessary and appropriate to the circumstances. The project team is
|
61
|
+
obligated to maintain confidentiality with regard to the reporter of an incident.
|
62
|
+
Further details of specific enforcement policies may be posted separately.
|
63
|
+
|
64
|
+
Project maintainers who do not follow or enforce the Code of Conduct in good
|
65
|
+
faith may face temporary or permanent repercussions as determined by other
|
66
|
+
members of the project's leadership.
|
67
|
+
|
68
|
+
## Attribution
|
69
|
+
|
70
|
+
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
|
71
|
+
available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
|
72
|
+
|
73
|
+
[homepage]: https://www.contributor-covenant.org
|
74
|
+
|
75
|
+
For answers to common questions about this code of conduct, see
|
76
|
+
https://www.contributor-covenant.org/faq
|
@@ -0,0 +1,58 @@
|
|
1
|
+
# Commit Convention
|
2
|
+
|
3
|
+
## How to work with a project
|
4
|
+
|
5
|
+
### As a repository maintainer
|
6
|
+
|
7
|
+
#### New update
|
8
|
+
|
9
|
+
1. clone a project from a repository to local workspace;
|
10
|
+
2. create a new branch for an update;
|
11
|
+
3. complete the update;
|
12
|
+
4. perform a Code Review;
|
13
|
+
5. merge your branch with `master`;
|
14
|
+
6. delete your branch.
|
15
|
+
|
16
|
+
#### Notes
|
17
|
+
|
18
|
+
1. always delete development branches;
|
19
|
+
2. always push squashed commit to `master`.
|
20
|
+
|
21
|
+
### As a contributor
|
22
|
+
|
23
|
+
1. clone a project from a repository to local workspace;
|
24
|
+
2. create a new branch for an update;
|
25
|
+
3. complete the update;
|
26
|
+
4. perform a Code Review;
|
27
|
+
5. create a Pull Request to the original repository.
|
28
|
+
|
29
|
+
## Branches
|
30
|
+
|
31
|
+
### In projects using next types of branches
|
32
|
+
|
33
|
+
* `master` - master branch. Contains a production version of the project. Don't push working changes to `master`!
|
34
|
+
* `version` - branch for a specific version.
|
35
|
+
* `issue` - branch for a specific issue.
|
36
|
+
|
37
|
+
## Commit message structure
|
38
|
+
|
39
|
+
### Template
|
40
|
+
|
41
|
+
```text
|
42
|
+
[DATE] [VERSION]: [MESSAGE]
|
43
|
+
```
|
44
|
+
|
45
|
+
### Example
|
46
|
+
|
47
|
+
```text
|
48
|
+
2019-05-12 v. 2.1.3: fixed bugs in History screen
|
49
|
+
```
|
50
|
+
|
51
|
+
#### Commit body sections order
|
52
|
+
|
53
|
+
1. `added` - what was added in the commit;
|
54
|
+
2. `closed` - what issues closed in the commit;
|
55
|
+
3. `fixed` - what was fixed in the commit;
|
56
|
+
4. `updated` - what was updated in the commit;
|
57
|
+
5. `deleted` - what was deleted in the commit;
|
58
|
+
6. `refactored` - what was refactored in the commit.
|
data/README.md
CHANGED
@@ -3,8 +3,9 @@
|
|
3
3
|
# flutter_rb
|
4
4
|
|
5
5
|
[](https://github.com/flutter-rb/flutter-rb/actions?branch=master)
|
6
|
-
[](https://codebeat.co/projects/github-com-
|
6
|
+
[](https://codebeat.co/projects/github-com-flutter-rb-flutter-rb-master)
|
7
7
|
[](https://badge.fury.io/rb/flutter_rb)
|
8
|
+
[](https://badge.fury.io/rb/flutter_rb)
|
8
9
|
|
9
10
|
## About
|
10
11
|
|
@@ -14,13 +15,13 @@ A tool for checking a Flutter plugin structure.
|
|
14
15
|
|
15
16
|
#### Levels
|
16
17
|
|
17
|
-
Each issue has a `level` parameter that describes
|
18
|
+
Each issue has a `level` parameter that describes its significant importance.
|
18
19
|
|
19
|
-
| Level | Description
|
20
|
-
|
21
|
-
| `NORMAL` | Issue
|
22
|
-
| `WARNING` | Issue is not serious and
|
23
|
-
| `ERROR` | Issue is critical and can break build
|
20
|
+
| Level | Description |
|
21
|
+
|-----------|----------------------------------------------|
|
22
|
+
| `NORMAL` | Issue not found |
|
23
|
+
| `WARNING` | Issue is not serious and can't break a build |
|
24
|
+
| `ERROR` | Issue is critical and can break a build |
|
24
25
|
|
25
26
|
#### Flutter
|
26
27
|
|
@@ -54,48 +55,43 @@ Each issue has a `level` parameter that describes his significate level.
|
|
54
55
|
|
55
56
|
### Android
|
56
57
|
|
57
|
-
You should add [flutter-rb-gradle-plugin](https://github.com/flutter-rb/flutter-rb-gradle-plugin) to Android side of
|
58
|
+
You should add [flutter-rb-gradle-plugin](https://github.com/flutter-rb/flutter-rb-gradle-plugin) to Android side of
|
59
|
+
your plugin.
|
58
60
|
|
59
61
|
### Download gem from RubyGems
|
60
62
|
|
61
|
-
Install gem:
|
62
|
-
|
63
63
|
```shell
|
64
|
-
gem
|
64
|
+
$ gem i flutter_rb
|
65
65
|
```
|
66
66
|
|
67
67
|
Then run from a Flutter plugin's project folder:
|
68
68
|
|
69
69
|
```shell
|
70
|
-
frb
|
70
|
+
$ frb
|
71
71
|
```
|
72
72
|
|
73
73
|
### As local installed gem
|
74
74
|
|
75
|
-
Build gem from sources:
|
76
|
-
|
77
|
-
```shell
|
78
|
-
gem build flutter_rb.gemspec
|
79
|
-
```
|
80
|
-
|
81
|
-
Install gem:
|
75
|
+
Build and install gem from sources:
|
82
76
|
|
83
77
|
```shell
|
84
|
-
gem
|
78
|
+
$ gem build flutter_rb.gemspec
|
79
|
+
$ gem i flutter_rb
|
85
80
|
```
|
86
81
|
|
87
82
|
Then run from a Flutter plugin's project folder:
|
88
83
|
|
89
84
|
```shell
|
90
|
-
frb
|
85
|
+
$ frb
|
91
86
|
```
|
92
87
|
|
93
88
|
### As local executable
|
94
89
|
|
95
|
-
Add `project_folder/bin` (where `project_folder` is path to project on your machine) to `PATH` variable in your
|
90
|
+
Add `project_folder/bin` (where `project_folder` is path to project on your machine) to `PATH` variable in your
|
91
|
+
environment. Then updated environment and run from a Flutter plugin's project folder:
|
96
92
|
|
97
93
|
```shell
|
98
|
-
local_frb
|
94
|
+
$ local_frb
|
99
95
|
```
|
100
96
|
|
101
97
|
### Arguments
|
@@ -105,7 +101,6 @@ local_frb
|
|
105
101
|
| `--help` | Print help info |
|
106
102
|
| `--checkstyle-report` | Generate report in Checkstyle format |
|
107
103
|
|
108
|
-
|
109
104
|
### Configuration
|
110
105
|
|
111
106
|
Add `.flutter_rb.yaml` to root of a project for select checks that you are want to execute:
|
@@ -127,14 +122,16 @@ include:
|
|
127
122
|
|
128
123
|
### Output report
|
129
124
|
|
130
|
-
Tool can make report in Checkstyle format. To enable this feature, pass `--checkstyle-report` as an CLI argument. The
|
125
|
+
Tool can make report in Checkstyle format. To enable this feature, pass `--checkstyle-report` as an CLI argument. The
|
126
|
+
report file name is `frb-checkstyle-report.xml`.
|
131
127
|
|
132
128
|
## How to contribute
|
133
129
|
|
134
|
-
Read [Commit Convention](
|
130
|
+
Read [Commit Convention](./COMMIT_CONVENTION.md). Make sure your build is green before you contribute your pull request.
|
131
|
+
Then:
|
135
132
|
|
136
133
|
```shell
|
137
|
-
bundle exec rake
|
134
|
+
$ bundle exec rake
|
138
135
|
```
|
139
136
|
|
140
137
|
If you don't see any error messages, submit your pull request.
|
@@ -4,12 +4,17 @@ require 'nokogiri'
|
|
4
4
|
module CheckstyleReport
|
5
5
|
# Class for create report in Checkstyle format
|
6
6
|
class CheckstyleReport
|
7
|
+
# @param {String} path
|
8
|
+
# @param {String} report_filename
|
9
|
+
# @param {CheckstyleError[]}
|
7
10
|
def initialize(path, report_filename, checks)
|
8
11
|
@path = path
|
9
12
|
@report_filename = report_filename
|
10
13
|
@checks = checks
|
11
14
|
end
|
12
15
|
|
16
|
+
# rubocop:disable Metrics/MethodLength
|
17
|
+
# noinspection RubyResolve
|
13
18
|
def create_report
|
14
19
|
checkstyle_files = sort_checks(@checks)
|
15
20
|
report = Nokogiri::XML::Builder.new do |xml|
|
@@ -19,9 +24,15 @@ module CheckstyleReport
|
|
19
24
|
.each { |file| write_file(xml, file) }
|
20
25
|
end
|
21
26
|
end
|
22
|
-
File.open("#{@path}/#{@report_filename}.xml", 'w')
|
27
|
+
File.open("#{@path}/#{@report_filename}.xml", 'w') do |file|
|
28
|
+
file.write(report.to_xml)
|
29
|
+
end
|
23
30
|
end
|
24
31
|
|
32
|
+
# rubocop:enable Metrics/MethodLength
|
33
|
+
|
34
|
+
# @param {CheckstyleError} checks
|
35
|
+
# @return {CheckstyleFile[]}
|
25
36
|
def sort_checks(checks)
|
26
37
|
checkstyle_files = {}
|
27
38
|
checks.each do |check|
|
@@ -32,6 +43,8 @@ module CheckstyleReport
|
|
32
43
|
checkstyle_files
|
33
44
|
end
|
34
45
|
|
46
|
+
# @param {XML} xml
|
47
|
+
# @param {CheckstyleFile} checkstyle_file
|
35
48
|
def write_file(xml, checkstyle_file)
|
36
49
|
xml.file(name: checkstyle_file.file) do
|
37
50
|
checkstyle_file.errors.each do |error|
|
@@ -40,6 +53,8 @@ module CheckstyleReport
|
|
40
53
|
end
|
41
54
|
end
|
42
55
|
|
56
|
+
# @param {XML} xml
|
57
|
+
# @param {CheckstyleError} error
|
43
58
|
def write_error(xml, error)
|
44
59
|
xml.error(
|
45
60
|
line: error.line,
|
@@ -53,6 +68,8 @@ module CheckstyleReport
|
|
53
68
|
|
54
69
|
# File representation for Checkstyle format
|
55
70
|
class CheckstyleFile
|
71
|
+
# @param {String} file
|
72
|
+
# @param {CheckstyleError[]} errors
|
56
73
|
def initialize(file, errors)
|
57
74
|
@file = file
|
58
75
|
@errors = errors
|
@@ -68,6 +85,12 @@ module CheckstyleReport
|
|
68
85
|
SEVERITY_ERROR = 'error'.freeze
|
69
86
|
|
70
87
|
# rubocop:disable Metrics/ParameterLists
|
88
|
+
# @param {String} severity
|
89
|
+
# @param {String} message
|
90
|
+
# @param {String} source
|
91
|
+
# @param {Integer} line
|
92
|
+
# @param {Integer} column
|
93
|
+
# @param {String} name
|
71
94
|
def initialize(
|
72
95
|
severity,
|
73
96
|
message,
|
@@ -83,6 +106,7 @@ module CheckstyleReport
|
|
83
106
|
@column = column
|
84
107
|
@name = name
|
85
108
|
end
|
109
|
+
|
86
110
|
# rubocop:enable Metrics/ParameterLists
|
87
111
|
|
88
112
|
attr_reader :severity, :message, :source, :line, :column, :name
|
@@ -5,20 +5,28 @@ module FlutterRb
|
|
5
5
|
class Check
|
6
6
|
UNIMPLEMENTED_ERROR = 'Error: missing method'.freeze
|
7
7
|
|
8
|
+
# @return {String}
|
8
9
|
def name
|
9
10
|
raise UNIMPLEMENTED_ERROR
|
10
11
|
end
|
11
12
|
|
13
|
+
# @return {String}
|
12
14
|
def summary
|
13
15
|
raise UNIMPLEMENTED_ERROR
|
14
16
|
end
|
15
17
|
|
18
|
+
# @return {String}
|
16
19
|
def description
|
17
20
|
'No provided'
|
18
21
|
end
|
19
22
|
|
20
|
-
|
23
|
+
# rubocop:disable Lint/UnusedMethodArgument
|
24
|
+
# @param {Project} project
|
25
|
+
# @return {CheckReport}
|
26
|
+
def check(project)
|
21
27
|
raise UNIMPLEMENTED_ERROR
|
22
28
|
end
|
29
|
+
|
30
|
+
# rubocop:enable Lint/UnusedMethodArgument
|
23
31
|
end
|
24
32
|
end
|
@@ -6,18 +6,23 @@ module FlutterRb
|
|
6
6
|
# Example: if a Flutter plugin has only Android specific code
|
7
7
|
# but not contains iOS folder with description, then iOS build fails
|
8
8
|
class PluginDirectoriesCheck < Check
|
9
|
+
# @return {String}
|
9
10
|
def name
|
10
11
|
'PluginDirectoriesCheck'
|
11
12
|
end
|
12
13
|
|
14
|
+
# @return {String}
|
13
15
|
def summary
|
14
16
|
'Validate Flutter plugin structure'
|
15
17
|
end
|
16
18
|
|
19
|
+
# @return {String}
|
17
20
|
def description
|
18
21
|
'Check plugin directories structure in pubspec file'
|
19
22
|
end
|
20
23
|
|
24
|
+
# @param {Project} project
|
25
|
+
# @return {CheckReport}
|
21
26
|
def check(project)
|
22
27
|
android_exists = !project.android_folder.nil?
|
23
28
|
ios_exists = !project.ios_folder.nil?
|
@@ -4,18 +4,23 @@ require_relative '../report/check_report'
|
|
4
4
|
module FlutterRb
|
5
5
|
# Check 'android; import not exists in Gradle project config (build.gradle file)
|
6
6
|
class PluginGradleAndroidPackageCheck < Check
|
7
|
+
# @return {String}
|
7
8
|
def name
|
8
9
|
'PluginGradleAndroidPackageCheck'
|
9
10
|
end
|
10
11
|
|
12
|
+
# @return {String}
|
11
13
|
def summary
|
12
14
|
'Validate that \android\ package not exists in build.gradle config'
|
13
15
|
end
|
14
16
|
|
17
|
+
# @return {String}
|
15
18
|
def description
|
16
19
|
'Validate that \android\ package not exists in Gradle project config (build.gradle file)'
|
17
20
|
end
|
18
21
|
|
22
|
+
# @param {Project} project
|
23
|
+
# @return {CheckReport}
|
19
24
|
def check(project)
|
20
25
|
gradle = project.android_folder.gradle
|
21
26
|
import_exist = File.readlines("#{gradle.path}/build.gradle").grep(/package android/).size.positive?
|
@@ -30,18 +35,23 @@ module FlutterRb
|
|
30
35
|
|
31
36
|
# Check Flutter plugin version in Gradle project config (build.gradle file)
|
32
37
|
class PluginGradleVersionCheck < Check
|
38
|
+
# @return {String}
|
33
39
|
def name
|
34
40
|
'PluginGradleVersionCheck'
|
35
41
|
end
|
36
42
|
|
43
|
+
# @return {String}
|
37
44
|
def summary
|
38
45
|
'Validate Flutter plugin\s version in build.gradle file'
|
39
46
|
end
|
40
47
|
|
48
|
+
# @return {String}
|
41
49
|
def description
|
42
50
|
'Check plugin version in Gradle project config (build.gradle file)'
|
43
51
|
end
|
44
52
|
|
53
|
+
# @param {Project} project
|
54
|
+
# @return {CheckReport}
|
45
55
|
def check(project)
|
46
56
|
version_in_pubspec = project.pubspec.pubspec_info.version
|
47
57
|
gradle = project.android_folder.gradle
|
@@ -4,14 +4,17 @@ require_relative '../report/check_report'
|
|
4
4
|
module FlutterRb
|
5
5
|
# Base class for all info parameters in Flutter plugin podspec file
|
6
6
|
class PluginPodspecCheck < Check
|
7
|
+
# @return {String}
|
7
8
|
def name
|
8
9
|
"PluginPodspec#{podspec_parameter.capitalize}Check"
|
9
10
|
end
|
10
11
|
|
12
|
+
# @return {String}
|
11
13
|
def podspec_parameter
|
12
14
|
UNIMPLEMENTED_ERROR
|
13
15
|
end
|
14
16
|
|
17
|
+
# @return {String}
|
15
18
|
def summary
|
16
19
|
"Validate Flutter plugin's #{podspec_parameter} in podspec file"
|
17
20
|
end
|
@@ -19,10 +22,18 @@ module FlutterRb
|
|
19
22
|
|
20
23
|
# Check Flutter plugin name in podspec file. Exists or not
|
21
24
|
class PluginPodspecNameCheck < PluginPodspecCheck
|
25
|
+
# @return {String}
|
22
26
|
def podspec_parameter
|
23
27
|
'name'
|
24
28
|
end
|
25
29
|
|
30
|
+
# @return {String}
|
31
|
+
def description
|
32
|
+
'Check plugin name in podspec file'
|
33
|
+
end
|
34
|
+
|
35
|
+
# @param {Project} project
|
36
|
+
# @return {CheckReport}
|
26
37
|
def check(project)
|
27
38
|
name_in_pubspec = project.pubspec.pubspec_info.name
|
28
39
|
podspec = project.ios_folder.podspec
|
@@ -34,18 +45,22 @@ module FlutterRb
|
|
34
45
|
podspec.path
|
35
46
|
)
|
36
47
|
end
|
37
|
-
|
38
|
-
def description
|
39
|
-
'Check plugin name in podspec file'
|
40
|
-
end
|
41
48
|
end
|
42
49
|
|
43
50
|
# Check Flutter plugin version in podspec file. Exists or not
|
44
51
|
class PluginPodspecVersionCheck < PluginPodspecCheck
|
52
|
+
# @return {String}
|
45
53
|
def podspec_parameter
|
46
54
|
'version'
|
47
55
|
end
|
48
56
|
|
57
|
+
# @return {String}
|
58
|
+
def description
|
59
|
+
'Check plugin version in podspec file'
|
60
|
+
end
|
61
|
+
|
62
|
+
# @param {Project} project
|
63
|
+
# @return {CheckReport}
|
49
64
|
def check(project)
|
50
65
|
version_in_pubspec = project.pubspec.pubspec_info.version
|
51
66
|
podspec = project.ios_folder.podspec
|
@@ -57,18 +72,22 @@ module FlutterRb
|
|
57
72
|
podspec.path
|
58
73
|
)
|
59
74
|
end
|
60
|
-
|
61
|
-
def description
|
62
|
-
'Check plugin version in podspec file'
|
63
|
-
end
|
64
75
|
end
|
65
76
|
|
66
77
|
# Check Flutter plugin's authors. Exists or not
|
67
78
|
class PluginPodspecAuthorsCheck < PluginPodspecCheck
|
79
|
+
# @return {String}
|
68
80
|
def podspec_parameter
|
69
81
|
'authors'
|
70
82
|
end
|
71
83
|
|
84
|
+
# @return {String}
|
85
|
+
def description
|
86
|
+
"Check plugin's authors in podspec file"
|
87
|
+
end
|
88
|
+
|
89
|
+
# @param {Project} project
|
90
|
+
# @return {CheckReport}
|
72
91
|
def check(project)
|
73
92
|
podspec = project.ios_folder.podspec
|
74
93
|
author_exists = !podspec.authors.nil?
|
@@ -79,19 +98,23 @@ module FlutterRb
|
|
79
98
|
podspec.path
|
80
99
|
)
|
81
100
|
end
|
82
|
-
|
83
|
-
def description
|
84
|
-
"Check plugin's authors in podspec file"
|
85
|
-
end
|
86
101
|
end
|
87
102
|
|
88
103
|
# Check plugin iOS source path in podspec file.
|
89
104
|
# If Flutter plugin cannot contains iOS specific code, source path must be '.'
|
90
105
|
class PluginPodspecSourceCheck < PluginPodspecCheck
|
106
|
+
# @return {String}
|
91
107
|
def podspec_parameter
|
92
108
|
'source'
|
93
109
|
end
|
94
110
|
|
111
|
+
# @return {String}
|
112
|
+
def description
|
113
|
+
'Check plugin iOS source path in podspec file'
|
114
|
+
end
|
115
|
+
|
116
|
+
# @param {Project} project
|
117
|
+
# @return {CheckReport}
|
95
118
|
def check(project)
|
96
119
|
podspec = project.ios_folder.podspec
|
97
120
|
CheckReport.new(
|
@@ -101,9 +124,5 @@ module FlutterRb
|
|
101
124
|
podspec.path
|
102
125
|
)
|
103
126
|
end
|
104
|
-
|
105
|
-
def description
|
106
|
-
'Check plugin iOS source path in podspec file'
|
107
|
-
end
|
108
127
|
end
|
109
128
|
end
|
@@ -4,14 +4,17 @@ require_relative '../report/check_report'
|
|
4
4
|
module FlutterRb
|
5
5
|
# Base class for all info parameters in Flutter plugin pubspec.yaml file
|
6
6
|
class PluginPubspecCheck < Check
|
7
|
+
# @return {String}
|
7
8
|
def name
|
8
9
|
"PluginPubspec#{pubspec_parameter.capitalize}Check"
|
9
10
|
end
|
10
11
|
|
12
|
+
# @return {String}
|
11
13
|
def pubspec_parameter
|
12
14
|
raise UNIMPLEMENTED_ERROR
|
13
15
|
end
|
14
16
|
|
17
|
+
# @return {String}
|
15
18
|
def summary
|
16
19
|
"Validate Flutter plugin's #{pubspec_parameter} in pubspec.yaml"
|
17
20
|
end
|
@@ -19,10 +22,18 @@ module FlutterRb
|
|
19
22
|
|
20
23
|
# Check Flutter plugin name in podspec file. Exists or not
|
21
24
|
class PluginPubspecNameCheck < PluginPubspecCheck
|
25
|
+
# @return {String}
|
22
26
|
def pubspec_parameter
|
23
27
|
'name'
|
24
28
|
end
|
25
29
|
|
30
|
+
# @return {String}
|
31
|
+
def description
|
32
|
+
'Check plugin name in pubspec file'
|
33
|
+
end
|
34
|
+
|
35
|
+
# @param {Project} project
|
36
|
+
# @return {CheckReport}
|
26
37
|
def check(project)
|
27
38
|
pubspec = project.pubspec
|
28
39
|
CheckReport.new(
|
@@ -32,18 +43,22 @@ module FlutterRb
|
|
32
43
|
pubspec.path
|
33
44
|
)
|
34
45
|
end
|
35
|
-
|
36
|
-
def description
|
37
|
-
'Check plugin name in pubspec file'
|
38
|
-
end
|
39
46
|
end
|
40
47
|
|
41
48
|
# Check Flutter plugin description in pubspec file. Exists or not
|
42
49
|
class PluginPubspecDescriptionCheck < PluginPubspecCheck
|
50
|
+
# @return {String}
|
43
51
|
def pubspec_parameter
|
44
52
|
'description'
|
45
53
|
end
|
46
54
|
|
55
|
+
# @return {String}
|
56
|
+
def description
|
57
|
+
'Check plugin description in pubspec file'
|
58
|
+
end
|
59
|
+
|
60
|
+
# @param {Project} project
|
61
|
+
# @return {CheckReport}
|
47
62
|
def check(project)
|
48
63
|
pubspec = project.pubspec
|
49
64
|
CheckReport.new(
|
@@ -53,18 +68,22 @@ module FlutterRb
|
|
53
68
|
pubspec.path
|
54
69
|
)
|
55
70
|
end
|
56
|
-
|
57
|
-
def description
|
58
|
-
'Check plugin description in pubspec file'
|
59
|
-
end
|
60
71
|
end
|
61
72
|
|
62
73
|
# Check Flutter plugin version in pubspec file. Exists or not
|
63
74
|
class PluginPubspecVersionCheck < PluginPubspecCheck
|
75
|
+
# @return {String}
|
64
76
|
def pubspec_parameter
|
65
77
|
'version'
|
66
78
|
end
|
67
79
|
|
80
|
+
# @return {String}
|
81
|
+
def description
|
82
|
+
'Check plugin version in pubspec'
|
83
|
+
end
|
84
|
+
|
85
|
+
# @param {Project} project
|
86
|
+
# @return {CheckReport}
|
68
87
|
def check(project)
|
69
88
|
pubspec = project.pubspec
|
70
89
|
CheckReport.new(
|
@@ -74,18 +93,22 @@ module FlutterRb
|
|
74
93
|
pubspec.path
|
75
94
|
)
|
76
95
|
end
|
77
|
-
|
78
|
-
def description
|
79
|
-
'Check plugin version in pubspec'
|
80
|
-
end
|
81
96
|
end
|
82
97
|
|
83
98
|
# Check Flutter plugin author in pubspec file. Exists or not
|
84
99
|
class PluginPubspecAuthorCheck < PluginPubspecCheck
|
100
|
+
# @return {String}
|
85
101
|
def pubspec_parameter
|
86
102
|
'author'
|
87
103
|
end
|
88
104
|
|
105
|
+
# @return {String}
|
106
|
+
def description
|
107
|
+
'Check plugin author in pubspec'
|
108
|
+
end
|
109
|
+
|
110
|
+
# @param {Project} project
|
111
|
+
# @return {CheckReport}
|
89
112
|
def check(project)
|
90
113
|
pubspec = project.pubspec
|
91
114
|
CheckReport.new(
|
@@ -95,18 +118,22 @@ module FlutterRb
|
|
95
118
|
pubspec.path
|
96
119
|
)
|
97
120
|
end
|
98
|
-
|
99
|
-
def description
|
100
|
-
'Check plugin author in pubspec'
|
101
|
-
end
|
102
121
|
end
|
103
122
|
|
104
123
|
# Check Flutter plugin homepage in pubspec file. Exists or not
|
105
124
|
class PluginPubspecHomepageCheck < PluginPubspecCheck
|
125
|
+
# @return {String}
|
106
126
|
def pubspec_parameter
|
107
127
|
'homepage'
|
108
128
|
end
|
109
129
|
|
130
|
+
# @return {String}
|
131
|
+
def description
|
132
|
+
'Check plugin homepage in pubspec'
|
133
|
+
end
|
134
|
+
|
135
|
+
# @param {Project} project
|
136
|
+
# @return {CheckReport}
|
110
137
|
def check(project)
|
111
138
|
pubspec = project.pubspec
|
112
139
|
CheckReport.new(
|
@@ -116,22 +143,28 @@ module FlutterRb
|
|
116
143
|
pubspec.path
|
117
144
|
)
|
118
145
|
end
|
119
|
-
|
120
|
-
def description
|
121
|
-
'Check plugin homepage in pubspec'
|
122
|
-
end
|
123
146
|
end
|
124
147
|
|
125
|
-
# Check Flutter plugin Effective Dart
|
148
|
+
# Check Flutter plugin Effective Dart dependency in pubspec file. Exists or not
|
149
|
+
# noinspection RubyClassModuleNamingConvention
|
126
150
|
class PluginPubspecEffectiveDartCheck < Check
|
151
|
+
# @return {String}
|
127
152
|
def name
|
128
153
|
'PluginPubspecEffectiveDartCheck'
|
129
154
|
end
|
130
155
|
|
156
|
+
# @return {String}
|
131
157
|
def summary
|
132
158
|
'Validate Flutter plugin\'s Effective Dart rules implementation in pubspec.yaml'
|
133
159
|
end
|
134
160
|
|
161
|
+
# @return {String}
|
162
|
+
def description
|
163
|
+
'Check Flutter plugin Effective Dart depencency in pubspec file'
|
164
|
+
end
|
165
|
+
|
166
|
+
# @param {Project} project
|
167
|
+
# @return {CheckReport}
|
135
168
|
def check(project)
|
136
169
|
pubspec = project.pubspec
|
137
170
|
effective_dart = pubspec.dev_dependencies&.detect do |dev_dependency|
|
@@ -144,9 +177,5 @@ module FlutterRb
|
|
144
177
|
pubspec.path
|
145
178
|
)
|
146
179
|
end
|
147
|
-
|
148
|
-
def description
|
149
|
-
'Check Flutter plugin Effective Dart depencency in pubspec file'
|
150
|
-
end
|
151
180
|
end
|
152
181
|
end
|
@@ -1,11 +1,10 @@
|
|
1
1
|
module FlutterRb
|
2
2
|
# FlutterRb configuration representation from config in Flutter plugin
|
3
3
|
class FlutterRbConfig
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
)
|
4
|
+
# @param {Check[]} flutter_checks
|
5
|
+
# @param {Check[]} android_checks
|
6
|
+
# @param {Check[]} ios_checks
|
7
|
+
def initialize(flutter_checks, android_checks, ios_checks)
|
9
8
|
@flutter_checks = flutter_checks
|
10
9
|
@android_checks = android_checks
|
11
10
|
@ios_checks = ios_checks
|
@@ -28,23 +28,38 @@ module FlutterRb
|
|
28
28
|
PluginPodspecSourceCheck.new
|
29
29
|
].freeze
|
30
30
|
|
31
|
-
# rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity
|
31
|
+
# rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity
|
32
|
+
# @param {String} path
|
32
33
|
def parse(path)
|
33
34
|
config = YAML.load_file(path)['include']
|
34
35
|
flutter_checks = []
|
35
|
-
|
36
|
+
unless config['flutter'].nil?
|
37
|
+
flutter_checks += config['flutter'].map do |check|
|
38
|
+
Object.const_get("FlutterRb::#{check}").new
|
39
|
+
end
|
40
|
+
end
|
36
41
|
android_checks = []
|
37
|
-
|
42
|
+
unless config['android'].nil?
|
43
|
+
android_checks += config['android'].map do |check|
|
44
|
+
Object.const_get("FlutterRb::#{check}").new
|
45
|
+
end
|
46
|
+
end
|
38
47
|
ios_checks = []
|
39
|
-
|
48
|
+
unless config['ios'].nil?
|
49
|
+
ios_checks += config['ios'].map do |check|
|
50
|
+
Object.const_get("FlutterRb::#{check}").new
|
51
|
+
end
|
52
|
+
end
|
40
53
|
FlutterRbConfig.new(
|
41
54
|
flutter_checks.empty? ? FLUTTER_CHECKS : flutter_checks,
|
42
55
|
android_checks.empty? ? ANDROID_CHECKS : android_checks,
|
43
56
|
ios_checks.empty? ? IOS_CHECKS : ios_checks
|
44
57
|
)
|
45
58
|
end
|
46
|
-
# rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity, Layout/LineLength
|
47
59
|
|
60
|
+
# rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity
|
61
|
+
|
62
|
+
# @return {FlutterRbConfig}
|
48
63
|
def default
|
49
64
|
FlutterRbConfig.new(
|
50
65
|
FLUTTER_CHECKS,
|
@@ -10,6 +10,10 @@ require 'yaml'
|
|
10
10
|
module FlutterRb
|
11
11
|
# Project representation
|
12
12
|
class Project
|
13
|
+
# @param {String} path
|
14
|
+
# @param {Pubspec} pubspec
|
15
|
+
# @param {AndroidFolder} android_folder
|
16
|
+
# @param {IOSFolder} ios_folder
|
13
17
|
def initialize(
|
14
18
|
path,
|
15
19
|
pubspec,
|
@@ -27,16 +31,19 @@ module FlutterRb
|
|
27
31
|
|
28
32
|
# Flutter plugin project parser
|
29
33
|
class ProjectParser
|
34
|
+
# @param {String} path
|
30
35
|
def initialize(path)
|
31
36
|
@path = path
|
32
37
|
end
|
33
38
|
|
39
|
+
# @return {Project}
|
34
40
|
def project
|
35
41
|
File.exist?("#{@path}/pubspec.yaml") ? parse_project : nil
|
36
42
|
end
|
37
43
|
|
38
44
|
private
|
39
45
|
|
46
|
+
# @return {Project}
|
40
47
|
def parse_project
|
41
48
|
pubspec_path = "#{@path}/pubspec.yaml"
|
42
49
|
android_path = "#{@path}/android"
|
@@ -3,6 +3,8 @@ require 'json'
|
|
3
3
|
module FlutterRb
|
4
4
|
# Gradle representation
|
5
5
|
class Gradle
|
6
|
+
# @param {String} path
|
7
|
+
# @param {String} version
|
6
8
|
def initialize(path, version)
|
7
9
|
@path = path
|
8
10
|
@version = version
|
@@ -13,10 +15,12 @@ module FlutterRb
|
|
13
15
|
|
14
16
|
# Gradle parser
|
15
17
|
class GradleParser
|
18
|
+
# @param {String} path
|
16
19
|
def initialize(path)
|
17
20
|
@path = path
|
18
21
|
end
|
19
22
|
|
23
|
+
# @return {Gradle}
|
20
24
|
def parse
|
21
25
|
`gradle -p #{@path} -q prepareInfo`
|
22
26
|
info_file = File.read "#{@path}/flutter_rb_gradle_plugin_output.json"
|
@@ -1,6 +1,9 @@
|
|
1
1
|
module FlutterRb
|
2
2
|
# Flutter plugin, contains platform, package and plugin class
|
3
3
|
class PlatformPlugin
|
4
|
+
# @param {String} platform
|
5
|
+
# @param {String} package
|
6
|
+
# @param {String} plugin_class
|
4
7
|
def initialize(platform, package, plugin_class)
|
5
8
|
@platform = platform
|
6
9
|
@package = package
|
@@ -5,6 +5,10 @@ require_relative './platform_plugin'
|
|
5
5
|
module FlutterRb
|
6
6
|
# pubspec.yaml representation
|
7
7
|
class Pubspec
|
8
|
+
# @param {String} path
|
9
|
+
# @param {PubspecInfo} pubspec_info
|
10
|
+
# @param {DevDependency[]} dev_dependencies
|
11
|
+
# @param {PlatformPlugin[]} platform_plugins
|
8
12
|
def initialize(
|
9
13
|
path,
|
10
14
|
pubspec_info,
|
@@ -22,11 +26,14 @@ module FlutterRb
|
|
22
26
|
|
23
27
|
# pubspec.yaml parser
|
24
28
|
class PubspecParser
|
29
|
+
# @param {String} path
|
30
|
+
# @param {Pubspec} pubspec
|
25
31
|
def initialize(path, pubspec)
|
26
32
|
@path = path
|
27
33
|
@pubspec = pubspec
|
28
34
|
end
|
29
35
|
|
36
|
+
# @return {Pubspec}
|
30
37
|
def parse
|
31
38
|
Pubspec.new(
|
32
39
|
@path,
|
@@ -36,6 +43,8 @@ module FlutterRb
|
|
36
43
|
)
|
37
44
|
end
|
38
45
|
|
46
|
+
# @param {Pubspec}
|
47
|
+
# @return {PubspecInfo}
|
39
48
|
def pubspec_info(pubspec)
|
40
49
|
PubspecInfo.new(
|
41
50
|
pubspec['name'],
|
@@ -46,6 +55,8 @@ module FlutterRb
|
|
46
55
|
)
|
47
56
|
end
|
48
57
|
|
58
|
+
# @param {Pubspec} pubspec
|
59
|
+
# @return {DevDependency[]}
|
49
60
|
def dev_dependencies(pubspec)
|
50
61
|
pubspec['dev_dependencies']&.map do |dev_dependency|
|
51
62
|
DevDependency.new(
|
@@ -55,6 +66,8 @@ module FlutterRb
|
|
55
66
|
end
|
56
67
|
end
|
57
68
|
|
69
|
+
# @param {Pubspec} pubspec
|
70
|
+
# @return {PlatformPlugin[]}
|
58
71
|
def platform_plugins(pubspec)
|
59
72
|
pubspec.dig('flutter', 'plugin', 'platforms')&.map do |platform_plugin|
|
60
73
|
plugin_info = platform_plugin.last
|
@@ -1,6 +1,11 @@
|
|
1
1
|
module FlutterRb
|
2
2
|
# Flutter plugin info from pubspec.yaml
|
3
3
|
class PubspecInfo
|
4
|
+
# @param {String} name
|
5
|
+
# @param {String} description
|
6
|
+
# @param {String} version
|
7
|
+
# @param {String} author
|
8
|
+
# @param {String} homepage
|
4
9
|
def initialize(
|
5
10
|
name,
|
6
11
|
description,
|
@@ -3,6 +3,11 @@ require 'cocoapods'
|
|
3
3
|
module FlutterRb
|
4
4
|
# Podspec representation
|
5
5
|
class Podspec
|
6
|
+
# @param {String} path
|
7
|
+
# @param {String} name
|
8
|
+
# @param {String} version
|
9
|
+
# @param {String[]} authors
|
10
|
+
# @param {String} source
|
6
11
|
def initialize(
|
7
12
|
path,
|
8
13
|
name,
|
@@ -22,10 +27,12 @@ module FlutterRb
|
|
22
27
|
|
23
28
|
# Podspec parser
|
24
29
|
class PodspecParser
|
30
|
+
# @param {String} path
|
25
31
|
def initialize(path)
|
26
32
|
@path = path
|
27
33
|
end
|
28
34
|
|
35
|
+
# @return {Podspec}
|
29
36
|
def parse
|
30
37
|
podspec = Pod::Specification.from_file(@path)
|
31
38
|
@podspec = Podspec.new(
|
@@ -3,6 +3,10 @@ require 'colorize'
|
|
3
3
|
module FlutterRb
|
4
4
|
# Check report
|
5
5
|
class CheckReport
|
6
|
+
# @param {String} check_name
|
7
|
+
# @param {CheckReportStatus} check_report_status
|
8
|
+
# @param {String} message
|
9
|
+
# @param {String} path
|
6
10
|
def initialize(
|
7
11
|
check_name,
|
8
12
|
check_report_status,
|
@@ -15,6 +19,8 @@ module FlutterRb
|
|
15
19
|
@path = path
|
16
20
|
end
|
17
21
|
|
22
|
+
# @param {Bool} colorize
|
23
|
+
# @return {String}
|
18
24
|
def print(colorize: true)
|
19
25
|
if colorize
|
20
26
|
status_color = color_for_report_status(@check_report_status)
|
@@ -24,6 +30,8 @@ module FlutterRb
|
|
24
30
|
end
|
25
31
|
end
|
26
32
|
|
33
|
+
# @param {CheckReportStatus} check_report_status
|
34
|
+
# @return {Presenter}
|
27
35
|
def color_for_report_status(check_report_status)
|
28
36
|
case check_report_status
|
29
37
|
when CheckReportStatus::NORMAL
|
@@ -32,6 +40,8 @@ module FlutterRb
|
|
32
40
|
:yellow
|
33
41
|
when CheckReportStatus::ERROR
|
34
42
|
:red
|
43
|
+
else
|
44
|
+
:blue
|
35
45
|
end
|
36
46
|
end
|
37
47
|
|
data/lib/flutter_rb.rb
CHANGED
@@ -9,6 +9,8 @@ require_relative './checkstyle_report/checkstyle_report'
|
|
9
9
|
|
10
10
|
module FlutterRb
|
11
11
|
# Start FlutterRb checks
|
12
|
+
# @param {String} path
|
13
|
+
# @param {Bool} with_report
|
12
14
|
class FlutterRb
|
13
15
|
def start(path, with_report)
|
14
16
|
project = ProjectParser.new(path).project
|
@@ -29,6 +31,9 @@ module FlutterRb
|
|
29
31
|
end
|
30
32
|
|
31
33
|
# rubocop:disable Metrics/AbcSize, Metrics/MethodLength
|
34
|
+
# @param {Project} project
|
35
|
+
# @param {String} path
|
36
|
+
# @param {Bool} with_report
|
32
37
|
def check_project(project, path, with_report)
|
33
38
|
config_initializer = FlutterRbConfigInitializer.new
|
34
39
|
config_path = "#{path}/.flutter_rb.yaml"
|
@@ -40,26 +45,44 @@ module FlutterRb
|
|
40
45
|
config.ios_checks
|
41
46
|
)
|
42
47
|
checks.each { |check| puts check.print }
|
43
|
-
errors = checks.reject
|
48
|
+
errors = checks.reject do |check|
|
49
|
+
check.check_report_status == CheckReportStatus::NORMAL
|
50
|
+
end
|
44
51
|
create_report(path, checks) if with_report
|
45
52
|
exit(errors.empty? ? 0 : -1)
|
46
53
|
end
|
54
|
+
|
47
55
|
# rubocop:enable Metrics/AbcSize, Metrics/MethodLength
|
48
56
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
)
|
57
|
+
# rubocop:disable Metrics/MethodLength
|
58
|
+
# @param {Project} project
|
59
|
+
# @param {Check[]} flutter_checks
|
60
|
+
# @param {Check[]} android_checks
|
61
|
+
# @param {Check[]} ios_checks
|
62
|
+
def explore_project(project, flutter_checks, android_checks, ios_checks)
|
55
63
|
result = []
|
56
|
-
result += flutter_checks.map
|
57
|
-
|
58
|
-
|
64
|
+
result += flutter_checks.map do |check|
|
65
|
+
check.check(project)
|
66
|
+
end
|
67
|
+
unless project.android_folder.nil?
|
68
|
+
result += android_checks.map do |check|
|
69
|
+
check.check(project)
|
70
|
+
end
|
71
|
+
end
|
72
|
+
unless project.ios_folder.nil?
|
73
|
+
result += ios_checks.map do |check|
|
74
|
+
check.check(project)
|
75
|
+
end
|
76
|
+
end
|
59
77
|
result
|
60
78
|
end
|
61
79
|
|
80
|
+
# rubocop:enable Metrics/MethodLength
|
81
|
+
|
62
82
|
# rubocop:disable Metrics/MethodLength
|
83
|
+
# @param {String} path
|
84
|
+
# @param {Check[]} checks
|
85
|
+
# @return {CheckstyleReport}
|
63
86
|
def create_report(path, checks)
|
64
87
|
errors = checks.map do |check|
|
65
88
|
CheckstyleReport::CheckstyleError.new(
|
@@ -77,8 +100,11 @@ module FlutterRb
|
|
77
100
|
errors
|
78
101
|
).create_report
|
79
102
|
end
|
103
|
+
|
80
104
|
# rubocop:enable Metrics/MethodLength
|
81
105
|
|
106
|
+
# @param {CheckReportStatus} check_report_status
|
107
|
+
# @return {CheckstyleReport}
|
82
108
|
def level_for_report(check_report_status)
|
83
109
|
case check_report_status
|
84
110
|
when CheckReportStatus::NORMAL
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: flutter_rb
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Artem Fomchenkov
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-08-19 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: cocoapods
|
@@ -94,6 +94,20 @@ dependencies:
|
|
94
94
|
- - '='
|
95
95
|
- !ruby/object:Gem::Version
|
96
96
|
version: '1.7'
|
97
|
+
- !ruby/object:Gem::Dependency
|
98
|
+
name: simplecov
|
99
|
+
requirement: !ruby/object:Gem::Requirement
|
100
|
+
requirements:
|
101
|
+
- - '='
|
102
|
+
- !ruby/object:Gem::Version
|
103
|
+
version: 0.22.0
|
104
|
+
type: :development
|
105
|
+
prerelease: false
|
106
|
+
version_requirements: !ruby/object:Gem::Requirement
|
107
|
+
requirements:
|
108
|
+
- - '='
|
109
|
+
- !ruby/object:Gem::Version
|
110
|
+
version: 0.22.0
|
97
111
|
description:
|
98
112
|
email: artem.fomchenkov@outlook.com
|
99
113
|
executables:
|
@@ -102,6 +116,8 @@ extensions: []
|
|
102
116
|
extra_rdoc_files:
|
103
117
|
- README.md
|
104
118
|
files:
|
119
|
+
- CODE_OF_CONDUCT.md
|
120
|
+
- COMMIT_CONVENTION.md
|
105
121
|
- LICENSE
|
106
122
|
- README.md
|
107
123
|
- bin/frb
|