- test driver script is now executable

- adds more generic procedure to perform implicit casting, thus eliminating duplicate code



git-svn-id: http://galileo.dmi.unict.it/svn/relational/trunk@271 014f5005-505e-4b48-8d0a-63407b615a7c
This commit is contained in:
LtWorf 2011-03-03 09:27:53 +00:00
parent 3b0392e867
commit 1e51f9784f
2 changed files with 21 additions and 28 deletions

View File

@ -93,6 +93,19 @@ class relation (object):
return other.projection(list(self.header.attributes)) return other.projection(list(self.header.attributes))
return None return None
def _autocast(self,string):
'''Depending on the regexp matched by the string,
it will perform automatic casting'''
tmpstring=rstring(string)
if len(tmpstring)>0 and tmpstring.isdigit():
return int(tmpstring)
elif len(tmpstring)>0 and tmpstring.isFloat():
return float(tmpstring)
elif len(tmpstring)>0 and tmpstring.isDate():
return rdate(tmpstring)
else:
return tmpstring
def selection(self,expr): def selection(self,expr):
'''Selection, expr must be a valid boolean expression, can contain field names, '''Selection, expr must be a valid boolean expression, can contain field names,
constant, math operations and boolean ones.''' constant, math operations and boolean ones.'''
@ -102,16 +115,7 @@ class relation (object):
for i in self.content: for i in self.content:
#Fills the attributes dictionary with the values of the tuple #Fills the attributes dictionary with the values of the tuple
for j in range(len(self.header.attributes)): for j in range(len(self.header.attributes)):
tmpstring=rstring(i[j]) attributes[self.header.attributes[j]]=self._autocast(i[j])
if len(tmpstring)>0 and tmpstring.isdigit():
attributes[self.header.attributes[j]]=int(tmpstring)
elif len(tmpstring)>0 and tmpstring.isFloat():
attributes[self.header.attributes[j]]=float(tmpstring)
elif len(tmpstring)>0 and tmpstring.isDate():
attributes[self.header.attributes[j]]=rdate(tmpstring)
else:
attributes[self.header.attributes[j]]=tmpstring
try: try:
if eval(expr,attributes): if eval(expr,attributes):
@ -442,15 +446,8 @@ class relation (object):
#new_content=[] #New content of the relation #new_content=[] #New content of the relation
for i in self.content: for i in self.content:
for j in range(len(self.header.attributes)): for j in range(len(self.header.attributes)):
#Giving to the field it's right format (hopefully) attributes[self.header.attributes[j]]=self._autocast(i[j])
if i[j].isdigit():
attributes[self.header.attributes[j]]=int(i[j])
elif rstring(i[j]).isFloat():
attributes[self.header.attributes[j]]=float(i[j])
elif isDate(i[j]):
attributes[self.header.attributes[j]]=rdate(i[j])
else:
attributes[self.header.attributes[j]]=i[j]
if eval(expr,attributes): #If expr is true, changing the tuple if eval(expr,attributes): #If expr is true, changing the tuple
affected+=1 affected+=1
new_tuple=list(i) new_tuple=list(i)
@ -496,14 +493,9 @@ class relation (object):
new_content=set() #New content of the relation new_content=set() #New content of the relation
for i in self.content: for i in self.content:
for j in range(len(self.header.attributes)): for j in range(len(self.header.attributes)):
if i[j].isdigit(): attributes[self.header.attributes[j]]=self._autocast(i[j])
attributes[self.header.attributes[j]]=int(i[j])
elif rstring(i[j]).isFloat():
attributes[self.header.attributes[j]]=float(i[j])
elif isDate(i[j]):
attributes[self.header.attributes[j]]=rdate(i[j])
else:
attributes[self.header.attributes[j]]=i[j]
if not eval(expr,attributes): if not eval(expr,attributes):
affected-=1 affected-=1
new_content.add(i) new_content.add(i)

View File

@ -1,3 +1,4 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# coding=UTF-8 # coding=UTF-8
# Relational # Relational