#!/usr/bin/env python3 ## # @file main.py # # @brief This program converts supported tablature source files to a printable format # # @section description Description # Creates Song objects of all tablatures it can find in a given directory or its subdirectories # Supported inputs currently: Any .txt file, as long as each section has a corresponding [] delimiter # Supported outputs currently: PNG format # Song objects are then parsed into separate metadata information and sections # Sections contain lines of lyric and corresponding tablature data # The program then tries to fit these sections within the chosen output dimensions (currently A4) # as best as it can, shrinking or growing sections to fit the remaining space # # @section notes Notes # - Splitting raw text into lyric and tablature info is very basic at the moment. # We need a better way to classify & split the various channels (raw tab, lyrics, chords, more?) that can be expected in tablature # # @section todo TODO # - Various prints should be printed at specific log levels, to easily switch between debug, info or warnings only import lib.chordFinder import lib.dataStructures import lib.initSongs import lib.transpose import lib.config import output2img def main(): # Init config file lib.config.initConfig() # Init Song objects for all songs with compatible inputs songs = lib.initSongs.getSongObjects() # Convert all songs into sections for song in songs: print("Start parsing of file '{}'...".format(song.inputFile)) # Initialise internal data structures song.initSections() if not song.isParsed: print("Song was not initialized correctly. Skipping...") continue # Fit all sections on each page, resizes down if it does not fit on width song.fitSectionsByWidth() # Prerender: calculate Pages, and move sections into Pages song.sectionsToPages() # Optimalisation: try to fill whitespace while song.canFillWhitespace(): print("Resizing down to fit whitespace more efficiently") song.resizeAllSections(-1) song.sectionsToPages() # Optimalisation: increase font size as long as the amount of pages does not increase or we cause an overflow on width song.increaseWhileSameAmountOfPages() # Parse as PNG a4 # Create subdirectory where we will output our images targetDirectory = song.outputLocation + "-a4-png" print("Successfully parsed file. Writing output to '{}'\n".format(targetDirectory)) # Write out metadata and sections, as many as can fit on one page output2img.outputToImage(targetDirectory, song) if __name__ == "__main__": main()