本仓库包含 Firebase C++ SDK 源代码,支持 Android、iOS 和桌面平台。它包括以下 Firebase 库:
<img height="200" align="right" src="https://yellow-cdn.veclightyear.com/835a84d5/ccc221ed-18f3-4b54-aaf7-878cfd00a573.png" />Google Analytics for Firebase | |
Firebase 身份验证 | Firebase 实时数据库 |
Firebase 动态链接 | Cloud Firestore |
Cloud Functions for Firebase | Firebase 邀请 |
Firebase 云消息传递 | Firebase 远程配置 |
Cloud Storage for Firebase |
Firebase 是一个应用开发平台,提供工具帮助你构建、增长和变现你的应用。关于 Firebase 的更多信息可以在这里找到。
<br>你可以使用以下命令克隆仓库:
<details><summary><h2>先决条件</h2></summary>git clone https://github.com/firebase/firebase-cpp-sdk.git
以下先决条件适用于所有平台。请确保根据需要将任何目录添加到你的 PATH 中。
注意:安装 Python 后,你可以使用以下命令安装所需的包:
在为桌面平台构建库时,需要以下先决条件。
可以通过谷歌搜索找到 OpenSSL 的预构建包,如果 CMake 无法找到安装路径,请使用命令行选项 -DOPENSSL_ROOT_DIR=[Open SSL Dir]。
可以使用 Homebrew 安装所需的依赖项:
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" source $HOME/.rvm/scripts/rvm brew install cmake python3 sudo chown -R $(whoami) /usr/local
在为 Android 构建库时,需要以下先决条件。
重要 - Strings EULA
在构建过程中使用 Strings 之前,你需要先从命令行运行一次 Strings 以接受 EULA。
注意,我们包含了 Gradle 包装器,如果使用它,将为你获取必要版本的 Gradle。
在为 iOS 或 tvOS 构建库时,需要以下先决条件。
</details> <details><summary><h2>构建</h2></summary>构建使用 CMake 生成必要的构建文件,并支持源外构建。 以下 CMake 目标可用于构建和链接:
功能 | CMake 目标 |
---|---|
App(基础库) | firebase_app |
Google Analytics for Firebase | firebase_analytics |
Firebase 身份验证 | firebase_auth |
Firebase 实时数据库 | firebase_database |
Firebase 动态链接 | firebase_dynamic_links |
Cloud Firestore | firebase_firestore |
Cloud Functions for Firebase | firebase_functions |
Firebase 邀请 | firebase_invites |
Firebase 云消息传递 | firebase_messaging |
Firebase 远程配置 | firebase_remote_config |
Cloud Storage for Firebase | firebase_storage |
例如,要构建 Analytics 库,你可以运行以下命令:
mkdir desktop_build && cd desktop_build cmake .. cmake --build . --target firebase_analytics
请注意,你可以在配置步骤中提供不同的生成器,例如,要为 Visual Studio 2017 生成项目,你可以运行:
cmake -G "Visual Studio 15 2017" ..
有关生成器的更多信息,请访问 https://cmake.org/cmake/help/latest/manual/cmake-generators.7.html。
默认情况下,在构 建 SDK 时,CMake 过程会下载构建所需的任何第三方依赖项。这个逻辑在 cmake/external_rules.cmake 中,以及随附的 cmake/external/CMakeLists.txt 中。如果你想为这些依赖项提供自己的目录,可以覆盖 [[dependency_name]]_SOURCE_DIR
和 [[dependency_name]]_BINARY_DIR
。如果未提供二进制目录,它将默认为给定的源目录,并附加 -build
。
例如,要提供自定义的 flatbuffer 目录,你可以运行:
cmake -DFLATBUFFERS_SOURCE_DIR=/tmp/flatbuffers ..
二进制目录将自动设置为 /tmp/flatbuffers-build
。
目前,可以通过这种方式提供的第三方库有:
库 |
---|
CURL |
FLATBUFFERS |
LIBUV |
NANOPB |
UWEBSOCKETS |
ZLIB |
Firebase C++ SDK 附带了一个 CMake 配置文件,用于为 iOS 平台构建库,cmake/toolchains/ios.cmake。要使用它构建,在运行 CMake 配置时,通过 CMAKE_TOOLCHAIN_FILE 定义传入它。例如,要为 iOS 构建 Auth 库,你可以运行以下命令:
mkdir ios_build && cd ios_build cmake -DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/ios.cmake .. cmake --build . --target firebase_auth
Firebase C++ SDK 附带了一个 CMake 配置文件,用于为 tvOS 平台构建库,cmake/toolchains/apple.toolchain.cmake。要使用它构建,在运行 CMake 配置时,通过 CMAKE_TOOLCHAIN_FILE 定义传入它。例如,要为 tvOS 构建 Auth 库,你可以运行以下命令:
mkdir tvos_build && cd tvos_build cmake -DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/apple.toolchain.cmake -DPLATFORM=TVOS .. cmake --build . --target firebase_auth
Firebase C++ SDK 附带了一个辅助 Python 脚本,用于构建同时适用于 iOS 和 tvOS 的 XCFrameworks。这很有帮助,因为我们可以在同一个 Xcode 项目中为 iOS 和 tvOS 目标使用相同的交付物。
# 安装先决条件(如 cocoapods) ./build_scripts/tvos/install_prereqs.sh python3 scripts/gha/build_ios_tvos.py -s . -b ios_tvos_build
在为 Android 构建 Firebase C++ SDK 时,使用 gradle 和 CMake 相结合来生成库文件。每个 Firebase 功能都是根目录下的一个独立 gradle 子项目。构建每个 Firebase 库的发布版本的 gradle 目标如下:
功能 | Gradle 目标 |
---|---|
App (基础库) | :app:assembleRelease |
Google Analytics for Firebase | :analytics:assembleRelease |
Firebase Authentication | :auth:assembleRelease |
Firebase Realtime Database | :database:assembleRelease |
Firebase Dynamic Links | :dynamic_links:assembleRelease |
Cloud Firestore | :firestore:assembleRelease |
Cloud Functions for Firebase | :functions:assembleRelease |
Firebase Invites | :invites:assembleRelease |
Firebase Cloud Messaging | :messaging:assembleRelease |
Firebase Remote Config | :remote_config:assembleRelease |
Cloud Storage for Firebase | :storage:assembleRelease |
例如,要构建 Analytics 库的发布版本,你可以在根目录下运行以下命令:
./gradlew :analytics:assembleRelease
请注意,作为构建过程的一部分,每个库都会生成一个应该包含在你的应用程序中的 proguard 文件。生成的文件位于每个库的构建目录中。例如,Analytics 的 proguard 文件会生成到 analytics/build/analytics.pro
。
此仓库中的每个 Firebase SDK 都包含一系列单元测试。这些测试由 CI 系统构建和执行,以验证更改和拉取请求。
提供的 test_windows_x32.bat
、test_windows_x64.bat
、test_linux.sh
和 test_mac_x64.sh
脚本分别在 Windows32、Windows64、Linux 和 MacOS 主机上通过 ctest 构建 SDK 并执行单元测试。这些脚本位于仓库的基目录中。
本仓库的内容根据 Apache License, version 2.0 许可。
你对 Firebase 的使用受 Firebase 服务条款 的约束。
AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公 助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高 效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同 传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献 解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。
一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型
Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号