[swift-evolution] Pitch: String Index Overhaul
    Dave Abrahams 
    dabrahams at apple.com
       
    Tue May 30 16:53:34 CDT 2017
    
    
  
on Tue May 30 2017, Jordan Rose <jordan_rose-AT-apple.com> wrote:
> My knee-jerk reaction is to say it's too late in Swift 4 for this kind
> of change, but with that out of the way, I'm most concerned about what
> it means to have, say, a UTF-8 index that's not on a UTF-16 boundary.
>
> let str = "言"
> let oneUnitIn = str.utf8.index(after: str.utf8.startIndex)
> let trailingBytes = str.utf8[oneUnitIn...]
This is not new; it exists today.  
> What can I do with 'oneUnitIn'? 
All the usual stuff; we're not proposing to change what you can do with
it.
> How do I test to see if it's on a Character boundary or a
> UnicodeScalar boundary?
as noted,
  Replacing the failable APIs listed [above](#motivation) that detect
  whether an index represents a valid position in a given view, and
  enhancement that explicitly round index positions to nearby boundaries
  in a given view, are left to a later proposal.  For now, we do not
  propose to remove the existing index conversion APIs.
That means you can use oneUnitIn.samePosition(in: str) or
oneUnitIn.samePosition(in: str.unicodeScalars) to find out if it's on ta
character or unicode scalar boundary.
-- 
-Dave
    
    
More information about the swift-evolution
mailing list