Tämän moduulin ohjeistuksen voi tehdä sivulle Moduuli:Kitarakirja/Lily/ohje

--- Funktioita nuottien Lilypond-muotoon muuttamiseksi.
local p = {}

local notedata = require "Moduuli:Kitarakirja/Nuottidata"


--- Lilypondin käyttämä oktaavimerkintä.
-- param index:     oktaavi suhteessa keski-c:hen
-- param notename:  nuotin nimi
-- return:          oktaavi Lilypond-muodossa, esim. ","
function p.getOctaveString(index, notename)
   -- Merkitään eri oktaaviin kuin soivat
   if notename == "b♯" or notename == "b𝄪" then
      index = index - 1
   elseif notename == "c♭" or notename == "c𝄫" then
      index = index + 1
   end
   
   if index < 0 then
      return string.rep(",", -index)
   elseif index > 0 then
      return string.rep("'", index)
   end
   return ""
end

--- Muuttaa annetut nuotinnimet Lilypondin käyttämään muotoon.
-- Esim. { "c", "e♭", "g" } -> "c", "ees", "g"
-- param args: Nuotinnimitaulukko.
function p.lilyfy(arg)
   local output = {}

   for i, notename in ipairs(arg) do
      local out = notename
      out = string.gsub(out, "♯", "is")
      out = string.gsub(out, "𝄪", "isis")
      out = string.gsub(out, "♭", "es")
      out = string.gsub(out, "𝄫", "eses")
      table.insert(output, out)
   end

   return unpack(output)
end


--- Palauttaa nuotinnimen oktaaveineen Lilypond-notaatiolla, esim. "dis''".
-- param noteset:  nuottijoukko josta nuotinnimi valitaan
-- param index:    absoluuttinen nuotin indeksi (jossa 36 vastaa keski-c:tä)
function p.toLilynote(noteset, index)
   local octave = math.floor((index - (notedata.getNoteIndex("c", 0))) / 12)
   local note   = noteset[index % 12 + 1]

   if index == -1 then
      return ""
   end
   
   return p.lilyfy{note} .. p.getOctaveString(octave, note)
end

--- Palauttaa nuotinnimen oktaaveineen Lilypond-notaatiolla.
-- Esim. { { "", 2} } -> "dis''".
-- param args: taulukko nuotti–oktaavi-pareja
function p.toLilyformat(args)
   local output = {}

   for i, note in ipairs(args) do
      local notename = note[1]
      local octave = note[2]
      table.insert(output, p.lilyfy{notename} .. p.getOctaveString(octave, notename))
   end

   return output
end


return p