Hi everyone,
I thought about sharing something with you all, and adding my humble contribution to our snippet library.
I'm currently working on a new project that will include midi files. I built a custom browser to list and play them but I needed a way to allow the user to sort these files, either by type, tempo, length, etc...
So this snippet is built to sort midi files, but obviously you'll be able to modify it to sort other file types.
It's not that complex but I tried (read: banged my head) to find the best and most condensed way to do this, so here's my method.
If you got a better solution, feel free to share !
const MIDIPlayer1 = Synth.getMidiPlayer("MIDI Player1");
const midiFiles = MIDIPlayer1.getMidiFileList();
const lblDisplayFiles = Content.getComponent("lblDisplayFiles");
// I'll leave you the task of handling how you want to add filters to this array... :)
// For this example you can do it manually, but you can add as many filters as you want.
const filterArray = ["2bars"];
/* --------------
We'll assume a file-naming system like this :
"FileName_Type_Feel_Tempo_Length"
i.e.: "MidiLoop1_Groove_Straight_120bpm_2bars.mid"
What we want is to get all files that match one or more words that we'll call 'filters'
The function goes like this :
1 - We'll push the midiFiles array into a local array f.
2 - The result of each filtering iteration i will be stored into another array into f.
3 - We'll iterate through f as many times as there are filters.
i.e. if there are 3 filters, we'll end up with :
f[0] = allFiles;
f[1] = allFiles - filteredFiles_1;
f[2] = filteredFiles_1 - filteredFiles_2;
f[3] = filteredFiles_2 - filteredFiles_3;
filterResult = filteredFiles_3;
-------------- */
inline function filterFilesLoop(files, filters)
{
// Start with f[0] = all midi files: so we begin to filter all available files.
local f = [midiFiles];
// This will contain the filtered files that we want the function to return.
local filterResult = [];
// Check: if there are no filters
if(filters.length == 0)
{
filterResult = midiFiles;
}
else
{
for(i = 0; i < filters.length; i++)
{
// Add as many empty arrays as filters
f.push([]);
// If the filter exists
if(isDefined(filters[i]))
{
// Go through each file of f[i] to check if the file contains the filter
for(j = 0; j < f[i].length; j++)
{
// if the file contains the filter
if(f[i][j].contains(filters[i]))
// Add the file to the next array, which will be analyzed further to filter the files even more
f[i+1].push(f[i][j]);
}
}
// the resulting array must be the last one, no matter how much filters are used
filterResult = f[i+1];
}
}
lblDisplayFiles.set("text", trace(filterResult));
return filterResult;
}
// Calling the function...
const filteredFiles = filterFilesLoop(midiFiles, filterArray);
HiseSnippet 1859.3ocsXs0aajaEdF4nsUS6VzEnO1GHzKQdiihjbtA6l1jXYGnVmDCKuaKfgg.0LbzvXNjpb3XG0Eo+P5ux9On8bHmYzL1dS85zU.9B44B+NW4g5HsJjkkozd9cNY0Rlm+ut8zURSxdITtzaxXO+eW62NY7DxAbAKiLUoMb4BuWuZIMKiE446uwaPN86bOO6m+8e50TAUFxVukm22q3grC4oby5cO5k+EtPb.MhcBOsF2O9kSBUx8TBUNfpMZOvaIM7b5B16nHasZ64+U6GwMJ8TC0vx77u2qUQqllntT53+64Y74BFtXn2TPQtsOPIhPDi65sWBWDcTo0m4AZ4n09hMb9Bvz4Q7p8W6S9sVBj0RT2e32pI71nA7FVGdCpAua.RspAoeQY3wBIAcESagxuwEdb6LrAP1KWqYRyT1eOmck.RAoSzfqsdr6PkZ49RJ.un5aiZeNv5zkrlD723VaqC+r1pGZV1bLL0XsYeOmY+MsmFp4KMqof19up8DogoiofwU2vc7505e1o8dJfCooeJ8b1AZXQkD8d5fAaQfes4tAAPFWlgfdxBGI4EDacP+ELyZOdut0c1cAIcBlVBdPrZJoTXjzg7LSuJADyEi4YKA1JEqDnfH6oRWpjvhdcuBe3IF7nGQlbegfHXzKXjUpbhIgQLzryIpXRBUFIfRTBDDrDujJMDihPihHwbAX8Y3RSBOiP0Z5p986S1YSTsGnzt8YejltT3TdHURhTDNXkTYNUHVsEYdtohFpWZFRbUk9g0kGc+Rmqi1qvSDL2S6NZNUm08rcaRmEU5PbqsqvrxdU93spqJqC4aIOrwmff+JC8PPBQdJiPQAXOTRSQ+R1pLCKkH3mybF6Njftnhw9KyvzsYGvXhYmvfnvrCYxEljtA79r96P5hQSDMCm8FsRcAa1TilxWjXlMbzf4KSmYsp9.V6BfHgZHWxbQ.t0qCQWB3Bs.B1.YHkZBSHP7l.d+TkF3WoiJHdo0NBQQtegy89jffSf.dbtLzvURxBEnpFlSPmgjGRb9fk4YI1Dj04n1nNgKwjBhPAZuXq39AcFARhpWyxxEFLihQA74Nbz+wg+RsGLmbIzAmLmQxfV.rnBUJUvwoqeJnd2tBQNEfnUqxW.ptJ8w.WDXSdPE.wM3mBiFTPGaLfviqQc6R5aU3oXxHR9R.WlDqiH9zAmA4Rf+yZ56BaLr9F.nZj2MaHxxnypx+p1+ZbNB4b6qy4nqw41.m1MN14Sew0oGzLAl7sOJHfKg53Zw4qVPDWuXHayfeHnCTCCch0FmCXswaC9tjtcHYJLobNaAWhojN4sbQufxEXyeGqfS2kcDiErU4OPIaG6QcBltYSAfJXCEUWBqx1pmiWVDXpm2BmslYx0x0mSSuzoUmzdIrvy2oYrWVB8rfN73dkIJBaAK4EufLXyfNfOoyUzZkc.J+SAcXhLVAeJcONvvfcgL6+.ooBg8dvC.EZ4Dgzqp01C5TXV4R3souU3BTZer.r2omAMpfkEBOItlqB51B2MX4FrCd1XVLD2iJsnS4msIdvtSFk9MppZmxZSFVnFCrhd0PzaU3rbDKhOY0NUqxPS9CNS9CnICJnxd+fydKOW7fuMpzFK.8b5GNqeIOWyTV6Bqzm8JIHpx9nw4IgR5DNXck8XnRpX0+.yqx01FLqycKUBbw0ELosIZwo.H4ACOyECJPkKPfg9heAHwT0vC6v45bklCWJMmYoInv+Csn2By5fF13gh2ullW0ZLylTlCSfXC6Wod2Bicwv+mvrNHgu4E68yXvs8Fv36tEAtRAFOotJ1DAsqXoQQxtAftpJnTx2oLr2K6Y6E.jHWkTb7MRCm8PqDBX.mahLNet9yIXOYd5bldKxETQNqhQX5slSG191McXnaTnZLpjSjby6Wxj+Xiu6UL+D7ee2jwTCEFe1uXOfukL3cKHD7Gyt.dKhapxNsGyxN2nVZ4sXnKXaik5WWLy4gz4LgGOBmB8JgMuOtdX3+3KWUeAFK8ZIa09z.Bo6Obzwu+Ou+dmL6f2e338O9SXCbxECGL35yQ7jqLGwVeF4G8ruH42dzWj3O8weQh+7uHoekPbGkGmya6YSvL20h9rmeKk7IyfHu3mnfGOVmmBEQUHNIONVvlMb3feJRWf4eLgCNy6RdjIAJz7+8s77RXHBwU+KeOOpfuPlZSv+p1BVrwiAEmTa8m+F2vatfG4phxETSyW9hO2uf.zDnw6tv2VIy3lUMdh3+udN7sEheS6i3vH02LFacCXDeo8OCXr3KQ3qauebLKzrFf2q8A+sed9FC7NVkiWg8VpQygdSseWd5TUtNjAmtTBy5fYCsv1kt0Cv0nGXJL4rcw+A9TPbHt1uf3vRhdozPHKLz05G+ZJ9k1c.LIseCMcZ+VbMYnm85f59Yb1qYggMU00DbzcUvsuqB936pfO4tJ3SuqB9r6pfO++sf3qaeUtQk5Ja77d6Q6auK02u5KEBZU7eA7rNWPK