Operators.swift 1.5 KB

123456789101112131415161718192021222324252627282930313233
  1. //
  2. // CryptoSwift
  3. //
  4. // Copyright (C) 2014-2017 Marcin Krzyżanowski <marcin@krzyzanowskim.com>
  5. // This software is provided 'as-is', without any express or implied warranty.
  6. //
  7. // In no event will the authors be held liable for any damages arising from the use of this software.
  8. //
  9. // Permission is granted to anyone to use this software for any purpose,including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions:
  10. //
  11. // - The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation is required.
  12. // - Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
  13. // - This notice may not be removed or altered from any source or binary distribution.
  14. //
  15. /*
  16. Bit shifting with overflow protection using overflow operator "&".
  17. Approach is consistent with standard overflow operators &+, &-, &*, &/
  18. and introduce new overflow operators for shifting: &<<, &>>
  19. Note: Works with unsigned integers values only
  20. Usage
  21. var i = 1 // init
  22. var j = i &<< 2 //shift left
  23. j &<<= 2 //shift left and assign
  24. @see: https://medium.com/@krzyzanowskim/swiftly-shift-bits-and-protect-yourself-be33016ce071
  25. This fuctonality is now implemented as part of Swift 3, SE-0104 https://github.com/apple/swift-evolution/blob/master/proposals/0104-improved-integers.md
  26. */