app.log - 日志 API

日志记录 API。每个插件都有独立的日志文件。

方法

app.log.verbose(message)

记录详细日志(仅写入插件日志)。

app.log.verbose("详细调试信息")

app.log.debug(message)

记录调试日志(仅写入插件日志)。

app.log.debug("调试信息")

app.log.info(message)

记录信息日志(仅写入插件日志)。

app.log.info("处理开始")

app.log.warning(message)

记录警告日志(写入插件日志 + 系统日志)。

app.log.warning("文件不存在,使用默认值")

app.log.warn(message)

warning 的别名。

app.log.warn("警告信息")

app.log.error(message)

记录错误日志(写入插件日志 + 系统日志)。

app.log.error("处理失败: " .. err)

app.log.getPath()

获取插件日志文件路径。

返回值: string - 日志文件路径

local path = app.log.getPath()
-- "~/Library/Group Containers/.../Logs/Plugins/com.example.plugin.log"

app.log.read(lines?)

读取日志文件的最后 N 行。

参数:

  • lines (number, 可选) - 要读取的行数(默认 100)

返回值: string - 日志内容

local content = app.log.read(50)

app.log.clear()

清空插件日志文件。

app.log.clear()

日志级别

级别 插件日志 系统日志
verbose
debug
info
warning
error

日志位置

  • 插件日志: ~/Library/Group Containers/group.net.ymlab.iRightMenu.pro/Logs/Plugins/{plugin_id}.log
  • 系统日志: ~/Library/Group Containers/group.net.ymlab.iRightMenu.pro/Logs/iRightMenu.log

示例

记录操作过程

function MyPlugin:handleConvert(context)
    app.log.info("开始转换,共 " .. #context.selectedFiles .. " 个文件")

    for i, file in ipairs(context.selectedFiles) do
        app.log.debug("处理文件: " .. file)

        local ok, err = self:convertFile(file)
        if ok then
            app.log.info("转换成功: " .. app.path.basename(file))
        else
            app.log.error("转换失败: " .. file .. " - " .. err)
        end
    end

    app.log.info("转换完成")
end
开发者文档
使用帮助
使用说明 脚本菜单 常见问题
脚本开发
开发指南
插件开发
快速开始 开发指南 示例插件
API 参考
概览 API 查询 插件信息 日志 Finder 上下文 插件设置 国际化
UI 与交互
对话框 进度条 系统通知 选择器 WebView 状态栏 Dock
文件与路径
文件操作 路径工具 Finder 操作 废纸篓 扩展属性 元数据 文件监听
数据格式
JSON Plist CSV XML PDF 图片
文本与编码
字符串 正则表达式 日期时间 颜色 加密编码
系统
Shell 命令 进程管理 应用管理 系统信息 AppleScript 快捷指令
系统信息
网络信息 电源/电池 屏幕/外观 音频控制 蓝牙设备 位置服务
网络
HTTP 请求 WebSocket URL 工具
输入与剪贴板
键盘模拟 鼠标模拟 全局热键 剪贴板 窗口管理
存储
SQLite Keychain UserDefaults
媒体
文字识别 二维码
工具
归档 类型标识 分享 定时器 防休眠 并发/协程