String+Misc.swift 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. //
  2. // String+Linux.swift
  3. // Swifter
  4. // Copyright (c) 2014 Damian Kołakowski. All rights reserved.
  5. //
  6. import Foundation
  7. extension String {
  8. public func split(separator: Character) -> [String] {
  9. return self.characters.split { $0 == separator }.map(String.init)
  10. }
  11. public func split(maxSplit: Int = Int.max, separator: Character) -> [String] {
  12. return self.characters.split(maxSplit) { $0 == separator }.map(String.init)
  13. }
  14. public func replace(old: Character, new: Character) -> String {
  15. var buffer = [Character]()
  16. self.characters.forEach { buffer.append($0 == old ? new : $0) }
  17. return String(buffer)
  18. }
  19. public func unquote() -> String {
  20. var scalars = self.unicodeScalars;
  21. if scalars.first == "\"" && scalars.last == "\"" && scalars.count >= 2 {
  22. scalars.removeFirst();
  23. scalars.removeLast();
  24. return String(scalars)
  25. }
  26. return self
  27. }
  28. public func trim() -> String {
  29. var scalars = self.unicodeScalars
  30. while let _ = unicodeScalarToUInt32Whitespace(scalars.first) { scalars.removeFirst() }
  31. while let _ = unicodeScalarToUInt32Whitespace(scalars.last) { scalars.removeLast() }
  32. return String(scalars)
  33. }
  34. public static func fromUInt8(array: [UInt8]) -> String {
  35. return String(data: NSData(bytes: array, length: array.count), encoding: NSUTF8StringEncoding) ?? ""
  36. }
  37. public func removePercentEncoding() -> String {
  38. var scalars = self.unicodeScalars
  39. var output = ""
  40. var bytesBuffer = [UInt8]()
  41. while let scalar = scalars.popFirst() {
  42. if scalar == "%" {
  43. let first = scalars.popFirst()
  44. let secon = scalars.popFirst()
  45. if let first = unicodeScalarToUInt32Hex(first), secon = unicodeScalarToUInt32Hex(secon) {
  46. bytesBuffer.append(first*16+secon)
  47. } else {
  48. if !bytesBuffer.isEmpty {
  49. output.appendContentsOf(String.fromUInt8(bytesBuffer))
  50. bytesBuffer.removeAll()
  51. }
  52. if let first = first { output.append(Character(first)) }
  53. if let secon = secon { output.append(Character(secon)) }
  54. }
  55. } else {
  56. if !bytesBuffer.isEmpty {
  57. output.appendContentsOf(String.fromUInt8(bytesBuffer))
  58. bytesBuffer.removeAll()
  59. }
  60. output.append(Character(scalar))
  61. }
  62. }
  63. if !bytesBuffer.isEmpty {
  64. output.appendContentsOf(String.fromUInt8(bytesBuffer))
  65. bytesBuffer.removeAll()
  66. }
  67. return output
  68. }
  69. private func unicodeScalarToUInt32Whitespace(x: UnicodeScalar?) -> UInt8? {
  70. if let x = x {
  71. if x.value >= 9 && x.value <= 13 {
  72. return UInt8(x.value)
  73. }
  74. if x.value == 32 {
  75. return UInt8(x.value)
  76. }
  77. }
  78. return nil
  79. }
  80. private func unicodeScalarToUInt32Hex(x: UnicodeScalar?) -> UInt8? {
  81. if let x = x {
  82. if x.value >= 48 && x.value <= 57 {
  83. return UInt8(x.value) - 48
  84. }
  85. if x.value >= 97 && x.value <= 102 {
  86. return UInt8(x.value) - 87
  87. }
  88. if x.value >= 65 && x.value <= 70 {
  89. return UInt8(x.value) - 55
  90. }
  91. }
  92. return nil
  93. }
  94. }