Skip to content

Commit

Permalink
[move] migrated to new constraint system (starcoinorg#2270)
Browse files Browse the repository at this point in the history
* [move] migrate to new constraint system

* [stdlib] migrated stdlib to the new constraints system

* [test] migrated functional test to abilities

* [prover] fix move prover

* fix unit tests and re-generate genesis
 - ignore test_that_rust_code_compiles

* ignore test_that_installed_rust_code_compiles

* fix integration tests

Co-authored-by: jolestar <jolestar@gmail.com>
  • Loading branch information
2 people authored and naughtyvenom committed Jul 19, 2021
1 parent 1aaf0c7 commit 3fa5c6f
Show file tree
Hide file tree
Showing 214 changed files with 935 additions and 1,985 deletions.
365 changes: 159 additions & 206 deletions Cargo.lock

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions cmd/starcoin/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -44,10 +44,10 @@ starcoin-genesis = { path = "../../core/genesis" }
starcoin-resource-viewer = { path = "../../vm/resource-viewer" }
starcoin-service-registry = { path = "../../commons/service-registry" }
starcoin-move-explain = { path = "../../vm/move-explain" }
errmapgen = { git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
errmapgen = { git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
network-api = {path = "../../network/api", package="network-api"}
starcoin-network-rpc-api = {path = "../../network-rpc/api"}
short-hex-str = { git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
short-hex-str = { git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }


[dev-dependencies]
Expand Down
4 changes: 2 additions & 2 deletions commons/crypto/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,8 @@ serde = { version = "1.0.124" }
serde_bytes = "0.11.5"
hex = "0.4.3"
anyhow = "1.0"
diem-crypto = { package="diem-crypto", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686", features = ["fuzzing"] }
diem-crypto-derive = { package="diem-crypto-derive", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
diem-crypto = { package="diem-crypto", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5", features = ["fuzzing"] }
diem-crypto-derive = { package="diem-crypto-derive", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
bcs-ext = { package="bcs-ext", path = "../bcs_ext" }
crypto-macro = { package="starcoin-crypto-macro", path = "./crypto-macro"}
rand = "0.8.3"
Expand Down
2 changes: 1 addition & 1 deletion commons/proptest-helpers/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ edition = "2018"

[dependencies]
crossbeam = "0.7.3"
diem-proptest-helpers = { package="diem-proptest-helpers", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
diem-proptest-helpers = { package="diem-proptest-helpers", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }

proptest = "1.0.0"
proptest-derive = "0.3.0"
2 changes: 1 addition & 1 deletion config/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ starcoin-vm-types = { path = "../vm/types" }
starcoin-uint = { path = "../types/uint" }
network-p2p-types = { path = "../network-p2p/types"}
starcoin-logger = {path = "../commons/logger", package="starcoin-logger"}
diem-temppath = { git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
diem-temppath = { git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
starcoin-system = {path = "../commons/system", package="starcoin-system"}
network-api = {path = "../network/api", package="network-api"}
stdlib = { path = "../vm/stdlib"}
2 changes: 1 addition & 1 deletion core/forkable-jellyfish-merkle/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ tiny-keccak = "1.5"
hex= "0.4.3"
once_cell = "1.7.2"
bcs-ext = { path = "../../commons/bcs_ext", package = "bcs-ext" }
short-hex-str = { git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
short-hex-str = { git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }

[dev-dependencies]
rand = "0.8.3"
Expand Down
Binary file modified core/genesis/generated/halley/genesis
Binary file not shown.
Binary file modified core/genesis/generated/proxima/genesis
Binary file not shown.
8 changes: 4 additions & 4 deletions devtools/x/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ globset = "0.4.6"
regex = "1.4.3"
rayon = "1.5.0"
indexmap = "1.6.2"
x-core = { package="x-core", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
x-lint = { package="x-lint", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
diem-workspace-hack = { package="diem-workspace-hack", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
diem-x = { package="x", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
x-core = { package="x-core", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
x-lint = { package="x-lint", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
diem-workspace-hack = { package="diem-workspace-hack", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
diem-x = { package="x", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
2 changes: 1 addition & 1 deletion examples/my_counter/module/MyCounter.move
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
module MyCounter {
use 0x1::Signer;

resource struct T {
struct T has key, store {
value:u64,
}
public fun init(account: &signer){
Expand Down
2 changes: 1 addition & 1 deletion examples/my_token/module/MyToken.move
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ module MyToken {
use 0x1::Token;
use 0x1::Account;

struct MyToken { }
struct MyToken has copy, drop, store { }

public fun init(account: &signer) {
Token::register_token<MyToken>(account, 3);
Expand Down
20 changes: 10 additions & 10 deletions executor/src/module_compatibility_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,13 +67,13 @@ module_compatibility_test!(
duplicate_module,
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
public fun f() { return }
}
",
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
public fun f() { return }
}
",
Expand All @@ -89,7 +89,7 @@ module_compatibility_test!(
",
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
}
",
Executed
Expand All @@ -115,12 +115,12 @@ module_compatibility_test!(
layout_incompatible_module_with_new_field,
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
}
",
"
module M {
resource struct T { f: u64, g: bool }
struct T has key,store { f: u64, g: bool }
}
",
MiscellaneousError
Expand All @@ -130,12 +130,12 @@ module_compatibility_test!(
layout_incompatible_module_with_changed_field,
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
}
",
"
module M {
resource struct T { f: bool }
struct T has key,store { f: bool }
}
",
MiscellaneousError
Expand All @@ -145,12 +145,12 @@ module_compatibility_test!(
layout_incompatible_module_with_removed_field,
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
}
",
"
module M {
resource struct T {}
struct T has key,store {}
}
",
MiscellaneousError
Expand All @@ -160,7 +160,7 @@ module_compatibility_test!(
layout_incompatible_module_with_removed_struct,
"
module M {
resource struct T { f: u64 }
struct T has key,store { f: u64 }
}
",
"
Expand Down
4 changes: 2 additions & 2 deletions executor/src/readonly_function_call_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,11 @@ fn test_readonly_function_call() -> Result<()> {
let module_source = r#"
module A {
struct S {
struct S has copy,drop,store {
f1: u64,
}
resource struct R {
struct R has key,store {
f1: u64,
}
Expand Down
4 changes: 2 additions & 2 deletions vm/compiler/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,8 @@ anyhow = "1.0.38"
once_cell = "1.7.2"
tempfile = "3.1.0"
regex = { version = "1.4.3", default-features = false, features = ["std", "perf"] }
move-lang = { package="move-lang", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
move-lang-test-utils = { package="move-lang-test-utils", git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
move-lang = { package="move-lang", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
move-lang-test-utils = { package="move-lang-test-utils", git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
starcoin-crypto = { path = "../../commons/crypto"}
starcoin-vm-types = { path = "../types"}
starcoin-logger = { path = "../../commons/logger"}
Expand Down
4 changes: 2 additions & 2 deletions vm/functional-tests/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ edition = "2018"
[dependencies]
anyhow = "1.0.38"
tempfile = "3.1.0"
datatest-stable = {git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
datatest-stable = {git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }
stdlib = { package="stdlib", path = "../stdlib"}
once_cell = "1.7.2"
regex = { version = "1.4.3", default-features = false, features = ["std", "perf"] }
Expand All @@ -30,7 +30,7 @@ executor = { package="starcoin-executor", path = "../../executor"}
starcoin-genesis = { path = "../../core/genesis" }
starcoin-consensus = { path = "../../consensus" }
starcoin-account-api = { path = "../../account/api" }
move-lang = { git = "https://github.com/starcoinorg/diem", rev="da7a2d8f2d91223a0c891561812757029b613686" }
move-lang = { git = "https://github.com/starcoinorg/diem", rev="35b83099823d040a310a52f96622ab5e97aed0f5" }

[dev-dependencies]
starcoin-vm-types = { path = "../types"}
Expand Down
6 changes: 3 additions & 3 deletions vm/functional-tests/tests/testsuite/account/basic.move
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,15 @@
module Holder {
use 0x1::Signer;

resource struct Hold<T> {
struct Hold<T> has key, store {
x: T
}

public fun hold<T>(account: &signer, x: T) {
public fun hold<T: store>(account: &signer, x: T) {
move_to(account, Hold<T>{x})
}

public fun get<T>(account: &signer): T
public fun get<T: store>(account: &signer): T
acquires Hold {
let Hold {x} = move_from<Hold<T>>(Signer::address_of(account));
x
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
module SillyColdWallet {
use 0x1::Account;

resource struct T {
struct T has key, store {
cap: Account::WithdrawCapability,
owner: address,
}
Expand Down
2 changes: 1 addition & 1 deletion vm/functional-tests/tests/testsuite/box/box.move
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
//! account: alice, 100000 0x1::STC::STC

module TestR {
resource struct TestR{id: u64}
struct TestR has key, store {id: u64}

public fun new(id: u64): TestR{
TestR{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
//! sender: alice

module A {
resource struct Coin {
struct Coin has key, store {
u: u64,
}

Expand All @@ -29,7 +29,7 @@ module A {
module Tester {
use {{alice}}::A;

resource struct Pair { x: A::Coin, y: A::Coin }
struct Pair has key, store { x: A::Coin, y: A::Coin }

public fun test(account: &signer) {
move_to<Pair>(account, Pair { x: A::new(), y: A::new() });
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
module M {
use 0x1::Signer;

resource struct Cup {
struct Cup has key, store {
a: u64,
}
public fun new(): Cup {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ module MyToken {
use 0x1::Token;
use 0x1::Dao;

struct MyToken { }
struct MyToken has copy, drop, store { }

public fun init(account: &signer) {
Token::register_token<MyToken>(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ module MyToken {
use 0x1::MintDaoProposal;
use 0x1::Dao;

struct MyToken { }
struct MyToken has copy, drop, store { }

public fun init(account: &signer) {
Token::register_token<MyToken>(
Expand Down
6 changes: 3 additions & 3 deletions vm/functional-tests/tests/testsuite/debug/debug.move
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,9 @@ module M {
use 0x1::Debug;
use 0x1::Vector;

struct Foo { x: bool }
struct Bar { x: u128, y: Foo, z: bool }
struct Box<T> { x: T }
struct Foo has copy, drop, store { x: bool }
struct Bar has copy, drop, store { x: u128, y: Foo, z: bool }
struct Box<T> has copy, drop, store { x: T }

public fun test() {
let x: u64;
Expand Down
Loading

0 comments on commit 3fa5c6f

Please sign in to comment.