summaryrefslogtreecommitdiff
path: root/vendor/github.com/uptrace/bun/dialect/pgdialect/append.go
diff options
context:
space:
mode:
authorLibravatar tobi <31960611+tsmethurst@users.noreply.github.com>2022-08-15 12:35:05 +0200
committerLibravatar GitHub <noreply@github.com>2022-08-15 11:35:05 +0100
commitac6ed3d939fe9dad81aadbd04541e905c625ca82 (patch)
tree6116baf25675837dc99f69c49b9fec2ff112ce5c /vendor/github.com/uptrace/bun/dialect/pgdialect/append.go
parent[frontend] Sensitive media spoilers (#752) (diff)
downloadgotosocial-ac6ed3d939fe9dad81aadbd04541e905c625ca82.tar.xz
[chore] Update bun / sqlite versions; update gtsmodels (#754)
* upstep bun and sqlite versions * allow specific columns to be updated in the db * only update necessary columns for user * bit tidier * only update necessary fields of media_attachment * only update relevant instance fields * update tests * update only specific account columns * use bool pointers on gtsmodels includes attachment, status, account, user * update columns more selectively * test all default fields on new account insert * updating remaining bools on gtsmodels * initialize pointer fields when extracting AP emoji * copy bools properly * add copyBoolPtr convenience function + test it * initialize false bool ptrs a bit more neatly
Diffstat (limited to 'vendor/github.com/uptrace/bun/dialect/pgdialect/append.go')
-rw-r--r--vendor/github.com/uptrace/bun/dialect/pgdialect/append.go55
1 files changed, 55 insertions, 0 deletions
diff --git a/vendor/github.com/uptrace/bun/dialect/pgdialect/append.go b/vendor/github.com/uptrace/bun/dialect/pgdialect/append.go
index d5e0d0a57..a60bf5de2 100644
--- a/vendor/github.com/uptrace/bun/dialect/pgdialect/append.go
+++ b/vendor/github.com/uptrace/bun/dialect/pgdialect/append.go
@@ -307,3 +307,58 @@ func arrayAppendString(b []byte, s string) []byte {
b = append(b, '"')
return b
}
+
+//------------------------------------------------------------------------------
+
+var mapStringStringType = reflect.TypeOf(map[string]string(nil))
+
+func (d *Dialect) hstoreAppender(typ reflect.Type) schema.AppenderFunc {
+ kind := typ.Kind()
+
+ switch kind {
+ case reflect.Ptr:
+ if fn := d.hstoreAppender(typ.Elem()); fn != nil {
+ return schema.PtrAppender(fn)
+ }
+ case reflect.Map:
+ // ok:
+ default:
+ return nil
+ }
+
+ if typ.Key() == stringType && typ.Elem() == stringType {
+ return appendMapStringStringValue
+ }
+
+ return func(fmter schema.Formatter, b []byte, v reflect.Value) []byte {
+ err := fmt.Errorf("bun: Hstore(unsupported %s)", v.Type())
+ return dialect.AppendError(b, err)
+ }
+}
+
+func appendMapStringString(b []byte, m map[string]string) []byte {
+ if m == nil {
+ return dialect.AppendNull(b)
+ }
+
+ b = append(b, '\'')
+
+ for key, value := range m {
+ b = arrayAppendString(b, key)
+ b = append(b, '=', '>')
+ b = arrayAppendString(b, value)
+ b = append(b, ',')
+ }
+ if len(m) > 0 {
+ b = b[:len(b)-1] // Strip trailing comma.
+ }
+
+ b = append(b, '\'')
+
+ return b
+}
+
+func appendMapStringStringValue(fmter schema.Formatter, b []byte, v reflect.Value) []byte {
+ m := v.Convert(mapStringStringType).Interface().(map[string]string)
+ return appendMapStringString(b, m)
+}