Files
lpms/ffmpeg/ffmpeg_errors.go
Ivan Tivonenko 76e01f3f59 satisfy linter
2021-11-30 23:54:44 +02:00

92 lines
2.6 KiB
Go

package ffmpeg
// #cgo pkg-config: libavformat
//#include "ffmpeg_errors.h"
//#include "transcoder.h"
import "C"
import (
"encoding/binary"
"errors"
"unsafe"
)
var lpmsErrors = []struct {
Code C.int
Desc string
}{
{Code: C.lpms_ERR_INPUT_PIXFMT, Desc: "Unsupported input pixel format"},
{Code: C.lpms_ERR_FILTERS, Desc: "Error initializing filtergraph"},
{Code: C.lpms_ERR_OUTPUTS, Desc: "Too many outputs"},
{Code: C.lpms_ERR_INPUT_CODEC, Desc: "Unsupported input codec"},
{Code: C.lpms_ERR_INPUT_NOKF, Desc: "No keyframes in input"},
{Code: C.lpms_ERR_UNRECOVERABLE, Desc: "Unrecoverable state, restart process"},
}
func error_map() map[int]error {
// errs is a []byte , we really need an []int so need to convert
errs := C.GoBytes(unsafe.Pointer(&C.ffmpeg_errors), C.sizeof_ffmpeg_errors)
m := make(map[int]error)
for i := 0; i < len(errs)/C.sizeof_int; i++ {
// unsigned -> C 4-byte signed int -> golang nativeint
// golang nativeint is usually 8 bytes on 64bit, so intermediate cast is
// needed to preserve sign
v := int(int32(binary.LittleEndian.Uint32(errs[i*C.sizeof_int : (i+1)*C.sizeof_int])))
m[v] = errors.New(Strerror(v))
}
for i := -255; i < 0; i++ {
v := Strerror(i)
if v != "UNKNOWN_ERROR" {
m[i] = errors.New(v)
}
}
// Add in LPMS specific errors
for _, v := range lpmsErrors {
m[int(v.Code)] = errors.New(v.Desc)
}
return m
}
var ErrorMap = error_map()
func non_retryable_errs() []string {
errs := []string{}
// Add in Cgo LPMS specific errors
for _, v := range lpmsErrors {
errs = append(errs, v.Desc)
}
// Add in internal FFmpeg errors
// from https://ffmpeg.org/doxygen/trunk/error_8c_source.html#l00034
ffmpegErrors := []string{
"Decoder not found", "Demuxer not found", "Encoder not found",
"Muxer not found", "Option not found", "Invalid argument",
}
errs = append(errs, ffmpegErrors...)
// Add in ffmpeg.go transcoder specific errors
transcoderErrors := []error{
ErrTranscoderRes, ErrTranscoderVid, ErrTranscoderFmt,
ErrTranscoderPrf, ErrTranscoderGOP, ErrTranscoderDev,
}
for _, v := range transcoderErrors {
errs = append(errs, v.Error())
}
return errs
}
var NonRetryableErrs = non_retryable_errs()
// Use of this source code is governed by a MIT license that can be found in the LICENSE file.
// Corbatto (luca@corbatto.de)
// Strerror returns a descriptive string of the given return code.
//
// C-Function: av_strerror
func Strerror(errnum int) string {
buf := make([]C.char, C.ffmpeg_AV_ERROR_MAX_STRING_SIZE)
if C.av_strerror(C.int(errnum), (*C.char)(unsafe.Pointer(&buf[0])), C.size_t(len(buf))) != 0 {
return "UNKNOWN_ERROR"
}
return C.GoString((*C.char)(unsafe.Pointer(&buf[0])))
}