# # Copyright 2011 Free Software Foundation, Inc. # # This file is part of GNU Radio # # GNU Radio is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 3, or (at your option) # any later version. # # GNU Radio is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with GNU Radio; see the file COPYING. If not, write to # the Free Software Foundation, Inc., 51 Franklin Street, # Boston, MA 02110-1301, USA. # ''' GNU Radio package for the Symplex Hardware Driver. ''' ######################################################################## # Prepare shd swig module to make it more pythonic ######################################################################## def _prepare_shd_swig(): import shd_swig #some useful typedefs for the user setattr(shd_swig, 'freq_range_t', shd_swig.meta_range_t) setattr(shd_swig, 'gain_range_t', shd_swig.meta_range_t) #Make the python tune request object inherit from float #so that it can be passed in GRC as a frequency parameter. #The type checking in GRC will accept the tune request. class tune_request_t(shd_swig.tune_request_t, float): def __new__(self, *args): return float.__new__(self) def __float__(self): return self.target_freq setattr(shd_swig, 'tune_request_t', tune_request_t) #Make the python tune request object inherit from string #so that it can be passed in GRC as a string parameter. #The type checking in GRC will accept the device address. #Define the set/get item special methods for dict access. class device_addr_t(shd_swig.device_addr_t, str): def __new__(self, *args): return str.__new__(self) def __getitem__(self, key): return self.get(key) def __setitem__(self, key, val): self.set(key, val) setattr(shd_swig, 'device_addr_t', device_addr_t) #handle general things on all shd_swig attributes #Install the __str__ and __repr__ handlers if applicable #Create aliases for shd swig attributes to avoid the "_t" for attr in dir(shd_swig): myobj = getattr(shd_swig, attr) if hasattr(myobj, 'to_string'): myobj.__repr__ = lambda o: o.to_string().strip() if hasattr(myobj, 'to_pp_string'): myobj.__str__ = lambda o: o.to_pp_string().strip() if hasattr(myobj, 'to_bool'): myobj.__nonzero__ = lambda o: o.to_bool() if hasattr(myobj, 'to_int'): myobj.__int__ = lambda o: o.to_int() if hasattr(myobj, 'to_real'): myobj.__float__ = lambda o: o.to_real() if attr.endswith('_t'): setattr(shd_swig, attr[:-2], myobj) #Cast constructor args (FIXME swig handle overloads?) for attr in ('smini_source', 'smini_sink'): def constructor_factory(old_constructor): def constructor_interceptor(*args, **kwargs): args = list(args) kwargs = dict(kwargs) for index, key, cast in ( (0, 'device_addr', device_addr), (1, 'io_type', io_type), ): if len(args) > index: args[index] = cast(args[index]) if kwargs.has_key(key): kwargs[key] = cast(kwargs[key]) return old_constructor(*args, **kwargs) return constructor_interceptor setattr(shd_swig, attr, constructor_factory(getattr(shd_swig, attr))) #Aliases for deprecated constructors setattr(shd_swig, 'single_smini_source', shd_swig.smini_source) setattr(shd_swig, 'single_smini_sink', shd_swig.smini_sink) setattr(shd_swig, 'multi_smini_source', shd_swig.smini_source) setattr(shd_swig, 'multi_smini_sink', shd_swig.smini_sink) ######################################################################## # Initialize this module with the contents of shd swig ######################################################################## _prepare_shd_swig() from shd_swig import *