python-awips/awips/dataaccess/PyGeometryData.py

80 lines
2.6 KiB
Python
Raw Normal View History

2015-06-12 11:57:06 -06:00
##
# This software was developed and / or modified by Raytheon Company,
# pursuant to Contract DG133W-05-CQ-1067 with the US Government.
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
# U.S. EXPORT CONTROLLED TECHNICAL DATA
# This software product contains export-restricted data whose
# export/transfer/disclosure is restricted by U.S. law. Dissemination
# to non-U.S. persons whether in the United States or abroad requires
# an export license or other authorization.
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
# Contractor Name: Raytheon Company
# Contractor Address: 6825 Pine Street, Suite 340
# Mail Stop B8
# Omaha, NE 68106
# 402.291.0100
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
# See the AWIPS II Master Rights File ("Master Rights File.pdf") for
# further licensing information.
##
#
# Implements IGeometryData for use by native Python clients to the Data Access
# Framework.
2016-03-16 16:32:17 -05:00
#
#
2015-06-12 11:57:06 -06:00
# SOFTWARE HISTORY
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
# Date Ticket# Engineer Description
# ------------ ---------- ----------- --------------------------
# 06/03/13 dgilling Initial Creation.
# 01/06/14 #2537 bsteffen Share geometry WKT.
# 03/19/14 #2882 dgilling Raise an exception when getNumber()
2016-03-16 16:32:17 -05:00
# is called for data that is not a
2015-06-12 11:57:06 -06:00
# numeric Type.
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
#
2016-03-11 15:05:01 -07:00
from awips.dataaccess import IGeometryData
from awips.dataaccess import PyData
2015-06-12 11:57:06 -06:00
class PyGeometryData(IGeometryData, PyData.PyData):
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def __init__(self, geoDataRecord, geometry):
PyData.PyData.__init__(self, geoDataRecord)
self.__geometry = geometry
self.__dataMap = {}
tempDataMap = geoDataRecord.getDataMap()
for key, value in tempDataMap.items():
self.__dataMap[key] = (value[0], value[1], value[2])
def getGeometry(self):
return self.__geometry
2016-03-16 16:32:17 -05:00
def getParameters(self):
2015-06-12 11:57:06 -06:00
return self.__dataMap.keys()
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getString(self, param):
value = self.__dataMap[param][0]
return str(value)
2016-03-16 16:32:17 -05:00
def getNumber(self, param):
2015-06-12 11:57:06 -06:00
value = self.__dataMap[param][0]
2016-03-16 16:32:17 -05:00
t = self.getType(param)
if t == 'INT':
2015-06-12 11:57:06 -06:00
return int(value)
elif t == 'LONG':
return long(value)
elif t == 'FLOAT':
return float(value)
elif t == 'DOUBLE':
return float(value)
else:
raise TypeError("Data for parameter " + param + " is not a numeric type.")
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getUnit(self, param):
return self.__dataMap[param][2]
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getType(self, param):
return self.__dataMap[param][1]