summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/gruf/go-iotools/write.go
diff options
context:
space:
mode:
authorLibravatar kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com>2023-01-11 11:13:13 +0000
committerLibravatar GitHub <noreply@github.com>2023-01-11 12:13:13 +0100
commit53180548083c0a100db2f703d5f5da047a9e0031 (patch)
treea8eb1df9d03b37f907a747ae42cc8992d2ff9f52 /vendor/codeberg.org/gruf/go-iotools/write.go
parent[feature] Add local user and post count to nodeinfo responses (#1325) (diff)
downloadgotosocial-53180548083c0a100db2f703d5f5da047a9e0031.tar.xz
[performance] media processing improvements (#1288)
* media processor consolidation and reformatting, reduce amount of required syscalls Signed-off-by: kim <grufwub@gmail.com> * update go-store library, stream jpeg/png encoding + use buffer pools, improved media processing AlreadyExists error handling Signed-off-by: kim <grufwub@gmail.com> * fix duration not being set, fix mp4 test expecting error Signed-off-by: kim <grufwub@gmail.com> * fix test expecting media files with different extension Signed-off-by: kim <grufwub@gmail.com> * remove unused code Signed-off-by: kim <grufwub@gmail.com> * fix expected storage paths in tests, update expected test thumbnails Signed-off-by: kim <grufwub@gmail.com> * remove dead code Signed-off-by: kim <grufwub@gmail.com> * fix cached presigned s3 url fetching Signed-off-by: kim <grufwub@gmail.com> * fix tests Signed-off-by: kim <grufwub@gmail.com> * fix test models Signed-off-by: kim <grufwub@gmail.com> * update media processing to use sync.Once{} for concurrency protection Signed-off-by: kim <grufwub@gmail.com> * shutup linter Signed-off-by: kim <grufwub@gmail.com> * fix passing in KVStore GetStream() as stream to PutStream() Signed-off-by: kim <grufwub@gmail.com> * fix unlocks of storage keys Signed-off-by: kim <grufwub@gmail.com> * whoops, return the error... Signed-off-by: kim <grufwub@gmail.com> * pour one out for tobi's code <3 Signed-off-by: kim <grufwub@gmail.com> * add back the byte slurping code Signed-off-by: kim <grufwub@gmail.com> * check for both ErrUnexpectedEOF and EOF Signed-off-by: kim <grufwub@gmail.com> * add back links to file format header information Signed-off-by: kim <grufwub@gmail.com> Signed-off-by: kim <grufwub@gmail.com>
Diffstat (limited to 'vendor/codeberg.org/gruf/go-iotools/write.go')
-rw-r--r--vendor/codeberg.org/gruf/go-iotools/write.go26
1 files changed, 26 insertions, 0 deletions
diff --git a/vendor/codeberg.org/gruf/go-iotools/write.go b/vendor/codeberg.org/gruf/go-iotools/write.go
new file mode 100644
index 000000000..c520b8636
--- /dev/null
+++ b/vendor/codeberg.org/gruf/go-iotools/write.go
@@ -0,0 +1,26 @@
+package iotools
+
+import "io"
+
+// WriterFunc is a function signature which allows
+// a function to implement the io.Writer type.
+type WriterFunc func([]byte) (int, error)
+
+func (w WriterFunc) Write(b []byte) (int, error) {
+ return w(b)
+}
+
+// WriteCloser wraps an io.Writer and io.Closer in order to implement io.WriteCloser.
+func WriteCloser(w io.Writer, c io.Closer) io.WriteCloser {
+ return &struct {
+ io.Writer
+ io.Closer
+ }{w, c}
+}
+
+// NopWriteCloser wraps an io.Writer to implement io.WriteCloser with empty io.Closer implementation.
+func NopWriteCloser(w io.Writer) io.WriteCloser {
+ return WriteCloser(w, CloserFunc(func() error {
+ return nil
+ }))
+}