makit 0.0.1 → 0.0.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (81) hide show
  1. checksums.yaml +4 -4
  2. data/lib/makit/apache.rb +32 -32
  3. data/lib/makit/cli/clean.rb +14 -14
  4. data/lib/makit/cli/clone.rb +59 -59
  5. data/lib/makit/cli/init.rb +38 -38
  6. data/lib/makit/cli/main.rb +33 -33
  7. data/lib/makit/cli/make.rb +54 -54
  8. data/lib/makit/cli/new.rb +37 -37
  9. data/lib/makit/cli/nuget_cache.rb +38 -38
  10. data/lib/makit/cli/pull.rb +31 -31
  11. data/lib/makit/cli/setup.rb +71 -71
  12. data/lib/makit/cli/work.rb +21 -21
  13. data/lib/makit/command_runner.rb +318 -237
  14. data/lib/makit/commands.rb +21 -21
  15. data/lib/makit/content/default_gitignore.rb +5 -5
  16. data/lib/makit/content/default_rakefile.rb +11 -11
  17. data/lib/makit/content/gem_rakefile.rb +14 -14
  18. data/lib/makit/data.rb +50 -50
  19. data/lib/makit/directories.rb +140 -140
  20. data/lib/makit/directory.rb +153 -120
  21. data/lib/makit/dotnet.rb +83 -75
  22. data/lib/makit/environment.rb +123 -123
  23. data/lib/makit/files.rb +47 -47
  24. data/lib/makit/git.rb +66 -66
  25. data/lib/makit/gitlab_runner.rb +60 -60
  26. data/lib/makit/humanize.rb +89 -89
  27. data/lib/makit/logging.rb +96 -96
  28. data/lib/makit/markdown.rb +75 -75
  29. data/lib/makit/mp/basic_object_mp.rb +16 -16
  30. data/lib/makit/mp/command_request.mp.rb +13 -0
  31. data/lib/makit/mp/project_mp.rb +156 -149
  32. data/lib/makit/mp/string_mp.rb +107 -101
  33. data/lib/makit/nuget.rb +57 -57
  34. data/lib/makit/protoc.rb +61 -61
  35. data/lib/makit/serializer.rb +115 -70
  36. data/lib/makit/storage.rb +131 -131
  37. data/lib/makit/symbols.rb +149 -149
  38. data/lib/makit/tasks.rb +67 -67
  39. data/lib/makit/tree.rb +37 -37
  40. data/lib/makit/v1/makit.v1_pb.rb +5 -5
  41. data/lib/makit/v1/makit.v1_services_pb.rb +25 -25
  42. data/lib/makit/version.rb +12 -12
  43. data/lib/makit/wix.rb +95 -95
  44. data/lib/makit/zip.rb +17 -17
  45. data/lib/makit.rb +243 -243
  46. metadata +4 -39
  47. data/.makit.project.json +0 -4
  48. data/.makit.project.yml +0 -2
  49. data/.rubocop.yml +0 -22
  50. data/.ruby-version +0 -1
  51. data/CHANGELOG.md +0 -8
  52. data/CODE_OF_CONDUCT.md +0 -84
  53. data/LICENSE +0 -21
  54. data/README.md +0 -119
  55. data/Rakefile +0 -200
  56. data/docs/Commands.md +0 -50
  57. data/docs_/Commands.md +0 -166
  58. data/docs_/Minitest.Timeouts.md +0 -332
  59. data/examples/protoc/Rakefile +0 -31
  60. data/examples/rake_default/Rakefile +0 -6
  61. data/examples/rubygem-foo/.gitkeep +0 -0
  62. data/examples/rubygem-foo/Rakefile +0 -3
  63. data/examples/run_mp/Rakefile +0 -8
  64. data/exe/makit +0 -5
  65. data/lib/makit/content/default_gitignore.txt +0 -222
  66. data/lib/makit/content/ruby_gitlab-ci.yml +0 -15
  67. data/lib/makit/v1/makit.v1.proto +0 -103
  68. data/makit.generated.sln +0 -30
  69. data/makit.sln +0 -69
  70. data/pages/.gitignore +0 -5
  71. data/pages/404.html +0 -25
  72. data/pages/Gemfile +0 -33
  73. data/pages/Gemfile.lock +0 -88
  74. data/pages/_config.yml +0 -55
  75. data/pages/_layouts/default.html +0 -1
  76. data/pages/_posts/2024-10-05-welcome-to-jekyll.markdown +0 -29
  77. data/pages/about.markdown +0 -18
  78. data/pages/index.markdown +0 -6
  79. data/sig/makit.rbs +0 -4
  80. data/src/ClassLib/Class1.cs +0 -6
  81. data/src/ClassLib/ClassLib.csproj +0 -13
@@ -1,237 +1,318 @@
1
- require "English"
2
- require "open3"
3
- require "socket"
4
- require "etc"
5
- require "logger"
6
-
7
- # This module provides classes for the Makit gem.
8
- module Makit
9
- # This class provide methods running commands.
10
- #
11
- class CommandRunner
12
- attr_accessor :show_output_on_success, :log_to_artifacts, :commands
13
-
14
- def initialize
15
- @show_output_on_success = false
16
- @log_to_artifacts = false
17
- @commands = []
18
- end
19
-
20
- def run(command_request)
21
- raise "Invalid command_request" unless command_request.is_a? Makit::V1::CommandRequest
22
- command = execute(command_request)
23
- show_output = true
24
- exit_on_error = true
25
-
26
- log_to_artifacts(command) if @log_to_artifacts
27
- if command.exit_code != 0
28
- puts Makit::CommandRunner.get_command_summary(command) + " (exit code #{command.exit_code})".colorize(:default)
29
- puts " directory: #{command.directory}\n"
30
- puts " duration: #{command.duration.seconds} seconds\n"
31
- puts Makit::Humanize::indent_string(command.output, 2) if command.output.length > 0
32
- puts Makit::Humanize::indent_string(command.error, 2) if command.error.length > 0
33
- exit 1 if command_request.exit_on_error
34
- else
35
- puts Makit::CommandRunner.get_command_summary(command) + " (#{command.duration.seconds} seconds)".colorize(:cyan)
36
- puts Makit::Humanize::indent_string(command.output, 2).colorize(:default) if show_output_on_success
37
- end
38
-
39
- commands.push(command)
40
- command
41
- end
42
-
43
- def log_to_artifacts(command)
44
- dir = File.join(Makit::Directories::PROJECT_ARTIFACTS, "commands")
45
- FileUtils.mkdir_p(dir) unless Dir.exist?(dir)
46
- filename_friendly_timestamp = Time.now.strftime("%Y.%m.%d_%H%M%S")
47
- log_filename = File.join(dir, "#{filename_friendly_timestamp}.json")
48
- # serialize to protobuf json
49
- json = command.to_json
50
- pretty_json = JSON.pretty_generate(JSON.parse(json))
51
- File.write(log_filename, pretty_json)
52
- end
53
-
54
- # Run a command and return a Makit::V1::Command.
55
- def try(args)
56
- request = parse_command_request(args)
57
- request.exit_on_error = false
58
- run(request)
59
- #run2(args, false)
60
- end
61
-
62
- # Show the output of a command and return a Makit::V1::Command.
63
- def show(args)
64
- request = parse_args(args)
65
- command = execute(request)
66
-
67
- show_output = true
68
- exit_on_error = true
69
- Makit::LOGGER.info(Makit::CommandRunner.get_command_summary(command))
70
- show_output = true if command.exit_code != 0
71
- Makit::LOGGER.info(indent_string("\n#{command.output}\n#{command.error}\n".strip, 2)) if show_output
72
- exit(command.exit_code) if exit_on_error && command.exit_code != 0 # unless process_status.success?
73
- command
74
- end
75
-
76
- # Parse and return a Makit::V1::CommandRequest.
77
- def parse_command_request(source)
78
- return Makit::V1::CommandRequest.new(source) if source.is_a? Hash
79
- return source if source.is_a? Makit::V1::CommandRequest
80
- if source.is_a? String
81
- return parse_args(source)
82
- end
83
-
84
- raise "Invalid source" unless source.is_a? Makit::V1::CommandRequest
85
- end
86
-
87
- def parse_command_request_from_hash(hash)
88
- raise "Invalid hash" unless hash.is_a? Hash
89
- Makit::V1::CommandRequest.new(hash)
90
- end
91
-
92
- def parse_command_request_from_string(source)
93
- raise "Invalid source" unless source.is_a? String
94
- words = source.split(" ")
95
- hash = {
96
- name: words.shift,
97
- arguments: words,
98
- exit_on_error: true,
99
- }
100
- end
101
-
102
- # Parse the command line arguments into a Makit::V1::CommandRequest.
103
- def parse_args(args)
104
- #raise "No command specified" if args.empty?
105
- if args.is_a? Makit::V1::CommandRequest
106
- args
107
- else
108
- if args.is_a? String
109
- args = args.split(" ")
110
- if (args.length == 1)
111
- hash = {
112
- name: args[0],
113
- arguments: [],
114
- exit_on_error: true,
115
- }
116
- Makit::V1::CommandRequest.new(hash)
117
- else
118
- hash = {
119
- name: args.shift,
120
- arguments: args,
121
- exit_on_error: true,
122
- }
123
-
124
- Makit::V1::CommandRequest.new(hash)
125
- end
126
- else
127
- Makit::V1::CommandRequest.new(args)
128
- end
129
- end
130
- end
131
-
132
- def get_path_name(name)
133
- # replace all characters that a not valid in a filename with an underscore
134
- name.gsub(/[^0-9a-z]/i, "_")
135
- end
136
-
137
- # Given a Makit::V1::CommandRequest, execute the command and return a Makit::V1::Command.
138
- def execute(args)
139
- command_request = parse_args(args)
140
- command_request.directory = Dir.pwd if command_request.directory.nil?
141
- command_request.directory = Dir.pwd if command_request.directory.length == 0
142
- result = Makit::V1::Command.new(name: command_request.name)
143
- command_request.arguments.each do |arg|
144
- result.arguments.push(arg)
145
- end
146
- command = "#{command_request.name} #{command_request.arguments.join(" ")}"
147
- result.directory = command_request.directory
148
- start = Time.now
149
- filename_friendly_timestamp = Time.now.strftime("%Y.%m.%d_%H%M%S")
150
- log_filename = File.join(Makit::Directories::LOG, "#{filename_friendly_timestamp}.log")
151
-
152
- # assign a directory variable to the current working directory, if not specified,
153
- # otherwise assign the specified directory
154
- command_request.directory = Dir.pwd if command_request.directory.nil?
155
- command_request.directory = Dir.pwd if command_request.directory.length == 0
156
- raise "Invalid directory" unless Dir.exist?(command_request.directory)
157
-
158
- result.started_at = Google::Protobuf::Timestamp.new(seconds: start.to_i, nanos: start.nsec.to_i)
159
- ############# execute the command
160
- (output, error, exit_code) = execute_command(command, command_request.directory, command_request.timeout)
161
- result.output = output.force_encoding("ASCII-8BIT")
162
- result.error = error.force_encoding("ASCII-8BIT")
163
- result.exit_code = exit_code.nil? ? 0 : exit_code
164
-
165
- elapsed_time = Time.now - start
166
- seconds = elapsed_time.to_i
167
- nanos = ((elapsed_time - seconds) * 1_000_000_000).to_i
168
-
169
- result.duration = Google::Protobuf::Duration.new(seconds: seconds, nanos: nanos)
170
-
171
- result
172
- end
173
-
174
- # pure function to execute a command
175
- # returns (stdout, stderr, exit_code) or raise an exception
176
- def execute_command(command, directory, timeout)
177
- original_directory = Dir.pwd
178
- begin
179
- output = nil
180
- error = nil
181
- process_status = nil
182
- Dir.chdir(directory) do
183
- output, error, process_status = Open3.capture3(command)
184
- end
185
- return [output, error, process_status.exitstatus]
186
- rescue => e
187
- # restore the original working directory
188
- Dir.chdir(original_directory)
189
- message_parts = []
190
- message_parts << "failed to execute #{command}"
191
- message_parts << "directory: #{directory}"
192
- message_parts << "timeout: #{timeout}" unless timeout.nil?
193
- message_parts << "error: #{e.message}"
194
- message = message_parts.join("\n") + "\n"
195
- return ["", message, 1]
196
- #raise Makit::Error, message
197
- end
198
- end
199
-
200
- def execute_command_request(command_request)
201
- # if the command_request is not a Makit::V1::CommandRequest, raise an error
202
- raise "Invalid command_request" unless command_request.is_a? Makit::V1::CommandRequest
203
-
204
- args = Array.new
205
- command_request.arguments.each do |arg|
206
- args.push(arg)
207
- end
208
- result = Makit::V1::Command.new({
209
- name: command_request.name,
210
- arguments: args,
211
- started_at: Google::Protobuf::Timestamp.new({ seconds: Time.now.to_i, nanos: Time.now.nsec }),
212
- })
213
-
214
- begin
215
- rescue => e
216
- end
217
- end
218
-
219
- def indent_string(input_string, indent_spaces)
220
- indentation = " " * indent_spaces
221
- input_string.lines.map { |line| indentation + line }.join
222
- end
223
-
224
- def self.get_command_summary(command)
225
- symbol = Makit::Symbols.warning
226
- symbol = Makit::Symbols.checkmark if !command.exit_code.nil? && command.exit_code.zero?
227
- symbol = Makit::Symbols.error if command.exit_code != 0
228
- summary = "#{symbol} #{command.name.colorize(:yellow)} #{command.arguments.join(" ")}"
229
-
230
- if summary.length > 80
231
- summary = summary.to_lines(80, command.name.length + 3)
232
- end
233
-
234
- summary
235
- end
236
- end # class CommandRunner
237
- end # module Makit
1
+ require "English"
2
+ require "open3"
3
+ require "socket"
4
+ require "etc"
5
+ require "logger"
6
+
7
+ # This module provides classes for the Makit gem.
8
+ module Makit
9
+ # This class provide methods running commands.
10
+ #
11
+ class CommandRunner
12
+ attr_accessor :show_output_on_success, :log_to_artifacts, :commands
13
+
14
+ def initialize
15
+ @show_output_on_success = false
16
+ @log_to_artifacts = true
17
+ @commands = []
18
+ end
19
+
20
+ def get_cache_filename(command)
21
+ # test if the command_request is a Makit::V1::CommandRequest
22
+ #if command_request.is_a? Makit::V1::CommandRequest || command_request.is_a? Makit::V1::Command
23
+ # also replacing any path delimiters with an underscore
24
+ int_hash = Digest::SHA256.hexdigest("{command.name}.#{command.arguments.join(" ")}")
25
+ # int_hash
26
+ #int_hash = command_request.to_hash
27
+ hash_string = "#{int_hash}"[0, 8]
28
+ cache_filename = Makit::Directories::PROJECT_ARTIFACTS +
29
+ "/commands/cache/#{hash_string}.pb"
30
+ # create the directory if it does not already exist
31
+ FileUtils.mkdir_p(File.dirname(cache_filename))
32
+ cache_filename
33
+ end
34
+ # if there is a matching cached command result, that then the specified timestamp,
35
+ # then return the cached result
36
+ # otherwise run the command and save the result to a cache file
37
+ # then return the result
38
+ def cache_run(command_request, timestamp)
39
+ # combine the command name and arguments into a single string
40
+ # and use it to create a cache filename, making sure it is a valid filename,
41
+ # by replacing all characters that are not valid in a filename with an underscore
42
+ # also replacing any path delimiters with an underscore
43
+ int_hash = command_request.to_hash
44
+ hash_string = "#{int_hash}"[0, 8]
45
+ cache_filename = Makit::Directories::PROJECT_ARTIFACTS +
46
+ "/commands/#{hash_string}.pb"
47
+ puts "cache_filename: #{cache_filename}"
48
+
49
+ #cache_filename = Makit::Directories::PROJECT_ARTIFACTS + "/commands/#{command_request.name}.#{command_request.arguments.join("_")}.#{timestamp.seconds}.pb"
50
+ if File.exist?(cache_filename)
51
+ puts "cache file date: #{File.mtime(cache_filename)}"
52
+ if (File.mtime(cache_filename) > timestamp)
53
+ puts "cache_filename exists and is newer than #{timestamp}"
54
+ return Makit::Serializer.open(cache_filename, Makit::V1::Command)
55
+ else
56
+ puts "cache_filename exists, but is older than #{timestamp}"
57
+ end
58
+ end
59
+
60
+ command = run(command_request)
61
+ # make sure the cache directory exists
62
+ FileUtils.mkdir_p(File.dirname(cache_filename))
63
+ puts "saving command to cache_filename"
64
+ Makit::Serializer.save_as(cache_filename, command)
65
+ command
66
+ end
67
+
68
+ # Run a command and return a Makit::V1::Command.
69
+ def run(command_request)
70
+ raise "Invalid command_request" unless command_request.is_a? Makit::V1::CommandRequest
71
+ command = execute(command_request)
72
+ show_output = true
73
+ exit_on_error = true
74
+
75
+ log_to_artifacts(command) if @log_to_artifacts
76
+ if command.exit_code != 0
77
+ puts Makit::CommandRunner.get_command_summary(command) + " (exit code #{command.exit_code})".colorize(:default)
78
+ puts " directory: #{command.directory}\n"
79
+ puts " duration: #{command.duration.seconds} seconds\n"
80
+ puts Makit::Humanize::indent_string(command.output, 2) if command.output.length > 0
81
+ puts Makit::Humanize::indent_string(command.error, 2) if command.error.length > 0
82
+ exit 1 if command_request.exit_on_error
83
+ else
84
+ puts Makit::CommandRunner.get_command_summary(command) + " (#{command.duration.seconds} seconds)".colorize(:cyan)
85
+ puts Makit::Humanize::indent_string(command.output, 2).colorize(:default) if show_output_on_success
86
+ end
87
+
88
+ commands.push(command)
89
+ command
90
+ end
91
+
92
+ def log_to_artifacts(command)
93
+ #dir = File.join(Makit::Directories::PROJECT_ARTIFACTS, "commands")
94
+ #FileUtils.mkdir_p(dir) unless Dir.exist?(dir)
95
+ #filename_friendly_timestamp = Time.now.strftime("%Y.%m.%d_%H%M%S")
96
+ #log_filename = File.join(dir, "#{filename_friendly_timestamp}.json")
97
+ log_filename = get_cache_filename(command)
98
+ # serialize to protobuf json
99
+ json = command.to_json
100
+ pretty_json = JSON.pretty_generate(JSON.parse(json))
101
+ File.write(log_filename, pretty_json)
102
+ end
103
+
104
+ # Run a command and return a Makit::V1::Command.
105
+ def try(args)
106
+ request = parse_command_request(args)
107
+ request.exit_on_error = false
108
+ run(request)
109
+ #run2(args, false)
110
+ end
111
+
112
+ # Show the output of a command and return a Makit::V1::Command.
113
+ def show(args)
114
+ request = parse_args(args)
115
+ command = execute(request)
116
+
117
+ show_output = true
118
+ exit_on_error = true
119
+ Makit::LOGGER.info(Makit::CommandRunner.get_command_summary(command))
120
+ show_output = true if command.exit_code != 0
121
+ Makit::LOGGER.info(indent_string("\n#{command.output}\n#{command.error}\n".strip, 2)) if show_output
122
+ exit(command.exit_code) if exit_on_error && command.exit_code != 0 # unless process_status.success?
123
+ command
124
+ end
125
+
126
+ # Parse and return a Makit::V1::CommandRequest.
127
+ def parse_command_request(source)
128
+ return Makit::V1::CommandRequest.new(source) if source.is_a? Hash
129
+ return source if source.is_a? Makit::V1::CommandRequest
130
+ if source.is_a? String
131
+ return parse_args(source)
132
+ end
133
+
134
+ raise "Invalid source" unless source.is_a? Makit::V1::CommandRequest
135
+ end
136
+
137
+ def parse_command_request_from_hash(hash)
138
+ raise "Invalid hash" unless hash.is_a? Hash
139
+ Makit::V1::CommandRequest.new(hash)
140
+ end
141
+
142
+ def parse_command_request_from_string(source)
143
+ raise "Invalid source" unless source.is_a? String
144
+ words = source.split(" ")
145
+ hash = {
146
+ name: words.shift,
147
+ arguments: words,
148
+ exit_on_error: true,
149
+ }
150
+ end
151
+
152
+ # Parse the command line arguments into a Makit::V1::CommandRequest.
153
+ def parse_args(args)
154
+ #raise "No command specified" if args.empty?
155
+ if args.is_a? Makit::V1::CommandRequest
156
+ args
157
+ else
158
+ if args.is_a? String
159
+ args = args.split(" ")
160
+ if (args.length == 1)
161
+ hash = {
162
+ name: args[0],
163
+ arguments: [],
164
+ exit_on_error: true,
165
+ }
166
+ Makit::V1::CommandRequest.new(hash)
167
+ else
168
+ hash = {
169
+ name: args.shift,
170
+ arguments: args,
171
+ exit_on_error: true,
172
+ }
173
+
174
+ Makit::V1::CommandRequest.new(hash)
175
+ end
176
+ else
177
+ Makit::V1::CommandRequest.new(args)
178
+ end
179
+ end
180
+ end
181
+
182
+ def get_path_name(name)
183
+ # replace all characters that a not valid in a filename with an underscore
184
+ name.gsub(/[^0-9a-z]/i, "_")
185
+ end
186
+
187
+ # Given a Makit::V1::CommandRequest, execute the command and return a Makit::V1::Command.
188
+ def execute(args)
189
+ command_request = parse_args(args)
190
+ command_request.directory = Dir.pwd if command_request.directory.nil?
191
+ command_request.directory = Dir.pwd if command_request.directory.length == 0
192
+ result = Makit::V1::Command.new(name: command_request.name)
193
+ command_request.arguments.each do |arg|
194
+ result.arguments.push(arg)
195
+ end
196
+ command = "#{command_request.name} #{command_request.arguments.join(" ")}"
197
+ result.directory = command_request.directory
198
+ start = Time.now
199
+ filename_friendly_timestamp = Time.now.strftime("%Y.%m.%d_%H%M%S")
200
+ log_filename = File.join(Makit::Directories::LOG, "#{filename_friendly_timestamp}.log")
201
+
202
+ # assign a directory variable to the current working directory, if not specified,
203
+ # otherwise assign the specified directory
204
+ command_request.directory = Dir.pwd if command_request.directory.nil?
205
+ command_request.directory = Dir.pwd if command_request.directory.length == 0
206
+ raise "Invalid directory" unless Dir.exist?(command_request.directory)
207
+
208
+ result.started_at = Google::Protobuf::Timestamp.new(seconds: start.to_i, nanos: start.nsec.to_i)
209
+ ############# execute the command
210
+ (output, error, exit_code) = execute_command(command, command_request.directory, command_request.timeout)
211
+ result.output = output.force_encoding("ASCII-8BIT")
212
+ result.error = error.force_encoding("ASCII-8BIT")
213
+ result.exit_code = exit_code.nil? ? 0 : exit_code
214
+
215
+ elapsed_time = Time.now - start
216
+ seconds = elapsed_time.to_i
217
+ nanos = ((elapsed_time - seconds) * 1_000_000_000).to_i
218
+
219
+ result.duration = Google::Protobuf::Duration.new(seconds: seconds, nanos: nanos)
220
+
221
+ result
222
+ end
223
+
224
+ # pure function to execute a command
225
+ # returns (stdout, stderr, exit_code) or raise an exception
226
+ def execute_command(command, directory, timeout)
227
+ original_directory = Dir.pwd
228
+ begin
229
+ output = nil
230
+ error = nil
231
+ process_status = nil
232
+ Dir.chdir(directory) do
233
+ output, error, process_status = Open3.capture3(command)
234
+ end
235
+ return [output, error, process_status.exitstatus]
236
+ rescue => e
237
+ # restore the original working directory
238
+ Dir.chdir(original_directory)
239
+ message_parts = []
240
+ message_parts << "failed to execute #{command}"
241
+ message_parts << "directory: #{directory}"
242
+ message_parts << "timeout: #{timeout}" unless timeout.nil?
243
+ message_parts << "error: #{e.message}"
244
+ message = message_parts.join("\n") + "\n"
245
+ return ["", message, 1]
246
+ #raise Makit::Error, message
247
+ end
248
+ end
249
+
250
+ def execute_command_request(command_request)
251
+ # if the command_request is not a Makit::V1::CommandRequest, raise an error
252
+ raise "Invalid command_request" unless command_request.is_a? Makit::V1::CommandRequest
253
+
254
+ args = Array.new
255
+ command_request.arguments.each do |arg|
256
+ args.push(arg)
257
+ end
258
+ result = Makit::V1::Command.new({
259
+ name: command_request.name,
260
+ arguments: args,
261
+ started_at: Google::Protobuf::Timestamp.new({ seconds: Time.now.to_i, nanos: Time.now.nsec }),
262
+ })
263
+
264
+ begin
265
+ rescue => e
266
+ end
267
+ end
268
+
269
+ def indent_string(input_string, indent_spaces)
270
+ indentation = " " * indent_spaces
271
+ input_string.lines.map { |line| indentation + line }.join
272
+ end
273
+
274
+ def self.get_command_summary(command)
275
+ symbol = Makit::Symbols.warning
276
+ symbol = Makit::Symbols.checkmark if !command.exit_code.nil? && command.exit_code.zero?
277
+ symbol = Makit::Symbols.error if command.exit_code != 0
278
+ summary = "#{symbol} #{command.name.colorize(:yellow)} #{command.arguments.join(" ")}"
279
+
280
+ if summary.length > 80
281
+ summary = summary.to_lines(80, command.name.length + 3)
282
+ end
283
+
284
+ summary
285
+ end
286
+
287
+ def log_rake_commands
288
+ dir = File.join(Makit::Directories::PROJECT_ARTIFACTS, "commands")
289
+ FileUtils.mkdir_p(dir) unless Dir.exist?(dir)
290
+
291
+ # open a text file to write to
292
+ File.open(File.join(dir, "rake.commands.txt"), "w") do |file|
293
+ #rake_commands = commands.select { |command| command.name == "rake" }
294
+ commands.each do |command|
295
+ file.puts " " + Makit::CommandRunner.get_command_summary(command).strip_color_codes
296
+ file.puts " start time: #{command.started_at}"
297
+ file.puts command.output.strip_color_codes unless command.output.strip_color_codes.strip.length == 0
298
+ file.puts command.error.strip_color_codes unless command.error.strip_color_codes.strip.length == 0
299
+ file.puts " "
300
+ end
301
+ end
302
+ end
303
+ def log_slowest_commands
304
+ dir = File.join(Makit::Directories::PROJECT_ARTIFACTS, "commands")
305
+ FileUtils.mkdir_p(dir) unless Dir.exist?(dir)
306
+
307
+ # open a text file to write to
308
+ File.open(File.join(dir, "slow.commands.txt"), "w") do |file|
309
+ Makit::RUNNER.commands.sort_by { |command| (command.duration.seconds + (command.duration.nanos / 1_000_000_000.0)) }.reverse.first(5).each do |command|
310
+ # Convert to float representation
311
+ duration_in_float = command.duration.seconds + (command.duration.nanos / 1_000_000_000.0)
312
+ #puts " #{command.name} took #{duration_in_float} seconds"
313
+ file.puts " " + Makit::CommandRunner.get_command_summary(command).strip_color_codes + " (#{command.duration.seconds} seconds)"
314
+ end
315
+ end
316
+ end
317
+ end # class CommandRunner
318
+ end # module Makit
@@ -1,21 +1,21 @@
1
- # frozen_string_literal: true
2
-
3
- require "English"
4
- require "open3"
5
- require "socket"
6
- require "etc"
7
- require "logger"
8
-
9
- # This module provides classes for the Makit gem.
10
- module Makit
11
- # This class provide methods running commands.
12
- #
13
- class Commands < Array
14
-
15
- # Generate the commands based on the current directory.
16
- def auto_generate
17
- self << Makit::V1::CommandRequest.new(name: "bundle", arguments: ["install"]) if File.exist?("Gemfile")
18
- self << Makit::V1::CommandRequest.new(name: "bundle", arguments: ["exec", "rake"]) if File.exist?("Rakefile")
19
- end
20
- end
21
- end
1
+ # frozen_string_literal: true
2
+
3
+ require "English"
4
+ require "open3"
5
+ require "socket"
6
+ require "etc"
7
+ require "logger"
8
+
9
+ # This module provides classes for the Makit gem.
10
+ module Makit
11
+ # This class provide methods running commands.
12
+ #
13
+ class Commands < Array
14
+
15
+ # Generate the commands based on the current directory.
16
+ def auto_generate
17
+ self << Makit::V1::CommandRequest.new(name: "bundle", arguments: ["install"]) if File.exist?("Gemfile")
18
+ self << Makit::V1::CommandRequest.new(name: "bundle", arguments: ["exec", "rake"]) if File.exist?("Rakefile")
19
+ end
20
+ end
21
+ end
@@ -1,5 +1,5 @@
1
- module Makit
2
- module Content
3
- GITIGNORE = File.read(File.join(__dir__, "default_gitignore.txt"))
4
- end # module Content
5
- end # module Makit
1
+ module Makit
2
+ module Content
3
+ GITIGNORE = File.read(File.join(__dir__, "default_gitignore.txt"))
4
+ end # module Content
5
+ end # module Makit
@@ -1,11 +1,11 @@
1
- module Makit
2
- module Content
3
- RAKEFILE = <<~HEREDOC
4
- require "makit"
5
-
6
- task :default do
7
- end
8
-
9
- HEREDOC
10
- end # module Content
11
- end # module Makit
1
+ module Makit
2
+ module Content
3
+ RAKEFILE = <<~HEREDOC
4
+ require "makit"
5
+
6
+ task :default do
7
+ end
8
+
9
+ HEREDOC
10
+ end # module Content
11
+ end # module Makit