aheinecke@5004: try: aheinecke@5004: from osgeo import ogr aheinecke@5077: except ImportError: aheinecke@5004: import ogr ingo@2861: ingo@2861: from importer import Importer ingo@2861: ingo@2861: TABLE_NAME="floodplain" ingo@2861: PATH="Hydrologie/Hydr.Grenzen" ingo@3654: NAME="Floodplains" ingo@2861: ingo@2861: ingo@2861: class Floodplain(Importer): ingo@2861: ingo@2861: def getPath(self, base): ingo@2861: return "%s/%s" % (base, PATH) ingo@2861: ingo@2861: ingo@2861: def getTablename(self): ingo@2861: return TABLE_NAME ingo@2861: ingo@2861: ingo@3654: def getName(self): ingo@3654: return NAME ingo@3654: ingo@3654: ingo@2861: def isGeometryValid(self, geomType): ingo@2861: return geomType == 3 or geomType == 6 ingo@2861: ingo@2861: ingo@2861: def isShapeRelevant(self, name, path): tom@7440: return name.lower().find("talaue") >= 0 ingo@2861: ingo@2861: ingo@2861: def createNewFeature(self, featureDef, feat, **args): ingo@2861: newFeat = ogr.Feature(featureDef) ingo@2861: geometry = feat.GetGeometryRef() ingo@2861: ingo@2861: newFeat.SetGeometry(geometry) ingo@2861: newFeat.SetField("name", args['name']) ingo@2861: aheinecke@5242: if args['path'].lower().endswith("/talaue.shp") and \ aheinecke@5242: not "sonstige" in args['path'].lower(): aheinecke@5242: newFeat.SetField("kind_id", 1) # offical aheinecke@5242: else: aheinecke@5242: newFeat.SetField("kind_id", 0) # misc aheinecke@5242: ingo@2861: if self.IsFieldSet(feat, "river_id"): ingo@2861: newFeat.SetField("river_id", feat.GetField("river_id")) ingo@2861: else: ingo@2861: newFeat.SetField("river_id", self.river_id) ingo@2861: ingo@2861: return newFeat ingo@2861: