makit 0.0.1 → 0.0.2

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 +274 -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 +151 -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 +101 -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,274 @@
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 = false
17
+ @commands = []
18
+ end
19
+
20
+ # if there is a matching cached command result, that then the specified timestamp,
21
+ # then return the cached result
22
+ # otherwise run the command and save the result to a cache file
23
+ # then return the result
24
+ def cache_run(command_request, timestamp)
25
+ # combine the command name and arguments into a single string
26
+ # and use it to create a cache filename, making sure it is a valid filename,
27
+ # by replacing all characters that are not valid in a filename with an underscore
28
+ # also replacing any path delimiters with an underscore
29
+ cache_filename = Makit::Directories::PROJECT_ARTIFACTS +
30
+ "/commands/#{command_request.to_hash}.pb"
31
+ puts "cache_filename: #{cache_filename}"
32
+
33
+
34
+ #cache_filename = Makit::Directories::PROJECT_ARTIFACTS + "/commands/#{command_request.name}.#{command_request.arguments.join("_")}.#{timestamp.seconds}.pb"
35
+ if File.exist?(cache_filename)
36
+ puts "cache file date: #{File.mtime(cache_filename)}"
37
+ if(File.mtime(cache_filename) > timestamp)
38
+ puts "cache_filename exists and is newer than #{timestamp}"
39
+ return Makit::Serializer.open(cache_filename, Makit::V1::Command)
40
+ else
41
+ puts "cache_filename exists, but is older than #{timestamp}"
42
+ end
43
+ end
44
+
45
+
46
+
47
+ command = run(command_request)
48
+ # make sure the cache directory exists
49
+ FileUtils.mkdir_p(File.dirname(cache_filename))
50
+ puts "saving command to cache_filename"
51
+ Makit::Serializer.save_as(cache_filename, command)
52
+ command
53
+
54
+ end
55
+
56
+ # Run a command and return a Makit::V1::Command.
57
+ def run(command_request)
58
+ raise "Invalid command_request" unless command_request.is_a? Makit::V1::CommandRequest
59
+ command = execute(command_request)
60
+ show_output = true
61
+ exit_on_error = true
62
+
63
+ log_to_artifacts(command) if @log_to_artifacts
64
+ if command.exit_code != 0
65
+ puts Makit::CommandRunner.get_command_summary(command) + " (exit code #{command.exit_code})".colorize(:default)
66
+ puts " directory: #{command.directory}\n"
67
+ puts " duration: #{command.duration.seconds} seconds\n"
68
+ puts Makit::Humanize::indent_string(command.output, 2) if command.output.length > 0
69
+ puts Makit::Humanize::indent_string(command.error, 2) if command.error.length > 0
70
+ exit 1 if command_request.exit_on_error
71
+ else
72
+ puts Makit::CommandRunner.get_command_summary(command) + " (#{command.duration.seconds} seconds)".colorize(:cyan)
73
+ puts Makit::Humanize::indent_string(command.output, 2).colorize(:default) if show_output_on_success
74
+ end
75
+
76
+ commands.push(command)
77
+ command
78
+ end
79
+
80
+ def log_to_artifacts(command)
81
+ dir = File.join(Makit::Directories::PROJECT_ARTIFACTS, "commands")
82
+ FileUtils.mkdir_p(dir) unless Dir.exist?(dir)
83
+ filename_friendly_timestamp = Time.now.strftime("%Y.%m.%d_%H%M%S")
84
+ log_filename = File.join(dir, "#{filename_friendly_timestamp}.json")
85
+ # serialize to protobuf json
86
+ json = command.to_json
87
+ pretty_json = JSON.pretty_generate(JSON.parse(json))
88
+ File.write(log_filename, pretty_json)
89
+ end
90
+
91
+ # Run a command and return a Makit::V1::Command.
92
+ def try(args)
93
+ request = parse_command_request(args)
94
+ request.exit_on_error = false
95
+ run(request)
96
+ #run2(args, false)
97
+ end
98
+
99
+ # Show the output of a command and return a Makit::V1::Command.
100
+ def show(args)
101
+ request = parse_args(args)
102
+ command = execute(request)
103
+
104
+ show_output = true
105
+ exit_on_error = true
106
+ Makit::LOGGER.info(Makit::CommandRunner.get_command_summary(command))
107
+ show_output = true if command.exit_code != 0
108
+ Makit::LOGGER.info(indent_string("\n#{command.output}\n#{command.error}\n".strip, 2)) if show_output
109
+ exit(command.exit_code) if exit_on_error && command.exit_code != 0 # unless process_status.success?
110
+ command
111
+ end
112
+
113
+ # Parse and return a Makit::V1::CommandRequest.
114
+ def parse_command_request(source)
115
+ return Makit::V1::CommandRequest.new(source) if source.is_a? Hash
116
+ return source if source.is_a? Makit::V1::CommandRequest
117
+ if source.is_a? String
118
+ return parse_args(source)
119
+ end
120
+
121
+ raise "Invalid source" unless source.is_a? Makit::V1::CommandRequest
122
+ end
123
+
124
+ def parse_command_request_from_hash(hash)
125
+ raise "Invalid hash" unless hash.is_a? Hash
126
+ Makit::V1::CommandRequest.new(hash)
127
+ end
128
+
129
+ def parse_command_request_from_string(source)
130
+ raise "Invalid source" unless source.is_a? String
131
+ words = source.split(" ")
132
+ hash = {
133
+ name: words.shift,
134
+ arguments: words,
135
+ exit_on_error: true,
136
+ }
137
+ end
138
+
139
+ # Parse the command line arguments into a Makit::V1::CommandRequest.
140
+ def parse_args(args)
141
+ #raise "No command specified" if args.empty?
142
+ if args.is_a? Makit::V1::CommandRequest
143
+ args
144
+ else
145
+ if args.is_a? String
146
+ args = args.split(" ")
147
+ if (args.length == 1)
148
+ hash = {
149
+ name: args[0],
150
+ arguments: [],
151
+ exit_on_error: true,
152
+ }
153
+ Makit::V1::CommandRequest.new(hash)
154
+ else
155
+ hash = {
156
+ name: args.shift,
157
+ arguments: args,
158
+ exit_on_error: true,
159
+ }
160
+
161
+ Makit::V1::CommandRequest.new(hash)
162
+ end
163
+ else
164
+ Makit::V1::CommandRequest.new(args)
165
+ end
166
+ end
167
+ end
168
+
169
+ def get_path_name(name)
170
+ # replace all characters that a not valid in a filename with an underscore
171
+ name.gsub(/[^0-9a-z]/i, "_")
172
+ end
173
+
174
+ # Given a Makit::V1::CommandRequest, execute the command and return a Makit::V1::Command.
175
+ def execute(args)
176
+ command_request = parse_args(args)
177
+ command_request.directory = Dir.pwd if command_request.directory.nil?
178
+ command_request.directory = Dir.pwd if command_request.directory.length == 0
179
+ result = Makit::V1::Command.new(name: command_request.name)
180
+ command_request.arguments.each do |arg|
181
+ result.arguments.push(arg)
182
+ end
183
+ command = "#{command_request.name} #{command_request.arguments.join(" ")}"
184
+ result.directory = command_request.directory
185
+ start = Time.now
186
+ filename_friendly_timestamp = Time.now.strftime("%Y.%m.%d_%H%M%S")
187
+ log_filename = File.join(Makit::Directories::LOG, "#{filename_friendly_timestamp}.log")
188
+
189
+ # assign a directory variable to the current working directory, if not specified,
190
+ # otherwise assign the specified directory
191
+ command_request.directory = Dir.pwd if command_request.directory.nil?
192
+ command_request.directory = Dir.pwd if command_request.directory.length == 0
193
+ raise "Invalid directory" unless Dir.exist?(command_request.directory)
194
+
195
+ result.started_at = Google::Protobuf::Timestamp.new(seconds: start.to_i, nanos: start.nsec.to_i)
196
+ ############# execute the command
197
+ (output, error, exit_code) = execute_command(command, command_request.directory, command_request.timeout)
198
+ result.output = output.force_encoding("ASCII-8BIT")
199
+ result.error = error.force_encoding("ASCII-8BIT")
200
+ result.exit_code = exit_code.nil? ? 0 : exit_code
201
+
202
+ elapsed_time = Time.now - start
203
+ seconds = elapsed_time.to_i
204
+ nanos = ((elapsed_time - seconds) * 1_000_000_000).to_i
205
+
206
+ result.duration = Google::Protobuf::Duration.new(seconds: seconds, nanos: nanos)
207
+
208
+ result
209
+ end
210
+
211
+ # pure function to execute a command
212
+ # returns (stdout, stderr, exit_code) or raise an exception
213
+ def execute_command(command, directory, timeout)
214
+ original_directory = Dir.pwd
215
+ begin
216
+ output = nil
217
+ error = nil
218
+ process_status = nil
219
+ Dir.chdir(directory) do
220
+ output, error, process_status = Open3.capture3(command)
221
+ end
222
+ return [output, error, process_status.exitstatus]
223
+ rescue => e
224
+ # restore the original working directory
225
+ Dir.chdir(original_directory)
226
+ message_parts = []
227
+ message_parts << "failed to execute #{command}"
228
+ message_parts << "directory: #{directory}"
229
+ message_parts << "timeout: #{timeout}" unless timeout.nil?
230
+ message_parts << "error: #{e.message}"
231
+ message = message_parts.join("\n") + "\n"
232
+ return ["", message, 1]
233
+ #raise Makit::Error, message
234
+ end
235
+ end
236
+
237
+ def execute_command_request(command_request)
238
+ # if the command_request is not a Makit::V1::CommandRequest, raise an error
239
+ raise "Invalid command_request" unless command_request.is_a? Makit::V1::CommandRequest
240
+
241
+ args = Array.new
242
+ command_request.arguments.each do |arg|
243
+ args.push(arg)
244
+ end
245
+ result = Makit::V1::Command.new({
246
+ name: command_request.name,
247
+ arguments: args,
248
+ started_at: Google::Protobuf::Timestamp.new({ seconds: Time.now.to_i, nanos: Time.now.nsec }),
249
+ })
250
+
251
+ begin
252
+ rescue => e
253
+ end
254
+ end
255
+
256
+ def indent_string(input_string, indent_spaces)
257
+ indentation = " " * indent_spaces
258
+ input_string.lines.map { |line| indentation + line }.join
259
+ end
260
+
261
+ def self.get_command_summary(command)
262
+ symbol = Makit::Symbols.warning
263
+ symbol = Makit::Symbols.checkmark if !command.exit_code.nil? && command.exit_code.zero?
264
+ symbol = Makit::Symbols.error if command.exit_code != 0
265
+ summary = "#{symbol} #{command.name.colorize(:yellow)} #{command.arguments.join(" ")}"
266
+
267
+ if summary.length > 80
268
+ summary = summary.to_lines(80, command.name.length + 3)
269
+ end
270
+
271
+ summary
272
+ end
273
+ end # class CommandRunner
274
+ 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
@@ -1,14 +1,14 @@
1
- module Makit
2
- module Content
3
- GEM_RAKEFILE = <<~HEREDOC
4
- require "bundler/gem_tasks" # for build, install and release tasks
5
- require "minitest/test_task"
6
- Minitest::TestTask.create
7
- require "makit"
8
-
9
- task :default => [:build, :install] do
10
- end
11
-
12
- HEREDOC
13
- end # module Content
14
- end # module Makit
1
+ module Makit
2
+ module Content
3
+ GEM_RAKEFILE = <<~HEREDOC
4
+ require "bundler/gem_tasks" # for build, install and release tasks
5
+ require "minitest/test_task"
6
+ Minitest::TestTask.create
7
+ require "makit"
8
+
9
+ task :default => [:build, :install] do
10
+ end
11
+
12
+ HEREDOC
13
+ end # module Content
14
+ end # module Makit