makit 0.0.139 → 0.0.140
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.
- checksums.yaml +4 -4
- data/README.md +41 -41
- data/exe/makit +5 -5
- data/lib/makit/apache.rb +28 -28
- data/lib/makit/auto.rb +48 -48
- data/lib/makit/cli/build_commands.rb +500 -500
- data/lib/makit/cli/generators/base_generator.rb +74 -74
- data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
- data/lib/makit/cli/generators/generator_factory.rb +49 -49
- data/lib/makit/cli/generators/node_generator.rb +50 -50
- data/lib/makit/cli/generators/ruby_generator.rb +77 -77
- data/lib/makit/cli/generators/rust_generator.rb +50 -50
- data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
- data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
- data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
- data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -40
- data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
- data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
- data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
- data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
- data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
- data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
- data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
- data/lib/makit/cli/main.rb +69 -67
- data/lib/makit/cli/project_commands.rb +868 -868
- data/lib/makit/cli/repository_commands.rb +661 -661
- data/lib/makit/cli/strategy_commands.rb +51 -0
- data/lib/makit/cli/utility_commands.rb +521 -521
- data/lib/makit/commands/factory.rb +359 -359
- data/lib/makit/commands/middleware/base.rb +73 -73
- data/lib/makit/commands/middleware/cache.rb +248 -248
- data/lib/makit/commands/middleware/command_logger.rb +312 -312
- data/lib/makit/commands/middleware/validator.rb +269 -269
- data/lib/makit/commands/request.rb +316 -316
- data/lib/makit/commands/result.rb +323 -323
- data/lib/makit/commands/runner.rb +385 -385
- data/lib/makit/commands/strategies/base.rb +171 -171
- data/lib/makit/commands/strategies/child_process.rb +1 -1
- data/lib/makit/commands/strategies/synchronous.rb +139 -139
- data/lib/makit/commands.rb +50 -50
- data/lib/makit/configuration/dotnet_project.rb +12 -12
- data/lib/makit/configuration/gitlab_helper.rb +58 -58
- data/lib/makit/configuration/project.rb +168 -168
- data/lib/makit/configuration/rakefile_helper.rb +43 -43
- data/lib/makit/configuration/step.rb +34 -34
- data/lib/makit/configuration/timeout.rb +74 -0
- data/lib/makit/configuration.rb +15 -14
- data/lib/makit/content/default_gitignore.rb +7 -7
- data/lib/makit/content/default_gitignore.txt +225 -225
- data/lib/makit/content/default_rakefile.rb +13 -13
- data/lib/makit/content/gem_rakefile.rb +16 -16
- data/lib/makit/context.rb +1 -1
- data/lib/makit/data.rb +49 -49
- data/lib/makit/directories.rb +140 -140
- data/lib/makit/directory.rb +262 -262
- data/lib/makit/docs/files.rb +89 -89
- data/lib/makit/docs/rake.rb +102 -102
- data/lib/makit/dotnet/cli.rb +69 -69
- data/lib/makit/dotnet/project.rb +217 -217
- data/lib/makit/dotnet/solution.rb +38 -38
- data/lib/makit/dotnet/solution_classlib.rb +239 -239
- data/lib/makit/dotnet/solution_console.rb +264 -264
- data/lib/makit/dotnet/solution_maui.rb +354 -354
- data/lib/makit/dotnet/solution_wasm.rb +275 -275
- data/lib/makit/dotnet/solution_wpf.rb +304 -304
- data/lib/makit/dotnet.rb +102 -102
- data/lib/makit/email.rb +90 -90
- data/lib/makit/environment.rb +142 -142
- data/lib/makit/examples/runner.rb +370 -370
- data/lib/makit/exceptions.rb +45 -45
- data/lib/makit/fileinfo.rb +24 -24
- data/lib/makit/files.rb +43 -43
- data/lib/makit/gems.rb +40 -40
- data/lib/makit/git/cli.rb +54 -54
- data/lib/makit/git/repository.rb +90 -90
- data/lib/makit/git.rb +98 -98
- data/lib/makit/gitlab_runner.rb +59 -59
- data/lib/makit/humanize.rb +137 -137
- data/lib/makit/indexer.rb +47 -47
- data/lib/makit/logging/configuration.rb +308 -308
- data/lib/makit/logging/format_registry.rb +84 -84
- data/lib/makit/logging/formatters/base.rb +39 -39
- data/lib/makit/logging/formatters/console_formatter.rb +140 -140
- data/lib/makit/logging/formatters/json_formatter.rb +65 -65
- data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
- data/lib/makit/logging/formatters/text_formatter.rb +64 -64
- data/lib/makit/logging/log_request.rb +119 -119
- data/lib/makit/logging/logger.rb +199 -199
- data/lib/makit/logging/sinks/base.rb +91 -91
- data/lib/makit/logging/sinks/console.rb +72 -72
- data/lib/makit/logging/sinks/file_sink.rb +92 -92
- data/lib/makit/logging/sinks/structured.rb +123 -123
- data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
- data/lib/makit/logging.rb +565 -565
- data/lib/makit/markdown.rb +75 -75
- data/lib/makit/mp/basic_object_mp.rb +17 -17
- data/lib/makit/mp/command_mp.rb +13 -13
- data/lib/makit/mp/command_request.mp.rb +17 -17
- data/lib/makit/mp/project_mp.rb +199 -199
- data/lib/makit/mp/string_mp.rb +191 -191
- data/lib/makit/nuget.rb +74 -74
- data/lib/makit/port.rb +32 -32
- data/lib/makit/process.rb +163 -163
- data/lib/makit/protoc.rb +107 -107
- data/lib/makit/rake/cli.rb +196 -196
- data/lib/makit/rake.rb +80 -80
- data/lib/makit/ruby/cli.rb +185 -185
- data/lib/makit/ruby.rb +25 -25
- data/lib/makit/secrets.rb +51 -51
- data/lib/makit/serializer.rb +130 -130
- data/lib/makit/services/builder.rb +186 -186
- data/lib/makit/services/error_handler.rb +226 -226
- data/lib/makit/services/repository_manager.rb +231 -231
- data/lib/makit/services/validator.rb +112 -112
- data/lib/makit/setup/classlib.rb +101 -101
- data/lib/makit/setup/gem.rb +268 -268
- data/lib/makit/setup/razorclasslib.rb +101 -101
- data/lib/makit/setup/runner.rb +54 -54
- data/lib/makit/setup.rb +5 -5
- data/lib/makit/show.rb +110 -110
- data/lib/makit/storage.rb +126 -126
- data/lib/makit/symbols.rb +170 -170
- data/lib/makit/task_info.rb +130 -130
- data/lib/makit/tasks/at_exit.rb +15 -15
- data/lib/makit/tasks/build.rb +22 -22
- data/lib/makit/tasks/clean.rb +13 -13
- data/lib/makit/tasks/configure.rb +10 -10
- data/lib/makit/tasks/format.rb +10 -10
- data/lib/makit/tasks/hook_manager.rb +443 -443
- data/lib/makit/tasks/init.rb +49 -49
- data/lib/makit/tasks/integrate.rb +29 -29
- data/lib/makit/tasks/pull_incoming.rb +13 -13
- data/lib/makit/tasks/setup.rb +13 -13
- data/lib/makit/tasks/sync.rb +17 -17
- data/lib/makit/tasks/tag.rb +16 -16
- data/lib/makit/tasks/task_monkey_patch.rb +81 -81
- data/lib/makit/tasks/test.rb +22 -22
- data/lib/makit/tasks/update.rb +18 -18
- data/lib/makit/tasks.rb +20 -20
- data/lib/makit/test_cache.rb +239 -239
- data/lib/makit/tree.rb +37 -37
- data/lib/makit/v1/makit.v1_pb.rb +35 -35
- data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
- data/lib/makit/version.rb +99 -99
- data/lib/makit/version_util.rb +21 -21
- data/lib/makit/wix.rb +95 -95
- data/lib/makit/yaml.rb +29 -29
- data/lib/makit/zip.rb +17 -17
- data/lib/makit copy.rb +44 -44
- data/lib/makit.rb +42 -42
- metadata +2 -1
data/lib/makit/process.rb
CHANGED
@@ -1,163 +1,163 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
# This module provides classes for the Makit gem.
|
4
|
-
module Makit
|
5
|
-
# Cross-platform process management utilities
|
6
|
-
#
|
7
|
-
# This class provides methods for checking, listing, and terminating processes
|
8
|
-
# across different operating systems (Windows, Linux, macOS). It abstracts
|
9
|
-
# platform-specific commands into a unified interface.
|
10
|
-
class Process
|
11
|
-
# Check if a process with the given name is currently running
|
12
|
-
#
|
13
|
-
# Uses platform-specific commands:
|
14
|
-
# - Windows: tasklist command
|
15
|
-
# - Unix: ps command with grep filtering
|
16
|
-
#
|
17
|
-
# @param name [String] Name of the process to check (without .exe extension)
|
18
|
-
# @return [Boolean] True if the process is running, false otherwise
|
19
|
-
def self.is_running?(name)
|
20
|
-
return false if name.nil? || name.strip.empty?
|
21
|
-
|
22
|
-
# provide a cross-platform way to check if a process is running
|
23
|
-
results = if Makit::Environment.is_windows?
|
24
|
-
# on windows, use the tasklist command
|
25
|
-
`tasklist /FI "imagename eq #{name}.exe" 2>nul`
|
26
|
-
else
|
27
|
-
# on linux/mac, use the ps command
|
28
|
-
`ps aux | grep "#{name}" | grep -v grep 2>/dev/null`
|
29
|
-
end
|
30
|
-
results.include?(name)
|
31
|
-
end
|
32
|
-
|
33
|
-
# Terminate all processes that match a given name
|
34
|
-
#
|
35
|
-
# Uses platform-specific termination commands:
|
36
|
-
# - Windows: taskkill command
|
37
|
-
# - Unix: kill command with SIGKILL (-9)
|
38
|
-
#
|
39
|
-
# @param name [String] Name of the process(es) to terminate
|
40
|
-
# @return [Array<String>] Array of killed process IDs (empty if none found/killed)
|
41
|
-
def self.kill(name)
|
42
|
-
return [] if name.nil? || name.strip.empty?
|
43
|
-
|
44
|
-
killed_pids = []
|
45
|
-
|
46
|
-
if Makit::Environment.is_windows?
|
47
|
-
# Windows: Use tasklist to find PIDs first, then kill them
|
48
|
-
begin
|
49
|
-
# Find processes by name
|
50
|
-
tasklist_output = `tasklist /FI "imagename eq #{name}.exe" /FO CSV 2>nul`
|
51
|
-
|
52
|
-
# Parse CSV output to extract PIDs
|
53
|
-
lines = tasklist_output.split("\n")
|
54
|
-
if lines.length > 1 # Skip header line
|
55
|
-
lines[1..].each do |line|
|
56
|
-
parts = line.split(",")
|
57
|
-
next unless parts.length >= 2
|
58
|
-
|
59
|
-
pid = parts[1]&.gsub('"', "")&.strip
|
60
|
-
next unless pid && !pid.empty? && pid.match?(/^\d+$/)
|
61
|
-
|
62
|
-
begin
|
63
|
-
`taskkill /PID #{pid} /F 2>nul`
|
64
|
-
killed_pids << pid
|
65
|
-
rescue StandardError => e
|
66
|
-
# Log error but continue with other processes
|
67
|
-
puts "Failed to kill process #{pid}: #{e.message}"
|
68
|
-
end
|
69
|
-
end
|
70
|
-
end
|
71
|
-
rescue StandardError => e
|
72
|
-
# If tasklist fails, try direct taskkill by name
|
73
|
-
begin
|
74
|
-
`taskkill /IM "#{name}.exe" /F 2>nul`
|
75
|
-
# Since we can't get PIDs from direct kill, return empty array
|
76
|
-
# but don't raise error
|
77
|
-
rescue StandardError => e2
|
78
|
-
# Both methods failed, return empty array
|
79
|
-
puts "Failed to kill processes by name #{name}: #{e2.message}"
|
80
|
-
end
|
81
|
-
end
|
82
|
-
else
|
83
|
-
# Unix (Linux/Mac): Use pgrep to find PIDs, then kill them
|
84
|
-
begin
|
85
|
-
# Use pgrep to find PIDs, handle both Linux and Mac
|
86
|
-
pids = if Makit::Environment.is_mac?
|
87
|
-
# Mac: pgrep -f might not work the same way
|
88
|
-
`pgrep -x "#{name}" 2>/dev/null`.split("\n").reject(&:empty?)
|
89
|
-
else
|
90
|
-
# Linux: pgrep -f works well
|
91
|
-
`pgrep -f "#{name}" 2>/dev/null`.split("\n").reject(&:empty?)
|
92
|
-
end
|
93
|
-
|
94
|
-
pids.each do |pid|
|
95
|
-
next unless pid.match?(/^\d+$/)
|
96
|
-
|
97
|
-
begin
|
98
|
-
`kill -9 #{pid} 2>/dev/null`
|
99
|
-
killed_pids << pid
|
100
|
-
rescue StandardError => e
|
101
|
-
puts "Failed to kill process #{pid}: #{e.message}"
|
102
|
-
end
|
103
|
-
end
|
104
|
-
rescue StandardError => e
|
105
|
-
# If pgrep fails, return empty array but don't raise error
|
106
|
-
puts "Failed to find processes by name #{name}: #{e.message}"
|
107
|
-
end
|
108
|
-
end
|
109
|
-
|
110
|
-
killed_pids
|
111
|
-
end
|
112
|
-
|
113
|
-
# List all running processes on the system
|
114
|
-
#
|
115
|
-
# Uses platform-specific commands to get a complete process listing:
|
116
|
-
# - Windows: tasklist command
|
117
|
-
# - Unix: ps aux command
|
118
|
-
#
|
119
|
-
# @return [String] Raw output from the system process listing command
|
120
|
-
def self.list
|
121
|
-
if Makit::Environment.is_windows?
|
122
|
-
`tasklist 2>nul`
|
123
|
-
else
|
124
|
-
`ps aux 2>/dev/null`
|
125
|
-
end
|
126
|
-
end
|
127
|
-
|
128
|
-
# List all running processes for the current user
|
129
|
-
#
|
130
|
-
# Filters the process list to show only processes owned by the current user.
|
131
|
-
# Uses platform-specific filtering:
|
132
|
-
# - Windows: tasklist with USERNAME filter
|
133
|
-
# - Unix: ps aux with grep filtering
|
134
|
-
#
|
135
|
-
# @return [String] Raw output from the filtered process listing command
|
136
|
-
def self.list_current_user
|
137
|
-
if Makit::Environment.is_windows?
|
138
|
-
`tasklist /FI "STATUS eq running and USERNAME eq #{Makit::Environment.current_user}" 2>nul`
|
139
|
-
else
|
140
|
-
`ps aux | grep "#{Makit::Environment.current_user}" | grep -v grep 2>/dev/null`
|
141
|
-
end
|
142
|
-
end
|
143
|
-
|
144
|
-
# List processes for the current user filtered by name
|
145
|
-
#
|
146
|
-
# Returns an array of process lines for consistency across platforms.
|
147
|
-
# Filters by both current user and process name.
|
148
|
-
#
|
149
|
-
# @param name [String] Process name to filter by
|
150
|
-
# @return [Array<String>] Array of process lines matching the criteria
|
151
|
-
def self.list_current_user_processes(name)
|
152
|
-
if Makit::Environment.is_windows?
|
153
|
-
# filter the results to only include the current user
|
154
|
-
results = `tasklist /FI "STATUS eq running and USERNAME eq #{Makit::Environment.current_user}" 2>nul`
|
155
|
-
results.split("\n").select { |line| line.include?(Makit::Environment.current_user) }
|
156
|
-
else
|
157
|
-
# Unix (Linux/Mac): return as array for consistency
|
158
|
-
results = `ps aux | grep "#{name}" | grep -v grep 2>/dev/null`
|
159
|
-
results.split("\n").reject(&:empty?)
|
160
|
-
end
|
161
|
-
end
|
162
|
-
end
|
163
|
-
end
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# This module provides classes for the Makit gem.
|
4
|
+
module Makit
|
5
|
+
# Cross-platform process management utilities
|
6
|
+
#
|
7
|
+
# This class provides methods for checking, listing, and terminating processes
|
8
|
+
# across different operating systems (Windows, Linux, macOS). It abstracts
|
9
|
+
# platform-specific commands into a unified interface.
|
10
|
+
class Process
|
11
|
+
# Check if a process with the given name is currently running
|
12
|
+
#
|
13
|
+
# Uses platform-specific commands:
|
14
|
+
# - Windows: tasklist command
|
15
|
+
# - Unix: ps command with grep filtering
|
16
|
+
#
|
17
|
+
# @param name [String] Name of the process to check (without .exe extension)
|
18
|
+
# @return [Boolean] True if the process is running, false otherwise
|
19
|
+
def self.is_running?(name)
|
20
|
+
return false if name.nil? || name.strip.empty?
|
21
|
+
|
22
|
+
# provide a cross-platform way to check if a process is running
|
23
|
+
results = if Makit::Environment.is_windows?
|
24
|
+
# on windows, use the tasklist command
|
25
|
+
`tasklist /FI "imagename eq #{name}.exe" 2>nul`
|
26
|
+
else
|
27
|
+
# on linux/mac, use the ps command
|
28
|
+
`ps aux | grep "#{name}" | grep -v grep 2>/dev/null`
|
29
|
+
end
|
30
|
+
results.include?(name)
|
31
|
+
end
|
32
|
+
|
33
|
+
# Terminate all processes that match a given name
|
34
|
+
#
|
35
|
+
# Uses platform-specific termination commands:
|
36
|
+
# - Windows: taskkill command
|
37
|
+
# - Unix: kill command with SIGKILL (-9)
|
38
|
+
#
|
39
|
+
# @param name [String] Name of the process(es) to terminate
|
40
|
+
# @return [Array<String>] Array of killed process IDs (empty if none found/killed)
|
41
|
+
def self.kill(name)
|
42
|
+
return [] if name.nil? || name.strip.empty?
|
43
|
+
|
44
|
+
killed_pids = []
|
45
|
+
|
46
|
+
if Makit::Environment.is_windows?
|
47
|
+
# Windows: Use tasklist to find PIDs first, then kill them
|
48
|
+
begin
|
49
|
+
# Find processes by name
|
50
|
+
tasklist_output = `tasklist /FI "imagename eq #{name}.exe" /FO CSV 2>nul`
|
51
|
+
|
52
|
+
# Parse CSV output to extract PIDs
|
53
|
+
lines = tasklist_output.split("\n")
|
54
|
+
if lines.length > 1 # Skip header line
|
55
|
+
lines[1..].each do |line|
|
56
|
+
parts = line.split(",")
|
57
|
+
next unless parts.length >= 2
|
58
|
+
|
59
|
+
pid = parts[1]&.gsub('"', "")&.strip
|
60
|
+
next unless pid && !pid.empty? && pid.match?(/^\d+$/)
|
61
|
+
|
62
|
+
begin
|
63
|
+
`taskkill /PID #{pid} /F 2>nul`
|
64
|
+
killed_pids << pid
|
65
|
+
rescue StandardError => e
|
66
|
+
# Log error but continue with other processes
|
67
|
+
puts "Failed to kill process #{pid}: #{e.message}"
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
rescue StandardError => e
|
72
|
+
# If tasklist fails, try direct taskkill by name
|
73
|
+
begin
|
74
|
+
`taskkill /IM "#{name}.exe" /F 2>nul`
|
75
|
+
# Since we can't get PIDs from direct kill, return empty array
|
76
|
+
# but don't raise error
|
77
|
+
rescue StandardError => e2
|
78
|
+
# Both methods failed, return empty array
|
79
|
+
puts "Failed to kill processes by name #{name}: #{e2.message}"
|
80
|
+
end
|
81
|
+
end
|
82
|
+
else
|
83
|
+
# Unix (Linux/Mac): Use pgrep to find PIDs, then kill them
|
84
|
+
begin
|
85
|
+
# Use pgrep to find PIDs, handle both Linux and Mac
|
86
|
+
pids = if Makit::Environment.is_mac?
|
87
|
+
# Mac: pgrep -f might not work the same way
|
88
|
+
`pgrep -x "#{name}" 2>/dev/null`.split("\n").reject(&:empty?)
|
89
|
+
else
|
90
|
+
# Linux: pgrep -f works well
|
91
|
+
`pgrep -f "#{name}" 2>/dev/null`.split("\n").reject(&:empty?)
|
92
|
+
end
|
93
|
+
|
94
|
+
pids.each do |pid|
|
95
|
+
next unless pid.match?(/^\d+$/)
|
96
|
+
|
97
|
+
begin
|
98
|
+
`kill -9 #{pid} 2>/dev/null`
|
99
|
+
killed_pids << pid
|
100
|
+
rescue StandardError => e
|
101
|
+
puts "Failed to kill process #{pid}: #{e.message}"
|
102
|
+
end
|
103
|
+
end
|
104
|
+
rescue StandardError => e
|
105
|
+
# If pgrep fails, return empty array but don't raise error
|
106
|
+
puts "Failed to find processes by name #{name}: #{e.message}"
|
107
|
+
end
|
108
|
+
end
|
109
|
+
|
110
|
+
killed_pids
|
111
|
+
end
|
112
|
+
|
113
|
+
# List all running processes on the system
|
114
|
+
#
|
115
|
+
# Uses platform-specific commands to get a complete process listing:
|
116
|
+
# - Windows: tasklist command
|
117
|
+
# - Unix: ps aux command
|
118
|
+
#
|
119
|
+
# @return [String] Raw output from the system process listing command
|
120
|
+
def self.list
|
121
|
+
if Makit::Environment.is_windows?
|
122
|
+
`tasklist 2>nul`
|
123
|
+
else
|
124
|
+
`ps aux 2>/dev/null`
|
125
|
+
end
|
126
|
+
end
|
127
|
+
|
128
|
+
# List all running processes for the current user
|
129
|
+
#
|
130
|
+
# Filters the process list to show only processes owned by the current user.
|
131
|
+
# Uses platform-specific filtering:
|
132
|
+
# - Windows: tasklist with USERNAME filter
|
133
|
+
# - Unix: ps aux with grep filtering
|
134
|
+
#
|
135
|
+
# @return [String] Raw output from the filtered process listing command
|
136
|
+
def self.list_current_user
|
137
|
+
if Makit::Environment.is_windows?
|
138
|
+
`tasklist /FI "STATUS eq running and USERNAME eq #{Makit::Environment.current_user}" 2>nul`
|
139
|
+
else
|
140
|
+
`ps aux | grep "#{Makit::Environment.current_user}" | grep -v grep 2>/dev/null`
|
141
|
+
end
|
142
|
+
end
|
143
|
+
|
144
|
+
# List processes for the current user filtered by name
|
145
|
+
#
|
146
|
+
# Returns an array of process lines for consistency across platforms.
|
147
|
+
# Filters by both current user and process name.
|
148
|
+
#
|
149
|
+
# @param name [String] Process name to filter by
|
150
|
+
# @return [Array<String>] Array of process lines matching the criteria
|
151
|
+
def self.list_current_user_processes(name)
|
152
|
+
if Makit::Environment.is_windows?
|
153
|
+
# filter the results to only include the current user
|
154
|
+
results = `tasklist /FI "STATUS eq running and USERNAME eq #{Makit::Environment.current_user}" 2>nul`
|
155
|
+
results.split("\n").select { |line| line.include?(Makit::Environment.current_user) }
|
156
|
+
else
|
157
|
+
# Unix (Linux/Mac): return as array for consistency
|
158
|
+
results = `ps aux | grep "#{name}" | grep -v grep 2>/dev/null`
|
159
|
+
results.split("\n").reject(&:empty?)
|
160
|
+
end
|
161
|
+
end
|
162
|
+
end
|
163
|
+
end
|
data/lib/makit/protoc.rb
CHANGED
@@ -1,107 +1,107 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require "pathname"
|
4
|
-
|
5
|
-
# This module provides classes for the Makit gem.
|
6
|
-
module Makit
|
7
|
-
# This class provide methods for working with the system Environment.
|
8
|
-
#
|
9
|
-
class Protoc
|
10
|
-
def self.grpc_tools_path
|
11
|
-
File.join(Makit::Directories::NUGET_PACKAGE_CACHE, "grpc.tools", Makit::Protoc.get_latest_grpc_tools_version)
|
12
|
-
end
|
13
|
-
|
14
|
-
def self.grpc_csharp_plugin_path
|
15
|
-
Makit::Protoc.find_plugin_path("grpc_csharp_plugin")
|
16
|
-
end
|
17
|
-
|
18
|
-
def self.setup
|
19
|
-
if Dir.exist?(Makit::Directories::NUGET_PACKAGE_CACHE)
|
20
|
-
Makit::NuGet.cache("Grpc.Tools", "2.66.0")
|
21
|
-
unless Dir.exist?(Makit::Directories::NUGET_PACKAGE_CACHE)
|
22
|
-
raise "Nuget package path #{Makit::Directories::NUGET_PACKAGE_CACHE} not found"
|
23
|
-
end
|
24
|
-
|
25
|
-
# test if protoc is installed by running >protoc --version
|
26
|
-
which_protoc = Makit::Environment.which("protoc")
|
27
|
-
if Makit::Environment.which("protoc").nil?
|
28
|
-
puts " protoc not found, installing...".colorize(:red)
|
29
|
-
"go version".run
|
30
|
-
"go install google.golang.org/protobuf/cmd/protoc-gen-go@latest".run
|
31
|
-
"go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-grpc-gateway@latest".run
|
32
|
-
"go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-openapiv2@latest".run
|
33
|
-
else
|
34
|
-
puts " protoc found at #{which_protoc}".colorize(:green)
|
35
|
-
end
|
36
|
-
raise "protoc not found" unless Makit::Environment.which("protoc")
|
37
|
-
|
38
|
-
# "git clone https://github.com/googleapis/googleapis.git third_party".run unless File.directory?("third_party/google")
|
39
|
-
puts " grpc_tools_path #{Makit::Protoc.grpc_tools_path.to_s.colorize(:green)}"
|
40
|
-
puts " grpc_csharp_plugin_path #{Makit::Protoc.grpc_csharp_plugin_path.to_s.colorize(:green)}"
|
41
|
-
else
|
42
|
-
puts " warning: Nuget package cache directory #{Makit::Directories::NUGET_PACKAGE_CACHE} not found".colorize(:red)
|
43
|
-
puts " warning: Unable to proceed with protoc setup".colorize(:red)
|
44
|
-
end
|
45
|
-
end
|
46
|
-
|
47
|
-
# get the latest version of the grpc.tools package
|
48
|
-
def self.get_latest_grpc_tools_version
|
49
|
-
Makit::NuGet.get_latest_version("Grpc.Tools")
|
50
|
-
end
|
51
|
-
|
52
|
-
# GRPC_CSHARP_PLUGIN_PATH = Makit::Protoc::find_plugin_path("grpc_csharp_plugin")
|
53
|
-
def self.find_plugin_path(plugin_name)
|
54
|
-
# search for a file matching the pattern *grpc_csharp_plugin* in the grpc.tools directory
|
55
|
-
# should match on Windows and Linux
|
56
|
-
plugin_name += ".exe" if Makit::Environment.is_windows?
|
57
|
-
|
58
|
-
plugin_path = Dir.glob("#{Makit::Directories::GRPC_TOOLS_PATH}/**/#{plugin_name}").first
|
59
|
-
|
60
|
-
raise "Plugin path #{plugin_path} not found" unless File.exist?(plugin_path)
|
61
|
-
|
62
|
-
plugin_path
|
63
|
-
end
|
64
|
-
|
65
|
-
def self.get_proto_files_from_path(proto_source_dir)
|
66
|
-
proto_files = []
|
67
|
-
Dir.chdir(proto_source_dir) do
|
68
|
-
Dir.glob("**/*.proto").each do |proto|
|
69
|
-
proto_files << proto
|
70
|
-
end
|
71
|
-
end
|
72
|
-
proto_files
|
73
|
-
end
|
74
|
-
|
75
|
-
def self.generate_source_file(proto_filename, language, csharp_output_dir)
|
76
|
-
FileUtils.mkdir_p(csharp_output_dir)
|
77
|
-
"protoc --#{language}_out=#{csharp_output_dir} #{proto_filename}".run
|
78
|
-
end
|
79
|
-
|
80
|
-
# language: charp, ruby, go, etc.
|
81
|
-
def self.generate_source_files(proto_source_dir, language, output_dir)
|
82
|
-
debug = false
|
83
|
-
puts "Generating source files for #{language} in #{proto_source_dir} to #{output_dir}" if debug
|
84
|
-
FileUtils.mkdir_p(output_dir)
|
85
|
-
|
86
|
-
path_a = Pathname.new(proto_source_dir)
|
87
|
-
path_b = Pathname.new(output_dir)
|
88
|
-
output_relative_path = path_b.relative_path_from(path_a)
|
89
|
-
puts "output_relative_path: #{output_relative_path}" if debug
|
90
|
-
|
91
|
-
Dir.chdir(proto_source_dir) do
|
92
|
-
Dir.glob("**/*.proto").each do |proto|
|
93
|
-
puts "Generating #{proto}" if debug
|
94
|
-
if language == "csharp"
|
95
|
-
namespace_dir = File.dirname(proto)
|
96
|
-
output_dir = "#{output_relative_path}/#{namespace_dir}"
|
97
|
-
puts "Generating #{proto} in #{output_dir}" if debug
|
98
|
-
FileUtils.mkdir_p(output_dir.to_s)
|
99
|
-
"protoc --csharp_out=#{output_dir} #{proto}".run
|
100
|
-
else
|
101
|
-
"protoc --#{language}_out=#{output_relative_path} #{proto}".run
|
102
|
-
end
|
103
|
-
end
|
104
|
-
end
|
105
|
-
end
|
106
|
-
end
|
107
|
-
end
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "pathname"
|
4
|
+
|
5
|
+
# This module provides classes for the Makit gem.
|
6
|
+
module Makit
|
7
|
+
# This class provide methods for working with the system Environment.
|
8
|
+
#
|
9
|
+
class Protoc
|
10
|
+
def self.grpc_tools_path
|
11
|
+
File.join(Makit::Directories::NUGET_PACKAGE_CACHE, "grpc.tools", Makit::Protoc.get_latest_grpc_tools_version)
|
12
|
+
end
|
13
|
+
|
14
|
+
def self.grpc_csharp_plugin_path
|
15
|
+
Makit::Protoc.find_plugin_path("grpc_csharp_plugin")
|
16
|
+
end
|
17
|
+
|
18
|
+
def self.setup
|
19
|
+
if Dir.exist?(Makit::Directories::NUGET_PACKAGE_CACHE)
|
20
|
+
Makit::NuGet.cache("Grpc.Tools", "2.66.0")
|
21
|
+
unless Dir.exist?(Makit::Directories::NUGET_PACKAGE_CACHE)
|
22
|
+
raise "Nuget package path #{Makit::Directories::NUGET_PACKAGE_CACHE} not found"
|
23
|
+
end
|
24
|
+
|
25
|
+
# test if protoc is installed by running >protoc --version
|
26
|
+
which_protoc = Makit::Environment.which("protoc")
|
27
|
+
if Makit::Environment.which("protoc").nil?
|
28
|
+
puts " protoc not found, installing...".colorize(:red)
|
29
|
+
"go version".run
|
30
|
+
"go install google.golang.org/protobuf/cmd/protoc-gen-go@latest".run
|
31
|
+
"go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-grpc-gateway@latest".run
|
32
|
+
"go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-openapiv2@latest".run
|
33
|
+
else
|
34
|
+
puts " protoc found at #{which_protoc}".colorize(:green)
|
35
|
+
end
|
36
|
+
raise "protoc not found" unless Makit::Environment.which("protoc")
|
37
|
+
|
38
|
+
# "git clone https://github.com/googleapis/googleapis.git third_party".run unless File.directory?("third_party/google")
|
39
|
+
puts " grpc_tools_path #{Makit::Protoc.grpc_tools_path.to_s.colorize(:green)}"
|
40
|
+
puts " grpc_csharp_plugin_path #{Makit::Protoc.grpc_csharp_plugin_path.to_s.colorize(:green)}"
|
41
|
+
else
|
42
|
+
puts " warning: Nuget package cache directory #{Makit::Directories::NUGET_PACKAGE_CACHE} not found".colorize(:red)
|
43
|
+
puts " warning: Unable to proceed with protoc setup".colorize(:red)
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
# get the latest version of the grpc.tools package
|
48
|
+
def self.get_latest_grpc_tools_version
|
49
|
+
Makit::NuGet.get_latest_version("Grpc.Tools")
|
50
|
+
end
|
51
|
+
|
52
|
+
# GRPC_CSHARP_PLUGIN_PATH = Makit::Protoc::find_plugin_path("grpc_csharp_plugin")
|
53
|
+
def self.find_plugin_path(plugin_name)
|
54
|
+
# search for a file matching the pattern *grpc_csharp_plugin* in the grpc.tools directory
|
55
|
+
# should match on Windows and Linux
|
56
|
+
plugin_name += ".exe" if Makit::Environment.is_windows?
|
57
|
+
|
58
|
+
plugin_path = Dir.glob("#{Makit::Directories::GRPC_TOOLS_PATH}/**/#{plugin_name}").first
|
59
|
+
|
60
|
+
raise "Plugin path #{plugin_path} not found" unless File.exist?(plugin_path)
|
61
|
+
|
62
|
+
plugin_path
|
63
|
+
end
|
64
|
+
|
65
|
+
def self.get_proto_files_from_path(proto_source_dir)
|
66
|
+
proto_files = []
|
67
|
+
Dir.chdir(proto_source_dir) do
|
68
|
+
Dir.glob("**/*.proto").each do |proto|
|
69
|
+
proto_files << proto
|
70
|
+
end
|
71
|
+
end
|
72
|
+
proto_files
|
73
|
+
end
|
74
|
+
|
75
|
+
def self.generate_source_file(proto_filename, language, csharp_output_dir)
|
76
|
+
FileUtils.mkdir_p(csharp_output_dir)
|
77
|
+
"protoc --#{language}_out=#{csharp_output_dir} #{proto_filename}".run
|
78
|
+
end
|
79
|
+
|
80
|
+
# language: charp, ruby, go, etc.
|
81
|
+
def self.generate_source_files(proto_source_dir, language, output_dir)
|
82
|
+
debug = false
|
83
|
+
puts "Generating source files for #{language} in #{proto_source_dir} to #{output_dir}" if debug
|
84
|
+
FileUtils.mkdir_p(output_dir)
|
85
|
+
|
86
|
+
path_a = Pathname.new(proto_source_dir)
|
87
|
+
path_b = Pathname.new(output_dir)
|
88
|
+
output_relative_path = path_b.relative_path_from(path_a)
|
89
|
+
puts "output_relative_path: #{output_relative_path}" if debug
|
90
|
+
|
91
|
+
Dir.chdir(proto_source_dir) do
|
92
|
+
Dir.glob("**/*.proto").each do |proto|
|
93
|
+
puts "Generating #{proto}" if debug
|
94
|
+
if language == "csharp"
|
95
|
+
namespace_dir = File.dirname(proto)
|
96
|
+
output_dir = "#{output_relative_path}/#{namespace_dir}"
|
97
|
+
puts "Generating #{proto} in #{output_dir}" if debug
|
98
|
+
FileUtils.mkdir_p(output_dir.to_s)
|
99
|
+
"protoc --csharp_out=#{output_dir} #{proto}".run
|
100
|
+
else
|
101
|
+
"protoc --#{language}_out=#{output_relative_path} #{proto}".run
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|