ingo@2853: import ogr ingo@2853: ingo@2853: from importer import Importer ingo@2853: ingo@2853: TABLE_NAME="lines" ingo@2853: PATH="Geodaesie/Linien" ingo@3654: NAME="Lines" ingo@2853: ingo@2853: ingo@2853: class Line(Importer): ingo@2853: ingo@2853: def getPath(self, base): ingo@2853: return "%s/%s" % (base, PATH) ingo@2853: ingo@2853: ingo@2853: def getTablename(self): ingo@2853: return TABLE_NAME ingo@2853: ingo@2853: ingo@3654: def getName(self): ingo@3654: return NAME ingo@3654: ingo@3654: ingo@2853: def isGeometryValid(self, geomType): ingo@2861: return geomType == 2 or geomType == -2147483646 ingo@2853: ingo@2853: ingo@2853: def isShapeRelevant(self, name, path): ingo@2853: return True ingo@2853: ingo@2853: ingo@2853: def createNewFeature(self, featureDef, feat, **args): ingo@2861: newFeat = ogr.Feature(featureDef) ingo@2861: geometry = feat.GetGeometryRef() ingo@2861: geometry.SetCoordinateDimension(2) ingo@2861: ingo@2861: newFeat.SetGeometry(geometry) ingo@2861: newFeat.SetField("name", args['name']) ingo@2853: ingo@2853: if self.IsFieldSet(feat, "river_id"): ingo@2853: newFeat.SetField("river_id", feat.GetField("river_id")) ingo@2853: else: ingo@2853: newFeat.SetField("river_id", self.river_id) ingo@2853: ingo@2853: if self.IsFieldSet(feat, "TYP"): ingo@2853: newFeat.SetField("kind", feat.GetFieldAsDouble("TYP")) ingo@2853: else: ingo@2861: newFeat.SetField("kind", "DAMM") ingo@2853: ingo@2853: if self.IsFieldSet(feat, "Z"): ingo@2853: newFeat.SetField("z", feat.GetFieldAsDouble("Z")) ingo@2853: else: ingo@2861: newFeat.SetField("z", 9999) ingo@2853: ingo@2853: return newFeat ingo@2853: