makit 0.0.140 → 0.0.142

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 (153) 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 -69
  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 +203 -203
  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 +388 -385
  37. data/lib/makit/commands/strategies/base.rb +171 -171
  38. data/lib/makit/commands/strategies/child_process.rb +165 -165
  39. data/lib/makit/commands/strategies/factory.rb +136 -136
  40. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  41. data/lib/makit/commands.rb +50 -50
  42. data/lib/makit/configuration/dotnet_project.rb +12 -12
  43. data/lib/makit/configuration/gitlab_helper.rb +58 -58
  44. data/lib/makit/configuration/project.rb +168 -168
  45. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  46. data/lib/makit/configuration/step.rb +34 -34
  47. data/lib/makit/configuration/timeout.rb +74 -74
  48. data/lib/makit/configuration.rb +15 -15
  49. data/lib/makit/content/default_gitignore.rb +7 -7
  50. data/lib/makit/content/default_gitignore.txt +225 -225
  51. data/lib/makit/content/default_rakefile.rb +13 -13
  52. data/lib/makit/content/gem_rakefile.rb +16 -16
  53. data/lib/makit/context.rb +1 -1
  54. data/lib/makit/data.rb +49 -49
  55. data/lib/makit/directories.rb +140 -140
  56. data/lib/makit/directory.rb +262 -262
  57. data/lib/makit/docs/files.rb +89 -89
  58. data/lib/makit/docs/rake.rb +102 -102
  59. data/lib/makit/dotnet/cli.rb +69 -69
  60. data/lib/makit/dotnet/project.rb +217 -217
  61. data/lib/makit/dotnet/solution.rb +38 -38
  62. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  63. data/lib/makit/dotnet/solution_console.rb +264 -264
  64. data/lib/makit/dotnet/solution_maui.rb +354 -354
  65. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  66. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  67. data/lib/makit/dotnet.rb +102 -102
  68. data/lib/makit/email.rb +90 -90
  69. data/lib/makit/environment.rb +142 -142
  70. data/lib/makit/examples/runner.rb +370 -370
  71. data/lib/makit/exceptions.rb +45 -45
  72. data/lib/makit/fileinfo.rb +24 -24
  73. data/lib/makit/files.rb +43 -43
  74. data/lib/makit/gems.rb +40 -40
  75. data/lib/makit/git/cli.rb +54 -54
  76. data/lib/makit/git/repository.rb +90 -90
  77. data/lib/makit/git.rb +98 -98
  78. data/lib/makit/gitlab_runner.rb +59 -59
  79. data/lib/makit/humanize.rb +137 -137
  80. data/lib/makit/indexer.rb +47 -47
  81. data/lib/makit/logging/configuration.rb +308 -308
  82. data/lib/makit/logging/format_registry.rb +84 -84
  83. data/lib/makit/logging/formatters/base.rb +39 -39
  84. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  85. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  86. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  87. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  88. data/lib/makit/logging/log_request.rb +119 -119
  89. data/lib/makit/logging/logger.rb +199 -199
  90. data/lib/makit/logging/sinks/base.rb +91 -91
  91. data/lib/makit/logging/sinks/console.rb +72 -72
  92. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  93. data/lib/makit/logging/sinks/structured.rb +123 -123
  94. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  95. data/lib/makit/logging.rb +565 -565
  96. data/lib/makit/markdown.rb +75 -75
  97. data/lib/makit/mp/basic_object_mp.rb +17 -17
  98. data/lib/makit/mp/command_mp.rb +13 -13
  99. data/lib/makit/mp/command_request.mp.rb +17 -17
  100. data/lib/makit/mp/project_mp.rb +199 -199
  101. data/lib/makit/mp/string_mp.rb +199 -191
  102. data/lib/makit/nuget.rb +74 -74
  103. data/lib/makit/port.rb +32 -32
  104. data/lib/makit/process.rb +163 -163
  105. data/lib/makit/protoc.rb +107 -107
  106. data/lib/makit/rake/cli.rb +196 -196
  107. data/lib/makit/rake/trace_controller.rb +173 -173
  108. data/lib/makit/rake.rb +80 -80
  109. data/lib/makit/ruby/cli.rb +185 -185
  110. data/lib/makit/ruby.rb +25 -25
  111. data/lib/makit/secrets.rb +51 -51
  112. data/lib/makit/serializer.rb +130 -130
  113. data/lib/makit/services/builder.rb +186 -186
  114. data/lib/makit/services/error_handler.rb +226 -226
  115. data/lib/makit/services/repository_manager.rb +231 -231
  116. data/lib/makit/services/validator.rb +112 -112
  117. data/lib/makit/setup/classlib.rb +101 -101
  118. data/lib/makit/setup/gem.rb +268 -268
  119. data/lib/makit/setup/razorclasslib.rb +101 -101
  120. data/lib/makit/setup/runner.rb +54 -54
  121. data/lib/makit/setup.rb +5 -5
  122. data/lib/makit/show.rb +110 -110
  123. data/lib/makit/storage.rb +126 -126
  124. data/lib/makit/symbols.rb +170 -170
  125. data/lib/makit/task_info.rb +130 -130
  126. data/lib/makit/tasks/at_exit.rb +15 -15
  127. data/lib/makit/tasks/build.rb +22 -22
  128. data/lib/makit/tasks/clean.rb +13 -13
  129. data/lib/makit/tasks/configure.rb +10 -10
  130. data/lib/makit/tasks/format.rb +10 -10
  131. data/lib/makit/tasks/hook_manager.rb +443 -443
  132. data/lib/makit/tasks/init.rb +49 -49
  133. data/lib/makit/tasks/integrate.rb +29 -29
  134. data/lib/makit/tasks/pull_incoming.rb +13 -13
  135. data/lib/makit/tasks/setup.rb +13 -13
  136. data/lib/makit/tasks/sync.rb +17 -17
  137. data/lib/makit/tasks/tag.rb +16 -16
  138. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  139. data/lib/makit/tasks/test.rb +22 -22
  140. data/lib/makit/tasks/update.rb +18 -18
  141. data/lib/makit/tasks.rb +20 -20
  142. data/lib/makit/test_cache.rb +239 -239
  143. data/lib/makit/tree.rb +37 -37
  144. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  145. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  146. data/lib/makit/version.rb +99 -99
  147. data/lib/makit/version_util.rb +21 -21
  148. data/lib/makit/wix.rb +95 -95
  149. data/lib/makit/yaml.rb +29 -29
  150. data/lib/makit/zip.rb +17 -17
  151. data/lib/makit copy.rb +44 -44
  152. data/lib/makit.rb +43 -42
  153. metadata +2 -2
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