Godley/MuseParse

View on GitHub
MuseParse/classes/ObjectHierarchy/ItemClasses/BarlinesAndMarkers.py

Summary

Maintainability
D
1 day
Test Coverage
from MuseParse.classes.ObjectHierarchy.ItemClasses import BaseClass


class Barline(BaseClass.Base):

    """
    Barline class.


    # Optional inputs

        - style: style of barline to display

        - repeat: bool whether it's a repeat or not

        - ending: instance of the EndingMark class representing which ending number this barline is, see below

        - repeatNum: number of repeats. Default is 2
    """

    def __init__(self, **kwargs):
        if "style" in kwargs:
            if kwargs["style"] is not None:
                self.style = kwargs["style"]
                '''style of the barline to display'''
        if "repeat" in kwargs:
            if kwargs["repeat"] is not None:
                self.repeat = kwargs["repeat"]
                '''boolean whether it's a repeat or not'''
        if "ending" in kwargs:
            if kwargs["ending"] is not None:
                self.ending = kwargs["ending"]
                '''instance of EndingMark class below'''
        if "repeatNum" in kwargs:
            if kwargs["repeatNum"] is not None:
                self.repeatNum = kwargs["repeatNum"]
            else:
                self.repeatNum = 2
        else:
            self.repeatNum = 2
        BaseClass.Base.__init__(self)

    def toLily(self):
        lilystring = ""
        if not hasattr(self, "ending") and not hasattr(self, "repeat"):
            lilystring += " \\bar \""
            if hasattr(self, "style"):
                options = {
                    "light-light": "||",
                    "heavy-light": ".|",
                    "light-heavy": "|.",
                    "heavy-heavy": "..",
                    "dotted": ";",
                    "dashed": "!",
                    "none": "",
                    "tick": "'"}
                if self.style in options:
                    lilystring += options[self.style]
                else:
                    lilystring += "|"
                lilystring += "\""
            else:
                lilystring += "\""
        else:

            if hasattr(self, "repeat"):
                if self.repeat == "forward":
                    lilystring = " \\repeat volta " + \
                        str(self.repeatNum) + " {"
                if self.repeat == "backward" and not hasattr(self, "ending"):
                    lilystring += "}"
                if self.repeat == "forward-barline":
                    lilystring = " \\bar \".|:\""
                if self.repeat == "backward-barline":
                    lilystring = " \\bar \":|.\""
                if self.repeat == "backward-barline-double":
                    lilystring = " \\bar \":|.|:\""
            if hasattr(self, "ending"):
                lilystring += self.ending.toLily()

        return lilystring


class EndingMark(BaseClass.Base):

    """
    Ending marker. Used particularly in lilypond where there are repeats with alternative endings.


    # Optional inputs

        - number: the ending which this is, e.g ending 1 or 2

        - type: the type of ending marker it is. If it comes at the beginning of a bar, it's anything that isn't
                discontinue or stop. If it's at the end, opposite is true.
    """

    def __init__(self, **kwargs):
        if "number" in kwargs:
            self.number = kwargs["number"]
        if "type" in kwargs:
            self.type = kwargs["type"]
        BaseClass.Base.__init__(self)

    def toLily(self):
        lilystring = ""
        if hasattr(self, "number"):
            if self.number == 1:
                lilystring = "\\alternative {\n"

        else:
            lilystring = "\\alternative {"
        if not hasattr(
                self,
                "type") or (
                self.type != "discontinue" and self.type != "stop"):
            lilystring += "{"
        if hasattr(self, "type"):
            if self.type == "stop":
                lilystring = "}"
            if self.type == "discontinue":
                lilystring = "}\n}"
        return lilystring


class Transposition(BaseClass.Base):

    def __init__(self, **kwargs):
        BaseClass.Base.__init__(self)
        if "diatonic" in kwargs:
            self.diatonic = kwargs["diatonic"]
        if "chromatic" in kwargs:
            self.chromatic = kwargs["chromatic"]
        if "octave" in kwargs:
            self.octave = kwargs["octave"]