KMBatchBaseParameter.swift 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. //
  2. // KMBatchBaseParameter.swift
  3. // PDF Master
  4. //
  5. // Created by kdanmobile on 2023/10/25.
  6. //
  7. import Cocoa
  8. @objcMembers class KMBatchBaseParameter: NSObject{
  9. var error: NSError?
  10. var operateFile: KMBatchOperateFile?
  11. var pageChoice: KMBatchOperatePageChoice = .All {
  12. willSet{
  13. }
  14. didSet {
  15. if pageChoice != oldValue {
  16. self.localPagesArray = nil
  17. }
  18. }
  19. }
  20. var pageRangeString: String? {
  21. willSet{
  22. }
  23. didSet {
  24. if pageRangeString != oldValue {
  25. self.localPagesArray = nil
  26. }
  27. }
  28. }
  29. var progress: Float?
  30. var status: KMBatchOperateStatus = .Waiting
  31. var savePath: String?
  32. var outPutPath: String?
  33. var pagesArray: [NSNumber]? {
  34. if self.localPagesArray == nil {
  35. self.localPagesArray = self.fetchUnlimitPagesArray()
  36. }
  37. return self.localPagesArray
  38. }
  39. private var localPagesArray: [NSNumber]?
  40. private var _doc: CPDFDocument?
  41. init(file:KMBatchOperateFile) {
  42. super.init()
  43. self.operateFile = file
  44. }
  45. func fetchUnlimitPagesArray() -> [NSNumber]? {
  46. var document = self._doc
  47. if document == nil { // 优化重复创建
  48. document = CPDFDocument(url: URL(fileURLWithPath: self.operateFile?.filePath ?? ""))
  49. self._doc = document
  50. }
  51. if let data = document?.isLocked, data { // 加锁的话,需要解锁
  52. if let data = self.operateFile?.password, data.isEmpty == false {
  53. document?.unlock(withPassword: data)
  54. }
  55. }
  56. let pageNumber = document?.pageCount ?? 0
  57. if pageNumber <= 0 { // 容错判断
  58. return nil
  59. }
  60. if self.pageChoice == .All {
  61. var selectPages: [NSNumber] = []
  62. for i in 1...pageNumber {
  63. selectPages.append(NSNumber(integerLiteral: Int(i)))
  64. }
  65. return selectPages
  66. } else if self.pageChoice == .Odd {
  67. var selectPages: [NSNumber] = []
  68. for i in stride(from: 1, through: pageNumber, by: 2) {
  69. selectPages.append(NSNumber(integerLiteral: Int(i)))
  70. }
  71. return selectPages
  72. } else if self.pageChoice == .Even {
  73. var selectPages: [NSNumber] = []
  74. for i in stride(from: 2, through: pageNumber, by: 2) {
  75. selectPages.append(NSNumber(integerLiteral: Int(i)))
  76. }
  77. return selectPages
  78. } else {
  79. var pageNumbers: [NSNumber] = []
  80. var isInvalid = false
  81. if self.pageRangeString?.count ?? 0 > 0{
  82. for c in self.pageRangeString! {
  83. if c != "0" && c != "1" && c != "2" && c != "3" && c != "4" && c != "5" && c != "6" && c != "7" && c != "8" && c != "9" && c != "," && c != "-" {
  84. isInvalid = true
  85. break
  86. } else {
  87. isInvalid = false
  88. }
  89. }
  90. }
  91. if !isInvalid {
  92. if let data = self.pageRangeString?.isEmpty, data { // 数据错误
  93. return nil
  94. }
  95. let array = self.pageRangeString!.components(separatedBy: ",")
  96. for s in array {
  97. if s.isEmpty {
  98. isInvalid = true
  99. break
  100. } else {
  101. let pages = s.components(separatedBy: "-")
  102. if pages.count > 2 {
  103. isInvalid = true
  104. break
  105. } else if pages.count == 1 {
  106. let p = pages[0]
  107. if p.isEmpty || Int(p)! > pageNumber || Int(p)! == 0 {
  108. isInvalid = true
  109. break
  110. } else {
  111. var isEqual = false
  112. for pageNumber in pageNumbers {
  113. if pageNumber.intValue == Int(p)! {
  114. isEqual = true
  115. isInvalid = true
  116. break
  117. }
  118. }
  119. if !isEqual {
  120. pageNumbers.append(NSNumber(integerLiteral: Int(p)!))
  121. }
  122. }
  123. } else if pages.count == 2 {
  124. let p1 = pages[0]
  125. let p2 = pages[1]
  126. if p1.isEmpty || p2.isEmpty || Int(p1)! >= Int(p2)! || Int(p2)! > pageNumber || Int(p1)! == 0 {
  127. isInvalid = true
  128. break
  129. } else {
  130. var isEqual = false
  131. for i in Int(p1)!...Int(p2)! {
  132. for pageNumber in pageNumbers {
  133. if pageNumber.intValue == i {
  134. isEqual = true
  135. isInvalid = true
  136. break
  137. }
  138. }
  139. }
  140. if !isEqual {
  141. for i in Int(p1)!...Int(p2)! {
  142. pageNumbers.append(NSNumber(integerLiteral: i))
  143. }
  144. }
  145. }
  146. }
  147. }
  148. }
  149. }
  150. if isInvalid {
  151. return nil
  152. }
  153. let tmpArray = NSMutableArray(array: pageNumbers)
  154. QuickSort(list: tmpArray, startIndex: 0, endIndex: pageNumbers.count - 1)
  155. return tmpArray as? [NSNumber]
  156. }
  157. }
  158. func QuickSort(list: NSMutableArray, startIndex: NSInteger, endIndex: NSInteger) {
  159. if startIndex >= endIndex {
  160. return
  161. }
  162. let temp = list[startIndex] as! NSNumber
  163. var tempIndex = startIndex
  164. for i in (startIndex + 1)...endIndex {
  165. let t = list[i] as! NSNumber
  166. if temp.intValue > t.intValue {
  167. tempIndex = tempIndex + 1
  168. list.exchangeObject(at: tempIndex, withObjectAt: i)
  169. }
  170. }
  171. list.exchangeObject(at: tempIndex, withObjectAt: startIndex)
  172. QuickSort(list: list, startIndex: startIndex, endIndex: tempIndex-1)
  173. QuickSort(list: list, startIndex: tempIndex+1, endIndex: endIndex)
  174. }
  175. func getUniqueFilePath(filePath: String) -> String {
  176. var i = 0
  177. var isDirectory = ObjCBool(false)
  178. var uniqueFilePath = filePath
  179. let fileManager = FileManager.default
  180. fileManager.fileExists(atPath: uniqueFilePath, isDirectory: &isDirectory)
  181. if isDirectory.boolValue {
  182. while fileManager.fileExists(atPath: uniqueFilePath) {
  183. i += 1
  184. uniqueFilePath = "\(filePath)(\(i))"
  185. }
  186. } else {
  187. while fileManager.fileExists(atPath: uniqueFilePath) {
  188. i += 1
  189. let path = "\(filePath.deletingPathExtension)(\(i))"
  190. uniqueFilePath = path.stringByAppendingPathComponent(filePath.extension)
  191. }
  192. }
  193. return uniqueFilePath
  194. }
  195. func resetState() {
  196. status = .Waiting
  197. progress = 0
  198. error = nil
  199. savePath = nil
  200. outPutPath = nil
  201. }
  202. func fetchDestinationFilepath() -> String? {
  203. if self.isEqual(self.operateFile?.convertInfo) {
  204. // 在子类重写了这个方法,这里永远不会调用,所以不需要写
  205. } else if self.isEqual(self.operateFile?.addPasswordInfo) {
  206. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  207. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_SetPassword")
  208. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  209. return self.outPutPath
  210. }
  211. } else if self.isEqual(self.operateFile?.removePasswordInfo) {
  212. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  213. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_RemovePassword")
  214. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  215. return self.outPutPath
  216. }
  217. } else if self.isEqual(self.operateFile?.addWatermarkInfo) {
  218. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  219. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_Watermark")
  220. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  221. return self.outPutPath
  222. }
  223. } else if self.isEqual(self.operateFile?.removeWatermarkInfo) {
  224. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  225. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_RemoveWatermark")
  226. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  227. return self.outPutPath
  228. }
  229. } else if self.isEqual(self.operateFile?.addBackgroundInfo) {
  230. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  231. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_AddBackground")
  232. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  233. return self.outPutPath
  234. }
  235. } else if self.isEqual(self.operateFile?.removeBackgroundInfo) {
  236. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  237. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_RemoveBackground")
  238. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  239. return self.outPutPath
  240. }
  241. } else if self.isEqual(self.operateFile?.addHeaderFooterInfo) {
  242. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  243. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_AddHeaderFooter")
  244. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  245. return self.outPutPath
  246. }
  247. } else if self.isEqual(self.operateFile?.removeHeaderFooterInfo) {
  248. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  249. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_RemoveHeaderFooter")
  250. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  251. return self.outPutPath
  252. }
  253. } else if self.isEqual(self.operateFile?.addBatesInfo) {
  254. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  255. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_AddBates")
  256. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  257. return self.outPutPath
  258. }
  259. } else if self.isEqual(self.operateFile?.removeBatesInfo) {
  260. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  261. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_RemoveBates")
  262. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  263. return self.outPutPath
  264. }
  265. } else if self.isEqual(self.operateFile?.compressInfo) {
  266. if self.savePath?.count ?? 0 > 0 && self.operateFile?.filePath.count ?? 0 > 0 {
  267. let filePath1 = self.savePath?.stringByAppendingPathComponent(self.operateFile!.filePath.getLastComponentDeleteExtension + "_Compressed")
  268. self.outPutPath = self.getUniqueFilePath(filePath: filePath1!.stringByAppendingPathExtension("pdf"))
  269. return self.outPutPath
  270. }
  271. }
  272. return nil
  273. }
  274. }