makit 0.0.139 → 0.0.140

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 (151) 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/cli/build_commands.rb +500 -500
  7. data/lib/makit/cli/generators/base_generator.rb +74 -74
  8. data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
  9. data/lib/makit/cli/generators/generator_factory.rb +49 -49
  10. data/lib/makit/cli/generators/node_generator.rb +50 -50
  11. data/lib/makit/cli/generators/ruby_generator.rb +77 -77
  12. data/lib/makit/cli/generators/rust_generator.rb +50 -50
  13. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
  14. data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
  15. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
  16. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -40
  17. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
  18. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
  19. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
  20. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
  21. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
  22. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
  23. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
  24. data/lib/makit/cli/main.rb +69 -67
  25. data/lib/makit/cli/project_commands.rb +868 -868
  26. data/lib/makit/cli/repository_commands.rb +661 -661
  27. data/lib/makit/cli/strategy_commands.rb +51 -0
  28. data/lib/makit/cli/utility_commands.rb +521 -521
  29. data/lib/makit/commands/factory.rb +359 -359
  30. data/lib/makit/commands/middleware/base.rb +73 -73
  31. data/lib/makit/commands/middleware/cache.rb +248 -248
  32. data/lib/makit/commands/middleware/command_logger.rb +312 -312
  33. data/lib/makit/commands/middleware/validator.rb +269 -269
  34. data/lib/makit/commands/request.rb +316 -316
  35. data/lib/makit/commands/result.rb +323 -323
  36. data/lib/makit/commands/runner.rb +385 -385
  37. data/lib/makit/commands/strategies/base.rb +171 -171
  38. data/lib/makit/commands/strategies/child_process.rb +1 -1
  39. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  40. data/lib/makit/commands.rb +50 -50
  41. data/lib/makit/configuration/dotnet_project.rb +12 -12
  42. data/lib/makit/configuration/gitlab_helper.rb +58 -58
  43. data/lib/makit/configuration/project.rb +168 -168
  44. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  45. data/lib/makit/configuration/step.rb +34 -34
  46. data/lib/makit/configuration/timeout.rb +74 -0
  47. data/lib/makit/configuration.rb +15 -14
  48. data/lib/makit/content/default_gitignore.rb +7 -7
  49. data/lib/makit/content/default_gitignore.txt +225 -225
  50. data/lib/makit/content/default_rakefile.rb +13 -13
  51. data/lib/makit/content/gem_rakefile.rb +16 -16
  52. data/lib/makit/context.rb +1 -1
  53. data/lib/makit/data.rb +49 -49
  54. data/lib/makit/directories.rb +140 -140
  55. data/lib/makit/directory.rb +262 -262
  56. data/lib/makit/docs/files.rb +89 -89
  57. data/lib/makit/docs/rake.rb +102 -102
  58. data/lib/makit/dotnet/cli.rb +69 -69
  59. data/lib/makit/dotnet/project.rb +217 -217
  60. data/lib/makit/dotnet/solution.rb +38 -38
  61. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  62. data/lib/makit/dotnet/solution_console.rb +264 -264
  63. data/lib/makit/dotnet/solution_maui.rb +354 -354
  64. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  65. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  66. data/lib/makit/dotnet.rb +102 -102
  67. data/lib/makit/email.rb +90 -90
  68. data/lib/makit/environment.rb +142 -142
  69. data/lib/makit/examples/runner.rb +370 -370
  70. data/lib/makit/exceptions.rb +45 -45
  71. data/lib/makit/fileinfo.rb +24 -24
  72. data/lib/makit/files.rb +43 -43
  73. data/lib/makit/gems.rb +40 -40
  74. data/lib/makit/git/cli.rb +54 -54
  75. data/lib/makit/git/repository.rb +90 -90
  76. data/lib/makit/git.rb +98 -98
  77. data/lib/makit/gitlab_runner.rb +59 -59
  78. data/lib/makit/humanize.rb +137 -137
  79. data/lib/makit/indexer.rb +47 -47
  80. data/lib/makit/logging/configuration.rb +308 -308
  81. data/lib/makit/logging/format_registry.rb +84 -84
  82. data/lib/makit/logging/formatters/base.rb +39 -39
  83. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  84. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  85. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  86. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  87. data/lib/makit/logging/log_request.rb +119 -119
  88. data/lib/makit/logging/logger.rb +199 -199
  89. data/lib/makit/logging/sinks/base.rb +91 -91
  90. data/lib/makit/logging/sinks/console.rb +72 -72
  91. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  92. data/lib/makit/logging/sinks/structured.rb +123 -123
  93. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  94. data/lib/makit/logging.rb +565 -565
  95. data/lib/makit/markdown.rb +75 -75
  96. data/lib/makit/mp/basic_object_mp.rb +17 -17
  97. data/lib/makit/mp/command_mp.rb +13 -13
  98. data/lib/makit/mp/command_request.mp.rb +17 -17
  99. data/lib/makit/mp/project_mp.rb +199 -199
  100. data/lib/makit/mp/string_mp.rb +191 -191
  101. data/lib/makit/nuget.rb +74 -74
  102. data/lib/makit/port.rb +32 -32
  103. data/lib/makit/process.rb +163 -163
  104. data/lib/makit/protoc.rb +107 -107
  105. data/lib/makit/rake/cli.rb +196 -196
  106. data/lib/makit/rake.rb +80 -80
  107. data/lib/makit/ruby/cli.rb +185 -185
  108. data/lib/makit/ruby.rb +25 -25
  109. data/lib/makit/secrets.rb +51 -51
  110. data/lib/makit/serializer.rb +130 -130
  111. data/lib/makit/services/builder.rb +186 -186
  112. data/lib/makit/services/error_handler.rb +226 -226
  113. data/lib/makit/services/repository_manager.rb +231 -231
  114. data/lib/makit/services/validator.rb +112 -112
  115. data/lib/makit/setup/classlib.rb +101 -101
  116. data/lib/makit/setup/gem.rb +268 -268
  117. data/lib/makit/setup/razorclasslib.rb +101 -101
  118. data/lib/makit/setup/runner.rb +54 -54
  119. data/lib/makit/setup.rb +5 -5
  120. data/lib/makit/show.rb +110 -110
  121. data/lib/makit/storage.rb +126 -126
  122. data/lib/makit/symbols.rb +170 -170
  123. data/lib/makit/task_info.rb +130 -130
  124. data/lib/makit/tasks/at_exit.rb +15 -15
  125. data/lib/makit/tasks/build.rb +22 -22
  126. data/lib/makit/tasks/clean.rb +13 -13
  127. data/lib/makit/tasks/configure.rb +10 -10
  128. data/lib/makit/tasks/format.rb +10 -10
  129. data/lib/makit/tasks/hook_manager.rb +443 -443
  130. data/lib/makit/tasks/init.rb +49 -49
  131. data/lib/makit/tasks/integrate.rb +29 -29
  132. data/lib/makit/tasks/pull_incoming.rb +13 -13
  133. data/lib/makit/tasks/setup.rb +13 -13
  134. data/lib/makit/tasks/sync.rb +17 -17
  135. data/lib/makit/tasks/tag.rb +16 -16
  136. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  137. data/lib/makit/tasks/test.rb +22 -22
  138. data/lib/makit/tasks/update.rb +18 -18
  139. data/lib/makit/tasks.rb +20 -20
  140. data/lib/makit/test_cache.rb +239 -239
  141. data/lib/makit/tree.rb +37 -37
  142. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  143. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  144. data/lib/makit/version.rb +99 -99
  145. data/lib/makit/version_util.rb +21 -21
  146. data/lib/makit/wix.rb +95 -95
  147. data/lib/makit/yaml.rb +29 -29
  148. data/lib/makit/zip.rb +17 -17
  149. data/lib/makit copy.rb +44 -44
  150. data/lib/makit.rb +42 -42
  151. metadata +2 -1
@@ -1,196 +1,196 @@
1
- # frozen_string_literal: true
2
-
3
- require "clamp"
4
-
5
- module Makit
6
- module Rake
7
- # CLI command for managing rake-related functionality
8
- # Command to run rake tasks
9
- class RunCommand < Clamp::Command
10
- self.description = "Run a rake task in a directory or repository"
11
-
12
- parameter "TARGET", "Directory path or repository URL"
13
- parameter "TASK", "Rake task to run"
14
- option ["-v", "--verbose"], :flag, "Verbose output"
15
- option ["-f", "--fail-fast"], :flag, "Stop on first failure"
16
- option ["-j", "--jobs"], "JOBS", "Number of parallel jobs", default: "1"
17
- option ["-t", "--trace"], :flag, "Show full backtrace on errors"
18
-
19
- def execute
20
- target_path = resolve_target(target)
21
-
22
- signal_usage_error "Target directory does not exist: #{target_path}" unless Dir.exist?(target_path)
23
-
24
- Dir.chdir(target_path) do
25
- puts "Running rake task '#{task}' in #{target_path}".colorize(:blue)
26
-
27
- # Build rake command with options
28
- rake_cmd = build_rake_command
29
-
30
- # Execute the command
31
- result = system(rake_cmd)
32
-
33
- if result
34
- puts "Rake task '#{task}' completed successfully".colorize(:green)
35
- else
36
- puts "Rake task '#{task}' failed".colorize(:red)
37
- exit(1)
38
- end
39
- end
40
- end
41
-
42
- private
43
-
44
- def resolve_target(target)
45
- return handle_repository_target(target) if target.start_with?("http")
46
-
47
- # It's a repository URL, clone or update it
48
-
49
- # It's a local path
50
- File.expand_path(target)
51
- end
52
-
53
- def handle_repository_target(url)
54
- local_path = File.join(
55
- Makit::Directories::HOME,
56
- "code",
57
- "work",
58
- Makit::Directories.get_relative_directory(url)
59
- )
60
-
61
- if Dir.exist?(local_path)
62
- puts "Updating existing repository: #{url}".colorize(:yellow)
63
- Dir.chdir(local_path) do
64
- "git pull".run
65
- end
66
- else
67
- puts "Cloning repository: #{url}".colorize(:green)
68
- `git clone #{url} #{local_path}`
69
- end
70
-
71
- local_path
72
- end
73
-
74
- def build_rake_command
75
- cmd_parts = ["rake", task]
76
-
77
- cmd_parts << "--verbose" if verbose?
78
- cmd_parts << "--fail-fast" if fail_fast?
79
- cmd_parts << "--jobs" << jobs if jobs != "1"
80
- cmd_parts << "--trace" if trace?
81
-
82
- cmd_parts.join(" ")
83
- end
84
- end
85
-
86
- # Command to list available rake tasks
87
- class ListCommand < Clamp::Command
88
- self.description = "List available rake tasks in a directory or repository"
89
-
90
- parameter "TARGET", "Directory path or repository URL"
91
- option ["-a", "--all"], :flag, "Show all tasks including private ones"
92
- option ["-p", "--pattern"], "PATTERN", "Filter tasks by pattern"
93
-
94
- def execute
95
- target_path = resolve_target(target)
96
-
97
- signal_usage_error "Target directory does not exist: #{target_path}" unless Dir.exist?(target_path)
98
-
99
- Dir.chdir(target_path) do
100
- puts "Available rake tasks in #{target_path}:".colorize(:blue)
101
-
102
- # Build rake command to list tasks
103
- rake_cmd = "rake --tasks"
104
- rake_cmd += " --all" if all?
105
-
106
- # Execute and capture output
107
- output = `#{rake_cmd} 2>/dev/null`
108
-
109
- if output.empty?
110
- puts "No rake tasks found or Rakefile not present".colorize(:yellow)
111
- return
112
- end
113
-
114
- # Filter by pattern if specified
115
- output = output.lines.select { |line| line.include?(pattern) }.join if pattern
116
-
117
- puts output
118
- end
119
- end
120
-
121
- private
122
-
123
- def resolve_target(target)
124
- return handle_repository_target(target) if target.start_with?("http")
125
-
126
- # It's a repository URL, clone or update it
127
-
128
- # It's a local path
129
- File.expand_path(target)
130
- end
131
-
132
- def handle_repository_target(url)
133
- local_path = File.join(
134
- Makit::Directories::HOME,
135
- "code",
136
- "work",
137
- Makit::Directories.get_relative_directory(url)
138
- )
139
-
140
- if Dir.exist?(local_path)
141
- puts "Updating existing repository: #{url}".colorize(:yellow)
142
- Dir.chdir(local_path) do
143
- "git pull".run
144
- end
145
- else
146
- puts "Cloning repository: #{url}".colorize(:green)
147
- `git clone #{url} #{local_path}`
148
- end
149
-
150
- local_path
151
- end
152
- end
153
-
154
- # Command to run rake tasks in repositories (legacy compatibility)
155
- class RepositoryCommand < Clamp::Command
156
- self.description = "Run a rake task in a repository (legacy command)"
157
-
158
- parameter "URL", "Repository URL"
159
- parameter "TASK", "Rake task to run"
160
-
161
- def execute
162
- puts "Running rake task '#{task}' in repository: #{url}".colorize(:blue)
163
- Makit::Rake.rake_repository(url, task)
164
- end
165
- end
166
-
167
- # CLI command for managing rake-related functionality
168
- class CliCommand < Clamp::Command
169
- self.description = <<~DESC
170
- Rake management commands for Makit.
171
-
172
- This command provides utilities for working with Rake tasks, including:
173
- - Running rake tasks in repositories
174
- - Managing rake task execution
175
- - Repository-based rake operations
176
-
177
- Common usage examples:
178
- # Run a rake task in a repository
179
- makit rake run https://github.com/user/repo test
180
- #{" "}
181
- # Run a rake task in a local directory
182
- makit rake run ./my-project build
183
- #{" "}
184
- # List available rake tasks in a repository
185
- makit rake list https://github.com/user/repo
186
- #{" "}
187
- # Run rake task with specific options
188
- makit rake run ./my-project test --verbose
189
- DESC
190
-
191
- subcommand "run", "Run a rake task in a repository or directory", RunCommand
192
- subcommand "list", "List available rake tasks", ListCommand
193
- subcommand "repository", "Run rake task in a repository", RepositoryCommand
194
- end
195
- end
196
- end
1
+ # frozen_string_literal: true
2
+
3
+ require "clamp"
4
+
5
+ module Makit
6
+ module Rake
7
+ # CLI command for managing rake-related functionality
8
+ # Command to run rake tasks
9
+ class RunCommand < Clamp::Command
10
+ self.description = "Run a rake task in a directory or repository"
11
+
12
+ parameter "TARGET", "Directory path or repository URL"
13
+ parameter "TASK", "Rake task to run"
14
+ option ["-v", "--verbose"], :flag, "Verbose output"
15
+ option ["-f", "--fail-fast"], :flag, "Stop on first failure"
16
+ option ["-j", "--jobs"], "JOBS", "Number of parallel jobs", default: "1"
17
+ option ["-t", "--trace"], :flag, "Show full backtrace on errors"
18
+
19
+ def execute
20
+ target_path = resolve_target(target)
21
+
22
+ signal_usage_error "Target directory does not exist: #{target_path}" unless Dir.exist?(target_path)
23
+
24
+ Dir.chdir(target_path) do
25
+ puts "Running rake task '#{task}' in #{target_path}".colorize(:blue)
26
+
27
+ # Build rake command with options
28
+ rake_cmd = build_rake_command
29
+
30
+ # Execute the command
31
+ result = system(rake_cmd)
32
+
33
+ if result
34
+ puts "Rake task '#{task}' completed successfully".colorize(:green)
35
+ else
36
+ puts "Rake task '#{task}' failed".colorize(:red)
37
+ exit(1)
38
+ end
39
+ end
40
+ end
41
+
42
+ private
43
+
44
+ def resolve_target(target)
45
+ return handle_repository_target(target) if target.start_with?("http")
46
+
47
+ # It's a repository URL, clone or update it
48
+
49
+ # It's a local path
50
+ File.expand_path(target)
51
+ end
52
+
53
+ def handle_repository_target(url)
54
+ local_path = File.join(
55
+ Makit::Directories::HOME,
56
+ "code",
57
+ "work",
58
+ Makit::Directories.get_relative_directory(url)
59
+ )
60
+
61
+ if Dir.exist?(local_path)
62
+ puts "Updating existing repository: #{url}".colorize(:yellow)
63
+ Dir.chdir(local_path) do
64
+ "git pull".run
65
+ end
66
+ else
67
+ puts "Cloning repository: #{url}".colorize(:green)
68
+ `git clone #{url} #{local_path}`
69
+ end
70
+
71
+ local_path
72
+ end
73
+
74
+ def build_rake_command
75
+ cmd_parts = ["rake", task]
76
+
77
+ cmd_parts << "--verbose" if verbose?
78
+ cmd_parts << "--fail-fast" if fail_fast?
79
+ cmd_parts << "--jobs" << jobs if jobs != "1"
80
+ cmd_parts << "--trace" if trace?
81
+
82
+ cmd_parts.join(" ")
83
+ end
84
+ end
85
+
86
+ # Command to list available rake tasks
87
+ class ListCommand < Clamp::Command
88
+ self.description = "List available rake tasks in a directory or repository"
89
+
90
+ parameter "TARGET", "Directory path or repository URL"
91
+ option ["-a", "--all"], :flag, "Show all tasks including private ones"
92
+ option ["-p", "--pattern"], "PATTERN", "Filter tasks by pattern"
93
+
94
+ def execute
95
+ target_path = resolve_target(target)
96
+
97
+ signal_usage_error "Target directory does not exist: #{target_path}" unless Dir.exist?(target_path)
98
+
99
+ Dir.chdir(target_path) do
100
+ puts "Available rake tasks in #{target_path}:".colorize(:blue)
101
+
102
+ # Build rake command to list tasks
103
+ rake_cmd = "rake --tasks"
104
+ rake_cmd += " --all" if all?
105
+
106
+ # Execute and capture output
107
+ output = `#{rake_cmd} 2>/dev/null`
108
+
109
+ if output.empty?
110
+ puts "No rake tasks found or Rakefile not present".colorize(:yellow)
111
+ return
112
+ end
113
+
114
+ # Filter by pattern if specified
115
+ output = output.lines.select { |line| line.include?(pattern) }.join if pattern
116
+
117
+ puts output
118
+ end
119
+ end
120
+
121
+ private
122
+
123
+ def resolve_target(target)
124
+ return handle_repository_target(target) if target.start_with?("http")
125
+
126
+ # It's a repository URL, clone or update it
127
+
128
+ # It's a local path
129
+ File.expand_path(target)
130
+ end
131
+
132
+ def handle_repository_target(url)
133
+ local_path = File.join(
134
+ Makit::Directories::HOME,
135
+ "code",
136
+ "work",
137
+ Makit::Directories.get_relative_directory(url)
138
+ )
139
+
140
+ if Dir.exist?(local_path)
141
+ puts "Updating existing repository: #{url}".colorize(:yellow)
142
+ Dir.chdir(local_path) do
143
+ "git pull".run
144
+ end
145
+ else
146
+ puts "Cloning repository: #{url}".colorize(:green)
147
+ `git clone #{url} #{local_path}`
148
+ end
149
+
150
+ local_path
151
+ end
152
+ end
153
+
154
+ # Command to run rake tasks in repositories (legacy compatibility)
155
+ class RepositoryCommand < Clamp::Command
156
+ self.description = "Run a rake task in a repository (legacy command)"
157
+
158
+ parameter "URL", "Repository URL"
159
+ parameter "TASK", "Rake task to run"
160
+
161
+ def execute
162
+ puts "Running rake task '#{task}' in repository: #{url}".colorize(:blue)
163
+ Makit::Rake.rake_repository(url, task)
164
+ end
165
+ end
166
+
167
+ # CLI command for managing rake-related functionality
168
+ class CliCommand < Clamp::Command
169
+ self.description = <<~DESC
170
+ Rake management commands for Makit.
171
+
172
+ This command provides utilities for working with Rake tasks, including:
173
+ - Running rake tasks in repositories
174
+ - Managing rake task execution
175
+ - Repository-based rake operations
176
+
177
+ Common usage examples:
178
+ # Run a rake task in a repository
179
+ makit rake run https://github.com/user/repo test
180
+ #{" "}
181
+ # Run a rake task in a local directory
182
+ makit rake run ./my-project build
183
+ #{" "}
184
+ # List available rake tasks in a repository
185
+ makit rake list https://github.com/user/repo
186
+ #{" "}
187
+ # Run rake task with specific options
188
+ makit rake run ./my-project test --verbose
189
+ DESC
190
+
191
+ subcommand "run", "Run a rake task in a repository or directory", RunCommand
192
+ subcommand "list", "List available rake tasks", ListCommand
193
+ subcommand "repository", "Run rake task in a repository", RepositoryCommand
194
+ end
195
+ end
196
+ end
data/lib/makit/rake.rb CHANGED
@@ -1,81 +1,81 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "rake/trace_controller"
4
-
5
- module Makit
6
- module Rake
7
- # Enhanced Rake integration for Makit
8
- #
9
- # This module provides enhanced Rake integration capabilities including
10
- # trace enhancement, task monitoring, and debugging utilities.
11
- #
12
- # @example Basic usage
13
- # require "makit"
14
- # Makit::Rake.setup
15
- #
16
- # @example With custom options
17
- # Makit::Rake.setup(trace: true, verbose: true)
18
- class << self
19
- # Set up enhanced Rake integration
20
- #
21
- # @param trace [Boolean] enable trace enhancement (default: auto-detect)
22
- # @param verbose [Boolean] enable verbose output (default: false)
23
- # @return [void]
24
- def setup(trace: nil, verbose: false)
25
- # Set up trace enhancement
26
- if trace.nil?
27
- TraceController.setup
28
- elsif trace
29
- ENV['MAKIT_TRACE'] = 'true'
30
- TraceController.setup
31
- end
32
-
33
- # Set up verbose output if requested
34
- if verbose
35
- ENV['MAKIT_VERBOSE'] = 'true'
36
- end
37
-
38
- # Log setup completion
39
- if defined?(Makit::Logging)
40
- Makit::Logging.debug("Makit Rake integration setup completed")
41
- Makit::Logging.debug("Trace status: #{TraceController.trace_status}")
42
- end
43
- end
44
-
45
- # Get current Rake integration status
46
- #
47
- # @return [Hash] integration status
48
- def status
49
- {
50
- trace_controller: TraceController.trace_status,
51
- verbose: ENV['MAKIT_VERBOSE'] == 'true',
52
- strategy: get_strategy_info
53
- }
54
- end
55
-
56
- # Check if enhanced tracing is active
57
- #
58
- # @return [Boolean] true if enhanced tracing is active
59
- def tracing_enabled?
60
- TraceController.should_enhance_trace?
61
- end
62
-
63
- private
64
-
65
- # Get strategy information safely
66
- #
67
- # @return [Hash] strategy information
68
- def get_strategy_info
69
- begin
70
- if defined?(Makit::Commands::Runner)
71
- Makit::Commands::Runner.default.strategy_info
72
- else
73
- { error: "Commands::Runner not available" }
74
- end
75
- rescue => e
76
- { error: e.message }
77
- end
78
- end
79
- end
80
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "rake/trace_controller"
4
+
5
+ module Makit
6
+ module Rake
7
+ # Enhanced Rake integration for Makit
8
+ #
9
+ # This module provides enhanced Rake integration capabilities including
10
+ # trace enhancement, task monitoring, and debugging utilities.
11
+ #
12
+ # @example Basic usage
13
+ # require "makit"
14
+ # Makit::Rake.setup
15
+ #
16
+ # @example With custom options
17
+ # Makit::Rake.setup(trace: true, verbose: true)
18
+ class << self
19
+ # Set up enhanced Rake integration
20
+ #
21
+ # @param trace [Boolean] enable trace enhancement (default: auto-detect)
22
+ # @param verbose [Boolean] enable verbose output (default: false)
23
+ # @return [void]
24
+ def setup(trace: nil, verbose: false)
25
+ # Set up trace enhancement
26
+ if trace.nil?
27
+ TraceController.setup
28
+ elsif trace
29
+ ENV['MAKIT_TRACE'] = 'true'
30
+ TraceController.setup
31
+ end
32
+
33
+ # Set up verbose output if requested
34
+ if verbose
35
+ ENV['MAKIT_VERBOSE'] = 'true'
36
+ end
37
+
38
+ # Log setup completion
39
+ if defined?(Makit::Logging)
40
+ Makit::Logging.debug("Makit Rake integration setup completed")
41
+ Makit::Logging.debug("Trace status: #{TraceController.trace_status}")
42
+ end
43
+ end
44
+
45
+ # Get current Rake integration status
46
+ #
47
+ # @return [Hash] integration status
48
+ def status
49
+ {
50
+ trace_controller: TraceController.trace_status,
51
+ verbose: ENV['MAKIT_VERBOSE'] == 'true',
52
+ strategy: get_strategy_info
53
+ }
54
+ end
55
+
56
+ # Check if enhanced tracing is active
57
+ #
58
+ # @return [Boolean] true if enhanced tracing is active
59
+ def tracing_enabled?
60
+ TraceController.should_enhance_trace?
61
+ end
62
+
63
+ private
64
+
65
+ # Get strategy information safely
66
+ #
67
+ # @return [Hash] strategy information
68
+ def get_strategy_info
69
+ begin
70
+ if defined?(Makit::Commands::Runner)
71
+ Makit::Commands::Runner.default.strategy_info
72
+ else
73
+ { error: "Commands::Runner not available" }
74
+ end
75
+ rescue => e
76
+ { error: e.message }
77
+ end
78
+ end
79
+ end
80
+ end
81
81
  end