another.im-ios/AnotherIM/AppData/Services/Logger.swift

43 lines
1.1 KiB
Swift
Raw Permalink Normal View History

2024-06-19 15:15:27 +00:00
import Combine
import Foundation
2024-06-26 09:29:30 +00:00
import SwiftUI
2024-06-19 15:15:27 +00:00
let isConsoleLoggingEnabled = false
enum LogLevels: String {
2024-06-26 09:29:30 +00:00
case info = "\u{F449}"
case warning = "\u{F071}"
case error = "\u{EA76}"
2024-06-19 15:15:27 +00:00
}
// For database errors logging
func logIt(_ level: LogLevels, _ message: String) {
#if DEBUG
let timeStr = dateFormatter.string(from: Date())
let str = "\(timeStr) \(level.rawValue) \(message)"
print(str)
if isConsoleLoggingEnabled {
NSLog(str)
}
#endif
}
private var dateFormatter: DateFormatter {
let formatter = DateFormatter()
formatter.locale = NSLocale(localeIdentifier: "en_US_POSIX") as Locale
formatter.dateFormat = "MM-dd HH:mm:ss.SSS"
return formatter
}
2024-08-07 12:49:47 +00:00
// For thread debugging
func ptInfo(_ message: String) {
#if DEBUG
let timeStr = dateFormatter.string(from: Date())
let str = "\(timeStr) \(message) -> \(Thread.current), \(String(validatingUTF8: __dispatch_queue_get_label(nil)) ?? "no queue label")"
print(str)
if isConsoleLoggingEnabled {
NSLog(str)
}
#endif
}