flutter_rb 1.1.1 → 1.2.1

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 5d708635770d65db09e97f3864f6e35ebcba46c13c84d6a388e6f10e9adc72e4
4
- data.tar.gz: 1db4f12f4a0d23ba569a1c885eb3db6b295f11f2954594207750e738c91fa885
3
+ metadata.gz: f13846c798d97f27a3f1aee5da6c2df8c62ad46f60e76064c00e278fe53f1c99
4
+ data.tar.gz: 31b0ad31e7eec759f2090070abad08fce769ffae5ea2efb875855258ba5c2f2c
5
5
  SHA512:
6
- metadata.gz: ce685d7cfeb7b65bd31113f167d91aa59fb5ba23368f744a4d1efa14d7b2f5e97e32e7b4fa2012a32ba2fafb94f29c6d30e68602e25648aff0fe7695bafc0ce5
7
- data.tar.gz: 6d11387d9654065b86410ab14612ec2ac4711f181d8c56d9551f762d408b6ba00ba0c1b81f72145af283d970e17b51dafa0c8d545925dae11df65b7630bfd70c
6
+ metadata.gz: 39f79dbc0e055a351c6f710f0ccfc059b90ff43a396c8ae9ebf5a8ee3c84b8e27b9f0c989f5677e0d1ff3e694127933c636bfd8ef585cc0b501b529467b0ccf1
7
+ data.tar.gz: b8adab81e7ed3e12e1dd8f6d2d4057fe94399505e6ceaeac1399398ebfefe3d5f81d8bb90e308969957ce4b89142f1e4e8f53de2bf25763a28d4d4d714f1c3e9
data/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2020-2023 Artem Fomchenkov
1
+ Copyright (c) 2020-2024 Artem Fomchenkov
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining
4
4
  a copy of this software and associated documentation files (the
data/README.md CHANGED
@@ -1,5 +1,4 @@
1
- <!--suppress CheckImageSize -->
2
- <img src="media/logo/ic_lib.png" height="100px" alt="Project's logo">
1
+ <img src="media/logo/ic_lib.jpg" height="100px" alt="Project's logo">
3
2
 
4
3
  # flutter_rb
5
4
 
@@ -84,7 +83,7 @@ $ gem i flutter_rb
84
83
  Then run from a Flutter plugin's project folder:
85
84
 
86
85
  ```shell
87
- $ frb
86
+ $ frb inspect --path=./project_folder
88
87
  ```
89
88
 
90
89
  ### As local executable
@@ -93,15 +92,39 @@ Add `project_folder/bin` (where `project_folder` is path to project on your mach
93
92
  environment. Then updated environment and run from a Flutter plugin's project folder:
94
93
 
95
94
  ```shell
96
- $ local_frb
95
+ $ local_frb inspect --path=./project_folder
96
+ ```
97
+
98
+ ### Commands
99
+
100
+ #### Inspect
101
+
102
+ Starts the flutter-rb.
103
+
104
+ ```shell
105
+ $ frb inspect --path=./project_folder --report
106
+ ```
107
+
108
+ | Argument | Description |
109
+ |------------|----------------------------------------------------------------------------------------------------|
110
+ | `--path` | Path to Dart/Flutter project. flutter-rb will be use current directory if this parameter are empty |
111
+ | `--report` | Generate report in Checkstyle format |
112
+
113
+ #### Version
114
+
115
+ Puts using version of flutter-rb.
116
+
117
+ ```shell
118
+ $ frb version
97
119
  ```
98
120
 
99
- ### Arguments
121
+ #### Author
122
+
123
+ Puts author and our contacts.
100
124
 
101
- | Argument | Description |
102
- |-----------------------|--------------------------------------|
103
- | `--help` | Print help info |
104
- | `--checkstyle-report` | Generate report in Checkstyle format |
125
+ ```shell
126
+ $ frb author
127
+ ```
105
128
 
106
129
  ### Configuration
107
130
 
@@ -129,6 +152,16 @@ report file name is `frb-checkstyle-report.xml`.
129
152
 
130
153
  ## How to contribute
131
154
 
155
+ ### Documentation
156
+
157
+ Just run:
158
+
159
+ ```shell
160
+ $ rdoc
161
+ ```
162
+
163
+ ### Contribution
164
+
132
165
  Read [Commit Convention](./COMMIT_CONVENTION.md). Make sure your build is green before you contribute your pull request.
133
166
  Then:
134
167
 
data/bin/frb CHANGED
@@ -2,20 +2,5 @@
2
2
 
3
3
  # frozen_string_literal: true
4
4
 
5
+ require_relative 'cli'
5
6
  require 'flutter_rb'
6
- require 'colorize'
7
-
8
- def light_blue_text(text)
9
- text.colorize(:light_blue)
10
- end
11
-
12
- if ARGV.include?('--help')
13
- puts "
14
- Available arguments:
15
- * #{light_blue_text('--help')}: print help info
16
- * #{light_blue_text('--checkstyle-report')}: generate report in Checkstyle format
17
- "
18
- else
19
- flutter_rb = FlutterRb::FlutterRb.new
20
- flutter_rb.start(Dir.pwd, ARGV.include?('--checkstyle-report'))
21
- end
@@ -2,21 +2,24 @@
2
2
 
3
3
  require 'nokogiri'
4
4
 
5
- # Module with classes for creating reports in Checkstyle format
6
5
  module CheckstyleReport
7
6
  # Class for create report in Checkstyle format
8
7
  class CheckstyleReport
9
- # @param {String} path
10
- # @param {String} report_filename
11
- # @param {CheckstyleError[]}
8
+ # Initializes a new instance of CheckstyleReport
9
+ #
10
+ # @param path [String] The path where the report file will be saved
11
+ # @param report_filename [String] The name of the report file
12
+ # @param checks [Array<CheckstyleError>] An array of CheckstyleError objects
12
13
  def initialize(path, report_filename, checks)
13
14
  @path = path
14
15
  @report_filename = report_filename
15
16
  @checks = checks
16
17
  end
17
18
 
18
- # rubocop:disable Metrics/MethodLength
19
- # noinspection RubyResolve
19
+ # Creates a Checkstyle report XML file
20
+ #
21
+ # This method groups the errors by file, creates a new CheckstyleFile object for each file,
22
+ # and writes the report to an XML file.
20
23
  def create_report
21
24
  checkstyle_files = sort_checks(@checks)
22
25
  report = Nokogiri::XML::Builder.new do |xml|
@@ -26,15 +29,17 @@ module CheckstyleReport
26
29
  .each { |file| write_file(xml, file) }
27
30
  end
28
31
  end
32
+
29
33
  File.open("#{@path}/#{@report_filename}.xml", 'w') do |file|
30
34
  file.write(report.to_xml)
31
35
  end
32
36
  end
33
37
 
34
- # rubocop:enable Metrics/MethodLength
35
-
36
- # @param {CheckstyleError} checks
37
- # @return {CheckstyleFile[]}
38
+ # Sorts the checks by file
39
+ #
40
+ # @param checks [Array<CheckstyleError>] An array of CheckstyleError objects
41
+ # @return [Hash<String, Array<CheckstyleError>>] A hash where the keys are file names
42
+ # and the values are arrays of CheckstyleError objects
38
43
  def sort_checks(checks)
39
44
  checkstyle_files = {}
40
45
  checks.each do |check|
@@ -42,11 +47,14 @@ module CheckstyleReport
42
47
  checkstyle_files[check.source] = [] if checkstyle_file.nil?
43
48
  checkstyle_files[check.source] += [check] if check.severity != CheckstyleError::SEVERITY_NORMAL
44
49
  end
50
+
45
51
  checkstyle_files
46
52
  end
47
53
 
48
- # @param {XML} xml
49
- # @param {CheckstyleFile} checkstyle_file
54
+ # Writes a file element to the XML report
55
+ #
56
+ # @param xml [Nokogiri::XML::Builder] The XML builder object
57
+ # @param checkstyle_file [CheckstyleFile] The CheckstyleFile object to be written
50
58
  def write_file(xml, checkstyle_file)
51
59
  xml.file(name: checkstyle_file.file) do
52
60
  checkstyle_file.errors.each do |error|
@@ -55,8 +63,10 @@ module CheckstyleReport
55
63
  end
56
64
  end
57
65
 
58
- # @param {XML} xml
59
- # @param {CheckstyleError} error
66
+ # Writes an error element to the XML report
67
+ #
68
+ # @param xml [Nokogiri::XML::Builder] The XML builder object
69
+ # @param error [CheckstyleError] The CheckstyleError object to be written
60
70
  def write_error(xml, error)
61
71
  xml.error(
62
72
  line: error.line,
@@ -68,39 +78,45 @@ module CheckstyleReport
68
78
  end
69
79
  end
70
80
 
71
- # File representation for Checkstyle format
81
+ # Represents a file in Checkstyle format.
72
82
  class CheckstyleFile
73
- # @param {String} file
74
- # @param {CheckstyleError[]} errors
83
+ # Initializes a new instance of CheckstyleFile.
84
+ #
85
+ # @param file [String] The name of the file.
86
+ # @param errors [Array<CheckstyleError>] An array of CheckstyleError objects related to this file.
75
87
  def initialize(file, errors)
76
88
  @file = file
77
89
  @errors = errors
78
90
  end
79
91
 
80
- attr_reader :file, :errors
92
+ # Returns the name of the file.
93
+ #
94
+ # @return [String] The name of the file.
95
+ attr_reader :file
96
+
97
+ # Returns the array of CheckstyleError objects related to this file.
98
+ #
99
+ # @return [Array<CheckstyleError>] An array of CheckstyleError objects related to this file.
100
+ attr_reader :errors
81
101
  end
82
102
 
83
- # Checkstyle error representation
103
+ # Represents a single error in Checkstyle format.
84
104
  class CheckstyleError
105
+ # Severity levels for Checkstyle errors.
85
106
  SEVERITY_NORMAL = 'normal'
86
107
  SEVERITY_WARNING = 'warning'
87
108
  SEVERITY_ERROR = 'error'
88
109
 
89
- # rubocop:disable Metrics/ParameterLists
90
- # @param {String} severity
91
- # @param {String} message
92
- # @param {String} source
93
- # @param {Integer} line
94
- # @param {Integer} column
95
- # @param {String} name
96
- def initialize(
97
- severity,
98
- message,
99
- source,
100
- line,
101
- column,
102
- name
103
- )
110
+ # Initializes a new instance of CheckstyleError.
111
+ #
112
+ # @param severity [CheckstyleError] The severity level of the error.
113
+ # Must be one of SEVERITY_NORMAL, SEVERITY_WARNING, or SEVERITY_ERROR.
114
+ # @param message [String] The error message.
115
+ # @param source [String] The source of the error.
116
+ # @param line [Integer] The line number where the error occurred.
117
+ # @param column [Integer] The column number where the error occurred.
118
+ # @param name [String] The name of the error.
119
+ def initialize(severity, message, source, line, column, name)
104
120
  @severity = severity
105
121
  @message = message
106
122
  @source = source
@@ -109,8 +125,34 @@ module CheckstyleReport
109
125
  @name = name
110
126
  end
111
127
 
112
- # rubocop:enable Metrics/ParameterLists
128
+ # Returns the severity level of the error.
129
+ #
130
+ # @return [String] The severity level of the error.
131
+ attr_reader :severity
132
+
133
+ # Returns the error message.
134
+ #
135
+ # @return [String] The error message.
136
+ attr_reader :message
137
+
138
+ # Returns the source of the error.
139
+ #
140
+ # @return [String] The source of the error.
141
+ attr_reader :source
142
+
143
+ # Returns the line number where the error occurred.
144
+ #
145
+ # @return [Integer] The line number where the error occurred.
146
+ attr_reader :line
147
+
148
+ # Returns the column number where the error occurred.
149
+ #
150
+ # @return [Integer] The column number where the error occurred.
151
+ attr_reader :column
113
152
 
114
- attr_reader :severity, :message, :source, :line, :column, :name
153
+ # Returns the name of the error.
154
+ #
155
+ # @return [String] The name of the error.
156
+ attr_reader :name
115
157
  end
116
158
  end
@@ -1,34 +1,34 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module FlutterRb
4
- # Base class for all checks
5
- # Class provides default methods structure
6
- # All methods using for create reports
4
+ # A class representing a check to be performed on a project.
7
5
  class Check
6
+ # Error message to be raised when a method is not implemented.
8
7
  UNIMPLEMENTED_ERROR = 'Error: missing method'
9
8
 
10
- # @return {String}
9
+ # Returns the name of the check.
10
+ #
11
+ # @return [String] the name of the check
12
+ # @raise [RuntimeError] if the method is not implemented
11
13
  def name
12
14
  raise UNIMPLEMENTED_ERROR
13
15
  end
14
16
 
15
- # @return {String}
16
- def summary
17
- raise UNIMPLEMENTED_ERROR
18
- end
19
-
20
- # @return {String}
17
+ # Returns a description of the check.
18
+ #
19
+ # @return [String] a description of the check
20
+ # @raise [RuntimeError] if the method is not implemented
21
21
  def description
22
- 'No provided'
22
+ raise UNIMPLEMENTED_ERROR
23
23
  end
24
24
 
25
- # rubocop:disable Lint/UnusedMethodArgument
26
- # @param {Project} project
27
- # @return {CheckReport}
25
+ # Performs the check on the given project and returns a report.
26
+ #
27
+ # @param project [Project, nil] the project to be checked
28
+ # @return [CheckReport] the report of the check
29
+ # @raise [RuntimeError] if the method is not implemented
28
30
  def check(project)
29
31
  raise UNIMPLEMENTED_ERROR
30
32
  end
31
-
32
- # rubocop:enable Lint/UnusedMethodArgument
33
33
  end
34
34
  end
@@ -4,31 +4,35 @@ require_relative 'check'
4
4
  require_relative '../report/check_report'
5
5
 
6
6
  module FlutterRb
7
- # Check plugin directories structure.
8
- # Example: if a Flutter plugin has only Android specific code
9
- # but not contains iOS folder with description, then iOS build fails
7
+ # This class represents a check for plugin directories structure in a Flutter project.
10
8
  class PluginDirectoriesCheck < Check
11
- # @return {String}
9
+ # Returns the name of the check.
10
+ #
11
+ # @return [String] The name of the check.
12
12
  def name
13
13
  'PluginDirectoriesCheck'
14
14
  end
15
15
 
16
- # @return {String}
17
- def summary
18
- 'Validate Flutter plugin structure'
19
- end
20
-
21
- # @return {String}
16
+ # Returns a description of the check.
17
+ #
18
+ # @return [String] A description of the check.
22
19
  def description
23
20
  'Check plugin directories structure in pubspec file'
24
21
  end
25
22
 
26
- # @param {Project} project
27
- # @return {CheckReport}
23
+ # Performs the check on the given project.
24
+ #
25
+ # @param project [Project] The project to perform the check on.
26
+ # @return [CheckReport] The report of the check result.
28
27
  def check(project)
28
+ # Check if android and ios folders exist.
29
29
  android_exists = !project.android_folder.nil?
30
30
  ios_exists = !project.ios_folder.nil?
31
+
32
+ # Determine the check result based on the existence of android and ios folders.
31
33
  check_result = android_exists && ios_exists || !android_exists && !ios_exists
34
+
35
+ # Create a new CheckReport with the result.
32
36
  CheckReport.new(
33
37
  name,
34
38
  check_result ? CheckReportStatus::NORMAL : CheckReportStatus::ERROR,
@@ -4,63 +4,78 @@ require_relative './check'
4
4
  require_relative '../report/check_report'
5
5
 
6
6
  module FlutterRb
7
- # Check 'android; import not exists in Gradle project config (build.gradle file)
7
+ # This class represents a check for validating that the 'android' package
8
+ # does not exist in the Gradle project configuration.
8
9
  class PluginGradleAndroidPackageCheck < Check
9
- # @return {String}
10
+ # Returns the name of the check.
11
+ #
12
+ # @return [String] The name of the check.
10
13
  def name
11
14
  'PluginGradleAndroidPackageCheck'
12
15
  end
13
16
 
14
- # @return {String}
15
- def summary
16
- 'Validate that \android\ package not exists in build.gradle config'
17
- end
18
-
19
- # @return {String}
17
+ # Returns the description of the check.
18
+ #
19
+ # @return [String] The description of the check.
20
20
  def description
21
21
  'Validate that \android\ package not exists in Gradle project config (build.gradle file)'
22
22
  end
23
23
 
24
- # @param {Project} project
25
- # @return {CheckReport}
24
+ # Performs the check on the given project.
25
+ #
26
+ # @param project [Project] The project to perform the check on.
27
+ # @return [CheckReport] The report of the check result.
26
28
  def check(project)
29
+ # Get the Gradle configuration file.
27
30
  gradle = project.android_folder.gradle
31
+
32
+ # Check if the 'package android' line exists in the build.gradle file.
28
33
  import_exist = File.readlines("#{gradle.path}/build.gradle").grep(/package android/).size.positive?
34
+
35
+ # Create a check report based on the result.
29
36
  CheckReport.new(
30
37
  name,
31
- import_exist ? CheckReportStatus::ERROR : CheckReportStatus::NORMAL,
38
+ import_exist ? ::CheckReportStatus::ERROR : ::CheckReportStatus::NORMAL,
32
39
  description,
33
40
  gradle.path
34
41
  )
35
42
  end
36
43
  end
37
44
 
38
- # Check Flutter plugin version in Gradle project config (build.gradle file)
45
+ # This class represents a check for validating the version of the plugin in the Gradle project configuration.
39
46
  class PluginGradleVersionCheck < Check
40
- # @return {String}
47
+ # Returns the name of the check.
48
+ #
49
+ # @return [String] The name of the check.
41
50
  def name
42
51
  'PluginGradleVersionCheck'
43
52
  end
44
53
 
45
- # @return {String}
46
- def summary
47
- 'Validate Flutter plugin\s version in build.gradle file'
48
- end
49
-
50
- # @return {String}
54
+ # Returns the description of the check.
55
+ #
56
+ # @return [String] The description of the check.
51
57
  def description
52
58
  'Check plugin version in Gradle project config (build.gradle file)'
53
59
  end
54
60
 
55
- # @param {Project} project
56
- # @return {CheckReport}
61
+ # Performs the check on the given project.
62
+ #
63
+ # @param project [Project] The project to perform the check on.
64
+ # @return [CheckReport] The report of the check result.
57
65
  def check(project)
66
+ # Get the version of the plugin from the pubspec file.
58
67
  version_in_pubspec = project.pubspec.pubspec_info.version
68
+
69
+ # Get the Gradle configuration file.
59
70
  gradle = project.android_folder.gradle
71
+
72
+ # Get the version of the plugin from the Gradle build file.
60
73
  version_in_gradle = gradle.version
74
+
75
+ # Create a check report based on the result.
61
76
  CheckReport.new(
62
77
  name,
63
- version_in_pubspec == version_in_gradle ? CheckReportStatus::NORMAL : CheckReportStatus::WARNING,
78
+ version_in_pubspec == version_in_gradle ? ::CheckReportStatus::NORMAL : ::CheckReportStatus::WARNING,
64
79
  description,
65
80
  gradle.path
66
81
  )