Skip to content

Commit 8c865b6

Browse files
authored
Base64 must relinquish use of OutputBuffer on error (#700)
1 parent 4a6aa00 commit 8c865b6

File tree

2 files changed

+25
-9
lines changed

2 files changed

+25
-9
lines changed

Sources/FoundationEssentials/OutputBuffer.swift

+21-9
Original file line numberDiff line numberDiff line change
@@ -193,10 +193,16 @@ extension String {
193193
initializing: buffer.baseAddress.unsafelyUnwrapped,
194194
capacity: capacity
195195
)
196-
try initializer(&output)
197-
let initialized = output.relinquishBorrowedMemory()
198-
assert(initialized.baseAddress == buffer.baseAddress)
199-
return initialized.count
196+
do {
197+
try initializer(&output)
198+
let initialized = output.relinquishBorrowedMemory()
199+
assert(initialized.baseAddress == buffer.baseAddress)
200+
return initialized.count
201+
} catch {
202+
// Do this regardless of outcome
203+
_ = output.relinquishBorrowedMemory()
204+
throw error
205+
}
200206
}
201207
)
202208
}
@@ -216,11 +222,17 @@ extension Data {
216222
initializing: buffer.baseAddress.unsafelyUnwrapped,
217223
capacity: capacity
218224
)
219-
try initializer(&output)
220-
let initialized = output.relinquishBorrowedMemory()
221-
assert(initialized.baseAddress == buffer.baseAddress)
222-
buffer[initialized.count..<buffer.count].initialize(repeating: 0)
223-
return initialized.count
225+
do {
226+
try initializer(&output)
227+
let initialized = output.relinquishBorrowedMemory()
228+
assert(initialized.baseAddress == buffer.baseAddress)
229+
buffer[initialized.count..<buffer.count].initialize(repeating: 0)
230+
return initialized.count
231+
} catch {
232+
// Do this regardless of outcome
233+
_ = output.relinquishBorrowedMemory()
234+
throw error
235+
}
224236
}
225237
}
226238
assert(count <= self.count)

Tests/FoundationEssentialsTests/DataTests.swift

+4
Original file line numberDiff line numberDiff line change
@@ -1804,6 +1804,10 @@ extension DataTests {
18041804
XCTAssertEqual("SGVsbG8gV29ybGQ=", base64, "trivial base64 conversion should work")
18051805
}
18061806

1807+
func test_base64Data_bad() {
1808+
XCTAssertNil(Data(base64Encoded: "signature-not-base64-encoded"))
1809+
}
1810+
18071811
func test_base64Data_medium() {
18081812
let data = Data("Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut at tincidunt arcu. Suspendisse nec sodales erat, sit amet imperdiet ipsum. Etiam sed ornare felis. Nunc mauris turpis, bibendum non lectus quis, malesuada placerat turpis. Nam adipiscing non massa et semper. Nulla convallis semper bibendum. Aliquam dictum nulla cursus mi ultricies, at tincidunt mi sagittis. Nulla faucibus at dui quis sodales. Morbi rutrum, dui id ultrices venenatis, arcu urna egestas felis, vel suscipit mauris arcu quis risus. Nunc venenatis ligula at orci tristique, et mattis purus pulvinar. Etiam ultricies est odio. Nunc eleifend malesuada justo, nec euismod sem ultrices quis. Etiam nec nibh sit amet lorem faucibus dapibus quis nec leo. Praesent sit amet mauris vel lacus hendrerit porta mollis consectetur mi. Donec eget tortor dui. Morbi imperdiet, arcu sit amet elementum interdum, quam nisl tempor quam, vitae feugiat augue purus sed lacus. In ac urna adipiscing purus venenatis volutpat vel et metus. Nullam nec auctor quam. Phasellus porttitor felis ac nibh gravida suscipit tempus at ante. Nunc pellentesque iaculis sapien a mattis. Aenean eleifend dolor non nunc laoreet, non dictum massa aliquam. Aenean quis turpis augue. Praesent augue lectus, mollis nec elementum eu, dignissim at velit. Ut congue neque id ullamcorper pellentesque. Maecenas euismod in elit eu vehicula. Nullam tristique dui nulla, nec convallis metus suscipit eget. Cras semper augue nec cursus blandit. Nulla rhoncus et odio quis blandit. Praesent lobortis dignissim velit ut pulvinar. Duis interdum quam adipiscing dolor semper semper. Nunc bibendum convallis dui, eget mollis magna hendrerit et. Morbi facilisis, augue eu fringilla convallis, mauris est cursus dolor, eu posuere odio nunc quis orci. Ut eu justo sem. Phasellus ut erat rhoncus, faucibus arcu vitae, vulputate erat. Aliquam nec magna viverra, interdum est vitae, rhoncus sapien. Duis tincidunt tempor ipsum ut dapibus. Nullam commodo varius metus, sed sollicitudin eros. Etiam nec odio et dui tempor blandit posuere.".utf8)
18091813
let base64 = data.base64EncodedString()

0 commit comments

Comments
 (0)