-
Notifications
You must be signed in to change notification settings - Fork 222
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
VoicingDictionary discussion #230
Comments
Could not agree more, that's much better. To integrate the idea of #227 a dictionary entry could look like this: { type: "shell", intervals: [...], chords: [...] }
/* */ get could take a type string instead:
This then filters the list and returns all entries that contain chord or an alias of chord (inside the chords property). |
On second thought, I not sure about add / remove, as this always requires 2 function calls.. Using a custom set of voicings should be as easy as possible. What about: get(chord: string, type?: string, dictionary = VoicingDictionary.all()) here, we could optionally pass an array of the VoicingDictionary format. Maybe we should also omit the type param, as it's easy as VoicingDictionary.get('7').filter(({type}) => type === 'xxx')) .. but now it's time for me to sleep 😴 |
The aim of this issue is to publish the first voicing package: Voicing Dictionary.
I create a new issue for this, instead of following #227 because I want to broaden the discussion. /cc @felixroos
First of all, to follow conventions of other tonal dictionaries, we don't have several dictionaries (like triads, lefthand, and all) but one dictionary with properties. I imagine something like
VoiceDictionary.get("m7")
and you get something like:where each object is of type
Voice
. I think is responsibility of the user to filter voices by type, for example.The advantage of this IMO is that makes easier to extend in the future (without breaking changes) and it's more flexible (you can decide how to query the dictionary)
And that leads to a second thing: I want to keep separated the internal structure from the external interface. We can use your data file structure or another, but we have to think better what to expose (the missing
Voice
type)Again, following other modules, I imagine the API of this module to something like this:
I know this is not the normal functional pattern, but I think it has the user comodity of having one (customisable) dictionary
How does it fit with your idea and with #227?
The text was updated successfully, but these errors were encountered: