from smnp.library.model import Function, CombinedFunction from smnp.library.signature import varargSignature, ofTypes, listOf from smnp.note.interval import intervalToString from smnp.note.model import Note from smnp.type.model import Type from smnp.type.value import Value _signature1 = varargSignature(ofTypes(Type.NOTE, Type.INTEGER)) def _function1(env, vararg): withoutPauses = [note.value for note in vararg if note.type == Type.NOTE] if len(withoutPauses) < 2: return Value(Type.LIST, []) semitones = [Note.checkInterval(withoutPauses[i-1], withoutPauses[i]) for i in range(1, len(withoutPauses))] return Value(Type.LIST, [Value(Type.STRING, intervalToString(s)) for s in semitones]).decompose() _signature2 = varargSignature(listOf(Type.NOTE, Type.INTEGER)) def _function2(env, vararg): return Value(Type.LIST, [_function1(env, arg.value) for arg in vararg]).decompose() function = CombinedFunction( 'interval', Function(_signature1, _function1), Function(_signature2, _function2) )