summaryrefslogtreecommitdiff
path: root/vendor/github.com/go-pg/pg/v10/orm/model_map.go
diff options
context:
space:
mode:
authorLibravatar Tobi Smethurst <31960611+tsmethurst@users.noreply.github.com>2021-08-12 21:03:24 +0200
committerLibravatar GitHub <noreply@github.com>2021-08-12 21:03:24 +0200
commit98263a7de64269898a2f81207e38943b5c8e8653 (patch)
tree743c90f109a6c5d27832d1dcef2388d939f0f77a /vendor/github.com/go-pg/pg/v10/orm/model_map.go
parentText duplication fix (#137) (diff)
downloadgotosocial-98263a7de64269898a2f81207e38943b5c8e8653.tar.xz
Grand test fixup (#138)
* start fixing up tests * fix up tests + automate with drone * fiddle with linting * messing about with drone.yml * some more fiddling * hmmm * add cache * add vendor directory * verbose * ci updates * update some little things * update sig
Diffstat (limited to 'vendor/github.com/go-pg/pg/v10/orm/model_map.go')
-rw-r--r--vendor/github.com/go-pg/pg/v10/orm/model_map.go53
1 files changed, 53 insertions, 0 deletions
diff --git a/vendor/github.com/go-pg/pg/v10/orm/model_map.go b/vendor/github.com/go-pg/pg/v10/orm/model_map.go
new file mode 100644
index 000000000..24533d43c
--- /dev/null
+++ b/vendor/github.com/go-pg/pg/v10/orm/model_map.go
@@ -0,0 +1,53 @@
+package orm
+
+import (
+ "github.com/go-pg/pg/v10/types"
+)
+
+type mapModel struct {
+ hookStubs
+ ptr *map[string]interface{}
+ m map[string]interface{}
+}
+
+var _ Model = (*mapModel)(nil)
+
+func newMapModel(ptr *map[string]interface{}) *mapModel {
+ model := &mapModel{
+ ptr: ptr,
+ }
+ if ptr != nil {
+ model.m = *ptr
+ }
+ return model
+}
+
+func (m *mapModel) Init() error {
+ return nil
+}
+
+func (m *mapModel) NextColumnScanner() ColumnScanner {
+ if m.m == nil {
+ m.m = make(map[string]interface{})
+ *m.ptr = m.m
+ }
+ return m
+}
+
+func (m mapModel) AddColumnScanner(ColumnScanner) error {
+ return nil
+}
+
+func (m *mapModel) ScanColumn(col types.ColumnInfo, rd types.Reader, n int) error {
+ val, err := types.ReadColumnValue(col, rd, n)
+ if err != nil {
+ return err
+ }
+
+ m.m[col.Name] = val
+ return nil
+}
+
+func (mapModel) useQueryOne() bool {
+ return true
+}