mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-10-31 19:02:25 -05:00
[feature] support processing of (many) more media types (#3090)
* initial work replacing our media decoding / encoding pipeline with ffprobe + ffmpeg
* specify the video codec to use when generating static image from emoji
* update go-storage library (fixes incompatibility after updating go-iotools)
* maintain image aspect ratio when generating a thumbnail for it
* update readme to show go-ffmpreg
* fix a bunch of media tests, move filesize checking to callers of media manager for more flexibility
* remove extra debug from error message
* fix up incorrect function signatures
* update PutFile to just use regular file copy, as changes are file is on separate partition
* fix remaining tests, remove some unneeded tests now we're working with ffmpeg/ffprobe
* update more tests, add more code comments
* add utilities to generate processed emoji / media outputs
* fix remaining tests
* add test for opus media file, add license header to utility cmds
* limit the number of concurrently available ffmpeg / ffprobe instances
* reduce number of instances
* further reduce number of instances
* fix envparsing test with configuration variables
* update docs and configuration with new media-{local,remote}-max-size variables
This commit is contained in:
parent
5bc567196b
commit
cde2fb6244
376 changed files with 8026 additions and 54091 deletions
110
vendor/github.com/superseriousbusiness/go-jpeg-image-structure/v2/utility.go
generated
vendored
110
vendor/github.com/superseriousbusiness/go-jpeg-image-structure/v2/utility.go
generated
vendored
|
|
@ -1,110 +0,0 @@
|
|||
package jpegstructure
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"fmt"
|
||||
"sort"
|
||||
"strings"
|
||||
|
||||
"github.com/dsoprea/go-logging"
|
||||
"github.com/go-xmlfmt/xmlfmt"
|
||||
)
|
||||
|
||||
// DumpBytes prints the hex for a given byte-slice.
|
||||
func DumpBytes(data []byte) {
|
||||
fmt.Printf("DUMP: ")
|
||||
for _, x := range data {
|
||||
fmt.Printf("%02x ", x)
|
||||
}
|
||||
|
||||
fmt.Printf("\n")
|
||||
}
|
||||
|
||||
// DumpBytesClause prints a Go-formatted byte-slice expression.
|
||||
func DumpBytesClause(data []byte) {
|
||||
fmt.Printf("DUMP: ")
|
||||
|
||||
fmt.Printf("[]byte { ")
|
||||
|
||||
for i, x := range data {
|
||||
fmt.Printf("0x%02x", x)
|
||||
|
||||
if i < len(data)-1 {
|
||||
fmt.Printf(", ")
|
||||
}
|
||||
}
|
||||
|
||||
fmt.Printf(" }\n")
|
||||
}
|
||||
|
||||
// DumpBytesToString returns a string of hex-encoded bytes.
|
||||
func DumpBytesToString(data []byte) string {
|
||||
b := new(bytes.Buffer)
|
||||
|
||||
for i, x := range data {
|
||||
_, err := b.WriteString(fmt.Sprintf("%02x", x))
|
||||
log.PanicIf(err)
|
||||
|
||||
if i < len(data)-1 {
|
||||
_, err := b.WriteRune(' ')
|
||||
log.PanicIf(err)
|
||||
}
|
||||
}
|
||||
|
||||
return b.String()
|
||||
}
|
||||
|
||||
// DumpBytesClauseToString returns a string of Go-formatted byte values.
|
||||
func DumpBytesClauseToString(data []byte) string {
|
||||
b := new(bytes.Buffer)
|
||||
|
||||
for i, x := range data {
|
||||
_, err := b.WriteString(fmt.Sprintf("0x%02x", x))
|
||||
log.PanicIf(err)
|
||||
|
||||
if i < len(data)-1 {
|
||||
_, err := b.WriteString(", ")
|
||||
log.PanicIf(err)
|
||||
}
|
||||
}
|
||||
|
||||
return b.String()
|
||||
}
|
||||
|
||||
// FormatXml prettifies XML data.
|
||||
func FormatXml(raw string) (formatted string, err error) {
|
||||
defer func() {
|
||||
if state := recover(); state != nil {
|
||||
err = log.Wrap(state.(error))
|
||||
}
|
||||
}()
|
||||
|
||||
formatted = xmlfmt.FormatXML(raw, " ", " ")
|
||||
formatted = strings.TrimSpace(formatted)
|
||||
|
||||
return formatted, nil
|
||||
}
|
||||
|
||||
// SortStringStringMap sorts a string-string dictionary and returns it as a list
|
||||
// of 2-tuples.
|
||||
func SortStringStringMap(data map[string]string) (sorted [][2]string) {
|
||||
// Sort keys.
|
||||
|
||||
sortedKeys := make([]string, len(data))
|
||||
i := 0
|
||||
for key := range data {
|
||||
sortedKeys[i] = key
|
||||
i++
|
||||
}
|
||||
|
||||
sort.Strings(sortedKeys)
|
||||
|
||||
// Build result.
|
||||
|
||||
sorted = make([][2]string, len(sortedKeys))
|
||||
for i, key := range sortedKeys {
|
||||
sorted[i] = [2]string{key, data[key]}
|
||||
}
|
||||
|
||||
return sorted
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue