class ProconBypassMan::Procon require "procon_bypass_man/procon/consts" require "procon_bypass_man/procon/mode_registry" require "procon_bypass_man/procon/macro_registry" require "procon_bypass_man/procon/layer_changer" require "procon_bypass_man/procon/button_collection" require "procon_bypass_man/procon/user_operation" require "procon_bypass_man/procon/flip_cache" require "procon_bypass_man/procon/press_button_aware" attr_accessor :user_operation def self.reset! @@status = { buttons: {}, current_layer_key: :up, ongoing_macro: MacroRegistry.load(:null), ongoing_mode: ModeRegistry.load(:manual), } end reset! def initialize(binary) self.user_operation = ProconBypassMan::Procon::UserOperation.new(binary.dup) end def status; @@status[:buttons]; end def ongoing_macro; @@status[:ongoing_macro]; end def ongoing_mode; @@status[:ongoing_mode]; end def current_layer_key; @@status[:current_layer_key]; end def current_layer ProconBypassMan::ButtonsSettingConfiguration.instance.layers[current_layer_key] end def apply! layer_changer = ProconBypassMan::Procon::LayerChanger.new(binary: user_operation.binary) if layer_changer.change_layer? @@status[:current_layer_key] = layer_changer.next_layer_key if layer_changer.pressed_next_layer? user_operation.set_no_action! return end if ongoing_macro.finished? current_layer.macros.each do |macro_name, options| if options[:if_pressed].all? { |b| user_operation.pressed_button?(b) } @@status[:ongoing_macro] = MacroRegistry.load(macro_name) end end end case current_layer.mode when :manual @@status[:ongoing_mode] = ModeRegistry.load(:manual) current_layer.flip_buttons.each do |button, options| if !options[:if_pressed] FlipCache.fetch(key: button, expires_in: options[:flip_interval]) do status[button] = !status[button] end next end if options[:if_pressed] && options[:if_pressed].all? { |b| user_operation.pressed_button?(b) } FlipCache.fetch(key: button, expires_in: options[:flip_interval]) do status[button] = !status[button] end else FlipCache.fetch(key: button, expires_in: options[:flip_interval]) do status[button] = false end end end else unless ongoing_mode.name == current_layer.mode @@status[:ongoing_mode] = ProconBypassMan::Procon::ModeRegistry.load(current_layer.mode) end if(binary = ongoing_mode.next_binary) self.user_operation.merge(target_binary: binary) end return end status end # @return [String] def to_binary if ongoing_mode.name != :manual return user_operation.binary end if ongoing_macro.ongoing? step = ongoing_macro.next_step or return(user_operation.binary) user_operation.press_button_only(step) return user_operation.binary end current_layer.disables.each do |button| user_operation.unpress_button(button) end current_layer.left_analog_stick_caps.each do |button, options| if button.nil? || button.all? { |b| user_operation.pressed_button?(b) } options[:force_neutral]&.each do |force_neutral_button| user_operation.unpress_button(force_neutral_button) end user_operation.apply_left_analog_stick_cap(cap: options[:cap]) end end current_layer.flip_buttons.each do |button, options| # 何もしないで常に連打 if !options[:if_pressed] && status[button] user_operation.press_button(button) next end # 押している時だけ連打 if options[:if_pressed] && options[:if_pressed].all? { |b| user_operation.pressed_button?(b) } if !status[button] user_operation.unpress_button(button) end options[:force_neutral]&.each do |force_neutral_button| user_operation.unpress_button(force_neutral_button) end end end current_layer.remaps.each do |from_button, to_buttons| if user_operation.pressed_button?(from_button) user_operation.unpress_button(from_button) # TODO 2重でpressしないようにしたい to_buttons[:to].each do |to_button| user_operation.press_button(to_button) end end end user_operation.binary end private def method_missing(name) if name.to_s =~ /\Apressed_[a-z]+\?\z/ user_operation.public_send(name) else super end end end