Files
go-astiav/log.go
2024-11-14 09:01:26 +01:00

87 lines
2.1 KiB
Go

package astiav
//#include "log.h"
//#include <libavutil/log.h>
//#include <stdlib.h>
import "C"
import (
"unsafe"
)
// https://ffmpeg.org/doxygen/7.0/group__lavu__log__constants.html#ga11e329935b59b83ca722b66674f37fd4
type LogLevel int
const (
LogLevelQuiet = LogLevel(C.AV_LOG_QUIET)
LogLevelPanic = LogLevel(C.AV_LOG_PANIC)
LogLevelFatal = LogLevel(C.AV_LOG_FATAL)
LogLevelError = LogLevel(C.AV_LOG_ERROR)
LogLevelWarning = LogLevel(C.AV_LOG_WARNING)
LogLevelInfo = LogLevel(C.AV_LOG_INFO)
LogLevelVerbose = LogLevel(C.AV_LOG_VERBOSE)
LogLevelDebug = LogLevel(C.AV_LOG_DEBUG)
)
// https://ffmpeg.org/doxygen/7.0/group__lavu__log.html#ga1fd32c74db581e3e2e7f35d277bb1e24
func SetLogLevel(l LogLevel) {
C.av_log_set_level(C.int(l))
}
// https://ffmpeg.org/doxygen/7.0/group__lavu__log.html#gae8ada5cc5722548d8698650b05207904
func GetLogLevel() LogLevel {
return LogLevel(C.av_log_get_level())
}
type LogCallback func(c Classer, l LogLevel, fmt, msg string)
var logCallback LogCallback
// https://ffmpeg.org/doxygen/7.0/group__lavu__log.html#ga14034761faf581a8b9ed6ef19b313708
func SetLogCallback(c LogCallback) {
logCallback = c
C.astiavSetLogCallback()
}
//export goAstiavLogCallback
func goAstiavLogCallback(ptr unsafe.Pointer, level C.int, fmt, msg *C.char) {
// No callback
if logCallback == nil {
return
}
// Get classer
var c Classer
if ptr != nil {
var ok bool
if c, ok = classers.get(ptr); !ok {
c = newUnknownClasser(ptr)
}
}
// Callback
logCallback(c, LogLevel(level), C.GoString(fmt), C.GoString(msg))
}
// https://ffmpeg.org/doxygen/7.0/group__lavu__log.html#ga5bd132d2e4ac6f9843ef6d8e3c05050a
func ResetLogCallback() {
C.astiavResetLogCallback()
}
// https://ffmpeg.org/doxygen/7.0/group__lavu__log.html#gabd386ffd4b27637cf34e98d5d1a6e8ae
func Log(c Classer, l LogLevel, fmt string, args ...string) {
fmtc := C.CString(fmt)
defer C.free(unsafe.Pointer(fmtc))
argc := (*C.char)(nil)
if len(args) > 0 {
argc = C.CString(args[0])
defer C.free(unsafe.Pointer(argc))
}
var ptr unsafe.Pointer
if c != nil {
if cl := c.Class(); cl != nil {
ptr = cl.ptr
}
}
C.astiavLog(ptr, C.int(l), fmtc, argc)
}