view py/cigar.py @ 7:fc1c7b6fb7b6 draft

planemo upload commit e96b43f96afce6a7b7dfd4499933aad7d05c955e-dirty
author thondeboer
date Tue, 15 May 2018 18:12:29 -0400
parents 6e75a84e9338
children
line wrap: on
line source

import re

class CigarString:
	def __init__(self, stringIn=None, listIn=None):

		if stringIn == None and listIn == None:
			print '\nError: CigarString object not initialized.\n'
			exit(1)

		self.cigarData = []

		if stringIn != None:
			self.joinCigar(j_stringIn=stringIn)

		if listIn != None:
			self.joinCigar(j_listIn=listIn)


	def stringToList(self, s):

		cigarDat = []
		letters = re.split(r"\d+",s)[1:]
		numbers = [int(n) for n in re.findall(r"\d+",s)]
		dReserve = 0
		for i in xrange(len(letters)):
			if letters[i] == 'D':
				dReserve = numbers[i]
			if letters[i] == 'M' or letters[i] == 'I':
				if dReserve:
					cigarDat += ['D'*dReserve+letters[i]] + [letters[i]]*(int(numbers[i])-1)
				else:
					cigarDat += [letters[i]]*int(numbers[i])
				dReserve = 0
		return cigarDat


	def listToString(self, l):

		symbols      = ''
		currentSym   = l[0]
		currentCount = 1
		if 'D' in currentSym:
			currentSym   = currentSym[-1]
		for k in xrange(1,len(l)):
			nextSym = l[k]
			if len(nextSym) == 1 and nextSym == currentSym:
				currentCount += 1
			else:
				symbols += str(currentCount) + currentSym
				if 'D' in nextSym:
					symbols += str(nextSym.count('D')) + 'D'
					currentSym   = nextSym[-1]
				else:
					currentSym   = nextSym
				currentCount = 1
		symbols += str(currentCount) + currentSym
		return symbols

	def getList(self):

		return self.cigarData


	def getString(self):

		return self.listToString(self.cigarData)


	def joinCigar(self, j_stringIn=None, j_listIn=None):

		if j_stringIn == None and j_listIn == None:
			print '\nError: Invalid join operation in CigarString\n'
			exit(1)

		if j_stringIn != None:
			self.cigarData += self.stringToList(j_stringIn)

		if j_listIn != None:
			self.cigarData += j_listIn


	def insertCigarElement(self, pos, i_stringIn=None, i_listIn=None):

		if i_stringIn == None and i_listIn == None:
			print '\nError: Invalid insertion operation in CigarString\n'
			exit(1)

		if pos < 0 or pos >= len(self.cigarData):
			print '\nError: Invalid insertion position in CigarString\n'
			exit(1)

		if i_stringIn != None:
			self.cigarData = self.cigarData[:pos] + self.stringToList(i_stringIn) + self.cigarData[pos:]

		if i_listIn != None:
			self.cigarData = self.cigarData[:pos] + i_listIn + self.cigarData[pos:]


if __name__ == '__main__':
	print 'testing CigarString class...'

	str1 = '50M10D7I23M'
	str2 = '10I25M'
	iPos = 20
	myCigar  = CigarString(stringIn=str1)
	myCigar.insertCigarElement(iPos,i_stringIn=str2)
	print str1,'+',str2,'[inserted at position',str(iPos)+']','=',myCigar.getString()