more variable name changes

This commit is contained in:
Mattias Põldaru 2011-02-18 09:53:40 +02:00
parent aac40357ae
commit 1651e42bca
5 changed files with 94 additions and 95 deletions

View File

@ -787,7 +787,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog):
verseId = unicode(item.data(QtCore.Qt.UserRole).toString()) verseId = unicode(item.data(QtCore.Qt.UserRole).toString())
verse_tag = verseId[0] verse_tag = verseId[0]
verse_num = verseId[1:] verse_num = verseId[1:]
sxml.add_verse_to_lyrics(verse_type, verse_num, sxml.add_verse_to_lyrics(verse_tag, verse_num,
unicode(item.text())) unicode(item.text()))
text = text + self.whitespace.sub(u' ', text = text + self.whitespace.sub(u' ',
unicode(self.verseListWidget.item(i, 0).text())) + u' ' unicode(self.verseListWidget.item(i, 0).text())) + u' '

View File

@ -127,11 +127,10 @@ class EditVerseForm(QtGui.QDialog, Ui_EditVerseDialog):
if match: if match:
verse_type = match.group(1) verse_type = match.group(1)
verse_type_index = VerseType.from_loose_input(verse_type) verse_type_index = VerseType.from_loose_input(verse_type)
regex = re.compile(r'(\d+)') verse_number = int(match.group(2))
verse_num = int(match.group(2))
if verse_type_index is not None: if verse_type_index is not None:
self.verseTypeComboBox.setCurrentIndex(verse_type_index) self.verseTypeComboBox.setCurrentIndex(verse_type_index)
self.verseNumberBox.setValue(verse_num) self.verseNumberBox.setValue(verse_number)
def setVerse(self, text, single=False, def setVerse(self, text, single=False,
tag=u'%s1' % VerseType.Tags[VerseType.Verse]): tag=u'%s1' % VerseType.Tags[VerseType.Verse]):

View File

@ -175,7 +175,7 @@ class VerseType(object):
if len(verse_name) > 1: if len(verse_name) > 1:
verse_index = VerseType.from_translated_string(verse_name) verse_index = VerseType.from_translated_string(verse_name)
if verse_index is None: if verse_index is None:
verseIndex = VerseType.from_string(verse_name) verse_index = VerseType.from_string(verse_name)
if verse_index is None: if verse_index is None:
verse_index = VerseType.from_translated_tag(verse_name) verse_index = VerseType.from_translated_tag(verse_name)
elif verse_index is None: elif verse_index is None:

View File

@ -161,8 +161,8 @@ class OpenSongImport(SongImport):
self.import_wizard.incrementProgressBar( self.import_wizard.incrementProgressBar(
unicode(translate('SongsPlugin.ImportWizardForm', unicode(translate('SongsPlugin.ImportWizardForm',
'Importing %s...')) % os.path.split(filename)[-1]) 'Importing %s...')) % os.path.split(filename)[-1])
songfile = open(filename) song_file = open(filename)
if self.do_import_file(songfile) and self.commit and \ if self.do_import_file(song_file) and self.commit and \
not self.stop_import_flag: not self.stop_import_flag:
self.finish() self.finish()
else: else:
@ -209,92 +209,92 @@ class OpenSongImport(SongImport):
verses = {} verses = {}
# keep track of verses appearance order # keep track of verses appearance order
our_verse_order = [] our_verse_order = []
# default versetype # default verse
versetype = u'v' verse_tag = u'v'
versenum = u'1' verse_num = u'1'
# for the case where song has several sections with same marker # for the case where song has several sections with same marker
inst = 1 inst = 1
lyrics = unicode(root.lyrics) lyrics = unicode(root.lyrics)
for thisline in lyrics.split(u'\n'): for this_line in lyrics.split(u'\n'):
# remove comments # remove comments
semicolon = thisline.find(u';') semicolon = this_line.find(u';')
if semicolon >= 0: if semicolon >= 0:
thisline = thisline[:semicolon] this_line = this_line[:semicolon]
thisline = thisline.strip() this_line = this_line.strip()
if not len(thisline): if not len(this_line):
continue continue
# skip guitar chords and page and column breaks # skip guitar chords and page and column breaks
if thisline.startswith(u'.') or thisline.startswith(u'---') \ if this_line.startswith(u'.') or this_line.startswith(u'---') \
or thisline.startswith(u'-!!'): or this_line.startswith(u'-!!'):
continue continue
# verse/chorus/etc. marker # verse/chorus/etc. marker
if thisline.startswith(u'['): if this_line.startswith(u'['):
# drop the square brackets # drop the square brackets
right_bracket = thisline.find(u']') right_bracket = this_line.find(u']')
content = thisline[1:right_bracket].lower() content = this_line[1:right_bracket].lower()
# have we got any digits? # have we got any digits?
# If so, verse number is everything from the digits # If so, verse number is everything from the digits
# to the end (even if there are some alpha chars on the end) # to the end (even if there are some alpha chars on the end)
match = re.match(u'(.*)(\d+.*)', content) match = re.match(u'(.*)(\d+.*)', content)
if match is not None: if match is not None:
versetype = match.group(1) verse_tag = match.group(1)
versenum = match.group(2) verse_num = match.group(2)
else: else:
# otherwise we assume number 1 and take the whole prefix as # otherwise we assume number 1 and take the whole prefix as
# the versetype # the verse tag
versetype = content verse_tag = content
versenum = u'1' verse_num = u'1'
inst = 1 inst = 1
if [versetype, versenum, inst] in our_verse_order \ if [verse_tag, verse_num, inst] in our_verse_order \
and verses.has_key(versetype) \ and verses.has_key(verse_tag) \
and verses[versetype].has_key(versenum): and verses[verse_tag].has_key(verse_num):
inst = len(verses[versetype][versenum])+1 inst = len(verses[verse_tag][verse_num])+1
our_verse_order.append([versetype, versenum, inst]) our_verse_order.append([verse_tag, verse_num, inst])
continue continue
# number at start of line.. it's verse number # number at start of line.. it's verse number
if thisline[0].isdigit(): if this_line[0].isdigit():
versenum = thisline[0] verse_num = this_line[0]
thisline = thisline[1:].strip() this_line = this_line[1:].strip()
our_verse_order.append([versetype, versenum, inst]) our_verse_order.append([verse_tag, verse_num, inst])
if not verses.has_key(versetype): if not verses.has_key(verse_tag):
verses[versetype] = {} verses[verse_tag] = {}
if not verses[versetype].has_key(versenum): if not verses[verse_tag].has_key(verse_num):
verses[versetype][versenum] = {} verses[verse_tag][verse_num] = {}
if not verses[versetype][versenum].has_key(inst): if not verses[verse_tag][verse_num].has_key(inst):
verses[versetype][versenum][inst] = [] verses[verse_tag][verse_num][inst] = []
# Tidy text and remove the ____s from extended words # Tidy text and remove the ____s from extended words
thisline = self.tidy_text(thisline) this_line = self.tidy_text(this_line)
thisline = thisline.replace(u'_', u'') this_line = this_line.replace(u'_', u'')
thisline = thisline.replace(u'|', u'\n') this_line = this_line.replace(u'|', u'\n')
verses[versetype][versenum][inst].append(thisline) verses[verse_tag][verse_num][inst].append(this_line)
# done parsing # done parsing
# add verses in original order # add verses in original order
for (versetype, versenum, inst) in our_verse_order: for (verse_tag, verse_num, inst) in our_verse_order:
vtag = u'%s%s' % (versetype, versenum) verse_def = u'%s%s' % (verse_tag, verse_num)
lines = u'\n'.join(verses[versetype][versenum][inst]) lines = u'\n'.join(verses[verse_tag][verse_num][inst])
self.add_verse(lines, vtag) self.add_verse(lines, verse_def)
# figure out the presentation order, if present # figure out the presentation order, if present
if u'presentation' in fields and root.presentation != u'': if u'presentation' in fields and root.presentation != u'':
order = unicode(root.presentation) order = unicode(root.presentation)
# We make all the tags in the lyrics lower case, so match that here # We make all the tags in the lyrics lower case, so match that here
# and then split into a list on the whitespace # and then split into a list on the whitespace
order = order.lower().split() order = order.lower().split()
for tag in order: for verse_def in order:
match = re.match(u'(.*)(\d+.*)', tag) match = re.match(u'(.*)(\d+.*)', verse_def)
if match is not None: if match is not None:
versetype = match.group(1) verse_tag = match.group(1)
versenum = match.group(2) verse_num = match.group(2)
if not len(versetype): if not len(verse_tag):
versetype = u'v' verse_tag = u'v'
else: else:
# Assume it's no.1 if there are no digits # Assume it's no.1 if there are no digits
versetype = tag verse_tag = verse_def
versenum = u'1' verse_num = u'1'
vtagString = u'%s%s' % (versetype, versenum) verse_def = u'%s%s' % (verse_tag, verse_num)
if verses.has_key(versetype) \ if verses.has_key(verse_tag) \
and verses[versetype].has_key(versenum): and verses[verse_tag].has_key(verse_num):
self.verse_order_list.append(vtagString) self.verse_order_list.append(verse_def)
else: else:
log.info(u'Got order %s but not in verse tags, dropping' log.info(u'Got order %s but not in verse tags, dropping'
u'this item from presentation order', vtagString) u'this item from presentation order', verse_def)
return True return True

View File

@ -200,39 +200,38 @@ class SongImport(QtCore.QObject):
return return
self.media_files.append(filename) self.media_files.append(filename)
def add_verse(self, versetext, versetag=u'v', lang=None): def add_verse(self, verse_text, verse_def=u'v', lang=None):
""" """
Add a verse. This is the whole verse, lines split by \\n. It will also Add a verse. This is the whole verse, lines split by \\n. It will also
attempt to detect duplicates. In this case it will just add to the verse attempt to detect duplicates. In this case it will just add to the verse
order. order.
``versetext`` ``verse_text``
The text of the verse. The text of the verse.
``versetag`` ``verse_def``
The verse tag can be V1/C1/B etc, or 'V' and 'C' (will count the The verse tag can be v1/c1/b etc, or 'v' and 'c' (will count the
verses/choruses itself) or None, where it will assume verse. verses/choruses itself) or None, where it will assume verse.
``lang`` ``lang``
The language code (ISO-639) of the verse, for example *en* or *de*. The language code (ISO-639) of the verse, for example *en* or *de*.
""" """
for (oldversetag, oldverse, oldlang) in self.verses: for (old_verse_def, old_verse, old_lang) in self.verses:
if oldverse.strip() == versetext.strip(): if old_verse.strip() == verse_text.strip():
# this verse is already present self.verse_order_list_generated.append(old_verse_def)
self.verse_order_list_generated.append(oldversetag)
self.verse_order_list_generated_useful = True self.verse_order_list_generated_useful = True
return return
if versetag[0] in self.versecounts: if verse_def[0] in self.verse_counts:
self.versecounts[versetag[0]] += 1 self.verse_counts[verse_def[0]] += 1
else: else:
self.versecounts[versetag[0]] = 1 self.verse_counts[verse_def[0]] = 1
if len(versetag) == 1: if len(verse_def) == 1:
versetag += unicode(self.versecounts[versetag[0]]) verse_def += unicode(self.versecounts[verse_def[0]])
elif int(versetag[1:]) > self.versecounts[versetag[0]]: elif int(verse_def[1:]) > self.versecounts[verse_def[0]]:
self.versecounts[versetag[0]] = int(versetag[1:]) self.versecounts[verse_def[0]] = int(verse_def[1:])
self.verses.append([versetag, versetext.rstrip(), lang]) self.verses.append([verse_def, versetext.rstrip(), lang])
self.verse_order_list_generated.append(versetag) self.verse_order_list_generated.append(verse_def)
def repeat_verse(self): def repeat_verse(self):
""" """
@ -277,28 +276,29 @@ class SongImport(QtCore.QObject):
verses_changed_to_other = {} verses_changed_to_other = {}
sxml = SongXML() sxml = SongXML()
other_count = 1 other_count = 1
for (versetag, versetext, lang) in self.verses: for (verse_def, verse_text, lang) in self.verses:
if versetag[0].lower() in VerseType.Tags: if verse_def[0].lower() in VerseType.Tags:
versetype = versetag[0].lower() verse_def = verse_def[0].lower()
else: else:
newversetag = u'%s%d' % (VerseType.Tags[VerseType.Other], new_verse_def = u'%s%d' % (VerseType.Tags[VerseType.Other],
other_count) other_count)
verses_changed_to_other[versetag] = newversetag verses_changed_to_other[verse_def] = new_verse_def
other_count += 1 other_count += 1
versetype = VerseType.Tags[VerseType.Other] verse_tag = VerseType.Tags[VerseType.Other]
log.info(u'Versetype %s changing to %s' , versetag, newversetag) log.info(u'Versetype %s changing to %s' , verse_def,
versetag = newversetag new_verse_def)
sxml.add_verse_to_lyrics(versetype, versetag[1:], versetext, lang) verse_def = new_verse_def
song.search_lyrics += u' ' + self.remove_punctuation(versetext) sxml.add_verse_to_lyrics(verse_tag, verse_def[1:], verse_text, lang)
song.search_lyrics += u' ' + self.remove_punctuation(verse_text)
song.search_lyrics = song.search_lyrics.lower() song.search_lyrics = song.search_lyrics.lower()
song.lyrics = unicode(sxml.extract_xml(), u'utf-8') song.lyrics = unicode(sxml.extract_xml(), u'utf-8')
if not len(self.verse_order_list) and \ if not len(self.verse_order_list) and \
self.verse_order_list_generated_useful: self.verse_order_list_generated_useful:
self.verse_order_list = self.verse_order_list_generated self.verse_order_list = self.verse_order_list_generated
for i, current_verse_tag in enumerate(self.verse_order_list): for i, current_verse_def in enumerate(self.verse_order_list):
if verses_changed_to_other.has_key(current_verse_tag): if verses_changed_to_other.has_key(current_verse_def):
self.verse_order_list[i] = \ self.verse_order_list[i] = \
verses_changed_to_other[current_verse_tag] verses_changed_to_other[current_verse_def]
song.verse_order = u' '.join(self.verse_order_list) song.verse_order = u' '.join(self.verse_order_list)
song.copyright = self.copyright song.copyright = self.copyright
song.comments = self.comments song.comments = self.comments
@ -343,8 +343,8 @@ class SongImport(QtCore.QObject):
+ u'========================================' + u'========================================'
print u'TITLE: ' + self.title print u'TITLE: ' + self.title
print u'ALT TITLE: ' + self.alternate_title print u'ALT TITLE: ' + self.alternate_title
for (versetag, versetext, lang) in self.verses: for (verse_def, verse_text, lang) in self.verses:
print u'VERSE ' + versetag + u': ' + versetext print u'VERSE ' + verse_def + u': ' + verse_text
print u'ORDER: ' + u' '.join(self.verse_order_list) print u'ORDER: ' + u' '.join(self.verse_order_list)
print u'GENERATED ORDER: ' + u' '.join(self.verse_order_list_generated) print u'GENERATED ORDER: ' + u' '.join(self.verse_order_list_generated)
for author in self.authors: for author in self.authors: