Skip to content

Commit

Permalink
TMP
Browse files Browse the repository at this point in the history
Signed-off-by: Norman Meier <[email protected]>
  • Loading branch information
n0izn0iz committed Aug 1, 2023
1 parent 2c6ff22 commit 6488680
Show file tree
Hide file tree
Showing 9 changed files with 135 additions and 9 deletions.
5 changes: 5 additions & 0 deletions examples/gno.land/r/demo/bugs/mis_ownership/gno.mod
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module "gno.land/r/demo/bugs/mis_ownership"

require (
"gno.land/r/demo/bugs/steal_ownership" v0.0.0-latest
)
16 changes: 16 additions & 0 deletions examples/gno.land/r/demo/bugs/mis_ownership/mis_ownership.gno
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package mis_ownership

import "gno.land/r/demo/bugs/steal_ownership"

var (
x = uint32(42)
ptr = &x
)

func init() {
steal_ownership.Steal(ptr)
}

func Mutate() {
*ptr = 21
}
16 changes: 9 additions & 7 deletions examples/gno.land/r/demo/bugs/slice_pop_push/slice_pop_push.gno
Original file line number Diff line number Diff line change
@@ -1,19 +1,21 @@
package slice_pop_push

import (
"strings"
)

var slice = []string{"undead-element"}

func Pop() {
func Pop() []string {
slice = slice[:len(slice)-1]
return slice
}

func Push() {
func Push() []string {
slice = append(slice, "new-element")
return slice
}

func Render(path string) string {
os := []string{"undead-element-2"}
os = os[:len(os)-1]
os = append(os, "new-element-2")

return os[0] + slice[0]
return strings.Join(slice, ",")
}
1 change: 1 addition & 0 deletions examples/gno.land/r/demo/bugs/steal_ownership/gno.mod
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
module "gno.land/r/demo/bugs/steal_ownership"
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package steal_ownership

var ptr *uint32

func Steal(xptr *uint32) {
ptr = xptr
}
49 changes: 48 additions & 1 deletion gnovm/pkg/gnolang/realm.go
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,15 @@ func (rlm *Realm) DidUpdate(po, xo, co Object) {
if rlm == nil {
return
}

shouldDebug := false
if (po != nil && strings.Contains(po.String(), "-element")) ||
(xo != nil && strings.Contains(xo.String(), "-element")) ||
(co != nil && strings.Contains(co.String(), "-element")) {
fmt.Println("intersting DidUpdate", xo, co)
shouldDebug = true
}

if debug {
if co != nil && co.GetIsDeleted() {
panic("cannot attach a deleted object")
Expand All @@ -142,6 +151,9 @@ func (rlm *Realm) DidUpdate(po, xo, co Object) {
}
}
if po == nil || !po.GetIsReal() {
if shouldDebug {
fmt.Println("DidUpdate - Do nothing 1")
}
return // do nothing.
}
if po.GetObjectID().PkgID != rlm.ID {
Expand All @@ -151,17 +163,32 @@ func (rlm *Realm) DidUpdate(po, xo, co Object) {
// Updates to .newCreated/.newEscaped /.newDeleted made here. (first gen)
// More appends happen during FinalizeRealmTransactions(). (second+ gen)
rlm.MarkDirty(po)
if shouldDebug {
fmt.Println("MarkDirty po", po)
}
if co != nil {
co.IncRefCount()
if co.GetRefCount() > 1 {
if shouldDebug {
fmt.Println("DidUpdate - ref count case")
}
if co.GetIsEscaped() {
fmt.Println("DidUpdate - already escaped")
// already escaped
} else {
fmt.Println("DidUpdate - mark escaped")
rlm.MarkNewEscaped(co)
}
} else if co.GetIsReal() {
}
if co.GetIsReal() {
if shouldDebug {
fmt.Println("MarkDirty co", co)
}
rlm.MarkDirty(co)
} else {
if shouldDebug {
fmt.Println("DidUpdate - else case")
}
co.SetOwner(po)
rlm.MarkNewReal(co)
}
Expand Down Expand Up @@ -211,6 +238,9 @@ func (rlm *Realm) MarkNewReal(oo Object) {
}

func (rlm *Realm) MarkDirty(oo Object) {
if strings.Contains(oo.(Value).String(), "-element") {
fmt.Println("MarkDirty implem", oo)
}
if debug {
if !oo.GetIsReal() && !oo.GetIsNewReal() {
panic("should not happen")
Expand Down Expand Up @@ -638,6 +668,9 @@ func (rlm *Realm) markDirtyAncestors(store Store) {
// Saves .created and .updated objects.
func (rlm *Realm) saveUnsavedObjects(store Store) {
for _, co := range rlm.created {
if strings.Contains(co.String(), "-element") {
fmt.Println("saveUnsavedObjects: created:", co.String())
}
// for i := len(rlm.created) - 1; i >= 0; i-- {
// co := rlm.created[i]
if !co.GetIsNewReal() {
Expand All @@ -649,6 +682,9 @@ func (rlm *Realm) saveUnsavedObjects(store Store) {
}
}
for _, uo := range rlm.updated {
if strings.Contains(uo.String(), "-element") {
fmt.Println("saveUnsavedObjects: updated:", uo.String())
}
// for i := len(rlm.updated) - 1; i >= 0; i-- {
// uo := rlm.updated[i]
if !uo.GetIsDirty() {
Expand Down Expand Up @@ -1057,6 +1093,9 @@ func copyValueWithRefs(parent Object, val Value) Value {
case nil:
return nil
case StringValue:
if cv == "undead-element" || cv == "new-element" {
fmt.Println("copyValueWithRefs", cv)
}
return cv
case BigintValue:
return cv
Expand Down Expand Up @@ -1088,6 +1127,9 @@ func copyValueWithRefs(parent Object, val Value) Value {
}
}
case *ArrayValue:
if strings.Contains(cv.String(), "-element") {
fmt.Println("copyValueWithRefs slice", cv)
}
if cv.Data == nil {
list := make([]TypedValue, len(cv.List))
for i, etv := range cv.List {
Expand All @@ -1104,6 +1146,11 @@ func copyValueWithRefs(parent Object, val Value) Value {
}
}
case *SliceValue:
if strings.Contains(cv.String(), "-element") {
fmt.Println("copyValueWithRefs slice", cv)
fmt.Println("copyValue base", cv.Base.(*ArrayValue))

}
return &SliceValue{
Base: toRefValue(parent, cv.Base),
Offset: cv.Offset,
Expand Down
3 changes: 3 additions & 0 deletions gnovm/pkg/gnolang/store.go
Original file line number Diff line number Diff line change
Expand Up @@ -296,6 +296,9 @@ func (ds *defaultStore) loadObjectSafe(oid ObjectID) Object {
// package values.
func (ds *defaultStore) SetObject(oo Object) {
oid := oo.GetObjectID()
if array, ok := oo.(Value).(*ArrayValue); ok && strings.Contains(array.String(), "-element") {
fmt.Println("SetObject intersting array", array)
}
// replace children/fields with Ref.
o2 := copyValueWithRefs(nil, oo)
// marshal to binary.
Expand Down
42 changes: 41 additions & 1 deletion gnovm/pkg/gnolang/values.go
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,12 @@ func (pv *PointerValue) GetBase(store Store) Object {
// TODO: document as something that enables into-native assignment.
// TODO: maybe consider this as entrypoint for DataByteValue too?
func (pv PointerValue) Assign2(alloc *Allocator, store Store, rlm *Realm, tv2 TypedValue, cu bool) {
shouldDebug := false
if strings.Contains(tv2.String(), "-element") {
fmt.Println("Assign2", tv2)
// rlm.MarkDirty(tv2.V.(*SliceValue).GetBase(store))
shouldDebug = true
}
// Special cases.
if pv.Index == PointerIndexNative {
// Special case if extended object && native.
Expand Down Expand Up @@ -276,10 +282,44 @@ func (pv PointerValue) Assign2(alloc *Allocator, store Store, rlm *Realm, tv2 Ty
}
// General case
if rlm != nil && pv.Base != nil {
if shouldDebug {
fmt.Println("Assign2 - DidUpdate", pv.TV, tv2)
}

oo1 := pv.TV.GetFirstObject(store)

markDirty := false
if pv.TV != nil && pv.TV.T != nil && pv.TV.V != nil && pv.TV.T.Kind() == SliceKind && tv2.T != nil && tv2.V != nil && tv2.T.Kind() == SliceKind && pv.TV.V.(*SliceValue).Length != tv2.V.(*SliceValue).Length {
//fmt.Println("MarkDirty weird", pv.TV, tv2)
markDirty = true
}

pv.TV.Assign(alloc, tv2, cu)
oo2 := pv.TV.GetFirstObject(store)
oo2 := tv2.GetFirstObject(store)
if shouldDebug {
fmt.Printf("Assign2 - DidUpdate after %p %p\n", oo1, oo2)
}
rlm.DidUpdate(pv.Base.(Object), oo1, oo2)
if markDirty {
//rlm.MarkDirty(oo1)
}

/*
if shouldDebug {
if pv.TV != nil && tv2.V != nil && oo1 != nil && oo2 != nil {
switch pv.TV.V.(type) {
case *SliceValue:
switch tv2.V.(type) {
case *SliceValue:
base := pv.TV.V.(*SliceValue).GetBase(store)
if base == tv2.V.(*SliceValue).GetBase(store) && base != nil {
rlm.MarkDirty(base)
}
}
}
}
}
*/
} else {
pv.TV.Assign(alloc, tv2, cu)
}
Expand Down
5 changes: 5 additions & 0 deletions result.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
❯ gnokey maketx call -pkgpath "gno.land/r/demo/bugs/mis_ownership" -func "Edit" -gas-fee 1000000ugnot -gas-wanted 2000000 -send "" -broadcast -chainid "dev" -remote "127.0.0.1:26657" onblock-test Native

Enter password.
--= Error =--
Data: cannot modify external-realm or non-realm object: object pkg path: gno.land/r/demo/bugs/steal_ownership, realm: gno.land/r/demo/bugs/mis_ownership

0 comments on commit 6488680

Please sign in to comment.