Browse Source

make sure that on cursor metrical sig crossing we start at 0 ticks internally

master
Nils 3 years ago
parent
commit
6daf2d271e
  1. 10
      engine/track.py

10
engine/track.py

@ -557,7 +557,7 @@ class Track(object):
def right(self): def right(self):
if self.currentBlock().right(): #side effect: actual moving if self.currentBlock().right(): #side effect: actual moving
self.parseRight() self.parseRight() #we parse the previous item
return 1 return 1
elif self.state.blockindex+1 < len(self.blocks): #block counts from 0, len from 1. If block+1 is smaller than the amount of blocks this means this is not the final block. elif self.state.blockindex+1 < len(self.blocks): #block counts from 0, len from 1. If block+1 is smaller than the amount of blocks this means this is not the final block.
#block end. This is already the previous state. right now we are in the next block already. #block end. This is already the previous state. right now we are in the next block already.
@ -600,7 +600,10 @@ class Track(object):
break break
def measureStart(self): def measureStart(self):
if self.state.ticksSinceLastMeasureStartLive < 0: #upbeats are lower than 0 if self.state.ticksSinceLastMeasureStartLive == 0:
#Already at the start
return
elif self.state.ticksSinceLastMeasureStartLive < 0: #upbeats are lower than 0
while not self.state.ticksSinceLastMeasureStartLive == 0: while not self.state.ticksSinceLastMeasureStartLive == 0:
self.right() self.right()
else: else:
@ -614,6 +617,8 @@ class Track(object):
else: else:
self.head() self.head()
assert self.state.ticksSinceLastMeasureStartLive == 0, self.state.ticksSinceLastMeasureStartLive
def startOfBlock(self): def startOfBlock(self):
currentBlock = self.currentBlock() #we stay in this block so this doesn't need to change. currentBlock = self.currentBlock() #we stay in this block so this doesn't need to change.
while not currentBlock.localCursorIndex == 0: while not currentBlock.localCursorIndex == 0:
@ -792,6 +797,7 @@ class Track(object):
self.state.keySignatures.append(item) self.state.keySignatures.append(item)
elif isinstance(item, MetricalInstruction): elif isinstance(item, MetricalInstruction):
self.state.metricalInstructions.append(item) self.state.metricalInstructions.append(item)
self.state.ticksSinceLastMeasureStartLive = 0 #by definition.
elif isinstance(item, DynamicSignature): elif isinstance(item, DynamicSignature):
self.state.dynamicSignatures.append(item) self.state.dynamicSignatures.append(item)
self.state.dynamicRamp = None #reset self.state.dynamicRamp = None #reset

Loading…
Cancel
Save