TextBuilder
  • August 21, 2025

Introduction


Text composition in SwiftUI can often be cumbersome, especially when there’s logic affecting its format and content.

TextBuilder leverages the power of Swift Result Builders to solve this problem. TextBuilder mimics SwiftUI’s ViewBuilder to make for a familiar experience at the point of use.

Usage


TextBuilder offers 3 ready-made builders out of the box, depending on which text separator you need.

Default (unspaced)

 

@TextBuilder
var loremIpsum: Text {
Text(“Lorem”).underline().foregroundColor(.blue)
Text(“ipsum dolor”)
Text(“sit”).bold()
Text(“amet, consectetur”)
}

With Spaces

@TextBuilderWithSpaces
var loremIpsum: Text {
Text(“Lorem”).underline().foregroundColor(.blue)
Text(“ipsum dolor”)
Text(“sit”).bold()
Text(“amet, consectetur”)
}

Multiline

 

 

@TextBuilderWithNewlines
var loremIpsum: Text {
Text(“Lorem”).underline().foregroundColor(.blue)
Text(“ipsum dolor”)
Text(“sit”).bold()
Text(“amet, consectetur”)
}

Pro Tip ✨

TextBuilder accepts String types directly as if they were plain Text, and also provides a String.text computed var to remove unwanted code noise when Text is explicitly needed.

@TextBuilderWithNewlines
var loremIpsum: Text {
“Lorem”.text.underline().foregroundColor(.blue)
“ipsum dolor”
“sit”.text.bold()
“amet, consectetur”
}

Other Separators

There are two options to customize the separator used to compose your Text.

First, you can use Text.init(separator:content:):

var loremIpsum: Text {
Text(separator: ” 🍆 “) {
“Lorem”.text.underline().foregroundColor(.blue)
“ipsum dolor”
“sit”.text.bold()
“amet, consectetur”
}
}

But if you prefer to keep using a result builder, you can:

struct EggplantSeparator: TextBuilderSeparator {
static var separator: String? { ” 🍆 ” }
}

@TextBuilderWith<EggplantSeparator>
var loremIpsum: Text {
“Lorem”.text.underline().foregroundColor(.blue)
“ipsum dolor”
“sit”.text.bold()
“amet, consectetur”
}


Benchmarks


MacBook Pro (14-inch, 2021)
Apple M1 Pro (10 cores, 8 performance and 2 efficiency)
32 GB Memory

$ swift run -c release Benchmarks

name time std iterations
————————————————
Result Builder 1875.000 ns ± 26.15 % 729940
Initializer 2542.000 ns ± 16.88 % 540826

GitHub


View Github

YOU MIGHT ALSO LIKE...
MijickPopups Hero

  Popups Alerts Resizable Sheets Banners

SwiftUI Tooltip

This package provides you with an easy way to show tooltips over any SwiftUI view, since Apple does not provide ...

SimpleToast for SwiftUI

SimpleToast is a simple, lightweight, flexible and easy to use library to show toasts / popup notifications inside iOS or ...

SSToastMessage

Create Toast Views with Minimal Effort in SwiftUI Using SSToastMessage. SSToastMessage enables you to effortlessly add toast notifications, alerts, and ...

ToastUI

A simple way to show toast in SwiftUI   Getting Started • Documentation • Change Log