Swift Package Index


Collection of utilities for interacting with NSRange


  • The latest stable release is 1.1.6. Released 4 months ago.
  • The last commit to main was 4 months ago.

Swift Version Compatibility

  • 1.1.6 and main
    5.3
    5.2
    5.1
    5.0
    4.2
Full build results

Platform Compatibility

  • 1.1.6 and main
    iOS
    macOS(Intel)
    macOS(ARM)
    Linux
    tvOS
    watchOS
Full build results

Github CI Carthage compatible

Rearrange

Rearrange is a collection of utilities for making it easier to work with NSRange. It's particularly handy when used with the Cocoa text system.

Integration

Swift Package Manager:

dependencies: [
    .package(url: "https://github.com/ChimeHQ/Rearrange.git")
]

Carthage:

github "ChimeHQ/Rearrange"

Types

RangeMutation

This is a struct that encapsulates a single change to an NSRange. It's useful for serializing, queuing, or otherwise storing changes and applying them.

You can also use this class to tranform individual points or other NSRanges. This is handy for updating a set of stored NSRanges as text is changed. This might seem easy, but there are a large number of edge cases that RangeMutation handles, including mutations that invalidate (for example completely delete) a range.

Extensions

NSRange

// convenience
static var zero
var max: Int

// shifting
public func shifted(by delta: Int) -> NSRange?
public func shifted(startBy delta: Int) -> NSRange?
public func shifted(endBy delta: Int) -> NSRange?

// mutating
func apply(_ change: RangeMutation) -> NSRange?

IndexSet

mutating func insert(range: NSRange)
mutating func insert(ranges: [NSRange])
var nsRangeView: [NSRange]
func contains(integersIn range: NSRange) -> Bool
var limitSpanningRange: NSRange?

Suggestions or Feedback

We'd love to hear from you! Get in touch via twitter, an issue, or a pull request.

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.