如何使用XCGlogger输出调用方法的名称?
我已经创建了一个mylogger
类,它将参数传递给xcglogger
到输出日志。我已经为XCGlogger的showfileName
和dateshowfunctionName
指定了true
,但它始终输出mylogger的文件名和方法名称。有什么方法可以使其输出呼叫者的文件名和方法名称?
这是现在的输出。
2022/06/17,11:44:54.054 [Debug] [MyLogger.swift] logWrite(level:message:) > New user is comming.
2022/06/17,11:44:54.054 [Warning] [MyLogger.swift] logWrite(level:message:) > Invaild login_name or password. [login_name:marverick] failed 1 times.
2022/06/17,11:44:58.058 [Info] [MyLogger.swift] logWrite(level:message:) > Login success. Hello maverick!
我想要的是。
2022/06/17,11:44:54.054 [Debug] [Login.swift] top() > New user is comming.
2022/06/17,11:44:54.054 [Warning] [Auth.swift] authCheck(login_name:password:) > Invaild login_name or password. [login_name:marverick] failed 1 times.
2022/06/17,11:44:58.058 [Info] [Main.swift] main(param:) > Login success. Hello maverick!
我的代码是这个。似乎有点长,但是我不知道是什么原因导致了问题,所以我没有缩写太多。
import Foundation
import SSZipArchive
import XCGLogger
publc class MyLogger: NSObject, URLSessionTaskDelegate {
static public func logWrite(level: LOGLEVEL, message:String) {
let logSetUp = settings.logger()
let fileName = createFileName()
let log = XCGLogger.default
do {
let folderName = FileManager.default.urls(for:.libraryDirectory,in:.userDomainMask).first?.appendingPathComponent("Logs",isDirectory:true)
try FileManager.default.createDirectory(at: folderName!, withIntermediateDirectories: true, attributes: nil)
}
catch{
MyLogger.logWrite(level: .ERROR, message: error.localizedDescription)
}
let path = FileManager.default.urls(for: .libraryDirectory,in: .userDomainMask).first?.appendingPathComponent("Logs", isDirectory: false).appendingPathComponent(fileName + ".log")
log.dateFormatter?.dateFormat = logSetUp.dateformat
let autorotateFileDestination = AutoRotatingFileDestination(writeToFile: path, identifier: log.identifier, shouldAppend: logSetUp.shouldappend, maxTimeInterval: logSetUp.targetmaxtimeinterval, targetMaxLogFiles: logSetUp.targetmaxlogfiles)
autorotateFileDestination.showLogIdentifier = logSetUp.showlogidentifier
autorotateFileDestination.showFunctionName = logSetUp.showfunctionname
autorotateFileDestination.showThreadName = logSetUp.showthreadname
autorotateFileDestination.showLevel = logSetUp.showlevel
autorotateFileDestination.showFileName = logSetUp.showfilenames
autorotateFileDestination.showLineNumber = logSetUp.showlinenumbers
autorotateFileDestination.showDate = logSetUp.showdata
log.add(destination: autorotateFileDestination)
switch level {
case .DEBUG:
log.debug(message)
case .INFO:
log.info(message)
case .WARNING:
log.warning(message)
case .ERROR:
log.error(message)
}
}
//other methods here
}
I have created a MyLogger
class and it passes parameters to XCGLogger
to output logs. I have specified true
for the XCGLogger's showFileName
and dateshowFunctionName
, but it always outputs MyLogger's own file name and method name. Is there any way to make it output the caller's file name and method name?
This is the output now.
2022/06/17,11:44:54.054 [Debug] [MyLogger.swift] logWrite(level:message:) > New user is comming.
2022/06/17,11:44:54.054 [Warning] [MyLogger.swift] logWrite(level:message:) > Invaild login_name or password. [login_name:marverick] failed 1 times.
2022/06/17,11:44:58.058 [Info] [MyLogger.swift] logWrite(level:message:) > Login success. Hello maverick!
What I want is this.
2022/06/17,11:44:54.054 [Debug] [Login.swift] top() > New user is comming.
2022/06/17,11:44:54.054 [Warning] [Auth.swift] authCheck(login_name:password:) > Invaild login_name or password. [login_name:marverick] failed 1 times.
2022/06/17,11:44:58.058 [Info] [Main.swift] main(param:) > Login success. Hello maverick!
My code is this. It seems a bit long, but I don't know what is causing the problem so I haven't abbreviated much.
import Foundation
import SSZipArchive
import XCGLogger
publc class MyLogger: NSObject, URLSessionTaskDelegate {
static public func logWrite(level: LOGLEVEL, message:String) {
let logSetUp = settings.logger()
let fileName = createFileName()
let log = XCGLogger.default
do {
let folderName = FileManager.default.urls(for:.libraryDirectory,in:.userDomainMask).first?.appendingPathComponent("Logs",isDirectory:true)
try FileManager.default.createDirectory(at: folderName!, withIntermediateDirectories: true, attributes: nil)
}
catch{
MyLogger.logWrite(level: .ERROR, message: error.localizedDescription)
}
let path = FileManager.default.urls(for: .libraryDirectory,in: .userDomainMask).first?.appendingPathComponent("Logs", isDirectory: false).appendingPathComponent(fileName + ".log")
log.dateFormatter?.dateFormat = logSetUp.dateformat
let autorotateFileDestination = AutoRotatingFileDestination(writeToFile: path, identifier: log.identifier, shouldAppend: logSetUp.shouldappend, maxTimeInterval: logSetUp.targetmaxtimeinterval, targetMaxLogFiles: logSetUp.targetmaxlogfiles)
autorotateFileDestination.showLogIdentifier = logSetUp.showlogidentifier
autorotateFileDestination.showFunctionName = logSetUp.showfunctionname
autorotateFileDestination.showThreadName = logSetUp.showthreadname
autorotateFileDestination.showLevel = logSetUp.showlevel
autorotateFileDestination.showFileName = logSetUp.showfilenames
autorotateFileDestination.showLineNumber = logSetUp.showlinenumbers
autorotateFileDestination.showDate = logSetUp.showdata
log.add(destination: autorotateFileDestination)
switch level {
case .DEBUG:
log.debug(message)
case .INFO:
log.info(message)
case .WARNING:
log.warning(message)
case .ERROR:
log.error(message)
}
}
//other methods here
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我没有得到答案,但是此代码给了我预期的结果。我从
#file
,#line
和#function
获得了呼叫者的信息。参数并将其添加为字符串。
I did not get an answer, but this code gave me the expected results. I got the caller's information from
#file
,#line
, and#function
parameters and added it as a string.