makit 0.0.168 → 0.0.169

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.
Files changed (179) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +41 -41
  3. data/exe/makit +5 -5
  4. data/lib/makit/apache.rb +28 -28
  5. data/lib/makit/auto.rb +48 -48
  6. data/lib/makit/azure/blob_storage.rb +257 -257
  7. data/lib/makit/azure/cli.rb +284 -284
  8. data/lib/makit/azure-pipelines.rb +187 -187
  9. data/lib/makit/cli/base.rb +17 -17
  10. data/lib/makit/cli/build_commands.rb +500 -500
  11. data/lib/makit/cli/generators/base_generator.rb +74 -74
  12. data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
  13. data/lib/makit/cli/generators/generator_factory.rb +49 -49
  14. data/lib/makit/cli/generators/node_generator.rb +50 -50
  15. data/lib/makit/cli/generators/ruby_generator.rb +77 -77
  16. data/lib/makit/cli/generators/rust_generator.rb +50 -50
  17. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
  18. data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
  19. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
  20. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +41 -41
  21. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
  22. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
  23. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
  24. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
  25. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
  26. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
  27. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
  28. data/lib/makit/cli/main.rb +78 -78
  29. data/lib/makit/cli/pipeline_commands.rb +311 -311
  30. data/lib/makit/cli/project_commands.rb +868 -868
  31. data/lib/makit/cli/repository_commands.rb +661 -661
  32. data/lib/makit/cli/strategy_commands.rb +207 -207
  33. data/lib/makit/cli/utility_commands.rb +521 -521
  34. data/lib/makit/commands/factory.rb +359 -359
  35. data/lib/makit/commands/middleware/base.rb +73 -73
  36. data/lib/makit/commands/middleware/cache.rb +248 -248
  37. data/lib/makit/commands/middleware/command_logger.rb +312 -312
  38. data/lib/makit/commands/middleware/validator.rb +269 -269
  39. data/lib/makit/commands/request.rb +316 -316
  40. data/lib/makit/commands/result.rb +323 -323
  41. data/lib/makit/commands/runner.rb +386 -386
  42. data/lib/makit/commands/strategies/base.rb +171 -171
  43. data/lib/makit/commands/strategies/child_process.rb +162 -162
  44. data/lib/makit/commands/strategies/factory.rb +136 -136
  45. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  46. data/lib/makit/commands.rb +50 -50
  47. data/lib/makit/configuration/dotnet_project.rb +48 -48
  48. data/lib/makit/configuration/gitlab_helper.rb +61 -61
  49. data/lib/makit/configuration/project.rb +292 -292
  50. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  51. data/lib/makit/configuration/step.rb +34 -34
  52. data/lib/makit/configuration/timeout.rb +74 -74
  53. data/lib/makit/configuration.rb +21 -21
  54. data/lib/makit/content/default_gitignore.rb +7 -7
  55. data/lib/makit/content/default_gitignore.txt +225 -225
  56. data/lib/makit/content/default_rakefile.rb +13 -13
  57. data/lib/makit/content/gem_rakefile.rb +16 -16
  58. data/lib/makit/context.rb +1 -1
  59. data/lib/makit/data.rb +49 -49
  60. data/lib/makit/directories.rb +170 -170
  61. data/lib/makit/directory.rb +262 -262
  62. data/lib/makit/docs/files.rb +89 -89
  63. data/lib/makit/docs/rake.rb +102 -102
  64. data/lib/makit/dotnet/cli.rb +224 -224
  65. data/lib/makit/dotnet/project.rb +217 -217
  66. data/lib/makit/dotnet/solution.rb +38 -38
  67. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  68. data/lib/makit/dotnet/solution_console.rb +264 -264
  69. data/lib/makit/dotnet/solution_maui.rb +354 -354
  70. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  71. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  72. data/lib/makit/dotnet.rb +110 -110
  73. data/lib/makit/email.rb +90 -90
  74. data/lib/makit/environment.rb +142 -142
  75. data/lib/makit/examples/runner.rb +370 -370
  76. data/lib/makit/exceptions.rb +45 -45
  77. data/lib/makit/fileinfo.rb +32 -32
  78. data/lib/makit/files.rb +43 -43
  79. data/lib/makit/gems.rb +49 -49
  80. data/lib/makit/git/cli.rb +103 -103
  81. data/lib/makit/git/repository.rb +100 -100
  82. data/lib/makit/git.rb +104 -104
  83. data/lib/makit/github_actions.rb +202 -202
  84. data/lib/makit/gitlab/pipeline.rb +857 -857
  85. data/lib/makit/gitlab/pipeline_service_impl.rb +1535 -1535
  86. data/lib/makit/gitlab_runner.rb +59 -59
  87. data/lib/makit/humanize.rb +218 -218
  88. data/lib/makit/indexer.rb +47 -47
  89. data/lib/makit/io/filesystem.rb +111 -111
  90. data/lib/makit/io/filesystem_service_impl.rb +337 -337
  91. data/lib/makit/lint.rb +212 -212
  92. data/lib/makit/logging/configuration.rb +309 -309
  93. data/lib/makit/logging/format_registry.rb +84 -84
  94. data/lib/makit/logging/formatters/base.rb +39 -39
  95. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  96. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  97. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  98. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  99. data/lib/makit/logging/log_request.rb +119 -119
  100. data/lib/makit/logging/logger.rb +199 -199
  101. data/lib/makit/logging/sinks/base.rb +91 -91
  102. data/lib/makit/logging/sinks/console.rb +72 -72
  103. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  104. data/lib/makit/logging/sinks/structured.rb +123 -123
  105. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  106. data/lib/makit/logging.rb +578 -578
  107. data/lib/makit/markdown.rb +75 -75
  108. data/lib/makit/mp/basic_object_mp.rb +17 -17
  109. data/lib/makit/mp/command_mp.rb +13 -13
  110. data/lib/makit/mp/command_request.mp.rb +17 -17
  111. data/lib/makit/mp/project_mp.rb +199 -199
  112. data/lib/makit/mp/string_mp.rb +205 -205
  113. data/lib/makit/nuget.rb +460 -458
  114. data/lib/makit/podman/podman.rb +458 -458
  115. data/lib/makit/podman/podman_service_impl.rb +1081 -1081
  116. data/lib/makit/port.rb +32 -32
  117. data/lib/makit/process.rb +377 -377
  118. data/lib/makit/protoc.rb +112 -112
  119. data/lib/makit/rake/cli.rb +196 -196
  120. data/lib/makit/rake/trace_controller.rb +174 -174
  121. data/lib/makit/rake.rb +81 -81
  122. data/lib/makit/ruby/cli.rb +185 -185
  123. data/lib/makit/ruby.rb +25 -25
  124. data/lib/makit/rubygems.rb +137 -137
  125. data/lib/makit/secrets/azure_key_vault.rb +322 -322
  126. data/lib/makit/secrets/azure_secrets.rb +221 -221
  127. data/lib/makit/secrets/local_secrets.rb +72 -72
  128. data/lib/makit/secrets/secrets_manager.rb +105 -105
  129. data/lib/makit/secrets.rb +96 -96
  130. data/lib/makit/serializer.rb +130 -130
  131. data/lib/makit/services/builder.rb +186 -186
  132. data/lib/makit/services/error_handler.rb +226 -226
  133. data/lib/makit/services/repository_manager.rb +367 -367
  134. data/lib/makit/services/validator.rb +112 -112
  135. data/lib/makit/setup/classlib.rb +101 -101
  136. data/lib/makit/setup/gem.rb +268 -268
  137. data/lib/makit/setup/pages.rb +11 -11
  138. data/lib/makit/setup/razorclasslib.rb +101 -101
  139. data/lib/makit/setup/runner.rb +54 -54
  140. data/lib/makit/setup.rb +5 -5
  141. data/lib/makit/show.rb +110 -110
  142. data/lib/makit/storage.rb +126 -126
  143. data/lib/makit/symbols.rb +175 -175
  144. data/lib/makit/task_info.rb +130 -130
  145. data/lib/makit/tasks/at_exit.rb +15 -15
  146. data/lib/makit/tasks/build.rb +22 -22
  147. data/lib/makit/tasks/bump.rb +7 -7
  148. data/lib/makit/tasks/clean.rb +13 -13
  149. data/lib/makit/tasks/configure.rb +10 -10
  150. data/lib/makit/tasks/format.rb +10 -10
  151. data/lib/makit/tasks/hook_manager.rb +443 -443
  152. data/lib/makit/tasks/info.rb +368 -368
  153. data/lib/makit/tasks/init.rb +49 -49
  154. data/lib/makit/tasks/integrate.rb +60 -60
  155. data/lib/makit/tasks/pull_incoming.rb +13 -13
  156. data/lib/makit/tasks/secrets.rb +7 -7
  157. data/lib/makit/tasks/setup.rb +16 -16
  158. data/lib/makit/tasks/sync.rb +14 -14
  159. data/lib/makit/tasks/tag.rb +27 -27
  160. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  161. data/lib/makit/tasks/test.rb +22 -22
  162. data/lib/makit/tasks/update.rb +21 -21
  163. data/lib/makit/tasks/version.rb +6 -6
  164. data/lib/makit/tasks.rb +24 -24
  165. data/lib/makit/test_cache.rb +239 -239
  166. data/lib/makit/tree.rb +37 -37
  167. data/lib/makit/v1/configuration/project_service_impl.rb +370 -370
  168. data/lib/makit/v1/git/git_repository_service_impl.rb +295 -295
  169. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  170. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  171. data/lib/makit/v1/services/repository_manager_service_impl.rb +572 -572
  172. data/lib/makit/version.rb +661 -661
  173. data/lib/makit/version_util.rb +21 -21
  174. data/lib/makit/wix.rb +95 -95
  175. data/lib/makit/yaml.rb +29 -29
  176. data/lib/makit/zip.rb +17 -17
  177. data/lib/makit copy.rb +44 -44
  178. data/lib/makit.rb +121 -121
  179. metadata +2 -2
@@ -1,226 +1,226 @@
1
- # frozen_string_literal: true
2
-
3
- module Makit
4
- module Services
5
- # Service class responsible for handling and formatting errors
6
- # Provides user-friendly error messages and recovery suggestions
7
- class ErrorHandler
8
- # Error message templates with suggestions
9
- ERROR_MESSAGES = {
10
- invalid_url: {
11
- message: "The repository URL '%<url>s' is not valid.",
12
- suggestions: [
13
- "Use HTTPS format: https://github.com/user/repo.git",
14
- "Use SSH format: git@github.com:user/repo.git",
15
- "Use simple format: user/repo",
16
- "Ensure the URL points to a git repository",
17
- ],
18
- },
19
- invalid_directory: {
20
- message: "The directory path '%<directory>s' is not valid.",
21
- suggestions: [
22
- "Use absolute paths like /path/to/directory",
23
- "Use relative paths like ./relative/path",
24
- "Ensure the path doesn't contain null characters",
25
- "Keep directory paths under 255 characters",
26
- ],
27
- },
28
- invalid_commit: {
29
- message: "The commit '%<commit>s' is not valid.",
30
- suggestions: [
31
- "Use 'latest' for the most recent commit",
32
- "Use a full 40-character commit hash",
33
- "Use a short 7+ character commit hash",
34
- "Verify the commit exists in the repository",
35
- ],
36
- },
37
- directory_not_found: {
38
- message: "The directory '%<directory>s' does not exist or is not accessible.",
39
- suggestions: [
40
- "Check that the directory path is correct",
41
- "Verify you have read permissions for the directory",
42
- "Create the directory first if it doesn't exist",
43
- "Use 'makit init' to create a new project directory",
44
- ],
45
- },
46
- git_command_failed: {
47
- message: "Git command failed: %<command>s",
48
- suggestions: [
49
- "Check that git is installed and available in PATH",
50
- "Verify you have network connectivity for remote operations",
51
- "Ensure you have proper permissions for the repository",
52
- "Check that the remote repository URL is accessible",
53
- ],
54
- },
55
- clone_failed: {
56
- message: "Failed to clone repository '%<url>s'.",
57
- suggestions: [
58
- "Check that the repository URL is correct and accessible",
59
- "Verify your network connectivity",
60
- "Ensure you have proper authentication (SSH keys, tokens)",
61
- "Check that you have write permissions to the destination directory",
62
- ],
63
- },
64
- pull_failed: {
65
- message: "Failed to pull changes from repository.",
66
- suggestions: [
67
- "Check that you have network connectivity",
68
- "Verify the remote repository is accessible",
69
- "Ensure your local repository is in a clean state",
70
- "Try 'git status' to check for conflicts",
71
- ],
72
- },
73
- build_failed: {
74
- message: "Build process failed for repository '%<url>s' at commit '%<commit>s'.",
75
- suggestions: [
76
- "Check the build logs for specific error messages",
77
- "Verify all dependencies are installed",
78
- "Ensure the commit hash is valid and exists",
79
- "Try building manually to isolate the issue",
80
- ],
81
- },
82
- }.freeze
83
-
84
- class << self
85
- # Format an error with user-friendly message and suggestions
86
- #
87
- # @param error_type [Symbol] the type of error from ERROR_MESSAGES
88
- # @param details [Hash] details to interpolate into the message
89
- # @param original_error [Exception] the original exception (optional)
90
- # @return [String] formatted error message with suggestions
91
- def format_error(error_type, details = {}, original_error = nil)
92
- error_config = ERROR_MESSAGES[error_type]
93
- return "Unknown error type: #{error_type}" unless error_config
94
-
95
- message = error_config[:message] % details
96
- suggestions = error_config[:suggestions]
97
-
98
- formatted_message = ["āŒ Error: #{message}"]
99
-
100
- if suggestions && !suggestions.empty?
101
- formatted_message << ""
102
- formatted_message << "šŸ’” Suggestions:"
103
- suggestions.each_with_index do |suggestion, index|
104
- formatted_message << " #{index + 1}. #{suggestion}"
105
- end
106
- end
107
-
108
- if original_error && !original_error.message.empty?
109
- formatted_message << ""
110
- formatted_message << "šŸ” Technical details:"
111
- formatted_message << " #{original_error.class}: #{original_error.message}"
112
- end
113
-
114
- formatted_message.join("\n")
115
- end
116
-
117
- # Handle ArgumentError exceptions with user-friendly formatting
118
- #
119
- # @param error [ArgumentError] the argument error to format
120
- # @param context [Hash] additional context about where the error occurred
121
- # @return [String] formatted error message
122
- def handle_argument_error(error, context = {})
123
- case error.message
124
- when /URL parameter cannot be nil|URL parameter cannot be empty|Invalid URL format/
125
- format_error(:invalid_url, { url: context[:url] || "unknown" }, error)
126
- when /directory parameter cannot be nil|directory parameter cannot be empty|directory path/
127
- format_error(:invalid_directory, { directory: context[:directory] || "unknown" }, error)
128
- when /commit parameter cannot be nil|commit parameter cannot be empty|Invalid commit format/
129
- format_error(:invalid_commit, { commit: context[:commit] || "unknown" }, error)
130
- else
131
- "āŒ Error: #{error.message}\nšŸ’” Please check your input parameters and try again."
132
- end
133
- end
134
-
135
- # Handle Makit-specific exceptions with user-friendly formatting
136
- #
137
- # @param error [Makit::Error] the Makit error to format
138
- # @param context [Hash] additional context about where the error occurred
139
- # @return [String] formatted error message
140
- def handle_makit_error(error, context = {})
141
- case error
142
- when Makit::DirectoryError
143
- format_error(:directory_not_found, { directory: context[:directory] || "unknown" }, error)
144
- when Makit::CloneError
145
- format_error(:clone_failed, { url: context[:url] || "unknown" }, error)
146
- when Makit::PullError
147
- format_error(:pull_failed, {}, error)
148
- when Makit::BuildError
149
- format_error(:build_failed, { url: context[:url] || "unknown", commit: context[:commit] || "unknown" },
150
- error)
151
- when Makit::GitError
152
- format_error(:git_command_failed, { command: context[:command] || "unknown" }, error)
153
- else
154
- "āŒ Error: #{error.message}\nšŸ’” Please refer to the documentation or run with --verbose for more details."
155
- end
156
- end
157
-
158
- # Log error with context for debugging
159
- #
160
- # @param error [Exception] the error to log
161
- # @param context [Hash] additional context information
162
- def log_error(error, context = {})
163
- return unless defined?(Makit::LOGGER) && Makit::LOGGER
164
-
165
- Makit::LOGGER.error "Error occurred: #{error.class} - #{error.message}"
166
- Makit::LOGGER.error "Context: #{context.inspect}" unless context.empty?
167
- Makit::LOGGER.debug "Backtrace: #{error.backtrace&.join("\n")}" if error.backtrace
168
- end
169
-
170
- # Wrap a block with comprehensive error handling
171
- #
172
- # @param context [Hash] context information for error messages
173
- # @yield block to execute with error handling
174
- # @return [Object] the result of the block
175
- def with_error_handling(context = {})
176
- yield
177
- rescue ArgumentError => e
178
- log_error(e, context)
179
- formatted_message = handle_argument_error(e, context)
180
- raise Makit::ValidationError, formatted_message
181
- rescue Makit::Error => e
182
- log_error(e, context)
183
- formatted_message = handle_makit_error(e, context)
184
- raise e.class, formatted_message
185
- rescue StandardError => e
186
- log_error(e, context)
187
- formatted_message = "āŒ An unexpected error occurred: #{e.message}\nšŸ’” Please check the logs or run with --verbose for more details."
188
- raise Makit::Error, formatted_message
189
- end
190
-
191
- # Validate input and provide helpful error messages
192
- #
193
- # @param validations [Array<Hash>] array of validation rules
194
- # @example
195
- # validate_inputs([
196
- # { value: url, validator: :url, name: 'repository URL' },
197
- # { value: commit, validator: :commit, name: 'commit hash' }
198
- # ])
199
- def validate_inputs(validations)
200
- validations.each do |validation|
201
- value = validation[:value]
202
- validator = validation[:validator]
203
- name = validation[:name] || "parameter"
204
-
205
- case validator
206
- when :url
207
- Validator.validate_url_parameter(value)
208
- when :directory
209
- Validator.validate_directory_parameter(value)
210
- when :commit
211
- Validator.validate_commit_parameter(value)
212
- when :required_string
213
- Validator.validate_required_string(value, name)
214
- when :boolean
215
- Validator.validate_boolean_parameter(value, name)
216
- end
217
- rescue ArgumentError => e
218
- context = { validator => value }
219
- formatted_message = handle_argument_error(e, context)
220
- raise Makit::ValidationError, formatted_message
221
- end
222
- end
223
- end
224
- end
225
- end
226
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Makit
4
+ module Services
5
+ # Service class responsible for handling and formatting errors
6
+ # Provides user-friendly error messages and recovery suggestions
7
+ class ErrorHandler
8
+ # Error message templates with suggestions
9
+ ERROR_MESSAGES = {
10
+ invalid_url: {
11
+ message: "The repository URL '%<url>s' is not valid.",
12
+ suggestions: [
13
+ "Use HTTPS format: https://github.com/user/repo.git",
14
+ "Use SSH format: git@github.com:user/repo.git",
15
+ "Use simple format: user/repo",
16
+ "Ensure the URL points to a git repository",
17
+ ],
18
+ },
19
+ invalid_directory: {
20
+ message: "The directory path '%<directory>s' is not valid.",
21
+ suggestions: [
22
+ "Use absolute paths like /path/to/directory",
23
+ "Use relative paths like ./relative/path",
24
+ "Ensure the path doesn't contain null characters",
25
+ "Keep directory paths under 255 characters",
26
+ ],
27
+ },
28
+ invalid_commit: {
29
+ message: "The commit '%<commit>s' is not valid.",
30
+ suggestions: [
31
+ "Use 'latest' for the most recent commit",
32
+ "Use a full 40-character commit hash",
33
+ "Use a short 7+ character commit hash",
34
+ "Verify the commit exists in the repository",
35
+ ],
36
+ },
37
+ directory_not_found: {
38
+ message: "The directory '%<directory>s' does not exist or is not accessible.",
39
+ suggestions: [
40
+ "Check that the directory path is correct",
41
+ "Verify you have read permissions for the directory",
42
+ "Create the directory first if it doesn't exist",
43
+ "Use 'makit init' to create a new project directory",
44
+ ],
45
+ },
46
+ git_command_failed: {
47
+ message: "Git command failed: %<command>s",
48
+ suggestions: [
49
+ "Check that git is installed and available in PATH",
50
+ "Verify you have network connectivity for remote operations",
51
+ "Ensure you have proper permissions for the repository",
52
+ "Check that the remote repository URL is accessible",
53
+ ],
54
+ },
55
+ clone_failed: {
56
+ message: "Failed to clone repository '%<url>s'.",
57
+ suggestions: [
58
+ "Check that the repository URL is correct and accessible",
59
+ "Verify your network connectivity",
60
+ "Ensure you have proper authentication (SSH keys, tokens)",
61
+ "Check that you have write permissions to the destination directory",
62
+ ],
63
+ },
64
+ pull_failed: {
65
+ message: "Failed to pull changes from repository.",
66
+ suggestions: [
67
+ "Check that you have network connectivity",
68
+ "Verify the remote repository is accessible",
69
+ "Ensure your local repository is in a clean state",
70
+ "Try 'git status' to check for conflicts",
71
+ ],
72
+ },
73
+ build_failed: {
74
+ message: "Build process failed for repository '%<url>s' at commit '%<commit>s'.",
75
+ suggestions: [
76
+ "Check the build logs for specific error messages",
77
+ "Verify all dependencies are installed",
78
+ "Ensure the commit hash is valid and exists",
79
+ "Try building manually to isolate the issue",
80
+ ],
81
+ },
82
+ }.freeze
83
+
84
+ class << self
85
+ # Format an error with user-friendly message and suggestions
86
+ #
87
+ # @param error_type [Symbol] the type of error from ERROR_MESSAGES
88
+ # @param details [Hash] details to interpolate into the message
89
+ # @param original_error [Exception] the original exception (optional)
90
+ # @return [String] formatted error message with suggestions
91
+ def format_error(error_type, details = {}, original_error = nil)
92
+ error_config = ERROR_MESSAGES[error_type]
93
+ return "Unknown error type: #{error_type}" unless error_config
94
+
95
+ message = error_config[:message] % details
96
+ suggestions = error_config[:suggestions]
97
+
98
+ formatted_message = ["āŒ Error: #{message}"]
99
+
100
+ if suggestions && !suggestions.empty?
101
+ formatted_message << ""
102
+ formatted_message << "šŸ’” Suggestions:"
103
+ suggestions.each_with_index do |suggestion, index|
104
+ formatted_message << " #{index + 1}. #{suggestion}"
105
+ end
106
+ end
107
+
108
+ if original_error && !original_error.message.empty?
109
+ formatted_message << ""
110
+ formatted_message << "šŸ” Technical details:"
111
+ formatted_message << " #{original_error.class}: #{original_error.message}"
112
+ end
113
+
114
+ formatted_message.join("\n")
115
+ end
116
+
117
+ # Handle ArgumentError exceptions with user-friendly formatting
118
+ #
119
+ # @param error [ArgumentError] the argument error to format
120
+ # @param context [Hash] additional context about where the error occurred
121
+ # @return [String] formatted error message
122
+ def handle_argument_error(error, context = {})
123
+ case error.message
124
+ when /URL parameter cannot be nil|URL parameter cannot be empty|Invalid URL format/
125
+ format_error(:invalid_url, { url: context[:url] || "unknown" }, error)
126
+ when /directory parameter cannot be nil|directory parameter cannot be empty|directory path/
127
+ format_error(:invalid_directory, { directory: context[:directory] || "unknown" }, error)
128
+ when /commit parameter cannot be nil|commit parameter cannot be empty|Invalid commit format/
129
+ format_error(:invalid_commit, { commit: context[:commit] || "unknown" }, error)
130
+ else
131
+ "āŒ Error: #{error.message}\nšŸ’” Please check your input parameters and try again."
132
+ end
133
+ end
134
+
135
+ # Handle Makit-specific exceptions with user-friendly formatting
136
+ #
137
+ # @param error [Makit::Error] the Makit error to format
138
+ # @param context [Hash] additional context about where the error occurred
139
+ # @return [String] formatted error message
140
+ def handle_makit_error(error, context = {})
141
+ case error
142
+ when Makit::DirectoryError
143
+ format_error(:directory_not_found, { directory: context[:directory] || "unknown" }, error)
144
+ when Makit::CloneError
145
+ format_error(:clone_failed, { url: context[:url] || "unknown" }, error)
146
+ when Makit::PullError
147
+ format_error(:pull_failed, {}, error)
148
+ when Makit::BuildError
149
+ format_error(:build_failed, { url: context[:url] || "unknown", commit: context[:commit] || "unknown" },
150
+ error)
151
+ when Makit::GitError
152
+ format_error(:git_command_failed, { command: context[:command] || "unknown" }, error)
153
+ else
154
+ "āŒ Error: #{error.message}\nšŸ’” Please refer to the documentation or run with --verbose for more details."
155
+ end
156
+ end
157
+
158
+ # Log error with context for debugging
159
+ #
160
+ # @param error [Exception] the error to log
161
+ # @param context [Hash] additional context information
162
+ def log_error(error, context = {})
163
+ return unless defined?(Makit::LOGGER) && Makit::LOGGER
164
+
165
+ Makit::LOGGER.error "Error occurred: #{error.class} - #{error.message}"
166
+ Makit::LOGGER.error "Context: #{context.inspect}" unless context.empty?
167
+ Makit::LOGGER.debug "Backtrace: #{error.backtrace&.join("\n")}" if error.backtrace
168
+ end
169
+
170
+ # Wrap a block with comprehensive error handling
171
+ #
172
+ # @param context [Hash] context information for error messages
173
+ # @yield block to execute with error handling
174
+ # @return [Object] the result of the block
175
+ def with_error_handling(context = {})
176
+ yield
177
+ rescue ArgumentError => e
178
+ log_error(e, context)
179
+ formatted_message = handle_argument_error(e, context)
180
+ raise Makit::ValidationError, formatted_message
181
+ rescue Makit::Error => e
182
+ log_error(e, context)
183
+ formatted_message = handle_makit_error(e, context)
184
+ raise e.class, formatted_message
185
+ rescue StandardError => e
186
+ log_error(e, context)
187
+ formatted_message = "āŒ An unexpected error occurred: #{e.message}\nšŸ’” Please check the logs or run with --verbose for more details."
188
+ raise Makit::Error, formatted_message
189
+ end
190
+
191
+ # Validate input and provide helpful error messages
192
+ #
193
+ # @param validations [Array<Hash>] array of validation rules
194
+ # @example
195
+ # validate_inputs([
196
+ # { value: url, validator: :url, name: 'repository URL' },
197
+ # { value: commit, validator: :commit, name: 'commit hash' }
198
+ # ])
199
+ def validate_inputs(validations)
200
+ validations.each do |validation|
201
+ value = validation[:value]
202
+ validator = validation[:validator]
203
+ name = validation[:name] || "parameter"
204
+
205
+ case validator
206
+ when :url
207
+ Validator.validate_url_parameter(value)
208
+ when :directory
209
+ Validator.validate_directory_parameter(value)
210
+ when :commit
211
+ Validator.validate_commit_parameter(value)
212
+ when :required_string
213
+ Validator.validate_required_string(value, name)
214
+ when :boolean
215
+ Validator.validate_boolean_parameter(value, name)
216
+ end
217
+ rescue ArgumentError => e
218
+ context = { validator => value }
219
+ formatted_message = handle_argument_error(e, context)
220
+ raise Makit::ValidationError, formatted_message
221
+ end
222
+ end
223
+ end
224
+ end
225
+ end
226
+ end