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
@@ -1,112 +1,112 @@
1
- # frozen_string_literal: true
2
-
3
- module Makit
4
- module Services
5
- # Service class responsible for validating all input parameters
6
- # Used by various Makit operations to ensure data integrity
7
- class Validator
8
- # Git-related validation constants
9
- COMMIT_HASH_LENGTH = 40
10
- COMMIT_LATEST = "latest"
11
- MAX_PAGINATION_LIMIT = 1000
12
- MAX_DIRECTORY_PATH_LENGTH = 255
13
-
14
- class << self
15
- # Validate directory parameter for initialization operations
16
- #
17
- # @param directory [String] the directory path to validate
18
- # @raise [ArgumentError] if directory parameter is invalid
19
- def validate_directory_parameter(directory)
20
- raise ArgumentError, "directory parameter cannot be nil" if directory.nil?
21
- raise ArgumentError, "directory parameter cannot be empty" if directory.to_s.strip.empty?
22
- raise ArgumentError, "directory path contains invalid characters" if directory.to_s.include?("\0")
23
- raise ArgumentError, "directory path is too long" if directory.to_s.length > MAX_DIRECTORY_PATH_LENGTH
24
- end
25
-
26
- # Validate URL parameter for git repository operations
27
- #
28
- # @param url [String] the repository URL to validate
29
- # @raise [ArgumentError] if URL parameter is invalid
30
- def validate_url_parameter(url)
31
- raise ArgumentError, "URL parameter cannot be nil" if url.nil?
32
- raise ArgumentError, "URL parameter cannot be empty" if url.to_s.strip.empty?
33
-
34
- url_str = url.to_s.strip
35
- # Basic URL format validation - accept git@, https://, http://, and simple names like "user/repo"
36
- valid_patterns = [
37
- %r{\Agit@[\w.-]+:[\w._/-]+\.git\z}, # SSH format: git@github.com:user/repo.git
38
- %r{\Ahttps?://[\w.-]+/[\w._/-]+(\.git)?\z}, # HTTPS format: https://github.com/user/repo
39
- %r{\A[\w.-]+/[\w._-]+\z}, # Simple format: user/repo
40
- ]
41
-
42
- return if valid_patterns.any? { |pattern| url_str.match?(pattern) }
43
-
44
- raise ArgumentError, "Invalid URL format: #{url_str}"
45
- end
46
-
47
- # Validate commit parameter for git operations
48
- #
49
- # @param commit [String] the commit hash or "latest" to validate
50
- # @raise [ArgumentError] if commit parameter is invalid
51
- def validate_commit_parameter(commit)
52
- raise ArgumentError, "commit parameter cannot be nil" if commit.nil?
53
-
54
- commit_str = commit.to_s.strip
55
- raise ArgumentError, "commit parameter cannot be empty" if commit_str.empty?
56
-
57
- # Allow "latest" or valid commit hash formats
58
- return if commit_str == COMMIT_LATEST
59
- return if commit_str.match?(/\A[0-9a-f]{7,#{COMMIT_HASH_LENGTH}}\z/i)
60
-
61
- raise ArgumentError, "Invalid commit format: #{commit_str}. Must be 'latest' or a valid git commit hash."
62
- end
63
-
64
- # Validate pagination parameters for log operations
65
- #
66
- # @param limit [Integer] maximum number of items to retrieve
67
- # @param skip [Integer] number of items to skip
68
- # @raise [ArgumentError] if pagination parameters are invalid
69
- def validate_pagination_parameters(limit, skip)
70
- unless limit.is_a?(Integer) && limit.positive?
71
- raise ArgumentError,
72
- "limit parameter must be a positive integer"
73
- end
74
- raise ArgumentError, "skip parameter must be a non-negative integer" unless skip.is_a?(Integer) && skip >= 0
75
- raise ArgumentError, "limit parameter is too large" if limit > MAX_PAGINATION_LIMIT
76
- end
77
-
78
- # Validate that a directory exists and is accessible
79
- #
80
- # @param directory [String] the directory path to check
81
- # @param description [String] human-readable description for error messages
82
- # @raise [Makit::DirectoryError] if directory doesn't exist or isn't accessible
83
- def validate_directory_exists(directory, description = "directory")
84
- return if Dir.exist?(directory)
85
-
86
- raise Makit::DirectoryError, "#{description} does not exist: #{directory}"
87
- end
88
-
89
- # Validate boolean parameters
90
- #
91
- # @param value [Object] the value to check
92
- # @param parameter_name [String] the parameter name for error messages
93
- # @raise [ArgumentError] if value is not boolean
94
- def validate_boolean_parameter(value, parameter_name)
95
- return if [true, false].include?(value)
96
-
97
- raise ArgumentError, "#{parameter_name} must be true or false, got #{value.class}"
98
- end
99
-
100
- # Validate string parameters that cannot be empty
101
- #
102
- # @param value [String] the string value to validate
103
- # @param parameter_name [String] the parameter name for error messages
104
- # @raise [ArgumentError] if string is nil or empty
105
- def validate_required_string(value, parameter_name)
106
- raise ArgumentError, "#{parameter_name} cannot be nil" if value.nil?
107
- raise ArgumentError, "#{parameter_name} cannot be empty" if value.to_s.strip.empty?
108
- end
109
- end
110
- end
111
- end
112
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Makit
4
+ module Services
5
+ # Service class responsible for validating all input parameters
6
+ # Used by various Makit operations to ensure data integrity
7
+ class Validator
8
+ # Git-related validation constants
9
+ COMMIT_HASH_LENGTH = 40
10
+ COMMIT_LATEST = "latest"
11
+ MAX_PAGINATION_LIMIT = 1000
12
+ MAX_DIRECTORY_PATH_LENGTH = 255
13
+
14
+ class << self
15
+ # Validate directory parameter for initialization operations
16
+ #
17
+ # @param directory [String] the directory path to validate
18
+ # @raise [ArgumentError] if directory parameter is invalid
19
+ def validate_directory_parameter(directory)
20
+ raise ArgumentError, "directory parameter cannot be nil" if directory.nil?
21
+ raise ArgumentError, "directory parameter cannot be empty" if directory.to_s.strip.empty?
22
+ raise ArgumentError, "directory path contains invalid characters" if directory.to_s.include?("\0")
23
+ raise ArgumentError, "directory path is too long" if directory.to_s.length > MAX_DIRECTORY_PATH_LENGTH
24
+ end
25
+
26
+ # Validate URL parameter for git repository operations
27
+ #
28
+ # @param url [String] the repository URL to validate
29
+ # @raise [ArgumentError] if URL parameter is invalid
30
+ def validate_url_parameter(url)
31
+ raise ArgumentError, "URL parameter cannot be nil" if url.nil?
32
+ raise ArgumentError, "URL parameter cannot be empty" if url.to_s.strip.empty?
33
+
34
+ url_str = url.to_s.strip
35
+ # Basic URL format validation - accept git@, https://, http://, and simple names like "user/repo"
36
+ valid_patterns = [
37
+ %r{\Agit@[\w.-]+:[\w._/-]+\.git\z}, # SSH format: git@github.com:user/repo.git
38
+ %r{\Ahttps?://[\w.-]+/[\w._/-]+(\.git)?\z}, # HTTPS format: https://github.com/user/repo
39
+ %r{\A[\w.-]+/[\w._-]+\z}, # Simple format: user/repo
40
+ ]
41
+
42
+ return if valid_patterns.any? { |pattern| url_str.match?(pattern) }
43
+
44
+ raise ArgumentError, "Invalid URL format: #{url_str}"
45
+ end
46
+
47
+ # Validate commit parameter for git operations
48
+ #
49
+ # @param commit [String] the commit hash or "latest" to validate
50
+ # @raise [ArgumentError] if commit parameter is invalid
51
+ def validate_commit_parameter(commit)
52
+ raise ArgumentError, "commit parameter cannot be nil" if commit.nil?
53
+
54
+ commit_str = commit.to_s.strip
55
+ raise ArgumentError, "commit parameter cannot be empty" if commit_str.empty?
56
+
57
+ # Allow "latest" or valid commit hash formats
58
+ return if commit_str == COMMIT_LATEST
59
+ return if commit_str.match?(/\A[0-9a-f]{7,#{COMMIT_HASH_LENGTH}}\z/i)
60
+
61
+ raise ArgumentError, "Invalid commit format: #{commit_str}. Must be 'latest' or a valid git commit hash."
62
+ end
63
+
64
+ # Validate pagination parameters for log operations
65
+ #
66
+ # @param limit [Integer] maximum number of items to retrieve
67
+ # @param skip [Integer] number of items to skip
68
+ # @raise [ArgumentError] if pagination parameters are invalid
69
+ def validate_pagination_parameters(limit, skip)
70
+ unless limit.is_a?(Integer) && limit.positive?
71
+ raise ArgumentError,
72
+ "limit parameter must be a positive integer"
73
+ end
74
+ raise ArgumentError, "skip parameter must be a non-negative integer" unless skip.is_a?(Integer) && skip >= 0
75
+ raise ArgumentError, "limit parameter is too large" if limit > MAX_PAGINATION_LIMIT
76
+ end
77
+
78
+ # Validate that a directory exists and is accessible
79
+ #
80
+ # @param directory [String] the directory path to check
81
+ # @param description [String] human-readable description for error messages
82
+ # @raise [Makit::DirectoryError] if directory doesn't exist or isn't accessible
83
+ def validate_directory_exists(directory, description = "directory")
84
+ return if Dir.exist?(directory)
85
+
86
+ raise Makit::DirectoryError, "#{description} does not exist: #{directory}"
87
+ end
88
+
89
+ # Validate boolean parameters
90
+ #
91
+ # @param value [Object] the value to check
92
+ # @param parameter_name [String] the parameter name for error messages
93
+ # @raise [ArgumentError] if value is not boolean
94
+ def validate_boolean_parameter(value, parameter_name)
95
+ return if [true, false].include?(value)
96
+
97
+ raise ArgumentError, "#{parameter_name} must be true or false, got #{value.class}"
98
+ end
99
+
100
+ # Validate string parameters that cannot be empty
101
+ #
102
+ # @param value [String] the string value to validate
103
+ # @param parameter_name [String] the parameter name for error messages
104
+ # @raise [ArgumentError] if string is nil or empty
105
+ def validate_required_string(value, parameter_name)
106
+ raise ArgumentError, "#{parameter_name} cannot be nil" if value.nil?
107
+ raise ArgumentError, "#{parameter_name} cannot be empty" if value.to_s.strip.empty?
108
+ end
109
+ end
110
+ end
111
+ end
112
+ end
@@ -1,101 +1,101 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "../configuration/project"
4
-
5
- module Makit
6
- module Setup
7
- class ClassLib
8
- def self.run
9
- # puts "Setting up Nuget project..."
10
- project = Makit::Configuration::Project.default
11
-
12
- dotnet_project_directory = "source/#{project.name}"
13
- dotnet_project = Makit::Configuration::DotNetProject.new
14
- dotnet_project.name = project.name
15
- dotnet_project.template = "classlib"
16
- dotnet_project.output_dir = dotnet_project_directory
17
- dotnet_project.frameworks = ["net8.0", "net8.0-browser"]
18
-
19
- project_filename = "source/#{project.name}/#{project.name}.csproj"
20
- if (!File.exist?(project_filename))
21
- Makit::DotNet::Project.new_project("classlib", project.name, "source/#{project.name}", "--framework net8.0")
22
- dotnet_project = Makit::DotNet::Project.new("source/#{project.name}/#{project.name}.csproj")
23
- # set the version to project.version
24
- dotnet_project.set_version(project.version)
25
- # set the frameworks = ["net8.0","net8.0-browser"]
26
- dotnet_project.set_target_frameworks(["net8.0", "net8.0-browser"])
27
- # set the nuget metadata
28
- dotnet_project.set_nuget_metadata(project.name, project.authors, project.description,
29
- project.license_expression)
30
- end
31
-
32
- test_project_filename = "tests/#{project.name}.Tests/#{project.name}.Tests.csproj"
33
- if (File.exist?(test_project_filename))
34
- Makit::DotNet::Project.new_project("TUnit", "#{project.name}.Tests", "tests/#{project.name}.Tests")
35
- dotnet_project = Makit::DotNet::Project.new("tests/#{project.name}.Tests/#{project.name}.Tests.csproj")
36
- # set the version to project.version
37
- dotnet_project.set_version(project.version)
38
- # set the frameworks = ["net8.0","net8.0-browser"]
39
- dotnet_project.set_target_frameworks(["net8.0"])
40
- # set the nuget metadata
41
- dotnet_project.set_nuget_metadata("#{project.name}.Tests", project.authors, project.description,
42
- project.license_expression)
43
- Makit::DotNet::Project.add_reference("tests/#{project.name}/#{project.name}.Tests.csproj",
44
- "source/#{project.name}/#{project.name}.csproj")
45
- end
46
- update_build_step(project)
47
- update_test_step(project)
48
-
49
- project.save
50
-
51
- # Setup the sln, then slnx
52
- if (!File.exist?("#{project.name}.slnx"))
53
- Makit::DotNet.new_solution(project.name)
54
- Makit::DotNet.sln_add_projects(project.name)
55
- # migrate the sln to slnx
56
- "dotnet sln migrate #{project.name}.sln".run
57
- FileUtils.rm_f("#{project.name}.sln") if File.exist?("#{project.name}.slnx")
58
- end
59
- Makit::Logging.default_logger.debug("Project setup completed")
60
- end
61
-
62
- def self.update_build_step(project)
63
- build_commands = []
64
- build_commands << "dotnet restore #{project.name}.slnx" if File.exist?("#{project.name}.slnx")
65
- build_commands << "dotnet build source/#{project.name}/#{project.name}.csproj --configuration Release"
66
- build_commands << "dotnet build tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release"
67
- build_commands << "dotnet pack source/#{project.name}/#{project.name}.csproj --configuration Release --output artifacts/Packages"
68
- build_commands << "dotnet pack tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release --output artifacts/Packages"
69
- steps = project.steps
70
- if steps.any? { |step| step.name == "build" }
71
- build_step = steps.find { |step| step.name == "build" }
72
- build_step.commands = build_commands
73
- else
74
- build_step = Makit::Configuration::Step.new(name: "build", description: "Build the project artifacts",
75
- commands: build_commands)
76
- build_step.commands = build_commands
77
- project.add_step(build_step)
78
- end
79
- build_step.commands = build_commands
80
-
81
- project.save
82
- end
83
-
84
- def self.update_test_step(project)
85
- test_commands = []
86
- test_commands << "dotnet test tests/#{project.name}/#{project.name}.Tests.csproj"
87
- steps = project.steps
88
- if steps.any? { |step| step.name == "test" }
89
- test_step = steps.find { |step| step.name == "test" }
90
- test_step.commands = test_commands
91
- else
92
- test_step = Makit::Configuration::Step.new(name: "test", description: "Run the project tests",
93
- commands: test_commands)
94
- test_step.commands = test_commands
95
- project.add_step(test_step)
96
- end
97
- project.save
98
- end
99
- end
100
- end
101
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../configuration/project"
4
+
5
+ module Makit
6
+ module Setup
7
+ class ClassLib
8
+ def self.run
9
+ # puts "Setting up Nuget project..."
10
+ project = Makit::Configuration::Project.default
11
+
12
+ dotnet_project_directory = "source/#{project.name}"
13
+ dotnet_project = Makit::Configuration::DotNetProject.new
14
+ dotnet_project.name = project.name
15
+ dotnet_project.template = "classlib"
16
+ dotnet_project.output_dir = dotnet_project_directory
17
+ dotnet_project.frameworks = ["net8.0", "net8.0-browser"]
18
+
19
+ project_filename = "source/#{project.name}/#{project.name}.csproj"
20
+ if (!File.exist?(project_filename))
21
+ Makit::DotNet::Project.new_project("classlib", project.name, "source/#{project.name}", "--framework net8.0")
22
+ dotnet_project = Makit::DotNet::Project.new("source/#{project.name}/#{project.name}.csproj")
23
+ # set the version to project.version
24
+ dotnet_project.set_version(project.version)
25
+ # set the frameworks = ["net8.0","net8.0-browser"]
26
+ dotnet_project.set_target_frameworks(["net8.0", "net8.0-browser"])
27
+ # set the nuget metadata
28
+ dotnet_project.set_nuget_metadata(project.name, project.authors, project.description,
29
+ project.license_expression)
30
+ end
31
+
32
+ test_project_filename = "tests/#{project.name}.Tests/#{project.name}.Tests.csproj"
33
+ if (File.exist?(test_project_filename))
34
+ Makit::DotNet::Project.new_project("TUnit", "#{project.name}.Tests", "tests/#{project.name}.Tests")
35
+ dotnet_project = Makit::DotNet::Project.new("tests/#{project.name}.Tests/#{project.name}.Tests.csproj")
36
+ # set the version to project.version
37
+ dotnet_project.set_version(project.version)
38
+ # set the frameworks = ["net8.0","net8.0-browser"]
39
+ dotnet_project.set_target_frameworks(["net8.0"])
40
+ # set the nuget metadata
41
+ dotnet_project.set_nuget_metadata("#{project.name}.Tests", project.authors, project.description,
42
+ project.license_expression)
43
+ Makit::DotNet::Project.add_reference("tests/#{project.name}/#{project.name}.Tests.csproj",
44
+ "source/#{project.name}/#{project.name}.csproj")
45
+ end
46
+ update_build_step(project)
47
+ update_test_step(project)
48
+
49
+ project.save
50
+
51
+ # Setup the sln, then slnx
52
+ if (!File.exist?("#{project.name}.slnx"))
53
+ Makit::DotNet.new_solution(project.name)
54
+ Makit::DotNet.sln_add_projects(project.name)
55
+ # migrate the sln to slnx
56
+ "dotnet sln migrate #{project.name}.sln".run
57
+ FileUtils.rm_f("#{project.name}.sln") if File.exist?("#{project.name}.slnx")
58
+ end
59
+ Makit::Logging.default_logger.debug("Project setup completed")
60
+ end
61
+
62
+ def self.update_build_step(project)
63
+ build_commands = []
64
+ build_commands << "dotnet restore #{project.name}.slnx" if File.exist?("#{project.name}.slnx")
65
+ build_commands << "dotnet build source/#{project.name}/#{project.name}.csproj --configuration Release"
66
+ build_commands << "dotnet build tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release"
67
+ build_commands << "dotnet pack source/#{project.name}/#{project.name}.csproj --configuration Release --output artifacts/Packages"
68
+ build_commands << "dotnet pack tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release --output artifacts/Packages"
69
+ steps = project.steps
70
+ if steps.any? { |step| step.name == "build" }
71
+ build_step = steps.find { |step| step.name == "build" }
72
+ build_step.commands = build_commands
73
+ else
74
+ build_step = Makit::Configuration::Step.new(name: "build", description: "Build the project artifacts",
75
+ commands: build_commands)
76
+ build_step.commands = build_commands
77
+ project.add_step(build_step)
78
+ end
79
+ build_step.commands = build_commands
80
+
81
+ project.save
82
+ end
83
+
84
+ def self.update_test_step(project)
85
+ test_commands = []
86
+ test_commands << "dotnet test tests/#{project.name}/#{project.name}.Tests.csproj"
87
+ steps = project.steps
88
+ if steps.any? { |step| step.name == "test" }
89
+ test_step = steps.find { |step| step.name == "test" }
90
+ test_step.commands = test_commands
91
+ else
92
+ test_step = Makit::Configuration::Step.new(name: "test", description: "Run the project tests",
93
+ commands: test_commands)
94
+ test_step.commands = test_commands
95
+ project.add_step(test_step)
96
+ end
97
+ project.save
98
+ end
99
+ end
100
+ end
101
+ end