Skip to content

Emoji renders as [?] boxes on iOS 26 simulator (Xcode 26) #56183

@Mile-Away

Description

@Mile-Away

Description

Emoji characters render as [?] placeholder boxes in React Native <Text> components on the iOS 26 simulator (Xcode 26.3, build 17C529). This affects all emoji — inline, standalone, flag sequences, and Unicode escape sequences.

Safari running in the same simulator renders emoji correctly, confirming the font (AppleColorEmoji) is present and registered. The issue is specific to React Native's CoreText text rendering path.

Steps to reproduce

  1. Create a new React Native project (tested with RN 0.84.1 via @react-native-community/cli)
  2. Add emoji to a <Text> component:
    <Text>Hello 🚀 World 🎨 Test ✅</Text>
    <Text>Pure emoji: 😀😃😄😁😆😅🤣😂</Text>
    <Text>Flags: 🇺🇸 🇨🇳 🇯🇵 🇬🇧</Text>
  3. Run on iOS 26 simulator (any device — iPhone 16, iPhone 17 Pro, etc.)
  4. All emoji appear as [?] boxes

Expected behavior

Emoji should render using the AppleColorEmoji font, as they do in Safari and native UIKit apps on the same simulator.

Actual behavior

All emoji render as [?] replacement characters/boxes.

Environment

  • React Native: 0.84.1 (also reproduced on 0.83.2)
  • JS Engine: Hermes (also tested with JSC — same result)
  • Architecture: New Architecture / Fabric (also tested with Old Architecture — same result)
  • Xcode: 26.3 (build 17C529)
  • iOS Simulator: 26.3.1 (23D8133)
  • macOS: Darwin 25.3.0 (arm64)

Investigation done

  • ✅ Confirmed AppleColorEmoji-160px.ttc exists in the simulator runtime at CoreAddition/AppleColorEmoji-160px.ttc
  • ✅ Confirmed font is registered (CTFontManagerRegisterFontsForURL returns "already exists")
  • ✅ Confirmed Safari in the same simulator renders emoji correctly
  • ✅ Tested Hermes vs JSC — no difference
  • ✅ Tested New Architecture vs Old Architecture — no difference
  • ✅ Tested RN 0.83.2 and 0.84.1 — both affected
  • ✅ Attempted RCTSetDefaultFontHandler with AppleColorEmoji in cascade list — no effect
  • ❌ Unable to test on iOS 18 simulator (Xcode 26 only ships iOS 26 runtime)

Notes

  • This may be an iOS 26 simulator-specific issue (real devices may be unaffected)
  • The root cause appears to be in how React Native's native text rendering (via CoreText/TextKit) resolves the emoji font cascade on iOS 26
  • No older iOS simulator runtimes are available through Xcode 26 to compare

Metadata

Metadata

Assignees

No one assigned

    Labels

    Needs: AttentionIssues where the author has responded to feedback.Needs: ReproThis issue could be improved with a clear list of steps to reproduce the issue.

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions