Merge remote-tracking branch 'origin/app-placement-new' into integration

This commit is contained in:
J. Nick Koston
2026-02-18 12:43:14 -06:00
2 changed files with 2 additions and 1 deletions

View File

@@ -675,6 +675,7 @@ void Application::yield_with_select_(uint32_t delay_ms) {
#ifndef __GXX_ABI_VERSION
#error "Application placement new requires Itanium C++ ABI (GCC/Clang)"
#endif
static_assert(std::is_default_constructible<Application>::value, "Application must be default-constructible");
// NOLINTNEXTLINE(cppcoreguidelines-avoid-non-const-global-variables)
alignas(Application) char app_storage[sizeof(Application)] asm("_ZN7esphome3AppE");

View File

@@ -513,7 +513,7 @@ async def to_code(config: ConfigType) -> None:
cg.add_global(cg.RawExpression("using std::max"))
# Construct App via placement new — see application.cpp for storage details
cg.add_global(cg.RawExpression("#include <new>"))
cg.add_global(cg.RawStatement("#include <new>"))
cg.add(cg.RawExpression("new (&App) Application()"))
cg.add(
cg.App.pre_setup(