Skip to content

Some changes in UnsafeBufferPointer to improve performance #2676

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 2 commits into from
May 26, 2016

Conversation

eeckstein
Copy link
Contributor

What's in this pull request?

Resolved bug number: (SR-)


Before merging this pull request to apple/swift repository:

  • Test pull request on Swift continuous integration.

Triggering Swift CI

The swift-ci is triggered by writing a comment on this PR addressed to the GitHub user @swift-ci. Different tests will run depending on the specific comment that you use. The currently available comments are:

Smoke Testing

Platform Comment
All supported platforms @swift-ci Please smoke test
All supported platforms @swift-ci Please smoke test and merge
OS X platform @swift-ci Please smoke test OS X platform
Linux platform @swift-ci Please smoke test Linux platform

Validation Testing

Platform Comment
All supported platforms @swift-ci Please test
All supported platforms @swift-ci Please test and merge
OS X platform @swift-ci Please test OS X platform
OS X platform @swift-ci Please benchmark
Linux platform @swift-ci Please test Linux platform

Lint Testing

Language Comment
Python @swift-ci Please Python lint

Note: Only members of the Apple organization can trigger swift-ci.

@eeckstein
Copy link
Contributor Author

@swift-ci Please smoke test

@eeckstein
Copy link
Contributor Author

@gribozavr, can you please review this?

@swiftix
Copy link
Contributor

swiftix commented May 24, 2016

👍

@gribozavr
Copy link
Contributor

@swift-ci Please test

@@ -57,6 +57,83 @@ public struct Unsafe${Mutable}BufferPointer<Element>
return count
}

public func index(after i: Int) -> Int {
// NOTE: this is a manual specialization of index movement for a Strideable
// index that is required for Array performance. The optimizer is not
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

s/Array/UnsafeBufferPointer/

@gribozavr
Copy link
Contributor

LGTM modulo the comment.

eeckstein added 2 commits May 25, 2016 14:27
The statement "if x == nil { }" involves creating an Optional.none for the RHS and calling the == function.
…ter.

This improves performance, especially for -Onone.
@eeckstein eeckstein force-pushed the stdlib-performance branch from 82caeef to 5bfe35a Compare May 25, 2016 21:33
@eeckstein
Copy link
Contributor Author

@swift-ci Please test

1 similar comment
@eeckstein
Copy link
Contributor Author

@swift-ci Please test

@eeckstein eeckstein merged commit d8a3920 into swiftlang:master May 26, 2016
@eeckstein eeckstein deleted the stdlib-performance branch August 18, 2016 14:42
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants