makit 0.0.99 → 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 (152) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +41 -0
  3. data/exe/makit +5 -0
  4. data/lib/makit/apache.rb +28 -32
  5. data/lib/makit/cli/build_commands.rb +500 -0
  6. data/lib/makit/cli/generators/base_generator.rb +74 -0
  7. data/lib/makit/cli/generators/dotnet_generator.rb +50 -0
  8. data/lib/makit/cli/generators/generator_factory.rb +49 -0
  9. data/lib/makit/cli/generators/node_generator.rb +50 -0
  10. data/lib/makit/cli/generators/ruby_generator.rb +77 -0
  11. data/lib/makit/cli/generators/rust_generator.rb +50 -0
  12. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -0
  13. data/lib/makit/cli/generators/templates/node_templates.rb +161 -0
  14. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -0
  15. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -0
  16. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -0
  17. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -0
  18. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -0
  19. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -0
  20. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -0
  21. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -0
  22. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -0
  23. data/lib/makit/cli/main.rb +62 -33
  24. data/lib/makit/cli/project_commands.rb +868 -0
  25. data/lib/makit/cli/repository_commands.rb +661 -0
  26. data/lib/makit/cli/utility_commands.rb +521 -0
  27. data/lib/makit/commands/factory.rb +359 -0
  28. data/lib/makit/commands/middleware/base.rb +73 -0
  29. data/lib/makit/commands/middleware/cache.rb +248 -0
  30. data/lib/makit/commands/middleware/command_logger.rb +320 -0
  31. data/lib/makit/commands/middleware/unified_logger.rb +243 -0
  32. data/lib/makit/commands/middleware/validator.rb +269 -0
  33. data/lib/makit/commands/request.rb +254 -0
  34. data/lib/makit/commands/result.rb +323 -0
  35. data/lib/makit/commands/runner.rb +337 -0
  36. data/lib/makit/commands/strategies/base.rb +160 -0
  37. data/lib/makit/commands/strategies/synchronous.rb +134 -0
  38. data/lib/makit/commands.rb +51 -21
  39. data/lib/makit/configuration/gitlab_helper.rb +60 -0
  40. data/lib/makit/configuration/project.rb +127 -0
  41. data/lib/makit/configuration/rakefile_helper.rb +43 -0
  42. data/lib/makit/configuration/step.rb +34 -0
  43. data/lib/makit/configuration.rb +14 -0
  44. data/lib/makit/content/default_gitignore.rb +7 -5
  45. data/lib/makit/content/default_rakefile.rb +13 -11
  46. data/lib/makit/content/gem_rakefile.rb +16 -14
  47. data/lib/makit/context.rb +1 -0
  48. data/lib/makit/data.rb +49 -50
  49. data/lib/makit/directories.rb +141 -145
  50. data/lib/makit/directory.rb +262 -276
  51. data/lib/makit/docs/files.rb +89 -94
  52. data/lib/makit/docs/rake.rb +102 -106
  53. data/lib/makit/dotnet/cli.rb +65 -0
  54. data/lib/makit/dotnet/project.rb +153 -0
  55. data/lib/makit/dotnet/solution.rb +38 -0
  56. data/lib/makit/dotnet/solution_classlib.rb +239 -0
  57. data/lib/makit/dotnet/solution_console.rb +264 -0
  58. data/lib/makit/dotnet/solution_maui.rb +354 -0
  59. data/lib/makit/dotnet/solution_wasm.rb +275 -0
  60. data/lib/makit/dotnet/solution_wpf.rb +304 -0
  61. data/lib/makit/dotnet.rb +102 -219
  62. data/lib/makit/email.rb +90 -61
  63. data/lib/makit/environment.rb +142 -139
  64. data/lib/makit/examples/runner.rb +370 -0
  65. data/lib/makit/exceptions.rb +45 -0
  66. data/lib/makit/fileinfo.rb +24 -26
  67. data/lib/makit/files.rb +43 -47
  68. data/lib/makit/gems.rb +29 -28
  69. data/lib/makit/git/cli.rb +54 -0
  70. data/lib/makit/git/repository.rb +90 -0
  71. data/lib/makit/git.rb +98 -145
  72. data/lib/makit/gitlab_runner.rb +59 -60
  73. data/lib/makit/humanize.rb +137 -129
  74. data/lib/makit/indexer.rb +47 -56
  75. data/lib/makit/logging/configuration.rb +305 -0
  76. data/lib/makit/logging/format_registry.rb +84 -0
  77. data/lib/makit/logging/formatters/base.rb +39 -0
  78. data/lib/makit/logging/formatters/console_formatter.rb +140 -0
  79. data/lib/makit/logging/formatters/json_formatter.rb +65 -0
  80. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -0
  81. data/lib/makit/logging/formatters/text_formatter.rb +64 -0
  82. data/lib/makit/logging/log_request.rb +115 -0
  83. data/lib/makit/logging/logger.rb +163 -0
  84. data/lib/makit/logging/sinks/base.rb +91 -0
  85. data/lib/makit/logging/sinks/console.rb +72 -0
  86. data/lib/makit/logging/sinks/file_sink.rb +92 -0
  87. data/lib/makit/logging/sinks/structured.rb +129 -0
  88. data/lib/makit/logging/sinks/unified_file_sink.rb +303 -0
  89. data/lib/makit/logging.rb +530 -106
  90. data/lib/makit/markdown.rb +75 -75
  91. data/lib/makit/mp/basic_object_mp.rb +17 -16
  92. data/lib/makit/mp/command_mp.rb +13 -13
  93. data/lib/makit/mp/command_request.mp.rb +17 -16
  94. data/lib/makit/mp/project_mp.rb +199 -210
  95. data/lib/makit/mp/string_mp.rb +193 -176
  96. data/lib/makit/nuget.rb +74 -72
  97. data/lib/makit/port.rb +32 -34
  98. data/lib/makit/process.rb +163 -65
  99. data/lib/makit/protoc.rb +107 -104
  100. data/lib/makit/rake/cli.rb +196 -0
  101. data/lib/makit/rake.rb +25 -25
  102. data/lib/makit/ruby/cli.rb +185 -0
  103. data/lib/makit/ruby.rb +25 -0
  104. data/lib/makit/secrets.rb +51 -51
  105. data/lib/makit/serializer.rb +130 -115
  106. data/lib/makit/services/builder.rb +186 -0
  107. data/lib/makit/services/error_handler.rb +226 -0
  108. data/lib/makit/services/repository_manager.rb +229 -0
  109. data/lib/makit/services/validator.rb +112 -0
  110. data/lib/makit/setup/classlib.rb +53 -0
  111. data/lib/makit/setup/gem.rb +263 -0
  112. data/lib/makit/setup/runner.rb +45 -0
  113. data/lib/makit/setup.rb +5 -0
  114. data/lib/makit/show.rb +110 -110
  115. data/lib/makit/storage.rb +126 -131
  116. data/lib/makit/symbols.rb +170 -149
  117. data/lib/makit/task_info.rb +128 -86
  118. data/lib/makit/tasks/at_exit.rb +13 -0
  119. data/lib/makit/tasks/build.rb +19 -0
  120. data/lib/makit/tasks/clean.rb +11 -0
  121. data/lib/makit/tasks/hook_manager.rb +393 -0
  122. data/lib/makit/tasks/init.rb +47 -0
  123. data/lib/makit/tasks/integrate.rb +17 -0
  124. data/lib/makit/tasks/pull_incoming.rb +11 -0
  125. data/lib/makit/tasks/setup.rb +6 -0
  126. data/lib/makit/tasks/sync.rb +12 -0
  127. data/lib/makit/tasks/tag.rb +15 -0
  128. data/lib/makit/tasks/task_monkey_patch.rb +79 -0
  129. data/lib/makit/tasks.rb +15 -150
  130. data/lib/makit/test_cache.rb +239 -0
  131. data/lib/makit/tree.rb +37 -37
  132. data/lib/makit/v1/makit.v1_pb.rb +3 -4
  133. data/lib/makit/v1/makit.v1_services_pb.rb +27 -25
  134. data/lib/makit/version.rb +5 -61
  135. data/lib/makit/version_util.rb +21 -0
  136. data/lib/makit/wix.rb +95 -95
  137. data/lib/makit/yaml.rb +29 -17
  138. data/lib/makit/zip.rb +17 -17
  139. data/lib/makit copy.rb +44 -0
  140. data/lib/makit.rb +40 -267
  141. metadata +117 -110
  142. data/lib/makit/cli/clean.rb +0 -14
  143. data/lib/makit/cli/clone.rb +0 -59
  144. data/lib/makit/cli/init.rb +0 -38
  145. data/lib/makit/cli/make.rb +0 -54
  146. data/lib/makit/cli/new.rb +0 -37
  147. data/lib/makit/cli/nuget_cache.rb +0 -38
  148. data/lib/makit/cli/pull.rb +0 -31
  149. data/lib/makit/cli/setup.rb +0 -71
  150. data/lib/makit/cli/work.rb +0 -21
  151. data/lib/makit/command_runner.rb +0 -404
  152. data/lib/makit/content/default_gitignore.txt +0 -222
@@ -1,94 +1,89 @@
1
- # frozen_string_literal: true
2
-
3
- require "find"
4
- require "pathname"
5
- #require "gitignore"
6
-
7
- # This module provides classes for the Makit gem.
8
- module Makit
9
- module Docs
10
- # This class provide methods for generating documentation
11
- # about source files and artifacts.
12
- #
13
- # docs/Files.md
14
- #
15
- #
16
- class Files
17
- def self.generate
18
- filename = "docs/Files.md"
19
- if !Dir.exist?("docs")
20
- Dir.mkdir("docs")
21
- end
22
- # overwrite the file if it exists
23
- if File.exist?(filename)
24
- File.delete(filename)
25
- end
26
- File.open(filename, "w") do |file|
27
- file.write("# Files\n\n")
28
- file.write("A file summary for the project #{Makit::Git::get_remote_url}.\n\n")
29
-
30
- #
31
- # Tracked Files
32
- #
33
- # report on the file tracked by git.
34
- tracked_file_infos = Makit::Git::get_file_infos
35
-
36
- # first display the count and total size of the files tracked by git.
37
- file.write("## Tracked Files\n\n")
38
- file.write("#{tracked_file_infos.count} files with a total size of #{Makit::Humanize.get_humanized_size(tracked_file_infos.sum(&:size))}.\n\n")
39
-
40
- # next display a table of the 10 tracked files that have been modified recently.
41
- # ordered by last modified date, display the size, name, and last modified date.
42
- # leverage the humanize class to display the size in a human readable format.
43
- # leverage the humanize class to display the last modified date in a human readable format.
44
- file.write("The 10 files tracked by git that have been modified recently are:\n\n")
45
- file.write("| Size | Name | Last Modified Date |\n")
46
- file.write("|------|------|------------------|\n")
47
- tracked_file_infos.sort_by(&:mtime).reverse.first(10).each do |file_info|
48
- file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
49
- end
50
- file.write("\n")
51
-
52
- # next display a table or the largest 10 files tracked by git.
53
- # ordered by latest size first, display the size, name, and last modified date.
54
- # leverage the humanize class to display the size in a human readable format.
55
- # leverage the humanize class to display the last modified date in a human readable format.
56
- file.write("The 10 largest files tracked by git are:\n\n")
57
- file.write("| Size | Name | Last Modified Date |\n")
58
- file.write("|------|------|------------------|\n")
59
- tracked_file_infos.sort_by(&:size).reverse.first(10).each do |file_info|
60
- file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
61
- end
62
- file.write("\n")
63
-
64
- #
65
- # Untracked Files
66
- #
67
- # report on the files that are not tracked by git.
68
- untracked_file_infos = Makit::Git::get_untracked_file_infos
69
- # display the count and total size of the files that are not tracked by git.
70
- file.write("## Untracked Files\n\n")
71
- file.write("#{untracked_file_infos.count} files with a total size of #{Makit::Humanize.get_humanized_size(untracked_file_infos.sum(&:size))}.\n\n")
72
- # next display a table or the largest 10 files not tracked by git.
73
- # ordered by latest size first, display the size, name, and last modified date.
74
- # leverage the humanize class to display the size in a human readable format.
75
- # leverage the humanize class to display the last modified date in a human readable format.
76
- file.write("The 10 largest files not tracked by git are:\n\n")
77
- file.write("| Size | Name | Last Modified Date |\n")
78
- file.write("|------|------|------------------|\n")
79
- untracked_file_infos.sort_by(&:size).reverse.first(10).each do |file_info|
80
- file.write("| #{Makit::Humanize.get_humanized_size(file_info.size)} | #{file_info.name} | #{Makit::Humanize.get_humanized_timestamp(file_info.mtime)} |\n")
81
- end
82
- file.write("\n")
83
-
84
- #
85
- # Git Repository Size
86
- #
87
- ## report on the git repository size
88
- file.write(Makit::RUNNER.execute("git count-objects -vH").to_markdown)
89
- file.write("\n\n")
90
- end
91
- end
92
- end
93
- end
94
- 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,106 +1,102 @@
1
- # frozen_string_literal: true
2
-
3
- require "find"
4
- require "pathname"
5
- #require "gitignore"
6
-
7
- # This module provides classes for the Makit gem.
8
- module Makit
9
- module Docs
10
- # This class provide methods for generating documentation
11
- # about source files and artifacts.
12
- #
13
- # docs/Files.md
14
- #
15
- #
16
- class Rake
17
- def self.get_top_level_tasks
18
- ::Rake.application.top_level_tasks
19
- end
20
-
21
- def self.get_top_task_name
22
- self.get_top_level_tasks.first
23
- end
24
-
25
- def self.duration
26
- Time.now - Makit::STARTTIME
27
- end
28
-
29
- def self.start_time
30
- Makit::STARTTIME
31
- end
32
-
33
- # return a hash of name => value for properties of the rake execution
34
- def self.properties
35
- {
36
- "top_level_tasks" => self.get_top_level_tasks,
37
- # If global VERSION is defined, then add it to the properties (this is NOT the Makit::VERSION)
38
- "version" => (defined?(VERSION) ? VERSION : ""),
39
- "branch" => Makit::Git.branch,
40
- # add the current user name
41
- "user" => ENV["USER"],
42
- # add the current machine name
43
- "machine" => ENV["COMPUTERNAME"],
44
- # add the os name
45
- "os" => ENV["OS"],
46
- "duration" => Makit::Humanize.get_humanized_duration(self.duration),
47
- "start_time" => Makit::Humanize.get_humanized_timestamp(self.start_time),
48
- "source_file_count" => Makit::Git.get_file_infos.count,
49
- "source_file_size" => Makit::Humanize.get_humanized_size(Makit::Git.get_file_infos.sum(&:size)),
50
- "untracked_file_count" => Makit::Git.get_untracked_file_infos.count,
51
- "untracked_file_size" => Makit::Humanize.get_humanized_size(Makit::Git.get_untracked_file_infos.sum(&:size)),
52
- # express the ratio of untracked file size to tracked file size as a percentage
53
- "ratio_untracked_size_to_tracked_size" => ((Makit::Git.get_untracked_file_infos.sum(&:size) / Makit::Git.get_file_infos.sum(&:size)) * 100).to_i,
54
- }
55
- end
56
-
57
- def self.generate
58
-
59
- # if the top level tasks are of size 1, with the name "default",
60
- # then we will continue to generate the documentation.
61
- # otherwise, we will display a message and exit.
62
- if self.get_top_level_tasks.size != 1 || self.get_top_level_tasks.first != "default"
63
- puts " no top level tasks specified, skipping rake documentation generation".colorize(:yellow)
64
- return
65
- end
66
-
67
- content = ""
68
- # display: "Rake default completed in HUMANIZED_DURATION"
69
- content += "# Rake default\n\n"
70
-
71
- # display a table of the properties
72
- content += "## Properties\n\n"
73
- self.properties.each do |key, value|
74
- content += "| #{key} | #{value} |\n"
75
- end
76
- content += "\n\n"
77
-
78
- # display the completed tasks
79
- content += "## Completed Tasks\n\n"
80
- Makit::TaskInfo.completed_tasks.each do |task_name, task_info|
81
- content += "| #{task_name} | #{Makit::Humanize.get_humanized_duration(task_info[:duration])} |\n"
82
- end
83
- content += "\n\n"
84
-
85
- ## report on the available rake tasks
86
- content += Makit::RUNNER.execute("rake -T").to_markdown
87
- content += "\n\n"
88
-
89
- filename = "docs/Rake.md"
90
- if !Dir.exist?("docs")
91
- Dir.mkdir("docs")
92
- end
93
- # overwrite the file if it exists
94
- if File.exist?(filename)
95
- existing_content = File.read(filename)
96
- if existing_content != content
97
- File.delete(filename)
98
- File.write(filename, content)
99
- end
100
- else
101
- File.write(filename, content)
102
- end
103
- end
104
- end
105
- end
106
- 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
@@ -0,0 +1,65 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Makit
4
+ class DotNet
5
+ class CLI
6
+ def self.new_solution(name)
7
+ if File.exist? "#{name}.sln"
8
+ # puts "Solution #{name}.sln already exists".colorize(:yellow)
9
+ else
10
+ "dotnet new sln --name #{name}".run
11
+ end
12
+ end
13
+
14
+ def self.sln_add_projects(sln_name)
15
+ raise "Solution #{sln_name}.sln does not exist" unless File.exist? "#{sln_name}.sln"
16
+
17
+ sln_path = "#{sln_name}.sln"
18
+ sln_content = File.read(sln_path)
19
+ Dir.glob("**/*.csproj").each do |project_path|
20
+ project_name = File.basename(project_path, ".csproj")
21
+ if sln_content.include?("\"#{project_name}\"")
22
+ # puts " #{project_name}".colorize(:green) + " is in ".colorize(:grey) + "#{sln_path}".colorize(:green)
23
+ else
24
+ "dotnet sln #{sln_path} add #{project_path}".run
25
+ end
26
+ end
27
+ end
28
+
29
+ #
30
+ # generate docs/DotNet.md
31
+ #
32
+ def self.generate_docs
33
+ content = "# DotNet\n\n"
34
+ content += "## Projects\n\n"
35
+ # scan for .csproj files in src directory
36
+ src_projects = Dir.glob("src/**/*.csproj")
37
+ src_projects.each do |project_path|
38
+ File.basename(project_path, ".csproj")
39
+ # "dotnet tool update --global dotnet-aspnet-codegenerator".run
40
+ # "dotnet aspnet-codegenerator controller --name #{project_name}Controller --output ~/Projects/makit/src/makit/Controllers --controllerName #{project_name}Controller --useAsyncActions --relativeFolderPath Controllers".run
41
+ end
42
+ content += "## Packages\n\n"
43
+ # scan for packages.config files in src directory
44
+ src_packages = Dir.glob("src/**/packages.config")
45
+ src_packages.each do |packages_path|
46
+ File.basename(packages_path, ".packages.config")
47
+ end
48
+ content += "## References\n\n"
49
+ # scan for project.json files in src directory
50
+ src_references = Dir.glob("src/**/project.json")
51
+ src_references.each do |references_path|
52
+ File.basename(references_path, ".project.json")
53
+ end
54
+
55
+ # write content to docs/DotNet.md file
56
+ if File.exist?("docs/DotNet.md")
57
+ existing_content = File.read("docs/DotNet.md")
58
+ File.write("docs/DotNet.md", content) if existing_content != content
59
+ else
60
+ File.write("docs/DotNet.md", content)
61
+ end
62
+ end
63
+ end
64
+ end
65
+ end
@@ -0,0 +1,153 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Makit
4
+ class DotNet
5
+ class Project
6
+ def self.is_installed?
7
+ File.exist?(Makit::Environment.which("dotnet"))
8
+ end
9
+
10
+ def self.installed?
11
+ is_installed?
12
+ end
13
+
14
+ def self.version
15
+ `dotnet --version`
16
+ end
17
+
18
+ def self.project_short_name(project_path)
19
+ File.basename(project_path, ".csproj")
20
+ end
21
+
22
+ def self.new_project(template, name, output, args = "")
23
+ if Dir.exist? output
24
+ Makit::Logging.default_logger.info("#{output}/#{name}.csproj")
25
+ #puts " .csproj ".colorize(:grey) + name.to_s.colorize(:green)
26
+ else
27
+ "dotnet new #{template} --name #{name} --output #{output} #{args}".run
28
+ end
29
+ end
30
+
31
+ def self.set_project_target_framework(project_hint, target_framework)
32
+ project_path = find_project(project_hint)
33
+ project_content = File.read(project_path)
34
+ project_content.gsub!(%r{<TargetFramework>.*</TargetFramework>},
35
+ "<TargetFramework>#{target_framework}</TargetFramework>")
36
+ File.write(project_path, project_content)
37
+ end
38
+
39
+ def self.find_project(project_hint)
40
+ matches = []
41
+ Dir.glob("**/*.csproj").each do |project_path|
42
+ matches << project_path if project_path.include?(project_hint)
43
+ end
44
+ if matches.length == 1
45
+ return matches.first
46
+ elsif matches.length > 1
47
+ raise "Multiple projects found matching #{project_hint}".colorize(:red)
48
+ end
49
+
50
+ raise "No project found matching #{project_hint}".colorize(:red)
51
+ end
52
+
53
+ def self.add_package(project_path, package_name)
54
+ unless File.exist?(project_path)
55
+ actual_project_path = Makit::DotNet::Project.find_project(project_path)
56
+ raise "Project #{project_path} does not exist".colorize(:red) unless File.exist?(actual_project_path)
57
+
58
+ project_path = actual_project_path
59
+ end
60
+
61
+ project_content = File.read(project_path)
62
+ if project_content.include?("\"#{package_name}\"")
63
+ puts " package ".colorize(:grey) + package_name.to_s.colorize(:green)
64
+ else
65
+ "dotnet add #{project_path} package #{package_name}".run
66
+ end
67
+ end
68
+
69
+ def self.add_packages(project_path, packages)
70
+ packages.each do |package|
71
+ add_package(project_path, package)
72
+ end
73
+ end
74
+
75
+ def self.add_reference(project_path, reference_path)
76
+ unless File.exist?(project_path)
77
+ actual_project_path = Makit::DotNet::Project.find_project(project_path)
78
+ raise "Project #{project_path} does not exist".colorize(:red) unless File.exist?(actual_project_path)
79
+
80
+ project_path = actual_project_path
81
+ end
82
+
83
+ unless File.exist?(reference_path)
84
+ actual_reference_path = Makit::DotNet::Project.find_project(reference_path)
85
+ raise "Project #{reference_path} does not exist".colorize(:red) unless File.exist?(actual_reference_path)
86
+
87
+ reference_path = actual_reference_path
88
+ end
89
+
90
+ project_content = File.read(project_path)
91
+ if project_content.include?(File.basename(reference_path))
92
+ #puts " reference ".colorize(:grey) + reference_path.to_s.colorize(:green)
93
+ else
94
+ "dotnet add #{project_path} reference #{reference_path}".run
95
+ end
96
+ end
97
+
98
+ def self.add_references(project_path, references)
99
+ references.each do |reference|
100
+ add_reference(project_path, reference)
101
+ end
102
+ end
103
+
104
+ def self.build(project_path, configuration = "Release", output = "artifacts")
105
+ project_dir = File.dirname(project_path)
106
+ newest_file = Makit::Directory.get_newest_file(project_dir)
107
+ command_request = Makit::Commands::Runner.default.parse_command_request("dotnet build #{project_path} --configuration #{configuration} --output #{output}")
108
+ newest_file_date = if newest_file.nil?
109
+ Time.now
110
+ else
111
+ File.mtime(newest_file)
112
+ end
113
+ RUNNER.cache_run(command_request, newest_file_date)
114
+ end
115
+
116
+ def self.publish(project_path, configuration = "Release", output = "artifacts")
117
+ project_dir = File.dirname(project_path)
118
+ newest_file = Makit::Directory.get_newest_file(project_dir)
119
+ command_request = Makit::Commands::Runner.default.parse_command_request("dotnet publish #{project_path} --configuration #{configuration} --output #{output}")
120
+ newest_file_date = if newest_file.nil?
121
+ Time.now
122
+ else
123
+ File.mtime(newest_file)
124
+ end
125
+ RUNNER.cache_run(command_request, newest_file_date)
126
+ end
127
+
128
+ def self.test(project_path, configuration = "Release", output = "artifacts")
129
+ project_dir = File.dirname(project_path)
130
+ newest_file = Makit::Directory.get_newest_file(project_dir)
131
+ command_request = Makit::Commands::Runner.default.parse_command_request("dotnet test #{project_path} --configuration #{configuration} --output #{output}")
132
+ newest_file_date = if newest_file.nil?
133
+ Time.now
134
+ else
135
+ File.mtime(newest_file)
136
+ end
137
+ RUNNER.cache_run(command_request, newest_file_date)
138
+ end
139
+
140
+ def self.format_project(project_path)
141
+ File.basename(project_path, ".csproj")
142
+ "dotnet tool update --global dotnet-format".run
143
+ "dotnet format #{project_path}".run
144
+ end
145
+
146
+ def self.upgrade_project(project_path)
147
+ File.basename(project_path, ".csproj")
148
+ "dotnet tool install --global dotnet-outdated-tool".run
149
+ "dotnet outdated #{project_path} --upgrade:Auto".run
150
+ end
151
+ end
152
+ end
153
+ end