makit 0.0.112 ā 0.0.128
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/README.md +41 -41
- data/exe/makit +5 -5
- data/lib/makit/apache.rb +28 -28
- data/lib/makit/cli/build_commands.rb +500 -500
- data/lib/makit/cli/generators/base_generator.rb +74 -74
- data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
- data/lib/makit/cli/generators/generator_factory.rb +49 -49
- data/lib/makit/cli/generators/node_generator.rb +50 -50
- data/lib/makit/cli/generators/ruby_generator.rb +77 -77
- data/lib/makit/cli/generators/rust_generator.rb +50 -50
- data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
- data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
- data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
- data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -40
- data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
- data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
- data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
- data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
- data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
- data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
- data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
- data/lib/makit/cli/main.rb +62 -62
- data/lib/makit/cli/project_commands.rb +868 -868
- data/lib/makit/cli/repository_commands.rb +661 -661
- data/lib/makit/cli/utility_commands.rb +521 -521
- data/lib/makit/commands/factory.rb +359 -359
- data/lib/makit/commands/middleware/base.rb +73 -73
- data/lib/makit/commands/middleware/cache.rb +248 -248
- data/lib/makit/commands/middleware/command_logger.rb +311 -320
- data/lib/makit/commands/middleware/validator.rb +269 -269
- data/lib/makit/commands/request.rb +316 -254
- data/lib/makit/commands/result.rb +323 -323
- data/lib/makit/commands/runner.rb +368 -337
- data/lib/makit/commands/strategies/base.rb +171 -160
- data/lib/makit/commands/strategies/synchronous.rb +139 -134
- data/lib/makit/commands.rb +50 -51
- data/lib/makit/configuration/gitlab_helper.rb +58 -60
- data/lib/makit/configuration/project.rb +167 -127
- data/lib/makit/configuration/rakefile_helper.rb +43 -43
- data/lib/makit/configuration/step.rb +34 -34
- data/lib/makit/configuration.rb +14 -14
- data/lib/makit/content/default_gitignore.rb +7 -7
- data/lib/makit/content/default_gitignore.txt +226 -0
- data/lib/makit/content/default_rakefile.rb +13 -13
- data/lib/makit/content/gem_rakefile.rb +16 -16
- data/lib/makit/context.rb +1 -1
- data/lib/makit/data.rb +49 -49
- data/lib/makit/directories.rb +140 -141
- data/lib/makit/directory.rb +262 -262
- data/lib/makit/docs/files.rb +89 -89
- data/lib/makit/docs/rake.rb +102 -102
- data/lib/makit/dotnet/cli.rb +69 -65
- data/lib/makit/dotnet/project.rb +217 -153
- data/lib/makit/dotnet/solution.rb +38 -38
- data/lib/makit/dotnet/solution_classlib.rb +239 -239
- data/lib/makit/dotnet/solution_console.rb +264 -264
- data/lib/makit/dotnet/solution_maui.rb +354 -354
- data/lib/makit/dotnet/solution_wasm.rb +275 -275
- data/lib/makit/dotnet/solution_wpf.rb +304 -304
- data/lib/makit/dotnet.rb +102 -102
- data/lib/makit/email.rb +90 -90
- data/lib/makit/environment.rb +142 -142
- data/lib/makit/examples/runner.rb +370 -370
- data/lib/makit/exceptions.rb +45 -45
- data/lib/makit/fileinfo.rb +24 -24
- data/lib/makit/files.rb +43 -43
- data/lib/makit/gems.rb +40 -40
- data/lib/makit/git/cli.rb +54 -54
- data/lib/makit/git/repository.rb +90 -90
- data/lib/makit/git.rb +98 -98
- data/lib/makit/gitlab_runner.rb +59 -59
- data/lib/makit/humanize.rb +137 -137
- data/lib/makit/indexer.rb +47 -47
- data/lib/makit/logging/configuration.rb +308 -305
- data/lib/makit/logging/format_registry.rb +84 -84
- data/lib/makit/logging/formatters/base.rb +39 -39
- data/lib/makit/logging/formatters/console_formatter.rb +140 -140
- data/lib/makit/logging/formatters/json_formatter.rb +65 -65
- data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
- data/lib/makit/logging/formatters/text_formatter.rb +64 -64
- data/lib/makit/logging/log_request.rb +119 -115
- data/lib/makit/logging/logger.rb +199 -163
- data/lib/makit/logging/sinks/base.rb +91 -91
- data/lib/makit/logging/sinks/console.rb +72 -72
- data/lib/makit/logging/sinks/file_sink.rb +92 -92
- data/lib/makit/logging/sinks/structured.rb +123 -129
- data/lib/makit/logging/sinks/unified_file_sink.rb +296 -303
- data/lib/makit/logging.rb +565 -530
- data/lib/makit/markdown.rb +75 -75
- data/lib/makit/mp/basic_object_mp.rb +17 -17
- data/lib/makit/mp/command_mp.rb +13 -13
- data/lib/makit/mp/command_request.mp.rb +17 -17
- data/lib/makit/mp/project_mp.rb +199 -199
- data/lib/makit/mp/string_mp.rb +191 -193
- data/lib/makit/nuget.rb +74 -74
- data/lib/makit/port.rb +32 -32
- data/lib/makit/process.rb +163 -163
- data/lib/makit/protoc.rb +107 -107
- data/lib/makit/rake/cli.rb +196 -196
- data/lib/makit/rake.rb +25 -25
- data/lib/makit/ruby/cli.rb +185 -185
- data/lib/makit/ruby.rb +25 -25
- data/lib/makit/secrets.rb +51 -51
- data/lib/makit/serializer.rb +130 -130
- data/lib/makit/services/builder.rb +186 -186
- data/lib/makit/services/error_handler.rb +226 -226
- data/lib/makit/services/repository_manager.rb +231 -229
- data/lib/makit/services/validator.rb +112 -112
- data/lib/makit/setup/classlib.rb +94 -53
- data/lib/makit/setup/gem.rb +268 -263
- data/lib/makit/setup/razorclasslib.rb +91 -0
- data/lib/makit/setup/runner.rb +54 -45
- data/lib/makit/setup.rb +5 -5
- data/lib/makit/show.rb +110 -110
- data/lib/makit/storage.rb +126 -126
- data/lib/makit/symbols.rb +170 -170
- data/lib/makit/task_info.rb +128 -128
- data/lib/makit/tasks/at_exit.rb +15 -13
- data/lib/makit/tasks/build.rb +22 -19
- data/lib/makit/tasks/clean.rb +13 -11
- data/lib/makit/tasks/configure.rb +10 -0
- data/lib/makit/tasks/format.rb +10 -0
- data/lib/makit/tasks/hook_manager.rb +391 -393
- data/lib/makit/tasks/init.rb +49 -47
- data/lib/makit/tasks/integrate.rb +29 -17
- data/lib/makit/tasks/pull_incoming.rb +13 -11
- data/lib/makit/tasks/setup.rb +13 -6
- data/lib/makit/tasks/sync.rb +17 -12
- data/lib/makit/tasks/tag.rb +16 -15
- data/lib/makit/tasks/task_monkey_patch.rb +81 -79
- data/lib/makit/tasks/test.rb +22 -0
- data/lib/makit/tasks/update.rb +18 -0
- data/lib/makit/tasks.rb +20 -15
- data/lib/makit/test_cache.rb +239 -239
- data/lib/makit/tree.rb +37 -37
- data/lib/makit/v1/makit.v1_pb.rb +35 -34
- data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
- data/lib/makit/version.rb +5 -5
- data/lib/makit/version_util.rb +21 -21
- data/lib/makit/wix.rb +95 -95
- data/lib/makit/yaml.rb +29 -29
- data/lib/makit/zip.rb +17 -17
- data/lib/makit copy.rb +44 -44
- data/lib/makit.rb +39 -40
- metadata +69 -7
- data/lib/makit/commands/middleware/unified_logger.rb +0 -243
@@ -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
|