"""
Simple module with a :func:`play` function that can be used to verify that SCAMP is installed successfully.
"""
#  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  #
#  This file is part of SCAMP (Suite for Computer-Assisted Music in Python)                      #
#  Copyright © 2020 Marc Evanstein <marc@marcevanstein.com>.                                     #
#                                                                                                #
#  This program is free software: you can redistribute it and/or modify it under the terms of    #
#  the GNU General Public License as published by the Free Software Foundation, either version   #
#  3 of the License, or (at your option) any later version.                                      #
#                                                                                                #
#  This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;     #
#  without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.     #
#  See the GNU General Public License for more details.                                          #
#                                                                                                #
#  You should have received a copy of the GNU General Public License along with this program.    #
#  If not, see <http://www.gnu.org/licenses/>.                                                   #
#  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++  #
from . import Session
[docs]def play(show_lilypond: bool = False, show_xml: bool = False) -> None:
    """
    Simple method for determining if scamp was installed correctly. Should play a sequence of pitches telescoping
    towards middle C.
    :param show_lilypond: shows a PDF LilyPond rendering of demo played (requires abjad package).
    :param show_xml: opens up a MusicXML rendering of the music played
    """
    s = Session()
    piano = s.new_part()
    if show_xml or show_lilypond:
        s.start_transcribing()
    s.set_rate_target(4, 10)
    for n in reversed(range(1, 40)):
        piano.play_note(60 + n * (-1) ** n, 1, 0.25)
    piano.play_note(60, 1.0, 6.25)
    if show_xml or show_lilypond:
        score = s.stop_transcribing().to_score()
        if show_lilypond:
            score.show()
        if show_xml:
            score.show_xml()