musa-dsl 0.23.16 → 0.23.17

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3b3e60773ea063a58c602a45986f15216e3015f945f89a49f352735cc1a87049
4
- data.tar.gz: 80f1c48c3ff0d433cd0c4bb8ff31ba6f68c18bf08324c765137fd092e4255554
3
+ metadata.gz: ef23a7cf410efe4d9fa21687e85678c5f2bbf4deca1255e188d199246d221e62
4
+ data.tar.gz: 5a97ebc91408d7d29a09ec441cecba974c8b994c83a982610288b52897cb1327
5
5
  SHA512:
6
- metadata.gz: 2159188db8b3f2155c700535b396431c3e962dcc89ab658d9c0ce802ad99938bbc16050b4ecedc75a32edc61960a1196ca82ec88ecd4d40d79749bc592ddb61e
7
- data.tar.gz: 78fd0289ba61f1269c03172e151f42841bc00472761d7653b613ce28f9e8d748a1e25576bae6b4a0d93b87e23a99d184c4b73d005402bf974db5e7662c24e62b
6
+ metadata.gz: 5ef6043e7356890a1806b73c2884f92cfbc1ad8c09f232f8c60254179737d85047bca63bfa1bd3a206a743aa11125d1ae61b3de3be3a88aac7b4fba1beade4b5
7
+ data.tar.gz: e3047601fd766e64103bbaa00c3cf14d28f509682b25fb1e6db2dac6878155827e6fb03bd3a324f11e877ee2765c071a51be43210557df678c2fbab92f652916
@@ -3,7 +3,7 @@ require_relative 'clock'
3
3
  module Musa
4
4
  module Clock
5
5
  class TimerClock < Clock
6
- def initialize(period = nil, ticks_per_beat: nil, bpm: nil, correction: nil, do_log: nil)
6
+ def initialize(period = nil, ticks_per_beat: nil, bpm: nil, correction: nil, logger: nil)
7
7
  do_log ||= false
8
8
 
9
9
  super()
@@ -20,7 +20,7 @@ module Musa
20
20
  @started = false
21
21
  @paused = false
22
22
 
23
- @do_log = do_log
23
+ @logger = logger
24
24
  end
25
25
 
26
26
  attr_reader :period, :ticks_per_beat, :bpm
@@ -55,7 +55,7 @@ module Musa
55
55
  @run = true
56
56
 
57
57
  while @run
58
- @timer = Timer.new(@period, correction: @correction, stop: true)
58
+ @timer = Timer.new(@period, correction: @correction, stop: true, logger: @logger)
59
59
 
60
60
  @timer.run do
61
61
  yield if block_given?
@@ -3,10 +3,11 @@ module Musa
3
3
  class Timer
4
4
  attr_accessor :period
5
5
 
6
- def initialize(period_in_seconds, correction: nil, stop: nil)
6
+ def initialize(period_in_seconds, correction: nil, stop: nil, logger: nil)
7
7
  @period = period_in_seconds.rationalize
8
8
  @correction = (correction || 0r).rationalize
9
9
  @stop = stop || false
10
+ @logger = logger
10
11
  end
11
12
 
12
13
  def run
@@ -21,6 +22,8 @@ module Musa
21
22
  @next_moment += @period
22
23
  to_sleep = (@next_moment + @correction) - Process.clock_gettime(Process::CLOCK_MONOTONIC)
23
24
 
25
+ @logger&.error "Timer spected to sleep a negative time #{to_sleep}" if to_sleep.negative?
26
+
24
27
  sleep to_sleep if to_sleep > 0.0
25
28
  end
26
29
 
data/lib/musa-dsl.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  module Musa
2
- VERSION = '0.23.16'
2
+ VERSION = '0.23.17'
3
3
  end
4
4
 
5
5
  require_relative 'musa-dsl/core-ext'
data/musa-dsl.gemspec CHANGED
@@ -1,7 +1,7 @@
1
1
  Gem::Specification.new do |s|
2
2
  s.name = 'musa-dsl'
3
- s.version = '0.23.16'
4
- s.date = '2021-09-13'
3
+ s.version = '0.23.17'
4
+ s.date = '2021-09-27'
5
5
  s.summary = 'A simple Ruby DSL for making complex music'
6
6
  s.description = 'Musa-DSL: A Ruby framework and DSL for algorithmic sound and musical thinking and composition'
7
7
  s.authors = ['Javier Sánchez Yeste']
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: musa-dsl
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.23.16
4
+ version: 0.23.17
5
5
  platform: ruby
6
6
  authors:
7
7
  - Javier Sánchez Yeste
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-09-13 00:00:00.000000000 Z
11
+ date: 2021-09-27 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: citrus