From 2e2ed8141881382fcdb32bc172d22f25e84d2cf0 Mon Sep 17 00:00:00 2001 From: s0600204 Date: Sat, 31 Aug 2019 16:37:09 +0100 Subject: [PATCH] Improve the approach to mapping one weekstart to another in WEEKLY --- src/ICal/ICal.php | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/ICal/ICal.php b/src/ICal/ICal.php index a16c54c..f9c916f 100644 --- a/src/ICal/ICal.php +++ b/src/ICal/ICal.php @@ -1313,11 +1313,8 @@ protected function processRecurrences() if (!empty($rrules['BYDAY'])) { // setISODate below uses the ISO-8601 specification of weeks: start on // a Monday, end on a Sunday. However, RRULEs (or the caller of the - // parser) may state an alternate WeeKSTart. In this case, we need to - // determine the point where days that ordinarily come after Monday now - // come before Monday. + // parser) may state an alternate WeeKSTart. $wkstTransition = 7; - if (empty($rrules['WKST'])) { if ($this->defaultWeekStart !== self::ISO_8601_WEEK_START) { $wkstTransition = array_search($this->defaultWeekStart, array_keys($this->weekdays)); @@ -1326,11 +1323,16 @@ protected function processRecurrences() $wkstTransition = array_search($rrules['WKST'], array_keys($this->weekdays)); } + $initialDayOfWeek = $frequencyRecurringDateTime->format('N'); $matchingDays = array_map( - function ($weekday) use ($wkstTransition) { + function ($weekday) use ($interval, $wkstTransition, $initialDayOfWeek) { $day = array_search($weekday, array_keys($this->weekdays)); + if ($day < $initialDayOfWeek) { + $day += 7; + } + if ($day >= $wkstTransition) { - $day -= 7; + $day += 7 * ($interval - 1); } // Ignoring alternate week starts, $day at this point will have a