protected override void Process(IFCAnyHandle ifcCurve) { base.Process(ifcCurve); IFCAnyHandle pnt = IFCImportHandleUtil.GetRequiredInstanceAttribute(ifcCurve, "Pnt", false); if (pnt == null) { return; } IFCAnyHandle dir = IFCImportHandleUtil.GetRequiredInstanceAttribute(ifcCurve, "Dir", false); if (dir == null) { return; } XYZ pntXYZ = IFCPoint.ProcessScaledLengthIFCCartesianPoint(pnt); XYZ dirXYZ = IFCUnitUtil.ScaleLength(IFCPoint.ProcessIFCVector(dir)); ParametericScaling = dirXYZ.GetLength(); if (MathUtil.IsAlmostZero(ParametericScaling)) { Importer.TheLog.LogWarning(ifcCurve.StepId, "Line has zero length, ignoring.", false); return; } Curve = Line.CreateUnbound(pntXYZ, dirXYZ / ParametericScaling); }