Acknowledged

Given that a newer SDK is required to build for CIQ 5.x devices, what does this mean for existing apps on devices that were upgraded from CIQ 4 to CIQ 5 (e.g. FR955, Fenix 7, etc)? Do these apps just break?

Background:

- it has always by my understanding that if you build an app for a device with a given SDK, then that app should continue to work regardless of future firmware updates (in general). This ofc excludes situations where:

  - the new firmware update has a bug or breaking change

  - the existing app has a dormant bug which is exposed by a legit change in new firmware. e.g. newer firmware has a change where Weather.CurrentConditions.observationLocationName is null, and this caused several existing watchfaces to crash because they assume that field will never be null. But that's an application error, since that field has always been typed to be possibly null

- CIQ 5.* devices require various 7.X (or 8.X) SDKs to run properly

- Compilers have a check to ensure you don't try to build a a too-new device with a too-old device

- Due to a bug in this check, where older compilers (pre 7.2.0) seem to incorrectly believe that SDK version X can build any device with CIQ version X (or lower), it's possible for an SDK 6.X compiler to build an app for CIQ 5 devices. However, it's very possible that such an app will crash when it's run in the simulator or the device (we've already seen "bug reports" about this

- The existing crop of devices that came out with CIQ 4 (e.g. fr955, fr965, fenix7) have all been updated to CIQ 5. As far as I know, this is the first time that existing devices have received a major CIQ update since the move from CIQ 1 to CIQ 2.

- Someone in the CIQ team already clarified that CIQ 5 devices require apps to be built with newer SDKs.

So here's what I don't understand.

The two following statements seem to be mutually exclusive:

- If an app is built for a device with an existing SDK (e.g. SDK 6.4.0) it will continue (in general) to work on the device for all future firmware updates

- Devices with CIQ 5.* require a 7.X or 8.X SDK

The problem is that it was entirely possible to build an app for an fr955 (for example) with SDK 6.4.0 in the past, when fr955 was only on CIQ 4. If I installed such an app on my fr955 when it had CIQ 4, it would expect it to continue to work now that my device is on CIQ 5.

So how can it be possible that going forward, a 7.X or 8.X SDK is required to build for my fr955?

What am I missing? Has something also changed with the device files that's relevant here?

Parents
  • I will also reiterate that the move from CIQ 4 to CIQ 5 is the first time in a long time that existing devices have received a major CIQ version update (the last time was CIQ 1 to 2, almost 9 years ago).

    In the past:

    - CIQ 2 devices never received CIQ 3

    - CIQ 3 devices never received CIQ 4 (in fact this was the impetus for the "CIQ system level" scheme, which is a version scheme created to track parallel updates to both CIQ 3 and CIQ 4 device). So for example, something major like the introduction of the graphics pool (and the requirement to change code related to buffered bitmaps) would not break any existing apps that were already installed on a CIQ 3 device, since no CIQ 3 device would be able to receive a CIq 4 update.

    I also don't remember any reports of existing apps breaking during the update to CIQ 1 to CIQ 2, but that was a long time ago.

    I guess what I'm saying is that if indeed CIQ 5 firmware is not compatible with apps built for CIQ 4, this would seemingly be the first time in a long time that apps would automatically break (in general), due to a firmware update.

    But then again, have we seen mass reports of apps breaking due to firmware updates (other than the observationLocationName thing)?

    If it was possible for existing apps to break due to firmware updates, wouldn't we expect Garmin to take steps here to warn users or devs (maybe even disable apps that haven't been updated, although that would surely be wildly unpopular)? (Other than posting stuff in the forums like "Connect IQ developers need to be constantly updating their apps in order to keep up with device firmware updates")

Comment
  • I will also reiterate that the move from CIQ 4 to CIQ 5 is the first time in a long time that existing devices have received a major CIQ version update (the last time was CIQ 1 to 2, almost 9 years ago).

    In the past:

    - CIQ 2 devices never received CIQ 3

    - CIQ 3 devices never received CIQ 4 (in fact this was the impetus for the "CIQ system level" scheme, which is a version scheme created to track parallel updates to both CIQ 3 and CIQ 4 device). So for example, something major like the introduction of the graphics pool (and the requirement to change code related to buffered bitmaps) would not break any existing apps that were already installed on a CIQ 3 device, since no CIQ 3 device would be able to receive a CIq 4 update.

    I also don't remember any reports of existing apps breaking during the update to CIQ 1 to CIQ 2, but that was a long time ago.

    I guess what I'm saying is that if indeed CIQ 5 firmware is not compatible with apps built for CIQ 4, this would seemingly be the first time in a long time that apps would automatically break (in general), due to a firmware update.

    But then again, have we seen mass reports of apps breaking due to firmware updates (other than the observationLocationName thing)?

    If it was possible for existing apps to break due to firmware updates, wouldn't we expect Garmin to take steps here to warn users or devs (maybe even disable apps that haven't been updated, although that would surely be wildly unpopular)? (Other than posting stuff in the forums like "Connect IQ developers need to be constantly updating their apps in order to keep up with device firmware updates")

Children
No Data