makit 0.0.111 → 0.0.112

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 (140) 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/cli/build_commands.rb +500 -500
  6. data/lib/makit/cli/generators/base_generator.rb +74 -74
  7. data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
  8. data/lib/makit/cli/generators/generator_factory.rb +49 -49
  9. data/lib/makit/cli/generators/node_generator.rb +50 -50
  10. data/lib/makit/cli/generators/ruby_generator.rb +77 -77
  11. data/lib/makit/cli/generators/rust_generator.rb +50 -50
  12. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
  13. data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
  14. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
  15. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -40
  16. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
  17. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
  18. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
  19. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
  20. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
  21. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
  22. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
  23. data/lib/makit/cli/main.rb +62 -62
  24. data/lib/makit/cli/project_commands.rb +868 -868
  25. data/lib/makit/cli/repository_commands.rb +661 -661
  26. data/lib/makit/cli/utility_commands.rb +521 -521
  27. data/lib/makit/commands/factory.rb +359 -359
  28. data/lib/makit/commands/middleware/base.rb +73 -73
  29. data/lib/makit/commands/middleware/cache.rb +248 -248
  30. data/lib/makit/commands/middleware/command_logger.rb +320 -323
  31. data/lib/makit/commands/middleware/unified_logger.rb +243 -243
  32. data/lib/makit/commands/middleware/validator.rb +269 -269
  33. data/lib/makit/commands/request.rb +254 -254
  34. data/lib/makit/commands/result.rb +323 -323
  35. data/lib/makit/commands/runner.rb +337 -317
  36. data/lib/makit/commands/strategies/base.rb +160 -160
  37. data/lib/makit/commands/strategies/synchronous.rb +134 -134
  38. data/lib/makit/commands.rb +51 -42
  39. data/lib/makit/configuration/gitlab_helper.rb +60 -60
  40. data/lib/makit/configuration/project.rb +127 -127
  41. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  42. data/lib/makit/configuration/step.rb +34 -34
  43. data/lib/makit/configuration.rb +14 -14
  44. data/lib/makit/content/default_gitignore.rb +7 -7
  45. data/lib/makit/content/default_rakefile.rb +13 -13
  46. data/lib/makit/content/gem_rakefile.rb +16 -16
  47. data/lib/makit/context.rb +1 -1
  48. data/lib/makit/data.rb +49 -49
  49. data/lib/makit/directories.rb +141 -141
  50. data/lib/makit/directory.rb +262 -262
  51. data/lib/makit/docs/files.rb +89 -89
  52. data/lib/makit/docs/rake.rb +102 -102
  53. data/lib/makit/dotnet/project.rb +153 -153
  54. data/lib/makit/dotnet/solution.rb +38 -38
  55. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  56. data/lib/makit/dotnet/solution_console.rb +264 -264
  57. data/lib/makit/dotnet/solution_maui.rb +354 -354
  58. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  59. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  60. data/lib/makit/dotnet.rb +102 -102
  61. data/lib/makit/email.rb +90 -90
  62. data/lib/makit/environment.rb +142 -142
  63. data/lib/makit/examples/runner.rb +370 -370
  64. data/lib/makit/exceptions.rb +45 -45
  65. data/lib/makit/fileinfo.rb +24 -24
  66. data/lib/makit/files.rb +43 -43
  67. data/lib/makit/gems.rb +40 -40
  68. data/lib/makit/git/cli.rb +54 -54
  69. data/lib/makit/git/repository.rb +90 -90
  70. data/lib/makit/git.rb +98 -98
  71. data/lib/makit/gitlab_runner.rb +59 -59
  72. data/lib/makit/humanize.rb +137 -137
  73. data/lib/makit/indexer.rb +47 -47
  74. data/lib/makit/logging/configuration.rb +305 -305
  75. data/lib/makit/logging/formatters/base.rb +39 -39
  76. data/lib/makit/logging/formatters/console_formatter.rb +140 -127
  77. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  78. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  79. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  80. data/lib/makit/logging/log_request.rb +115 -115
  81. data/lib/makit/logging/logger.rb +163 -159
  82. data/lib/makit/logging/sinks/console.rb +72 -72
  83. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  84. data/lib/makit/logging/sinks/unified_file_sink.rb +303 -303
  85. data/lib/makit/logging.rb +530 -521
  86. data/lib/makit/markdown.rb +75 -75
  87. data/lib/makit/mp/basic_object_mp.rb +17 -17
  88. data/lib/makit/mp/command_mp.rb +13 -13
  89. data/lib/makit/mp/command_request.mp.rb +17 -17
  90. data/lib/makit/mp/project_mp.rb +199 -199
  91. data/lib/makit/mp/string_mp.rb +193 -348
  92. data/lib/makit/nuget.rb +74 -74
  93. data/lib/makit/port.rb +32 -32
  94. data/lib/makit/process.rb +163 -163
  95. data/lib/makit/protoc.rb +107 -107
  96. data/lib/makit/rake/cli.rb +196 -196
  97. data/lib/makit/rake.rb +25 -25
  98. data/lib/makit/ruby/cli.rb +185 -185
  99. data/lib/makit/ruby.rb +25 -25
  100. data/lib/makit/secrets.rb +51 -51
  101. data/lib/makit/serializer.rb +130 -117
  102. data/lib/makit/services/builder.rb +186 -186
  103. data/lib/makit/services/error_handler.rb +226 -226
  104. data/lib/makit/services/repository_manager.rb +229 -229
  105. data/lib/makit/services/validator.rb +112 -112
  106. data/lib/makit/setup/classlib.rb +53 -53
  107. data/lib/makit/setup/gem.rb +30 -17
  108. data/lib/makit/setup/runner.rb +45 -40
  109. data/lib/makit/setup.rb +5 -0
  110. data/lib/makit/show.rb +110 -110
  111. data/lib/makit/storage.rb +126 -126
  112. data/lib/makit/symbols.rb +170 -161
  113. data/lib/makit/task_info.rb +128 -128
  114. data/lib/makit/tasks/at_exit.rb +13 -13
  115. data/lib/makit/tasks/build.rb +19 -18
  116. data/lib/makit/tasks/clean.rb +11 -11
  117. data/lib/makit/tasks/hook_manager.rb +393 -239
  118. data/lib/makit/tasks/init.rb +47 -47
  119. data/lib/makit/tasks/integrate.rb +17 -15
  120. data/lib/makit/tasks/pull_incoming.rb +11 -12
  121. data/lib/makit/tasks/setup.rb +6 -6
  122. data/lib/makit/tasks/sync.rb +12 -11
  123. data/lib/makit/tasks/tag.rb +15 -0
  124. data/lib/makit/tasks/task_monkey_patch.rb +79 -79
  125. data/lib/makit/tasks.rb +10 -0
  126. data/lib/makit/test_cache.rb +239 -239
  127. data/lib/makit/tree.rb +37 -37
  128. data/lib/makit/v1/makit.v1_pb.rb +34 -34
  129. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  130. data/lib/makit/version.rb +5 -5
  131. data/lib/makit/version_util.rb +21 -0
  132. data/lib/makit/wix.rb +95 -95
  133. data/lib/makit/yaml.rb +29 -29
  134. data/lib/makit/zip.rb +17 -17
  135. data/lib/makit copy.rb +44 -0
  136. data/lib/makit.rb +40 -8
  137. metadata +50 -7
  138. data/lib/makit/command_runner.rb +0 -463
  139. data/lib/makit/commands/compatibility.rb +0 -365
  140. data/lib/makit/task_hooks.rb +0 -125
@@ -1,64 +1,64 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "base"
4
-
5
- module Makit
6
- module Logging
7
- module Formatters
8
- # Text formatter with timestamp and log level
9
- #
10
- # Formats log requests as human-readable text with timestamp, log level,
11
- # and message. This is the most common format for traditional log files.
12
- #
13
- # @example
14
- # formatter = TextFormatter.new
15
- # formatted = formatter.format(log_request)
16
- # # => '[2024-01-15 10:30:45] INFO User logged in'
17
- class TextFormatter < Base
18
- # @return [String] timestamp format string
19
- attr_reader :timestamp_format
20
- # @return [Boolean] whether to include context in output
21
- attr_reader :include_context
22
-
23
- # Initialize text formatter
24
- #
25
- # @param timestamp_format [String] strftime format for timestamps
26
- # @param include_context [Boolean] whether to include context in output
27
- def initialize(timestamp_format: "%Y-%m-%d %H:%M:%S", include_context: false)
28
- @timestamp_format = timestamp_format
29
- @include_context = include_context
30
- end
31
-
32
- # Format log request as text
33
- #
34
- # @param log_request [LogRequest] the log request to format
35
- # @return [String] text formatted log entry
36
- def format(log_request)
37
- timestamp = log_request.timestamp.strftime(@timestamp_format)
38
- level = log_request.level.to_s.upcase
39
- message = log_request.message
40
-
41
- formatted = "[#{timestamp}] #{level} #{message}"
42
-
43
- # Add context if enabled and present
44
- if @include_context && !log_request.context.empty?
45
- context_str = log_request.context.map { |k, v| "#{k}=#{v}" }.join(" ")
46
- formatted += " #{context_str}"
47
- end
48
-
49
- formatted
50
- end
51
-
52
- # Get formatter configuration
53
- #
54
- # @return [Hash] formatter configuration
55
- def config
56
- super.merge(
57
- timestamp_format: @timestamp_format,
58
- include_context: @include_context,
59
- )
60
- end
61
- end
62
- end
63
- end
64
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "base"
4
+
5
+ module Makit
6
+ module Logging
7
+ module Formatters
8
+ # Text formatter with timestamp and log level
9
+ #
10
+ # Formats log requests as human-readable text with timestamp, log level,
11
+ # and message. This is the most common format for traditional log files.
12
+ #
13
+ # @example
14
+ # formatter = TextFormatter.new
15
+ # formatted = formatter.format(log_request)
16
+ # # => '[2024-01-15 10:30:45] INFO User logged in'
17
+ class TextFormatter < Base
18
+ # @return [String] timestamp format string
19
+ attr_reader :timestamp_format
20
+ # @return [Boolean] whether to include context in output
21
+ attr_reader :include_context
22
+
23
+ # Initialize text formatter
24
+ #
25
+ # @param timestamp_format [String] strftime format for timestamps
26
+ # @param include_context [Boolean] whether to include context in output
27
+ def initialize(timestamp_format: "%Y-%m-%d %H:%M:%S", include_context: false)
28
+ @timestamp_format = timestamp_format
29
+ @include_context = include_context
30
+ end
31
+
32
+ # Format log request as text
33
+ #
34
+ # @param log_request [LogRequest] the log request to format
35
+ # @return [String] text formatted log entry
36
+ def format(log_request)
37
+ timestamp = log_request.timestamp.strftime(@timestamp_format)
38
+ level = log_request.level.to_s.upcase
39
+ message = log_request.message
40
+
41
+ formatted = "[#{timestamp}] #{level} #{message}"
42
+
43
+ # Add context if enabled and present
44
+ if @include_context && !log_request.context.empty?
45
+ context_str = log_request.context.map { |k, v| "#{k}=#{v}" }.join(" ")
46
+ formatted += " #{context_str}"
47
+ end
48
+
49
+ formatted
50
+ end
51
+
52
+ # Get formatter configuration
53
+ #
54
+ # @return [Hash] formatter configuration
55
+ def config
56
+ super.merge(
57
+ timestamp_format: @timestamp_format,
58
+ include_context: @include_context,
59
+ )
60
+ end
61
+ end
62
+ end
63
+ end
64
+ end
@@ -1,115 +1,115 @@
1
- # frozen_string_literal: true
2
-
3
- module Makit
4
- module Logging
5
- # Represents a log request that flows through the logging middleware chain
6
- #
7
- # This class encapsulates all the information needed for a log entry,
8
- # including the log level, message, context, and metadata. It provides
9
- # a clean interface for middleware to process and modify log information.
10
- #
11
- # @example Basic usage
12
- # request = LogRequest.new(:info, "Processing started")
13
- # request.add_metadata(process_id: 12345)
14
- # puts request.to_h
15
- #
16
- # @example With context
17
- # request = LogRequest.new(:error, "Build failed", {
18
- # repository: "user/repo",
19
- # commit: "abc123"
20
- # })
21
- class LogRequest
22
- # @return [Symbol] the log level (:debug, :info, :warn, :error, :fatal, :success)
23
- attr_reader :level
24
-
25
- # @return [String] the log message
26
- attr_reader :message
27
-
28
- # @return [Hash] additional context information
29
- attr_reader :context
30
-
31
- # @return [Hash] metadata about the log entry
32
- attr_reader :metadata
33
-
34
- # @return [Time] when the log request was created
35
- attr_reader :timestamp
36
-
37
- # Initialize a new log request
38
- #
39
- # @param level [Symbol] the log level
40
- # @param message [String] the log message
41
- # @param context [Hash] additional context information
42
- def initialize(level, message, context = {})
43
- @level = level
44
- @message = message
45
- @context = context.dup
46
- @metadata = {}
47
- @timestamp = Time.now
48
- end
49
-
50
- # Add metadata to the log request
51
- #
52
- # @param data [Hash] metadata to add
53
- # @return [void]
54
- def add_metadata(data)
55
- @metadata.merge!(data)
56
- end
57
-
58
- # Convert the log request to a hash representation
59
- #
60
- # @return [Hash] hash representation of the log request
61
- def to_h
62
- {
63
- level: @level,
64
- message: @message,
65
- context: @context,
66
- metadata: @metadata,
67
- timestamp: @timestamp.iso8601,
68
- }
69
- end
70
-
71
- # Convert the log request to a JSON string
72
- #
73
- # @return [String] JSON representation of the log request
74
- def to_json
75
- require "json"
76
- JSON.generate(to_h)
77
- end
78
-
79
- # Get a formatted string representation
80
- #
81
- # @return [String] formatted string representation
82
- def to_s
83
- "[#{@timestamp.strftime("%Y-%m-%d %H:%M:%S")}] #{@level.to_s.upcase}: #{@message}"
84
- end
85
-
86
- # Check if this is an error level log
87
- #
88
- # @return [Boolean] true if error level
89
- def error?
90
- @level == :error || @level == :fatal
91
- end
92
-
93
- # Check if this is a success level log
94
- #
95
- # @return [Boolean] true if success level
96
- def success?
97
- @level == :success
98
- end
99
-
100
- # Check if this is an info level log
101
- #
102
- # @return [Boolean] true if info level
103
- def info?
104
- @level == :info
105
- end
106
-
107
- # Check if this is a warning level log
108
- #
109
- # @return [Boolean] true if warn level
110
- def warn?
111
- @level == :warn
112
- end
113
- end
114
- end
115
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Makit
4
+ module Logging
5
+ # Represents a log request that flows through the logging middleware chain
6
+ #
7
+ # This class encapsulates all the information needed for a log entry,
8
+ # including the log level, message, context, and metadata. It provides
9
+ # a clean interface for middleware to process and modify log information.
10
+ #
11
+ # @example Basic usage
12
+ # request = LogRequest.new(:info, "Processing started")
13
+ # request.add_metadata(process_id: 12345)
14
+ # puts request.to_h
15
+ #
16
+ # @example With context
17
+ # request = LogRequest.new(:error, "Build failed", {
18
+ # repository: "user/repo",
19
+ # commit: "abc123"
20
+ # })
21
+ class LogRequest
22
+ # @return [Symbol] the log level (:debug, :info, :warn, :error, :fatal, :success)
23
+ attr_reader :level
24
+
25
+ # @return [String] the log message
26
+ attr_reader :message
27
+
28
+ # @return [Hash] additional context information
29
+ attr_reader :context
30
+
31
+ # @return [Hash] metadata about the log entry
32
+ attr_reader :metadata
33
+
34
+ # @return [Time] when the log request was created
35
+ attr_reader :timestamp
36
+
37
+ # Initialize a new log request
38
+ #
39
+ # @param level [Symbol] the log level
40
+ # @param message [String] the log message
41
+ # @param context [Hash] additional context information
42
+ def initialize(level, message, context = {})
43
+ @level = level
44
+ @message = message
45
+ @context = context.dup
46
+ @metadata = {}
47
+ @timestamp = Time.now
48
+ end
49
+
50
+ # Add metadata to the log request
51
+ #
52
+ # @param data [Hash] metadata to add
53
+ # @return [void]
54
+ def add_metadata(data)
55
+ @metadata.merge!(data)
56
+ end
57
+
58
+ # Convert the log request to a hash representation
59
+ #
60
+ # @return [Hash] hash representation of the log request
61
+ def to_h
62
+ {
63
+ level: @level,
64
+ message: @message,
65
+ context: @context,
66
+ metadata: @metadata,
67
+ timestamp: @timestamp.iso8601,
68
+ }
69
+ end
70
+
71
+ # Convert the log request to a JSON string
72
+ #
73
+ # @return [String] JSON representation of the log request
74
+ def to_json
75
+ require "json"
76
+ JSON.generate(to_h)
77
+ end
78
+
79
+ # Get a formatted string representation
80
+ #
81
+ # @return [String] formatted string representation
82
+ def to_s
83
+ "[#{@timestamp.strftime("%Y-%m-%d %H:%M:%S")}] #{@level.to_s.upcase}: #{@message}"
84
+ end
85
+
86
+ # Check if this is an error level log
87
+ #
88
+ # @return [Boolean] true if error level
89
+ def error?
90
+ @level == :error || @level == :fatal
91
+ end
92
+
93
+ # Check if this is a success level log
94
+ #
95
+ # @return [Boolean] true if success level
96
+ def success?
97
+ @level == :success
98
+ end
99
+
100
+ # Check if this is an info level log
101
+ #
102
+ # @return [Boolean] true if info level
103
+ def info?
104
+ @level == :info
105
+ end
106
+
107
+ # Check if this is a warning level log
108
+ #
109
+ # @return [Boolean] true if warn level
110
+ def warn?
111
+ @level == :warn
112
+ end
113
+ end
114
+ end
115
+ end