procon_bypass_man 0.1.5 → 0.1.6
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/.circleci/config.yml +3 -0
- data/.rubocop.yml +24 -0
- data/CHANGELOG.md +3 -0
- data/Gemfile +1 -0
- data/Gemfile.lock +22 -1
- data/README.md +5 -5
- data/examples/practical/app.rb +2 -2
- data/lib/procon_bypass_man.rb +6 -1
- data/lib/procon_bypass_man/configuration.rb +2 -4
- data/lib/procon_bypass_man/configuration/loader.rb +17 -16
- data/lib/procon_bypass_man/configuration/validator.rb +20 -19
- data/lib/procon_bypass_man/device_connector.rb +1 -1
- data/lib/procon_bypass_man/procon/pressed_button_helper.rb +1 -1
- data/lib/procon_bypass_man/runner.rb +4 -3
- data/lib/procon_bypass_man/version.rb +1 -1
- data/procon_bypass_man.gemspec +1 -1
- metadata +6 -5
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 21149148015d5d8194ba9b0dc35fc1699ba1fe4eff6aaf1dd0956e0b35856e14
|
|
4
|
+
data.tar.gz: 6af893ef0a8ff0fdad56b53d9bd117f6cbd39ec7bdb5c216d44cf2d773b9974f
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 7185d5bf2246b3c1e2ae00eb08e170db017e78b7ed43fecde3757f2fc99bf1132f01b4e541ba669b9fc2ef39ee17e035368eabe7d4b973728c8ae49fd2873a0a
|
|
7
|
+
data.tar.gz: 6c3152904d3f4af9e3e3e4f519d4fbe3391cf7d727c3ee42966d9492672bb9ead227ce451e8b97088d8b5e27176e9427939009ff59873fac507cbdabeb7fa61a
|
data/.circleci/config.yml
CHANGED
data/.rubocop.yml
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
AllCops:
|
|
2
|
+
NewCops: enable
|
|
3
|
+
SuggestExtensions: false
|
|
4
|
+
Include:
|
|
5
|
+
- 'lib/**/*.rb'
|
|
6
|
+
- 'spec/**/*.rb'
|
|
7
|
+
Style:
|
|
8
|
+
Enabled: false
|
|
9
|
+
|
|
10
|
+
Metrics:
|
|
11
|
+
Enabled: false
|
|
12
|
+
|
|
13
|
+
Layout:
|
|
14
|
+
Enabled: false
|
|
15
|
+
|
|
16
|
+
Naming:
|
|
17
|
+
Enabled: false
|
|
18
|
+
|
|
19
|
+
Lint/ConstantDefinitionInBlock:
|
|
20
|
+
Enabled: false
|
|
21
|
+
Lint/UselessAssignment:
|
|
22
|
+
Enabled: false
|
|
23
|
+
Lint/EmptyBlock:
|
|
24
|
+
Enabled: false
|
data/CHANGELOG.md
CHANGED
data/Gemfile
CHANGED
data/Gemfile.lock
CHANGED
|
@@ -1,18 +1,25 @@
|
|
|
1
1
|
PATH
|
|
2
2
|
remote: .
|
|
3
3
|
specs:
|
|
4
|
-
procon_bypass_man (0.1.
|
|
4
|
+
procon_bypass_man (0.1.6)
|
|
5
5
|
|
|
6
6
|
GEM
|
|
7
7
|
remote: https://rubygems.org/
|
|
8
8
|
specs:
|
|
9
|
+
ast (2.4.2)
|
|
9
10
|
coderay (1.1.3)
|
|
10
11
|
diff-lcs (1.4.4)
|
|
11
12
|
method_source (1.0.0)
|
|
13
|
+
parallel (1.20.1)
|
|
14
|
+
parser (3.0.2.0)
|
|
15
|
+
ast (~> 2.4.1)
|
|
12
16
|
pry (0.14.1)
|
|
13
17
|
coderay (~> 1.1)
|
|
14
18
|
method_source (~> 1.0)
|
|
19
|
+
rainbow (3.0.0)
|
|
15
20
|
rake (13.0.3)
|
|
21
|
+
regexp_parser (2.1.1)
|
|
22
|
+
rexml (3.2.5)
|
|
16
23
|
rspec (3.10.0)
|
|
17
24
|
rspec-core (~> 3.10.0)
|
|
18
25
|
rspec-expectations (~> 3.10.0)
|
|
@@ -26,7 +33,20 @@ GEM
|
|
|
26
33
|
diff-lcs (>= 1.2.0, < 2.0)
|
|
27
34
|
rspec-support (~> 3.10.0)
|
|
28
35
|
rspec-support (3.10.2)
|
|
36
|
+
rubocop (1.18.4)
|
|
37
|
+
parallel (~> 1.10)
|
|
38
|
+
parser (>= 3.0.0.0)
|
|
39
|
+
rainbow (>= 2.2.2, < 4.0)
|
|
40
|
+
regexp_parser (>= 1.8, < 3.0)
|
|
41
|
+
rexml
|
|
42
|
+
rubocop-ast (>= 1.8.0, < 2.0)
|
|
43
|
+
ruby-progressbar (~> 1.7)
|
|
44
|
+
unicode-display_width (>= 1.4.0, < 3.0)
|
|
45
|
+
rubocop-ast (1.8.0)
|
|
46
|
+
parser (>= 3.0.1.1)
|
|
47
|
+
ruby-progressbar (1.11.0)
|
|
29
48
|
timecop (0.9.4)
|
|
49
|
+
unicode-display_width (2.0.0)
|
|
30
50
|
|
|
31
51
|
PLATFORMS
|
|
32
52
|
arm-linux
|
|
@@ -38,6 +58,7 @@ DEPENDENCIES
|
|
|
38
58
|
pry
|
|
39
59
|
rake (~> 13.0)
|
|
40
60
|
rspec
|
|
61
|
+
rubocop
|
|
41
62
|
timecop
|
|
42
63
|
|
|
43
64
|
BUNDLED WITH
|
data/README.md
CHANGED
|
@@ -25,12 +25,12 @@ Switch <-- (PBM): ZR連打
|
|
|
25
25
|
|
|
26
26
|
## Usage
|
|
27
27
|
* USBガジェットモードで起動するRaspberry Pi4を用意する
|
|
28
|
-
* https://github.com/
|
|
28
|
+
* https://github.com/splaplapla/procon_bypass_man/blob/master/docs/setup_raspi.md
|
|
29
29
|
* Raspberry Pi4で https://github.com/jiikko/procon_bypass_man_sample をclone して実行ファイルを動かす
|
|
30
|
-
* 実行ファイルと設定ファイルについては https://github.com/
|
|
30
|
+
* 実行ファイルと設定ファイルについては https://github.com/splaplapla/procon_bypass_man/wiki に詳細を書いていますが、まず動かすためにはcloneしたほうが早いです
|
|
31
31
|
|
|
32
32
|
## Plugins
|
|
33
|
-
* https://github.com/
|
|
33
|
+
* https://github.com/splaplapla/procon_bypass_man-splatoon2
|
|
34
34
|
|
|
35
35
|
## FAQ
|
|
36
36
|
* どうやって動かすの?
|
|
@@ -38,7 +38,7 @@ Switch <-- (PBM): ZR連打
|
|
|
38
38
|
* どうやって使うの?
|
|
39
39
|
* ケーブルでそれらを接続した状態で、Raspberry Pi4にsshして本プログラムを起動することで使用します
|
|
40
40
|
* ラズベリーパイ4のセットアップ方法は?
|
|
41
|
-
* https://github.com/
|
|
41
|
+
* https://github.com/splaplapla/procon_bypass_man/tree/master/docs/setup_raspi.md
|
|
42
42
|
* モード, マクロの違いは?
|
|
43
43
|
* modeはProconの入力をそのまま再現するため機能。レイヤーを切り替えるまで繰り返し続ける
|
|
44
44
|
* マクロは特定のキーを順番に入れていく機能。キーの入力が終わったらマクロは終了する
|
|
@@ -52,10 +52,10 @@ Switch <-- (PBM): ZR連打
|
|
|
52
52
|
* 操作するdeviceファイルの所有者がrootだから
|
|
53
53
|
|
|
54
54
|
## TODO
|
|
55
|
-
* 設定ファイルをwebから反映できる
|
|
56
55
|
* ラズパイのプロビジョニングを楽にしたい
|
|
57
56
|
* レコーディング機能(プロコンの入力をマクロとして登録ができる)
|
|
58
57
|
* マクロにdelayを入れれるようにする
|
|
58
|
+
* 設定ファイル マクロの引数に、ボタンを取れるようにする
|
|
59
59
|
|
|
60
60
|
## 開発系
|
|
61
61
|
```ruby
|
data/examples/practical/app.rb
CHANGED
|
@@ -8,8 +8,8 @@ require 'bundler/inline'
|
|
|
8
8
|
|
|
9
9
|
gemfile do
|
|
10
10
|
source 'https://rubygems.org'
|
|
11
|
-
gem 'procon_bypass_man', github: '
|
|
12
|
-
gem 'procon_bypass_man-splatoon2', github: '
|
|
11
|
+
gem 'procon_bypass_man', github: 'splaplapla/procon_bypass_man', branch: "edge"
|
|
12
|
+
gem 'procon_bypass_man-splatoon2', github: 'splaplapla/procon_bypass_man-splatoon2', branch: "0.1.0"
|
|
13
13
|
end
|
|
14
14
|
|
|
15
15
|
ProconBypassMan.tap do |pbm|
|
data/lib/procon_bypass_man.rb
CHANGED
|
@@ -40,12 +40,13 @@ module ProconBypassMan
|
|
|
40
40
|
ProconBypassMan.logger.error "設定ファイルが不正です。設定ファイルの読み込みに失敗しました"
|
|
41
41
|
puts "設定ファイルが不正です。設定ファイルの読み込みに失敗しました"
|
|
42
42
|
FileUtils.rm_rf(ProconBypassMan.pid_path)
|
|
43
|
+
FileUtils.rm_rf(ProconBypassMan.digest_path)
|
|
43
44
|
exit 1
|
|
44
45
|
rescue EternalConnectionError
|
|
45
46
|
ProconBypassMan.logger.error "接続の見込みがないのでsleepしまくります"
|
|
46
47
|
puts "接続の見込みがないのでsleepしまくります"
|
|
47
48
|
FileUtils.rm_rf(ProconBypassMan.pid_path)
|
|
48
|
-
sleep(
|
|
49
|
+
sleep(999999999)
|
|
49
50
|
rescue FirstConnectionError
|
|
50
51
|
puts "接続を確立できませんでした。やりなおします。"
|
|
51
52
|
retry
|
|
@@ -86,4 +87,8 @@ module ProconBypassMan
|
|
|
86
87
|
def self.root=(path)
|
|
87
88
|
@@root = path
|
|
88
89
|
end
|
|
90
|
+
|
|
91
|
+
def self.digest_path
|
|
92
|
+
"#{root}/.setting_yaml_digest"
|
|
93
|
+
end
|
|
89
94
|
end
|
|
@@ -4,7 +4,6 @@ require "procon_bypass_man/configuration/layer"
|
|
|
4
4
|
|
|
5
5
|
module ProconBypassMan
|
|
6
6
|
class Configuration
|
|
7
|
-
include Validator
|
|
8
7
|
|
|
9
8
|
attr_accessor :layers,
|
|
10
9
|
:setting_path,
|
|
@@ -19,13 +18,12 @@ module ProconBypassMan
|
|
|
19
18
|
@@context[@@current_context_key] ||= new
|
|
20
19
|
end
|
|
21
20
|
|
|
22
|
-
def self.
|
|
23
|
-
@@context[key]
|
|
21
|
+
def self.switch_new_context(key)
|
|
22
|
+
@@context[key] = new
|
|
24
23
|
previous_key = @@current_context_key
|
|
25
24
|
if block_given?
|
|
26
25
|
@@current_context_key = key
|
|
27
26
|
value = yield(@@context[key])
|
|
28
|
-
@@context[key].reset!
|
|
29
27
|
@@current_context_key = previous_key
|
|
30
28
|
return value
|
|
31
29
|
else
|
|
@@ -1,24 +1,22 @@
|
|
|
1
1
|
module ProconBypassMan
|
|
2
2
|
class Configuration
|
|
3
3
|
module Loader
|
|
4
|
+
require 'digest/md5'
|
|
5
|
+
|
|
4
6
|
def self.load(setting_path: )
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
instance.errors[:base] << "yamlのシンタックスエラーです"
|
|
14
|
-
next(instance)
|
|
7
|
+
ProconBypassMan::Configuration.switch_new_context(:validation) do |validation_instance|
|
|
8
|
+
yaml = YAML.load_file(setting_path) or raise "読み込みに失敗しました"
|
|
9
|
+
validation_instance.instance_eval(yaml["setting"])
|
|
10
|
+
validator = Validator.new(validation_instance)
|
|
11
|
+
if validator.valid?
|
|
12
|
+
next
|
|
13
|
+
else
|
|
14
|
+
raise ProconBypassMan::CouldNotLoadConfigError, validator.errors
|
|
15
15
|
end
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
if !validation_instance.errors.empty?
|
|
21
|
-
raise ProconBypassMan::CouldNotLoadConfigError, validation_instance.errors
|
|
16
|
+
rescue SyntaxError
|
|
17
|
+
raise ProconBypassMan::CouldNotLoadConfigError, "Rubyのシンタックスエラーです"
|
|
18
|
+
rescue Psych::SyntaxError
|
|
19
|
+
raise ProconBypassMan::CouldNotLoadConfigError, "yamlのシンタックスエラーです"
|
|
22
20
|
end
|
|
23
21
|
|
|
24
22
|
yaml = YAML.load_file(setting_path)
|
|
@@ -33,6 +31,9 @@ module ProconBypassMan
|
|
|
33
31
|
ProconBypassMan.logger.warn "不明なバージョンです。failoverします"
|
|
34
32
|
ProconBypassMan::Configuration.instance.instance_eval(yaml["setting"])
|
|
35
33
|
end
|
|
34
|
+
|
|
35
|
+
File.write(ProconBypassMan.digest_path, Digest::MD5.hexdigest(yaml["setting"]))
|
|
36
|
+
|
|
36
37
|
ProconBypassMan::Configuration.instance
|
|
37
38
|
end
|
|
38
39
|
|
|
@@ -1,6 +1,11 @@
|
|
|
1
1
|
module ProconBypassMan
|
|
2
2
|
class Configuration
|
|
3
|
-
|
|
3
|
+
class Validator
|
|
4
|
+
def initialize(config)
|
|
5
|
+
@layers = config.layers
|
|
6
|
+
@prefix_keys = config.prefix_keys
|
|
7
|
+
end
|
|
8
|
+
|
|
4
9
|
# @return [Boolean]
|
|
5
10
|
def valid?
|
|
6
11
|
@errors = Hash.new {|h,k| h[k] = [] }
|
|
@@ -38,7 +43,7 @@ module ProconBypassMan
|
|
|
38
43
|
end
|
|
39
44
|
|
|
40
45
|
def validate_require_prefix_keys
|
|
41
|
-
if prefix_keys.empty?
|
|
46
|
+
if @prefix_keys.empty?
|
|
42
47
|
@errors[:prefix_keys] ||= []
|
|
43
48
|
@errors[:prefix_keys] << "prefix_keys_for_changing_layerに値が入っていません。"
|
|
44
49
|
end
|
|
@@ -48,24 +53,20 @@ module ProconBypassMan
|
|
|
48
53
|
@layers.each do |layer_key, value|
|
|
49
54
|
unverified_buttons = []
|
|
50
55
|
# teplevel target button
|
|
51
|
-
value.
|
|
52
|
-
value.
|
|
56
|
+
value.flips.keys.map(&:to_sym).each { |b| unverified_buttons << b }
|
|
57
|
+
value.remaps.keys.map(&:to_sym).each { |b| unverified_buttons << b }
|
|
53
58
|
# internal target button
|
|
54
|
-
value.
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
flip_option_target_button
|
|
60
|
-
}
|
|
59
|
+
value.flips.flat_map { |_flip_button, flip_option|
|
|
60
|
+
flip_option.flat_map { |flip_option_key, flip_option_target_button|
|
|
61
|
+
next if flip_option_key == :flip_interval
|
|
62
|
+
next if flip_option_target_button.is_a?(FalseClass) || flip_option_target_button.is_a?(TrueClass)
|
|
63
|
+
flip_option_target_button
|
|
61
64
|
}
|
|
62
65
|
}.compact.each { |b| unverified_buttons << b }
|
|
63
|
-
value.
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
flip_option_target_button
|
|
68
|
-
}
|
|
66
|
+
value.remaps.flat_map { |_button, option|
|
|
67
|
+
option.flat_map { |_flip_option_key, flip_option_target_button|
|
|
68
|
+
next if flip_option_target_button.is_a?(FalseClass) || flip_option_target_button.is_a?(TrueClass)
|
|
69
|
+
flip_option_target_button
|
|
69
70
|
}
|
|
70
71
|
}.compact.each { |b| unverified_buttons << b }
|
|
71
72
|
unless(nunsupport_buttons = (unverified_buttons - ProconBypassMan::Procon::ButtonCollection::BUTTONS)).length.zero?
|
|
@@ -78,8 +79,8 @@ module ProconBypassMan
|
|
|
78
79
|
@layers.each do |layer_key, value|
|
|
79
80
|
flip_buttons = []
|
|
80
81
|
remap_buttons = []
|
|
81
|
-
value.
|
|
82
|
-
value.
|
|
82
|
+
value.flips.keys.map(&:to_sym).each { |b| flip_buttons << b }
|
|
83
|
+
value.remaps.keys.map(&:to_sym).each { |b| remap_buttons << b }
|
|
83
84
|
if(duplicated_buttons = flip_buttons & remap_buttons).length > 0
|
|
84
85
|
@errors[:layers] << "レイヤー#{layer_key}で、連打とリマップの定義が重複しているボタン#{duplicated_buttons.join(", ")}があります"
|
|
85
86
|
end
|
|
@@ -13,7 +13,7 @@ module ProconBypassMan::Procon::PushedButtonHelper
|
|
|
13
13
|
@@compiled = false
|
|
14
14
|
def compile_if_not_compile_yet!
|
|
15
15
|
unless @@compiled
|
|
16
|
-
::ProconBypassMan::Procon::ButtonCollection::BUTTONS_MAP.each do |button,
|
|
16
|
+
::ProconBypassMan::Procon::ButtonCollection::BUTTONS_MAP.each do |button, _value|
|
|
17
17
|
define_method "pressed_#{button}?" do
|
|
18
18
|
pressed_button?(button)
|
|
19
19
|
end
|
|
@@ -28,7 +28,7 @@ class ProconBypassMan::Runner
|
|
|
28
28
|
main_loop_pid = fork { main_loop }
|
|
29
29
|
|
|
30
30
|
begin
|
|
31
|
-
while
|
|
31
|
+
while(readable_io = IO.select([self_read]))
|
|
32
32
|
signal = readable_io.first[0].gets.strip
|
|
33
33
|
handle_signal(signal)
|
|
34
34
|
end
|
|
@@ -51,6 +51,7 @@ class ProconBypassMan::Runner
|
|
|
51
51
|
@gadget&.close
|
|
52
52
|
@procon&.close
|
|
53
53
|
FileUtils.rm_rf(ProconBypassMan.pid_path)
|
|
54
|
+
FileUtils.rm_rf(ProconBypassMan.digest_path)
|
|
54
55
|
exit 1
|
|
55
56
|
end
|
|
56
57
|
end
|
|
@@ -119,7 +120,7 @@ class ProconBypassMan::Runner
|
|
|
119
120
|
|
|
120
121
|
ProconBypassMan.logger.info "子プロセスでgraceful shutdownの準備ができました"
|
|
121
122
|
begin
|
|
122
|
-
while
|
|
123
|
+
while(readable_io = IO.select([self_read]))
|
|
123
124
|
signal = readable_io.first[0].gets.strip
|
|
124
125
|
handle_signal(signal)
|
|
125
126
|
end
|
|
@@ -135,7 +136,7 @@ class ProconBypassMan::Runner
|
|
|
135
136
|
def first_negotiation
|
|
136
137
|
return if $will_terminate_token
|
|
137
138
|
|
|
138
|
-
@gadget, @procon = ProconBypassMan::DeviceConnector.connect
|
|
139
|
+
@gadget, @procon = ProconBypassMan::DeviceConnector.connect
|
|
139
140
|
rescue ProconBypassMan::Timer::Timeout
|
|
140
141
|
::ProconBypassMan.logger.error "デバイスとの通信でタイムアウトが起きて接続ができませんでした。"
|
|
141
142
|
@gadget&.close
|
data/procon_bypass_man.gemspec
CHANGED
|
@@ -10,7 +10,7 @@ Gem::Specification.new do |spec|
|
|
|
10
10
|
|
|
11
11
|
spec.summary = "extension for Nintendo Switch Pro Controller"
|
|
12
12
|
spec.description = spec.summary
|
|
13
|
-
spec.homepage = "https://github.com/
|
|
13
|
+
spec.homepage = "https://github.com/splaplapla/procon_bypass_man"
|
|
14
14
|
spec.license = "MIT"
|
|
15
15
|
spec.required_ruby_version = Gem::Requirement.new(">= 2.4.0")
|
|
16
16
|
|
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: procon_bypass_man
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.1.
|
|
4
|
+
version: 0.1.6
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- jiikko
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: exe
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2021-
|
|
11
|
+
date: 2021-08-18 00:00:00.000000000 Z
|
|
12
12
|
dependencies: []
|
|
13
13
|
description: extension for Nintendo Switch Pro Controller
|
|
14
14
|
email:
|
|
@@ -20,6 +20,7 @@ files:
|
|
|
20
20
|
- ".circleci/config.yml"
|
|
21
21
|
- ".gitignore"
|
|
22
22
|
- ".rspec"
|
|
23
|
+
- ".rubocop.yml"
|
|
23
24
|
- ".ruby-version"
|
|
24
25
|
- CHANGELOG.md
|
|
25
26
|
- Gemfile
|
|
@@ -57,12 +58,12 @@ files:
|
|
|
57
58
|
- lib/procon_bypass_man/timer.rb
|
|
58
59
|
- lib/procon_bypass_man/version.rb
|
|
59
60
|
- procon_bypass_man.gemspec
|
|
60
|
-
homepage: https://github.com/
|
|
61
|
+
homepage: https://github.com/splaplapla/procon_bypass_man
|
|
61
62
|
licenses:
|
|
62
63
|
- MIT
|
|
63
64
|
metadata:
|
|
64
|
-
homepage_uri: https://github.com/
|
|
65
|
-
source_code_uri: https://github.com/
|
|
65
|
+
homepage_uri: https://github.com/splaplapla/procon_bypass_man
|
|
66
|
+
source_code_uri: https://github.com/splaplapla/procon_bypass_man
|
|
66
67
|
post_install_message:
|
|
67
68
|
rdoc_options: []
|
|
68
69
|
require_paths:
|