encodedOffset deprecation
Asked Answered
R

2

10

In my application, I have some code to fetch the range of the host in a URL. It looks like this:

private func rangeOfHost(text: String) -> NSRange? {
    let url = URL(string: text)
    if let host: String = url?.host {
        if let range = text.range(of: host) {
            return NSRange(
                location: range.lowerBound.encodedOffset,
                length: range.upperBound.encodedOffset - range.lowerBound.encodedOffset
            )
        }
    }
    return nil
}

Xcode has been warning me that 'encodedOffset' is deprecated: encodedOffset has been deprecated as the most common usage is incorrect. Use utf16Offset(in:) to achieve the same behavior.. However, it's not clear to me how I can replace those encodedOffsets with these suggestions. Any ideas?

Repression answered 9/4, 2019 at 8:24 Comment(0)
U
9

A simple and correct way to create an NSRange from a Range<String.Index> is to use its initializer:

public init<R, S>(_ region: R, in target: S) where R : RangeExpression, S : StringProtocol, R.Bound == String.Index

In your case:

if let range = text.range(of: host) {
    return NSRange(range, in: text)
}
Ulema answered 9/4, 2019 at 8:34 Comment(0)
G
2
yourString1.yourIndex.utf16Offset(in: yourString2)
Gambeson answered 31/5, 2019 at 11:41 Comment(1)
I've found that for me that the value of yourString2 can be anything at all, and I still get the result I expect. So I don't understand what that string is for, and I worry that in the future it will suddenly matter and things will break. The docs, of course, are super helpful: "No description."Gateshead

© 2022 - 2024 — McMap. All rights reserved.