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.
Files changed (147) 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 +311 -320
  31. data/lib/makit/commands/middleware/validator.rb +269 -269
  32. data/lib/makit/commands/request.rb +316 -254
  33. data/lib/makit/commands/result.rb +323 -323
  34. data/lib/makit/commands/runner.rb +368 -337
  35. data/lib/makit/commands/strategies/base.rb +171 -160
  36. data/lib/makit/commands/strategies/synchronous.rb +139 -134
  37. data/lib/makit/commands.rb +50 -51
  38. data/lib/makit/configuration/gitlab_helper.rb +58 -60
  39. data/lib/makit/configuration/project.rb +167 -127
  40. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  41. data/lib/makit/configuration/step.rb +34 -34
  42. data/lib/makit/configuration.rb +14 -14
  43. data/lib/makit/content/default_gitignore.rb +7 -7
  44. data/lib/makit/content/default_gitignore.txt +226 -0
  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 +140 -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/cli.rb +69 -65
  54. data/lib/makit/dotnet/project.rb +217 -153
  55. data/lib/makit/dotnet/solution.rb +38 -38
  56. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  57. data/lib/makit/dotnet/solution_console.rb +264 -264
  58. data/lib/makit/dotnet/solution_maui.rb +354 -354
  59. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  60. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  61. data/lib/makit/dotnet.rb +102 -102
  62. data/lib/makit/email.rb +90 -90
  63. data/lib/makit/environment.rb +142 -142
  64. data/lib/makit/examples/runner.rb +370 -370
  65. data/lib/makit/exceptions.rb +45 -45
  66. data/lib/makit/fileinfo.rb +24 -24
  67. data/lib/makit/files.rb +43 -43
  68. data/lib/makit/gems.rb +40 -40
  69. data/lib/makit/git/cli.rb +54 -54
  70. data/lib/makit/git/repository.rb +90 -90
  71. data/lib/makit/git.rb +98 -98
  72. data/lib/makit/gitlab_runner.rb +59 -59
  73. data/lib/makit/humanize.rb +137 -137
  74. data/lib/makit/indexer.rb +47 -47
  75. data/lib/makit/logging/configuration.rb +308 -305
  76. data/lib/makit/logging/format_registry.rb +84 -84
  77. data/lib/makit/logging/formatters/base.rb +39 -39
  78. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  79. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  80. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  81. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  82. data/lib/makit/logging/log_request.rb +119 -115
  83. data/lib/makit/logging/logger.rb +199 -163
  84. data/lib/makit/logging/sinks/base.rb +91 -91
  85. data/lib/makit/logging/sinks/console.rb +72 -72
  86. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  87. data/lib/makit/logging/sinks/structured.rb +123 -129
  88. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -303
  89. data/lib/makit/logging.rb +565 -530
  90. data/lib/makit/markdown.rb +75 -75
  91. data/lib/makit/mp/basic_object_mp.rb +17 -17
  92. data/lib/makit/mp/command_mp.rb +13 -13
  93. data/lib/makit/mp/command_request.mp.rb +17 -17
  94. data/lib/makit/mp/project_mp.rb +199 -199
  95. data/lib/makit/mp/string_mp.rb +191 -193
  96. data/lib/makit/nuget.rb +74 -74
  97. data/lib/makit/port.rb +32 -32
  98. data/lib/makit/process.rb +163 -163
  99. data/lib/makit/protoc.rb +107 -107
  100. data/lib/makit/rake/cli.rb +196 -196
  101. data/lib/makit/rake.rb +25 -25
  102. data/lib/makit/ruby/cli.rb +185 -185
  103. data/lib/makit/ruby.rb +25 -25
  104. data/lib/makit/secrets.rb +51 -51
  105. data/lib/makit/serializer.rb +130 -130
  106. data/lib/makit/services/builder.rb +186 -186
  107. data/lib/makit/services/error_handler.rb +226 -226
  108. data/lib/makit/services/repository_manager.rb +231 -229
  109. data/lib/makit/services/validator.rb +112 -112
  110. data/lib/makit/setup/classlib.rb +94 -53
  111. data/lib/makit/setup/gem.rb +268 -263
  112. data/lib/makit/setup/razorclasslib.rb +91 -0
  113. data/lib/makit/setup/runner.rb +54 -45
  114. data/lib/makit/setup.rb +5 -5
  115. data/lib/makit/show.rb +110 -110
  116. data/lib/makit/storage.rb +126 -126
  117. data/lib/makit/symbols.rb +170 -170
  118. data/lib/makit/task_info.rb +128 -128
  119. data/lib/makit/tasks/at_exit.rb +15 -13
  120. data/lib/makit/tasks/build.rb +22 -19
  121. data/lib/makit/tasks/clean.rb +13 -11
  122. data/lib/makit/tasks/configure.rb +10 -0
  123. data/lib/makit/tasks/format.rb +10 -0
  124. data/lib/makit/tasks/hook_manager.rb +391 -393
  125. data/lib/makit/tasks/init.rb +49 -47
  126. data/lib/makit/tasks/integrate.rb +29 -17
  127. data/lib/makit/tasks/pull_incoming.rb +13 -11
  128. data/lib/makit/tasks/setup.rb +13 -6
  129. data/lib/makit/tasks/sync.rb +17 -12
  130. data/lib/makit/tasks/tag.rb +16 -15
  131. data/lib/makit/tasks/task_monkey_patch.rb +81 -79
  132. data/lib/makit/tasks/test.rb +22 -0
  133. data/lib/makit/tasks/update.rb +18 -0
  134. data/lib/makit/tasks.rb +20 -15
  135. data/lib/makit/test_cache.rb +239 -239
  136. data/lib/makit/tree.rb +37 -37
  137. data/lib/makit/v1/makit.v1_pb.rb +35 -34
  138. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  139. data/lib/makit/version.rb +5 -5
  140. data/lib/makit/version_util.rb +21 -21
  141. data/lib/makit/wix.rb +95 -95
  142. data/lib/makit/yaml.rb +29 -29
  143. data/lib/makit/zip.rb +17 -17
  144. data/lib/makit copy.rb +44 -44
  145. data/lib/makit.rb +39 -40
  146. metadata +69 -7
  147. data/lib/makit/commands/middleware/unified_logger.rb +0 -243
data/lib/makit/git.rb CHANGED
@@ -1,98 +1,98 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "git/repository"
4
- require_relative "git/cli"
5
-
6
- # This module provides classes for the Makit gem.
7
- module Makit
8
- # This class provides a unified interface for git operations.
9
- # Methods have been organized into Repository (state/metadata) and CLI (commands) classes.
10
- #
11
- class Git
12
- # Delegate repository state and metadata methods to Repository class
13
- def self.git_repo?
14
- Repository.git_repo?
15
- end
16
-
17
- def self.ci?
18
- Repository.ci?
19
- end
20
-
21
- def self.detached
22
- Repository.detached
23
- end
24
-
25
- def self.read_only?
26
- Repository.read_only?
27
- end
28
-
29
- def self.clean?
30
- Repository.clean?
31
- end
32
-
33
- def self.unstaged_files
34
- Repository.unstaged_files
35
- end
36
-
37
- def self.untracked_files
38
- Repository.untracked_files
39
- end
40
-
41
- def self.get_file_infos
42
- Repository.get_file_infos
43
- end
44
-
45
- def self.get_untracked_file_infos
46
- Repository.get_untracked_file_infos
47
- end
48
-
49
- def self.branch
50
- Repository.branch
51
- end
52
-
53
- def self.commitsha
54
- Repository.commitsha
55
- end
56
-
57
- def self.commitmsg
58
- Repository.commitmsg
59
- end
60
-
61
- def self.commitdate
62
- Repository.commitdate
63
- end
64
-
65
- def self.commitauthor
66
- Repository.commitauthor
67
- end
68
-
69
- def self.commitemail
70
- Repository.commitemail
71
- end
72
-
73
- def self.get_remote_url
74
- Repository.get_remote_url
75
- end
76
-
77
- # Delegate command execution methods to CLI class
78
- def self.integrate
79
- CLI.integrate
80
- end
81
-
82
- def self.sync
83
- CLI.sync
84
- end
85
-
86
- def self.pull
87
- CLI.pull
88
- end
89
-
90
- def self.zip_source_files(zipfilename)
91
- CLI.zip_source_files(zipfilename)
92
- end
93
-
94
- def self.tag(version)
95
- CLI.tag(version)
96
- end
97
- end
98
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "git/repository"
4
+ require_relative "git/cli"
5
+
6
+ # This module provides classes for the Makit gem.
7
+ module Makit
8
+ # This class provides a unified interface for git operations.
9
+ # Methods have been organized into Repository (state/metadata) and CLI (commands) classes.
10
+ #
11
+ class Git
12
+ # Delegate repository state and metadata methods to Repository class
13
+ def self.git_repo?
14
+ Repository.git_repo?
15
+ end
16
+
17
+ def self.ci?
18
+ Repository.ci?
19
+ end
20
+
21
+ def self.detached
22
+ Repository.detached
23
+ end
24
+
25
+ def self.read_only?
26
+ Repository.read_only?
27
+ end
28
+
29
+ def self.clean?
30
+ Repository.clean?
31
+ end
32
+
33
+ def self.unstaged_files
34
+ Repository.unstaged_files
35
+ end
36
+
37
+ def self.untracked_files
38
+ Repository.untracked_files
39
+ end
40
+
41
+ def self.get_file_infos
42
+ Repository.get_file_infos
43
+ end
44
+
45
+ def self.get_untracked_file_infos
46
+ Repository.get_untracked_file_infos
47
+ end
48
+
49
+ def self.branch
50
+ Repository.branch
51
+ end
52
+
53
+ def self.commitsha
54
+ Repository.commitsha
55
+ end
56
+
57
+ def self.commitmsg
58
+ Repository.commitmsg
59
+ end
60
+
61
+ def self.commitdate
62
+ Repository.commitdate
63
+ end
64
+
65
+ def self.commitauthor
66
+ Repository.commitauthor
67
+ end
68
+
69
+ def self.commitemail
70
+ Repository.commitemail
71
+ end
72
+
73
+ def self.get_remote_url
74
+ Repository.get_remote_url
75
+ end
76
+
77
+ # Delegate command execution methods to CLI class
78
+ def self.integrate
79
+ CLI.integrate
80
+ end
81
+
82
+ def self.sync
83
+ CLI.sync
84
+ end
85
+
86
+ def self.pull
87
+ CLI.pull
88
+ end
89
+
90
+ def self.zip_source_files(zipfilename)
91
+ CLI.zip_source_files(zipfilename)
92
+ end
93
+
94
+ def self.tag(version)
95
+ CLI.tag(version)
96
+ end
97
+ end
98
+ end
@@ -1,59 +1,59 @@
1
- # frozen_string_literal: true
2
-
3
- require "yaml"
4
- require "fileutils"
5
-
6
- # This module provides classes for the Makit gem.
7
- module Makit
8
- # This class provide methods for working with Directories/
9
- #
10
- # Example:
11
- #
12
- # Makit::Directory.find_directory_with_pattern("/home/user", "*.rb")
13
- #
14
- class GitLabRunner
15
- # Parse the .gitlab-ci.yml file
16
- def parse_gitlab_ci_file(file_path)
17
- YAML.load_file(file_path)
18
- end
19
-
20
- # Extract the script for a specified job
21
- def extract_script(ci_config, job_name)
22
- job = ci_config[job_name]
23
- job ? job["script"] : nil
24
- end
25
-
26
- # Write the script to a temporary file
27
- def write_script_to_file(script, file_path)
28
- File.open(file_path, "w") do |file|
29
- script.each { |line| file.puts(line) }
30
- end
31
- end
32
-
33
- # Run the script in a Docker container
34
- def run_script_in_docker(image, script_file)
35
- system("docker run --rm -v #{Dir.pwd}:/workspace -w /workspace #{image} /bin/sh #{script_file}")
36
- end
37
-
38
- # Main function to execute the process
39
- def run_job(ci_file_path, job_name, docker_image)
40
- ci_config = parse_gitlab_ci_file(ci_file_path)
41
- script = extract_script(ci_config, job_name)
42
-
43
- unless script
44
- puts "Job '#{job_name}' not found in #{ci_file_path}"
45
- return
46
- end
47
-
48
- script_file = "temp_script.sh"
49
- write_script_to_file(script, script_file)
50
- FileUtils.chmod("+x", script_file)
51
-
52
- puts "Running script in Docker container..."
53
- run_script_in_docker(docker_image, script_file)
54
-
55
- # Clean up the temporary script file
56
- FileUtils.rm(script_file)
57
- end
58
- end
59
- end
1
+ # frozen_string_literal: true
2
+
3
+ require "yaml"
4
+ require "fileutils"
5
+
6
+ # This module provides classes for the Makit gem.
7
+ module Makit
8
+ # This class provide methods for working with Directories/
9
+ #
10
+ # Example:
11
+ #
12
+ # Makit::Directory.find_directory_with_pattern("/home/user", "*.rb")
13
+ #
14
+ class GitLabRunner
15
+ # Parse the .gitlab-ci.yml file
16
+ def parse_gitlab_ci_file(file_path)
17
+ YAML.load_file(file_path)
18
+ end
19
+
20
+ # Extract the script for a specified job
21
+ def extract_script(ci_config, job_name)
22
+ job = ci_config[job_name]
23
+ job ? job["script"] : nil
24
+ end
25
+
26
+ # Write the script to a temporary file
27
+ def write_script_to_file(script, file_path)
28
+ File.open(file_path, "w") do |file|
29
+ script.each { |line| file.puts(line) }
30
+ end
31
+ end
32
+
33
+ # Run the script in a Docker container
34
+ def run_script_in_docker(image, script_file)
35
+ system("docker run --rm -v #{Dir.pwd}:/workspace -w /workspace #{image} /bin/sh #{script_file}")
36
+ end
37
+
38
+ # Main function to execute the process
39
+ def run_job(ci_file_path, job_name, docker_image)
40
+ ci_config = parse_gitlab_ci_file(ci_file_path)
41
+ script = extract_script(ci_config, job_name)
42
+
43
+ unless script
44
+ puts "Job '#{job_name}' not found in #{ci_file_path}"
45
+ return
46
+ end
47
+
48
+ script_file = "temp_script.sh"
49
+ write_script_to_file(script, script_file)
50
+ FileUtils.chmod("+x", script_file)
51
+
52
+ puts "Running script in Docker container..."
53
+ run_script_in_docker(docker_image, script_file)
54
+
55
+ # Clean up the temporary script file
56
+ FileUtils.rm(script_file)
57
+ end
58
+ end
59
+ end
@@ -1,137 +1,137 @@
1
- # frozen_string_literal: true
2
-
3
- # This module provides classes for the Makit gem.
4
- module Makit
5
- # Provides utilities for converting data into human-readable formats.
6
- #
7
- # This class handles formatting of file sizes, timestamps, durations,
8
- # and build result summaries for display to users.
9
- #
10
- # @example Basic usage
11
- # Makit::Humanize.get_humanized_size(1024) # => "1.00 KB"
12
- # Makit::Humanize.get_humanized_duration(3661) # => "1 hour, 1 minute, 1 second"
13
- #
14
- class Humanize
15
- def self.get_humanized_size(bytes, precision = 2)
16
- units = %w[B KB MB GB TB PB]
17
- return "0 B" if bytes.zero?
18
-
19
- exp = (Math.log(bytes) / Math.log(1024)).to_i
20
- exp = units.size - 1 if exp >= units.size
21
-
22
- size = bytes.to_f / (1024 ** exp)
23
- format("%.#{precision}f %s", size, units[exp])
24
- end
25
-
26
- def self.get_humanized_timestamp(timestamp)
27
- return timestamp.strftime("%Y-%m-%d %I:%M:%S %p") if timestamp.respond_to?(:strftime)
28
-
29
- timestamp.strftime("%Y-%m-%d %H:%M:%S")
30
- end
31
-
32
- def self.get_make_result_summary(make_result)
33
- summary = "Make Result\n"
34
- summary += " Repository: #{make_result.repository}\n"
35
- summary += " Commit: #{make_result.commit}\n"
36
- summary += " Branch: #{make_result.branch}\n"
37
- summary += " Tag: #{make_result.tag}\n"
38
- summary += " Device: #{make_result.device}\n"
39
- summary += " Runtime Identifier: #{make_result.runtime_identifier}\n"
40
- summary += " Initial Size: #{get_humanized_size(make_result.initial_size)}\n"
41
- summary += " Final Size: #{get_humanized_size(make_result.final_size)}\n"
42
- summary += " Delta Size: #{get_humanized_size(make_result.final_size - make_result.initial_size)}\n"
43
- summary += " Commands: (#{make_result.commands.length})\n"
44
- make_result.commands.each do |command|
45
- details = get_command_details(command)
46
- summary += "\n"
47
- summary += indent_string(details, 4)
48
- summary += "\n"
49
- end
50
-
51
- summary
52
- end
53
-
54
- def self.get_commands(commands)
55
- message = ""
56
- commands.each do |command|
57
- message += Makit::Humanize.get_command_details(command)
58
- end
59
- message
60
- end
61
-
62
- def self.get_command_summary(command)
63
- symbol = Makit::Symbols.warning
64
- symbol = Makit::Symbols.checkmark if !command.exit_code.nil? && command.exit_code.zero?
65
- symbol = Makit::Symbols.error if command.exit_code != 0
66
- "#{symbol} #{command.name} #{command.arguments.join(" ")}"
67
- end
68
-
69
- def self.get_command_details(command)
70
- summary = "#{get_command_summary(command)}\n"
71
- summary += " Name: #{command.name}\n"
72
- summary += " Arguments: #{command.arguments.join(" ")}\n"
73
- summary += " Directory: #{command.directory}\n"
74
- summary += " Exit Code: #{command.exit_code}\n"
75
- if command.output.length.positive?
76
- summary += " Output:\n"
77
- summary += indent_string(command.output, 4)
78
- summary += "\n"
79
- end
80
- if command.error.length.positive?
81
- summary += " Error:\n"
82
- summary += indent_string(command.error, 4)
83
- summary += "\n"
84
- end
85
- summary
86
- end
87
-
88
- def self.indent_string(string, spaces)
89
- string.split("\n").map { |line| (" " * spaces) + line }.join("\n")
90
- end
91
-
92
- def self.get_protobuf_timestamp(timestamp)
93
- Time.at(timestamp.seconds, timestamp.nanos / 1000.0).strftime("%Y-%m-%d %H:%M:%S")
94
- end
95
-
96
- def self.get_protobuf_duration(duration)
97
- total_seconds = duration.seconds + (duration.nanos / 1_000_000_000.0)
98
- hours = (total_seconds / 3600).to_i
99
- minutes = ((total_seconds % 3600) / 60).to_i
100
- seconds = (total_seconds % 60).round(2)
101
- "#{hours}h #{minutes}m #{seconds}s"
102
- end
103
-
104
- def self.get_humanized_duration(seconds_value)
105
- minutes = (seconds_value / 60).to_i
106
- seconds = (seconds_value % 60).to_i
107
- hours = (minutes / 60).to_i
108
- minutes %= 60
109
- days = (hours / 24).to_i
110
- hours %= 24
111
- milliseconds = (seconds_value % 1 * 1000).to_i
112
-
113
- parts = []
114
- parts << "#{days} days" if days.positive?
115
- parts << "#{hours} hours" if hours.positive?
116
- if minutes.positive?
117
- parts << if minutes == 1
118
- "1 minute"
119
- else
120
- "#{minutes} minutes"
121
- end
122
- end
123
- if seconds.positive?
124
- parts << if seconds == 1
125
- "1 second"
126
- else
127
- "#{seconds} seconds"
128
- end
129
- end
130
- # parts << "#{seconds} seconds" if seconds > 0
131
- parts << "#{milliseconds} milliseconds" if milliseconds.positive? && seconds < 1
132
-
133
- parts << "0 seconds" if parts.empty?
134
- parts.join(", ")
135
- end
136
- end
137
- end
1
+ # frozen_string_literal: true
2
+
3
+ # This module provides classes for the Makit gem.
4
+ module Makit
5
+ # Provides utilities for converting data into human-readable formats.
6
+ #
7
+ # This class handles formatting of file sizes, timestamps, durations,
8
+ # and build result summaries for display to users.
9
+ #
10
+ # @example Basic usage
11
+ # Makit::Humanize.get_humanized_size(1024) # => "1.00 KB"
12
+ # Makit::Humanize.get_humanized_duration(3661) # => "1 hour, 1 minute, 1 second"
13
+ #
14
+ class Humanize
15
+ def self.get_humanized_size(bytes, precision = 2)
16
+ units = %w[B KB MB GB TB PB]
17
+ return "0 B" if bytes.zero?
18
+
19
+ exp = (Math.log(bytes) / Math.log(1024)).to_i
20
+ exp = units.size - 1 if exp >= units.size
21
+
22
+ size = bytes.to_f / (1024 ** exp)
23
+ format("%.#{precision}f %s", size, units[exp])
24
+ end
25
+
26
+ def self.get_humanized_timestamp(timestamp)
27
+ return timestamp.strftime("%Y-%m-%d %I:%M:%S %p") if timestamp.respond_to?(:strftime)
28
+
29
+ timestamp.strftime("%Y-%m-%d %H:%M:%S")
30
+ end
31
+
32
+ def self.get_make_result_summary(make_result)
33
+ summary = "Make Result\n"
34
+ summary += " Repository: #{make_result.repository}\n"
35
+ summary += " Commit: #{make_result.commit}\n"
36
+ summary += " Branch: #{make_result.branch}\n"
37
+ summary += " Tag: #{make_result.tag}\n"
38
+ summary += " Device: #{make_result.device}\n"
39
+ summary += " Runtime Identifier: #{make_result.runtime_identifier}\n"
40
+ summary += " Initial Size: #{get_humanized_size(make_result.initial_size)}\n"
41
+ summary += " Final Size: #{get_humanized_size(make_result.final_size)}\n"
42
+ summary += " Delta Size: #{get_humanized_size(make_result.final_size - make_result.initial_size)}\n"
43
+ summary += " Commands: (#{make_result.commands.length})\n"
44
+ make_result.commands.each do |command|
45
+ details = get_command_details(command)
46
+ summary += "\n"
47
+ summary += indent_string(details, 4)
48
+ summary += "\n"
49
+ end
50
+
51
+ summary
52
+ end
53
+
54
+ def self.get_commands(commands)
55
+ message = ""
56
+ commands.each do |command|
57
+ message += Makit::Humanize.get_command_details(command)
58
+ end
59
+ message
60
+ end
61
+
62
+ def self.get_command_summary(command)
63
+ symbol = Makit::Symbols.warning
64
+ symbol = Makit::Symbols.checkmark if !command.exit_code.nil? && command.exit_code.zero?
65
+ symbol = Makit::Symbols.error if command.exit_code != 0
66
+ "#{symbol} #{command.name} #{command.arguments.join(" ")}"
67
+ end
68
+
69
+ def self.get_command_details(command)
70
+ summary = "#{get_command_summary(command)}\n"
71
+ summary += " Name: #{command.name}\n"
72
+ summary += " Arguments: #{command.arguments.join(" ")}\n"
73
+ summary += " Directory: #{command.directory}\n"
74
+ summary += " Exit Code: #{command.exit_code}\n"
75
+ if command.output.length.positive?
76
+ summary += " Output:\n"
77
+ summary += indent_string(command.output, 4)
78
+ summary += "\n"
79
+ end
80
+ if command.error.length.positive?
81
+ summary += " Error:\n"
82
+ summary += indent_string(command.error, 4)
83
+ summary += "\n"
84
+ end
85
+ summary
86
+ end
87
+
88
+ def self.indent_string(string, spaces)
89
+ string.split("\n").map { |line| (" " * spaces) + line }.join("\n")
90
+ end
91
+
92
+ def self.get_protobuf_timestamp(timestamp)
93
+ Time.at(timestamp.seconds, timestamp.nanos / 1000.0).strftime("%Y-%m-%d %H:%M:%S")
94
+ end
95
+
96
+ def self.get_protobuf_duration(duration)
97
+ total_seconds = duration.seconds + (duration.nanos / 1_000_000_000.0)
98
+ hours = (total_seconds / 3600).to_i
99
+ minutes = ((total_seconds % 3600) / 60).to_i
100
+ seconds = (total_seconds % 60).round(2)
101
+ "#{hours}h #{minutes}m #{seconds}s"
102
+ end
103
+
104
+ def self.get_humanized_duration(seconds_value)
105
+ minutes = (seconds_value / 60).to_i
106
+ seconds = (seconds_value % 60).to_i
107
+ hours = (minutes / 60).to_i
108
+ minutes %= 60
109
+ days = (hours / 24).to_i
110
+ hours %= 24
111
+ milliseconds = (seconds_value % 1 * 1000).to_i
112
+
113
+ parts = []
114
+ parts << "#{days} days" if days.positive?
115
+ parts << "#{hours} hours" if hours.positive?
116
+ if minutes.positive?
117
+ parts << if minutes == 1
118
+ "1 minute"
119
+ else
120
+ "#{minutes} minutes"
121
+ end
122
+ end
123
+ if seconds.positive?
124
+ parts << if seconds == 1
125
+ "1 second"
126
+ else
127
+ "#{seconds} seconds"
128
+ end
129
+ end
130
+ # parts << "#{seconds} seconds" if seconds > 0
131
+ parts << "#{milliseconds} milliseconds" if milliseconds.positive? && seconds < 1
132
+
133
+ parts << "0 seconds" if parts.empty?
134
+ parts.join(", ")
135
+ end
136
+ end
137
+ end