// https://wokwi.com/projects/416810674937171969
// show the RTC steaming along at real time during bogged down simulation

# include "RTClib.h"

RTC_DS1307 rtc;

char daysOfTheWeek[7][12] = {"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"};

void setupBOG(void);
void loopBOG(void);

void setup()
{
  Serial.begin(115200);
  Serial.println("\nJello Whirled!\n");

  setupRTC();
  setupBOG();
}

void setupRTC()
{
  if (!rtc.begin()) {
    Serial.println("Couldn't find RTC");
    Serial.flush();
    abort();
  }
}

void loop()
{
  loopRTC();
  loopBOG();
}

// advance and print a counter based on millis
// advance and print a counter based on the RTC

int millisCounter;
int rtcCounter;

void loopRTC()
{
  static unsigned long lastTime;
  unsigned long ms_now = millis();

  if (ms_now - lastTime >= 1000) {
    lastTime = ms_now;
    Serial.print("millis                  ");
    Serial.println(millisCounter);
        millisCounter++;
  }

  DateTime now = rtc.now();

  static byte lastSecond;
  byte thisSecond = now.second();
  if (lastSecond != thisSecond) {
    lastSecond = thisSecond;
    Serial.print("RTC            ");
    Serial.println(rtcCounter);
        rtcCounter++;
  }
}



mega:SCL
mega:SDA
mega:AREF
mega:GND.1
mega:13
mega:12
mega:11
mega:10
mega:9
mega:8
mega:7
mega:6
mega:5
mega:4
mega:3
mega:2
mega:1
mega:0
mega:14
mega:15
mega:16
mega:17
mega:18
mega:19
mega:20
mega:21
mega:5V.1
mega:5V.2
mega:22
mega:23
mega:24
mega:25
mega:26
mega:27
mega:28
mega:29
mega:30
mega:31
mega:32
mega:33
mega:34
mega:35
mega:36
mega:37
mega:38
mega:39
mega:40
mega:41
mega:42
mega:43
mega:44
mega:45
mega:46
mega:47
mega:48
mega:49
mega:50
mega:51
mega:52
mega:53
mega:GND.4
mega:GND.5
mega:IOREF
mega:RESET
mega:3.3V
mega:5V
mega:GND.2
mega:GND.3
mega:VIN
mega:A0
mega:A1
mega:A2
mega:A3
mega:A4
mega:A5
mega:A6
mega:A7
mega:A8
mega:A9
mega:A10
mega:A11
mega:A12
mega:A13
mega:A14
mega:A15
matrix1:V+
matrix1:GND
matrix1:DIN
matrix1:CS
matrix1:CLK
matrix1:V+.2
matrix1:GND.2
matrix1:DOUT
matrix1:CS.2
matrix1:CLK.2
matrix2:V+
matrix2:GND
matrix2:DIN
matrix2:CS
matrix2:CLK
matrix2:V+.2
matrix2:GND.2
matrix2:DOUT
matrix2:CS.2
matrix2:CLK.2
matrix3:V+
matrix3:GND
matrix3:DIN
matrix3:CS
matrix3:CLK
matrix3:V+.2
matrix3:GND.2
matrix3:DOUT
matrix3:CS.2
matrix3:CLK.2
matrix4:V+
matrix4:GND
matrix4:DIN
matrix4:CS
matrix4:CLK
matrix4:V+.2
matrix4:GND.2
matrix4:DOUT
matrix4:CS.2
matrix4:CLK.2
GND5VSDASCLSQWRTCDS1307+
ds1307:GND
ds1307:5V
ds1307:SDA
ds1307:SCL
ds1307:SQW