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,89 +1,89 @@
1
- # frozen_string_literal: true
2
-
3
- require "find"
4
- require "pathname"
5
-
6
- # This module provides classes for the Makit gem.
7
- module Makit
8
- module Docs
9
- # This class provide methods for generating documentation
10
- # about source files and artifacts.
11
- #
12
- # docs/Files.md
13
- #
14
- #
15
- class Files
16
- def self.generate
17
- filename = "docs/Files.md"
18
- FileUtils.mkdir_p("docs")
19
- # overwrite the file if it exists
20
- FileUtils.rm_f(filename)
21
- File.open(filename, "w") do |file|
22
- file.write("# Files\n\n")
23
- file.write("A file summary for the project #{Makit::Git::Repository.get_remote_url}.\n\n")
24
-
25
- #
26
- # Tracked Files
27
- #
28
- # report on the file tracked by git.
29
- tracked_file_infos = Makit::Git::Repository.get_file_infos
30
-
31
- # first display the count and total size of the files tracked by git.
32
- file.write("## Tracked Files\n\n")
33
- file.write("#{tracked_file_infos.count} files with a total size of #{Makit::Humanize.get_humanized_size(tracked_file_infos.sum(&:size))}.\n\n")
34
-
35
- # next display a table of the 10 tracked files that have been modified recently.
36
- # ordered by last modified date, display the size, name, and last modified date.
37
- # leverage the humanize class to display the size in a human readable format.
38
- # leverage the humanize class to display the last modified date in a human readable format.
39
- file.write("The 10 files tracked by git that have been modified recently are:\n\n")
40
- file.write("| Size | Name | Last Modified Date |\n")
41
- file.write("|------|------|------------------|\n")
42
- tracked_file_infos.sort_by(&:mtime).reverse.first(10).each do |file_info|
43
- file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
44
- end
45
- file.write("\n")
46
-
47
- # next display a table or the largest 10 files tracked by git.
48
- # ordered by latest size first, display the size, name, and last modified date.
49
- # leverage the humanize class to display the size in a human readable format.
50
- # leverage the humanize class to display the last modified date in a human readable format.
51
- file.write("The 10 largest files tracked by git are:\n\n")
52
- file.write("| Size | Name | Last Modified Date |\n")
53
- file.write("|------|------|------------------|\n")
54
- tracked_file_infos.sort_by(&:size).reverse.first(10).each do |file_info|
55
- file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
56
- end
57
- file.write("\n")
58
-
59
- #
60
- # Untracked Files
61
- #
62
- # report on the files that are not tracked by git.
63
- untracked_file_infos = Makit::Git::Repository.get_untracked_file_infos
64
- # display the count and total size of the files that are not tracked by git.
65
- file.write("## Untracked Files\n\n")
66
- file.write("#{untracked_file_infos.count} files with a total size of #{Makit::Humanize.get_humanized_size(untracked_file_infos.sum(&:size))}.\n\n")
67
- # next display a table or the largest 10 files not tracked by git.
68
- # ordered by latest size first, display the size, name, and last modified date.
69
- # leverage the humanize class to display the size in a human readable format.
70
- # leverage the humanize class to display the last modified date in a human readable format.
71
- file.write("The 10 largest files not tracked by git are:\n\n")
72
- file.write("| Size | Name | Last Modified Date |\n")
73
- file.write("|------|------|------------------|\n")
74
- untracked_file_infos.sort_by(&:size).reverse.first(10).each do |file_info|
75
- file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
76
- end
77
- file.write("\n")
78
-
79
- #
80
- # Git Repository Size
81
- #
82
- ## report on the git repository size
83
- file.write(Makit::Commands::Runner.default.execute("git count-objects -vH").to_markdown)
84
- file.write("\n\n")
85
- end
86
- end
87
- end
88
- end
89
- end
1
+ # frozen_string_literal: true
2
+
3
+ require "find"
4
+ require "pathname"
5
+
6
+ # This module provides classes for the Makit gem.
7
+ module Makit
8
+ module Docs
9
+ # This class provide methods for generating documentation
10
+ # about source files and artifacts.
11
+ #
12
+ # docs/Files.md
13
+ #
14
+ #
15
+ class Files
16
+ def self.generate
17
+ filename = "docs/Files.md"
18
+ FileUtils.mkdir_p("docs")
19
+ # overwrite the file if it exists
20
+ FileUtils.rm_f(filename)
21
+ File.open(filename, "w") do |file|
22
+ file.write("# Files\n\n")
23
+ file.write("A file summary for the project #{Makit::Git::Repository.get_remote_url}.\n\n")
24
+
25
+ #
26
+ # Tracked Files
27
+ #
28
+ # report on the file tracked by git.
29
+ tracked_file_infos = Makit::Git::Repository.get_file_infos
30
+
31
+ # first display the count and total size of the files tracked by git.
32
+ file.write("## Tracked Files\n\n")
33
+ file.write("#{tracked_file_infos.count} files with a total size of #{Makit::Humanize.get_humanized_size(tracked_file_infos.sum(&:size))}.\n\n")
34
+
35
+ # next display a table of the 10 tracked files that have been modified recently.
36
+ # ordered by last modified date, display the size, name, and last modified date.
37
+ # leverage the humanize class to display the size in a human readable format.
38
+ # leverage the humanize class to display the last modified date in a human readable format.
39
+ file.write("The 10 files tracked by git that have been modified recently are:\n\n")
40
+ file.write("| Size | Name | Last Modified Date |\n")
41
+ file.write("|------|------|------------------|\n")
42
+ tracked_file_infos.sort_by(&:mtime).reverse.first(10).each do |file_info|
43
+ file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
44
+ end
45
+ file.write("\n")
46
+
47
+ # next display a table or the largest 10 files tracked by git.
48
+ # ordered by latest size first, display the size, name, and last modified date.
49
+ # leverage the humanize class to display the size in a human readable format.
50
+ # leverage the humanize class to display the last modified date in a human readable format.
51
+ file.write("The 10 largest files tracked by git are:\n\n")
52
+ file.write("| Size | Name | Last Modified Date |\n")
53
+ file.write("|------|------|------------------|\n")
54
+ tracked_file_infos.sort_by(&:size).reverse.first(10).each do |file_info|
55
+ file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
56
+ end
57
+ file.write("\n")
58
+
59
+ #
60
+ # Untracked Files
61
+ #
62
+ # report on the files that are not tracked by git.
63
+ untracked_file_infos = Makit::Git::Repository.get_untracked_file_infos
64
+ # display the count and total size of the files that are not tracked by git.
65
+ file.write("## Untracked Files\n\n")
66
+ file.write("#{untracked_file_infos.count} files with a total size of #{Makit::Humanize.get_humanized_size(untracked_file_infos.sum(&:size))}.\n\n")
67
+ # next display a table or the largest 10 files not tracked by git.
68
+ # ordered by latest size first, display the size, name, and last modified date.
69
+ # leverage the humanize class to display the size in a human readable format.
70
+ # leverage the humanize class to display the last modified date in a human readable format.
71
+ file.write("The 10 largest files not tracked by git are:\n\n")
72
+ file.write("| Size | Name | Last Modified Date |\n")
73
+ file.write("|------|------|------------------|\n")
74
+ untracked_file_infos.sort_by(&:size).reverse.first(10).each do |file_info|
75
+ file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
76
+ end
77
+ file.write("\n")
78
+
79
+ #
80
+ # Git Repository Size
81
+ #
82
+ ## report on the git repository size
83
+ file.write(Makit::Commands::Runner.default.execute("git count-objects -vH").to_markdown)
84
+ file.write("\n\n")
85
+ end
86
+ end
87
+ end
88
+ end
89
+ end
@@ -1,102 +1,102 @@
1
- # frozen_string_literal: true
2
-
3
- require "find"
4
- require "pathname"
5
-
6
- # This module provides classes for the Makit gem.
7
- module Makit
8
- module Docs
9
- # This class provide methods for generating documentation
10
- # about source files and artifacts.
11
- #
12
- # docs/Files.md
13
- #
14
- #
15
- class Rake
16
- def self.get_top_level_tasks
17
- ::Rake.application.top_level_tasks
18
- end
19
-
20
- def self.get_top_task_name
21
- get_top_level_tasks.first
22
- end
23
-
24
- def self.duration
25
- Time.now - Makit::STARTTIME
26
- end
27
-
28
- def self.start_time
29
- Makit::STARTTIME
30
- end
31
-
32
- # return a hash of name => value for properties of the rake execution
33
- def self.properties
34
- {
35
- "top_level_tasks" => get_top_level_tasks,
36
- # If global VERSION is defined, then add it to the properties (this is NOT the Makit::VERSION)
37
- "version" => (defined?(VERSION) ? VERSION : ""),
38
- "branch" => Makit::Git::Repository.branch,
39
- # add the current user name
40
- "user" => ENV.fetch("USER", nil),
41
- # add the current machine name
42
- "machine" => ENV.fetch("COMPUTERNAME", nil),
43
- # add the os name
44
- "os" => ENV.fetch("OS", nil),
45
- "duration" => Makit::Humanize.get_humanized_duration(duration),
46
- "start_time" => Makit::Humanize.get_humanized_timestamp(start_time),
47
- "source_file_count" => Makit::Git::Repository.get_file_infos.count,
48
- "source_file_size" => Makit::Humanize.get_humanized_size(Makit::Git::Repository.get_file_infos.sum(&:size)),
49
- "untracked_file_count" => Makit::Git::Repository.get_untracked_file_infos.count,
50
- "untracked_file_size" => Makit::Humanize.get_humanized_size(Makit::Git::Repository.get_untracked_file_infos.sum(&:size)),
51
- # express the ratio of untracked file size to tracked file size as a percentage
52
- "ratio_untracked_size_to_tracked_size" => ((Makit::Git::Repository.get_untracked_file_infos.sum(&:size) / Makit::Git::Repository.get_file_infos.sum(&:size)) * 100).to_i,
53
- }
54
- end
55
-
56
- def self.generate
57
- # if the top level tasks are of size 1, with the name "default",
58
- # then we will continue to generate the documentation.
59
- # otherwise, we will display a message and exit.
60
- if get_top_level_tasks.size != 1 || get_top_level_tasks.first != "default"
61
- puts " no top level tasks specified, skipping rake documentation generation".colorize(:yellow)
62
- return
63
- end
64
-
65
- content = ""
66
- # display: "Rake default completed in HUMANIZED_DURATION"
67
- content += "# Rake default\n\n"
68
-
69
- # display a table of the properties
70
- content += "## Properties\n\n"
71
- properties.each do |key, value|
72
- content += "| #{key} | #{value} |\n"
73
- end
74
- content += "\n\n"
75
-
76
- # display the completed tasks
77
- content += "## Completed Tasks\n\n"
78
- Makit::TaskInfo.completed_tasks.each do |task_name, task_info|
79
- content += "| #{task_name} | #{Makit::Humanize.get_humanized_duration(task_info[:duration])} |\n"
80
- end
81
- content += "\n\n"
82
-
83
- ## report on the available rake tasks
84
- content += Makit::Commands::Runner.default.execute("rake -T").to_markdown
85
- content += "\n\n"
86
-
87
- filename = "docs/Rake.md"
88
- FileUtils.mkdir_p("docs")
89
- # overwrite the file if it exists
90
- if File.exist?(filename)
91
- existing_content = File.read(filename)
92
- if existing_content != content
93
- File.delete(filename)
94
- File.write(filename, content)
95
- end
96
- else
97
- File.write(filename, content)
98
- end
99
- end
100
- end
101
- end
102
- end
1
+ # frozen_string_literal: true
2
+
3
+ require "find"
4
+ require "pathname"
5
+
6
+ # This module provides classes for the Makit gem.
7
+ module Makit
8
+ module Docs
9
+ # This class provide methods for generating documentation
10
+ # about source files and artifacts.
11
+ #
12
+ # docs/Files.md
13
+ #
14
+ #
15
+ class Rake
16
+ def self.get_top_level_tasks
17
+ ::Rake.application.top_level_tasks
18
+ end
19
+
20
+ def self.get_top_task_name
21
+ get_top_level_tasks.first
22
+ end
23
+
24
+ def self.duration
25
+ Time.now - Makit::STARTTIME
26
+ end
27
+
28
+ def self.start_time
29
+ Makit::STARTTIME
30
+ end
31
+
32
+ # return a hash of name => value for properties of the rake execution
33
+ def self.properties
34
+ {
35
+ "top_level_tasks" => get_top_level_tasks,
36
+ # If global VERSION is defined, then add it to the properties (this is NOT the Makit::VERSION)
37
+ "version" => (defined?(VERSION) ? VERSION : ""),
38
+ "branch" => Makit::Git::Repository.branch,
39
+ # add the current user name
40
+ "user" => ENV.fetch("USER", nil),
41
+ # add the current machine name
42
+ "machine" => ENV.fetch("COMPUTERNAME", nil),
43
+ # add the os name
44
+ "os" => ENV.fetch("OS", nil),
45
+ "duration" => Makit::Humanize.get_humanized_duration(duration),
46
+ "start_time" => Makit::Humanize.get_humanized_timestamp(start_time),
47
+ "source_file_count" => Makit::Git::Repository.get_file_infos.count,
48
+ "source_file_size" => Makit::Humanize.get_humanized_size(Makit::Git::Repository.get_file_infos.sum(&:size)),
49
+ "untracked_file_count" => Makit::Git::Repository.get_untracked_file_infos.count,
50
+ "untracked_file_size" => Makit::Humanize.get_humanized_size(Makit::Git::Repository.get_untracked_file_infos.sum(&:size)),
51
+ # express the ratio of untracked file size to tracked file size as a percentage
52
+ "ratio_untracked_size_to_tracked_size" => ((Makit::Git::Repository.get_untracked_file_infos.sum(&:size) / Makit::Git::Repository.get_file_infos.sum(&:size)) * 100).to_i,
53
+ }
54
+ end
55
+
56
+ def self.generate
57
+ # if the top level tasks are of size 1, with the name "default",
58
+ # then we will continue to generate the documentation.
59
+ # otherwise, we will display a message and exit.
60
+ if get_top_level_tasks.size != 1 || get_top_level_tasks.first != "default"
61
+ puts " no top level tasks specified, skipping rake documentation generation".colorize(:yellow)
62
+ return
63
+ end
64
+
65
+ content = ""
66
+ # display: "Rake default completed in HUMANIZED_DURATION"
67
+ content += "# Rake default\n\n"
68
+
69
+ # display a table of the properties
70
+ content += "## Properties\n\n"
71
+ properties.each do |key, value|
72
+ content += "| #{key} | #{value} |\n"
73
+ end
74
+ content += "\n\n"
75
+
76
+ # display the completed tasks
77
+ content += "## Completed Tasks\n\n"
78
+ Makit::TaskInfo.completed_tasks.each do |task_name, task_info|
79
+ content += "| #{task_name} | #{Makit::Humanize.get_humanized_duration(task_info[:duration])} |\n"
80
+ end
81
+ content += "\n\n"
82
+
83
+ ## report on the available rake tasks
84
+ content += Makit::Commands::Runner.default.execute("rake -T").to_markdown
85
+ content += "\n\n"
86
+
87
+ filename = "docs/Rake.md"
88
+ FileUtils.mkdir_p("docs")
89
+ # overwrite the file if it exists
90
+ if File.exist?(filename)
91
+ existing_content = File.read(filename)
92
+ if existing_content != content
93
+ File.delete(filename)
94
+ File.write(filename, content)
95
+ end
96
+ else
97
+ File.write(filename, content)
98
+ end
99
+ end
100
+ end
101
+ end
102
+ end