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,205 +1,205 @@
1
- # frozen_string_literal: true
2
-
3
- require "json"
4
- require "fileutils"
5
- # monkey patch String class with command execution methods
6
-
7
- class String
8
- def run(args = nil)
9
- command = self
10
- if args.nil?
11
- request = Makit::Commands::Request.from_string(command)
12
- else
13
- # Parse initial request
14
- base_request = Makit::Commands::Request.from_string(command)
15
-
16
- if args.is_a?(Hash)
17
- # Create new request with combined options
18
- request_options = {
19
- command: base_request.command,
20
- arguments: base_request.arguments || [],
21
- directory: base_request.directory,
22
- timeout: base_request.timeout,
23
- environment: base_request.environment || {},
24
- metadata: base_request.metadata || {},
25
- }
26
-
27
- # Apply args to the request options
28
- args.each do |key, value|
29
- case key.to_s
30
- when "arguments"
31
- # Append additional arguments
32
- request_options[:arguments] = (request_options[:arguments] + Array(value)).flatten
33
- when "directory"
34
- request_options[:directory] = value
35
- when "timeout"
36
- request_options[:timeout] = value
37
- when "environment"
38
- request_options[:environment] = (request_options[:environment] || {}).merge(value)
39
- when "metadata"
40
- request_options[:metadata] = (request_options[:metadata] || {}).merge(value)
41
- else
42
- # Add unknown keys to metadata
43
- request_options[:metadata] = (request_options[:metadata] || {}).merge(key.to_s => value)
44
- end
45
- end
46
-
47
- # Create new request with combined options
48
- request = Makit::Commands::Request.new(**request_options)
49
- else
50
- # args is an array of additional arguments
51
- request = Makit::Commands::Request.new(
52
- command: base_request.command,
53
- arguments: (base_request.arguments || []) + Array(args),
54
- directory: base_request.directory,
55
- timeout: base_request.timeout,
56
- environment: base_request.environment || {},
57
- metadata: base_request.metadata || {},
58
- )
59
- end
60
- end
61
- Makit::Commands::Runner.default.execute(request)
62
- end
63
-
64
- def cache_run(timestamp = nil, timeout: nil)
65
- #puts "cache_run: #{self}"
66
- command = self
67
- request = Makit::Commands::Request.from_string(command)
68
-
69
- # Build request options
70
- request_options = {
71
- command: request.command,
72
- arguments: request.arguments,
73
- directory: request.directory,
74
- timeout: timeout || request.timeout,
75
- environment: request.environment || {},
76
- metadata: request.metadata || {},
77
- }
78
-
79
- if timestamp
80
- # Add timestamp to metadata for cache key generation
81
- request_options[:metadata] = request_options[:metadata].merge(timestamp: timestamp)
82
- #puts "timestamp: #{timestamp}"
83
- else
84
- #puts "no timestamp"
85
- end
86
-
87
- request = Makit::Commands::Request.new(**request_options)
88
- Makit::Commands::Runner.default.execute(request)
89
- end
90
-
91
- def try
92
- command = self
93
- request = Makit::Commands::Request.from_string(command).exit_on_failure(false)
94
- Makit::Commands::Runner.default.execute(request)
95
- end
96
-
97
- def show
98
- command = self
99
- request = Makit::Commands::Request.from_string(command)
100
- Makit::Commands::Runner.default.execute(request)
101
- end
102
-
103
- def log(log_file = nil)
104
- command = self
105
- request = Makit::Commands::Request.from_string(command)
106
- result = Makit::Commands::Runner.default.execute(request)
107
-
108
- # If a log file is provided, write outputs to the file (maintains backward compatibility)
109
- if log_file
110
- FileUtils.mkdir_p(File.dirname(log_file))
111
- File.write(log_file, "") unless File.exist?(log_file)
112
- File.write(log_file, result.stdout, mode: "w") if result.stdout && !result.stdout.empty?
113
- File.write(log_file, result.stderr, mode: "a") if result.stderr && !result.stderr.empty?
114
- else
115
- # Otherwise, log to the Makit logger
116
- if result.success?
117
- Makit::Logging.info("Command completed successfully: #{command}")
118
- else
119
- Makit::Logging.error("Command failed: #{command} (exit code: #{result.exit_code})")
120
- end
121
- end
122
-
123
- result
124
- end
125
-
126
- def cache_try(timestamp = nil)
127
- command = self
128
- request = Makit::Commands::Request.from_string(command)
129
- if timestamp
130
- # Add timestamp to metadata for cache key generation
131
- request = Makit::Commands::Request.new(
132
- command: request.command,
133
- arguments: request.arguments,
134
- directory: request.directory,
135
- timeout: request.timeout,
136
- environment: request.environment || {},
137
- metadata: (request.metadata || {}).merge(timestamp: timestamp),
138
- )
139
- end
140
- Makit::Commands::Runner.default.execute(request)
141
- end
142
-
143
- def show_command(cmd)
144
- if cmd.success?
145
- puts "✅ #{cmd.command} #{cmd.arguments&.join(" ")}".colorize(:green)
146
- else
147
- puts "❌ #{cmd.command} #{cmd.arguments&.join(" ")}".colorize(:red)
148
- puts " Exit code: #{cmd.exit_code}".colorize(:red)
149
- puts " Error: #{cmd.stderr}".colorize(:red) if cmd.stderr && !cmd.stderr.empty?
150
- end
151
- end
152
-
153
- def to_markdown
154
- command = self
155
- request = Makit::Commands::Request.from_string(command)
156
- result = Makit::Commands::Runner.default.execute(request)
157
-
158
- if result.success?
159
- "```\n#{result.stdout}\n```"
160
- else
161
- "```\nError: #{result.stderr}\n```"
162
- end
163
- end
164
-
165
- def cache_run_with_timestamp(timestamp)
166
- command = self
167
- request = Makit::Commands::Request.from_string(command)
168
- request = Makit::Commands::Request.new(
169
- command: request.command,
170
- arguments: request.arguments,
171
- directory: request.directory,
172
- timeout: request.timeout,
173
- environment: request.environment || {},
174
- metadata: (request.metadata || {}).merge(timestamp: timestamp),
175
- )
176
- Makit::Commands::Runner.default.execute(request)
177
- end
178
-
179
- def cache_try_with_timestamp(timestamp)
180
- command = self
181
- request = Makit::Commands::Request.from_string(command)
182
- request = Makit::Commands::Request.new(
183
- command: request.command,
184
- arguments: request.arguments,
185
- directory: request.directory,
186
- timeout: request.timeout,
187
- environment: request.environment || {},
188
- metadata: (request.metadata || {}).merge(timestamp: timestamp),
189
- )
190
- Makit::Commands::Runner.default.execute(request)
191
- end
192
-
193
- def cache_log(log_file)
194
- command = self
195
- request = Makit::Commands::Request.from_string(command)
196
- result = Makit::Commands::Runner.default.execute(request)
197
-
198
- # Write output to log file
199
- FileUtils.mkdir_p(File.dirname(log_file))
200
- File.write(log_file, result.stdout) if result.stdout && !result.stdout.empty?
201
- File.write(log_file, result.stderr, mode: "a") if result.stderr && !result.stderr.empty?
202
-
203
- result
204
- end
205
- end
1
+ # frozen_string_literal: true
2
+
3
+ require "json"
4
+ require "fileutils"
5
+ # monkey patch String class with command execution methods
6
+
7
+ class String
8
+ def run(args = nil)
9
+ command = self
10
+ if args.nil?
11
+ request = Makit::Commands::Request.from_string(command)
12
+ else
13
+ # Parse initial request
14
+ base_request = Makit::Commands::Request.from_string(command)
15
+
16
+ if args.is_a?(Hash)
17
+ # Create new request with combined options
18
+ request_options = {
19
+ command: base_request.command,
20
+ arguments: base_request.arguments || [],
21
+ directory: base_request.directory,
22
+ timeout: base_request.timeout,
23
+ environment: base_request.environment || {},
24
+ metadata: base_request.metadata || {},
25
+ }
26
+
27
+ # Apply args to the request options
28
+ args.each do |key, value|
29
+ case key.to_s
30
+ when "arguments"
31
+ # Append additional arguments
32
+ request_options[:arguments] = (request_options[:arguments] + Array(value)).flatten
33
+ when "directory"
34
+ request_options[:directory] = value
35
+ when "timeout"
36
+ request_options[:timeout] = value
37
+ when "environment"
38
+ request_options[:environment] = (request_options[:environment] || {}).merge(value)
39
+ when "metadata"
40
+ request_options[:metadata] = (request_options[:metadata] || {}).merge(value)
41
+ else
42
+ # Add unknown keys to metadata
43
+ request_options[:metadata] = (request_options[:metadata] || {}).merge(key.to_s => value)
44
+ end
45
+ end
46
+
47
+ # Create new request with combined options
48
+ request = Makit::Commands::Request.new(**request_options)
49
+ else
50
+ # args is an array of additional arguments
51
+ request = Makit::Commands::Request.new(
52
+ command: base_request.command,
53
+ arguments: (base_request.arguments || []) + Array(args),
54
+ directory: base_request.directory,
55
+ timeout: base_request.timeout,
56
+ environment: base_request.environment || {},
57
+ metadata: base_request.metadata || {},
58
+ )
59
+ end
60
+ end
61
+ Makit::Commands::Runner.default.execute(request)
62
+ end
63
+
64
+ def cache_run(timestamp = nil, timeout: nil)
65
+ #puts "cache_run: #{self}"
66
+ command = self
67
+ request = Makit::Commands::Request.from_string(command)
68
+
69
+ # Build request options
70
+ request_options = {
71
+ command: request.command,
72
+ arguments: request.arguments,
73
+ directory: request.directory,
74
+ timeout: timeout || request.timeout,
75
+ environment: request.environment || {},
76
+ metadata: request.metadata || {},
77
+ }
78
+
79
+ if timestamp
80
+ # Add timestamp to metadata for cache key generation
81
+ request_options[:metadata] = request_options[:metadata].merge(timestamp: timestamp)
82
+ #puts "timestamp: #{timestamp}"
83
+ else
84
+ #puts "no timestamp"
85
+ end
86
+
87
+ request = Makit::Commands::Request.new(**request_options)
88
+ Makit::Commands::Runner.default.execute(request)
89
+ end
90
+
91
+ def try
92
+ command = self
93
+ request = Makit::Commands::Request.from_string(command).exit_on_failure(false)
94
+ Makit::Commands::Runner.default.execute(request)
95
+ end
96
+
97
+ def show
98
+ command = self
99
+ request = Makit::Commands::Request.from_string(command)
100
+ Makit::Commands::Runner.default.execute(request)
101
+ end
102
+
103
+ def log(log_file = nil)
104
+ command = self
105
+ request = Makit::Commands::Request.from_string(command)
106
+ result = Makit::Commands::Runner.default.execute(request)
107
+
108
+ # If a log file is provided, write outputs to the file (maintains backward compatibility)
109
+ if log_file
110
+ FileUtils.mkdir_p(File.dirname(log_file))
111
+ File.write(log_file, "") unless File.exist?(log_file)
112
+ File.write(log_file, result.stdout, mode: "w") if result.stdout && !result.stdout.empty?
113
+ File.write(log_file, result.stderr, mode: "a") if result.stderr && !result.stderr.empty?
114
+ else
115
+ # Otherwise, log to the Makit logger
116
+ if result.success?
117
+ Makit::Logging.info("Command completed successfully: #{command}")
118
+ else
119
+ Makit::Logging.error("Command failed: #{command} (exit code: #{result.exit_code})")
120
+ end
121
+ end
122
+
123
+ result
124
+ end
125
+
126
+ def cache_try(timestamp = nil)
127
+ command = self
128
+ request = Makit::Commands::Request.from_string(command)
129
+ if timestamp
130
+ # Add timestamp to metadata for cache key generation
131
+ request = Makit::Commands::Request.new(
132
+ command: request.command,
133
+ arguments: request.arguments,
134
+ directory: request.directory,
135
+ timeout: request.timeout,
136
+ environment: request.environment || {},
137
+ metadata: (request.metadata || {}).merge(timestamp: timestamp),
138
+ )
139
+ end
140
+ Makit::Commands::Runner.default.execute(request)
141
+ end
142
+
143
+ def show_command(cmd)
144
+ if cmd.success?
145
+ puts "✅ #{cmd.command} #{cmd.arguments&.join(" ")}".colorize(:green)
146
+ else
147
+ puts "❌ #{cmd.command} #{cmd.arguments&.join(" ")}".colorize(:red)
148
+ puts " Exit code: #{cmd.exit_code}".colorize(:red)
149
+ puts " Error: #{cmd.stderr}".colorize(:red) if cmd.stderr && !cmd.stderr.empty?
150
+ end
151
+ end
152
+
153
+ def to_markdown
154
+ command = self
155
+ request = Makit::Commands::Request.from_string(command)
156
+ result = Makit::Commands::Runner.default.execute(request)
157
+
158
+ if result.success?
159
+ "```\n#{result.stdout}\n```"
160
+ else
161
+ "```\nError: #{result.stderr}\n```"
162
+ end
163
+ end
164
+
165
+ def cache_run_with_timestamp(timestamp)
166
+ command = self
167
+ request = Makit::Commands::Request.from_string(command)
168
+ request = Makit::Commands::Request.new(
169
+ command: request.command,
170
+ arguments: request.arguments,
171
+ directory: request.directory,
172
+ timeout: request.timeout,
173
+ environment: request.environment || {},
174
+ metadata: (request.metadata || {}).merge(timestamp: timestamp),
175
+ )
176
+ Makit::Commands::Runner.default.execute(request)
177
+ end
178
+
179
+ def cache_try_with_timestamp(timestamp)
180
+ command = self
181
+ request = Makit::Commands::Request.from_string(command)
182
+ request = Makit::Commands::Request.new(
183
+ command: request.command,
184
+ arguments: request.arguments,
185
+ directory: request.directory,
186
+ timeout: request.timeout,
187
+ environment: request.environment || {},
188
+ metadata: (request.metadata || {}).merge(timestamp: timestamp),
189
+ )
190
+ Makit::Commands::Runner.default.execute(request)
191
+ end
192
+
193
+ def cache_log(log_file)
194
+ command = self
195
+ request = Makit::Commands::Request.from_string(command)
196
+ result = Makit::Commands::Runner.default.execute(request)
197
+
198
+ # Write output to log file
199
+ FileUtils.mkdir_p(File.dirname(log_file))
200
+ File.write(log_file, result.stdout) if result.stdout && !result.stdout.empty?
201
+ File.write(log_file, result.stderr, mode: "a") if result.stderr && !result.stderr.empty?
202
+
203
+ result
204
+ end
205
+ end