From 8fdcbce5ac4da834e5df591d9356aaf7b8a0f18d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Wed, 16 Oct 2013 13:15:08 +0200 Subject: [PATCH] Improve argument reading in Segment. --- src/path/Segment.js | 24 +++++++++++------------- 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/src/path/Segment.js b/src/path/Segment.js index 722c2ebb..56849317 100644 --- a/src/path/Segment.js +++ b/src/path/Segment.js @@ -125,20 +125,18 @@ var Segment = Base.extend(/** @lends Segment# */{ } else { point = arg0; } - } else if (count < 6) { - if (count == 2 && arg1.x === undefined) { - point = [ arg0, arg1 ]; - } else { - point = arg0; - // Doesn't matter if these arguments exist, SegmentPointcreate - // produces creates points with (0, 0) otherwise - handleIn = arg1; - handleOut = arg2; - } - } else if (count === 6) { + } else if (count === 2 && typeof arg0 === 'number') { point = [ arg0, arg1 ]; - handleIn = [ arg2, arg3 ]; - handleOut = [ arg4, arg5 ]; + } else if (count <= 3) { + point = arg0; + // Doesn't matter if these arguments exist, SegmentPointcreate + // produces creates points with (0, 0) otherwise + handleIn = arg1; + handleOut = arg2; + } else { + point = arg0 !== undefined ? [ arg0, arg1 ] : null; + handleIn = arg2 !== undefined ? [ arg2, arg3 ] : null; + handleOut = arg4 !== undefined ? [ arg4, arg5 ] : null; } this._point = new SegmentPoint(point, this); this._handleIn = new SegmentPoint(handleIn, this);