now using String refinement

Events Director module renamed

patch bump
This commit is contained in:
onyx-and-iris 2023-08-29 22:55:11 +01:00
parent 3a0f298045
commit 4c4746fe8a
4 changed files with 19 additions and 17 deletions

View File

@ -28,8 +28,8 @@ module OBSWS
ALL = LOW_VOLUME | HIGH_VOLUME
end
module EventDirector
include Util::String
module Director
using Util::CoreExtensions
def observers
@observers ||= {}
@ -50,13 +50,13 @@ module OBSWS
end
def fire(event, data)
observers[snakecase(event).to_sym]&.each { |block| data.empty? ? block.call : block.call(data) }
observers[event.snakecase.to_sym]&.each { |block| data.empty? ? block.call : block.call(data) }
end
end
class Client
include Logging
include EventDirector
include Events::Director
include Mixin::TearDown
include Mixin::OPCodes

View File

@ -1,16 +1,17 @@
module OBSWS
module Mixin
module Meta
include Util::String
using Util::CoreExtensions
def make_field_methods(*params)
params.each do |param|
define_singleton_method(snakecase(param.to_s)) { @resp[param] }
define_singleton_method(param.to_s.snakecase) { @resp[param] }
end
end
end
class MetaObject
using Util::CoreExtensions
include Mixin::Meta
def initialize(resp, fields)
@ -21,7 +22,7 @@ module OBSWS
def empty? = @fields.empty?
def attrs = @fields.map { |f| snakecase(f.to_s) }
def attrs = @fields.map { |f| f.to_s.snakecase }
end
# Represents a request response object

View File

@ -1,15 +1,16 @@
module OBSWS
module Util
module String
def camelcase(s)
s.split("_").map(&:capitalize).join
end
module CoreExtensions
refine String do
def camelcase
split("_").map(&:capitalize).join
end
def snakecase(s)
s
.gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2')
.gsub(/([a-z\d])([A-Z])/, '\1_\2')
.downcase
def snakecase
gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2')
.gsub(/([a-z\d])([A-Z])/, '\1_\2')
.downcase
end
end
end
end

View File

@ -11,7 +11,7 @@ module OBSWS
end
def patch
1
2
end
def to_a