X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfa%2Futil%2Ffilter.py;h=ada44ba5d4f5263a74a73ae214673f32c0895c44;hb=bfcea75fd4f7d91b186f4f0e479db0e6f0a231ae;hp=5ab166403203ec56abeb404b242c658cdeeb09ef;hpb=ad2502fe33259cf1b23be45d4980f81bb8d8c919;p=sfa.git diff --git a/sfa/util/filter.py b/sfa/util/filter.py index 5ab16640..ada44ba5 100644 --- a/sfa/util/filter.py +++ b/sfa/util/filter.py @@ -1,5 +1,3 @@ -# $Id: Filter.py 14587 2009-07-19 13:18:50Z thierry $ -# $URL: svn+ssh://svn.planet-lab.org/svn/PLCAPI/trunk/PLC/Filter.py $ from types import StringTypes try: set @@ -8,7 +6,8 @@ except NameError: set = Set import time -import pgdb +try: import pgdb +except: pass from sfa.util.faults import * from sfa.util.parameter import Parameter, Mixed, python_type @@ -136,7 +135,7 @@ class Filter(Parameter, dict): # filter on fields if not modifiers['-']: if field not in self.fields: - raise GeniInvalidArgument, "Invalid filter field '%s'" % field + raise SfaInvalidArgument, "Invalid filter field '%s'" % field if isinstance(value, (list, tuple, set)): # handling filters like '~slice_id':[] @@ -186,7 +185,7 @@ class Filter(Parameter, dict): # sorting and clipping else: if field not in ('SORT','OFFSET','LIMIT'): - raise GeniInvalidArgument, "Invalid filter, unknown sort and clip field %r"%field + raise SfaInvalidArgument, "Invalid filter, unknown sort and clip field %r"%field # sorting if field == 'SORT': if not isinstance(value,(list,tuple,set)): @@ -199,7 +198,7 @@ class Filter(Parameter, dict): field = field[1:] order = 'DESC' if field not in self.fields: - raise GeniInvalidArgument, "Invalid field %r in SORT filter"%field + raise SfaInvalidArgument, "Invalid field %r in SORT filter"%field sorts.append("%s %s"%(field,order)) # clipping elif field == 'OFFSET': @@ -214,5 +213,4 @@ class Filter(Parameter, dict): clip_part += " ORDER BY " + ",".join(sorts) if clips: clip_part += " " + " ".join(clips) -# print 'where_part=',where_part,'clip_part',clip_part return (where_part,clip_part)