firebase / firebase-cpp-sdk

Firebase C++ SDK
http://firebase.google.com
Apache License 2.0
276 stars 114 forks source link

[FR] Linux - Yocto support #1508

Open jwinarske opened 8 months ago

jwinarske commented 8 months ago

Feature proposal

Describe your use case and/or feature request here.

Enable cross compiling using Yocto/open-embedded. This enables building for any machine/architecture from an x86_64 host.

Building a Yocto image is a custom Linux distro and the defacto standard for commercial products on Linux.

A Yocto build has two build passes:

  1. native (tools that run on host side)
  2. target (binaries that run on the device)

There are no cases where you build both in the same pass.

Yocto will cache all source in a "fetch" stage. This enable LTS scenarios. Meaning no network access during configuration and compile. This enables rebuilding from source at a much later time without network access.

Something else Yocto enables is reproducible builds. Meaning you build today or ten years, and the bits will be identical.

Yocto has multiple branches. Some have LTS support. For a given branch it sticks with a particular set of versions. Kirkstone for example is on clang-14. Dunfell is on clang-12.

The standard approach in scenarios with complex CMake integrations is to use the system libraries, as these are controlled in Yocto. Then one patches core source as needed based on the Yocto branch.

One example of a Yocto recipe that deals with a complex CMake project is Google Filament: https://github.com/jwinarske/meta-vulkan/blob/kirkstone/recipes-graphics/filament/filament-vk_1.4.92.bb

The base recipe is dependent on the -native variant. So the host tools are built in the -native build pass, then are used in the target build pass.

My feature request / proposal is to enable support for Yocto while maintaining existing build behavior. I am willing to do the work (submit the PRs) if there is willingness to collaborate.

google-oss-bot commented 8 months ago

I couldn't figure out how to label this issue, so I've labeled it for a human to triage. Hang tight.

jwinarske commented 8 months ago

Currently I have flutter-cpp-sdk v116.0 working on x86_64 (desktop) Linux with flutterfire: cloud_firestore, firebase_auth, firebase_storage, and firebase_core.

jwinarske commented 7 months ago

I have a naive first pass working here: https://github.com/meta-flutter/meta-flutter/pull/376/files Helpful to identify the patterns upstream would need to adopt.

Tested building for aarch64 - raspberrypi4

chadrockey commented 4 months ago

+1