From 0beafc3d4fd025c2c871c5ed4b35ad48eb4a0d92 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 20:29:06 +0300 Subject: [PATCH 01/13] Arrange the cells for easier debugging --- mx-semantics/targets/testing/configuration.md | 2 +- rust-semantics/config.md | 2 +- rust-semantics/targets/execution/configuration.md | 4 ++-- rust-semantics/targets/preprocessing/configuration.md | 2 +- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/mx-semantics/targets/testing/configuration.md b/mx-semantics/targets/testing/configuration.md index 3f6e4b5..9e0155c 100644 --- a/mx-semantics/targets/testing/configuration.md +++ b/mx-semantics/targets/testing/configuration.md @@ -17,9 +17,9 @@ module MX-CONFIGURATION configuration - + endmodule diff --git a/rust-semantics/config.md b/rust-semantics/config.md index 2f7f00f..155771d 100644 --- a/rust-semantics/config.md +++ b/rust-semantics/config.md @@ -6,8 +6,8 @@ module RUST-CONFIGURATION configuration - + endmodule diff --git a/rust-semantics/targets/execution/configuration.md b/rust-semantics/targets/execution/configuration.md index c035ed0..bb59e86 100644 --- a/rust-semantics/targets/execution/configuration.md +++ b/rust-semantics/targets/execution/configuration.md @@ -15,9 +15,9 @@ module RUST-RUNNING-CONFIGURATION configuration - - + + endmodule diff --git a/rust-semantics/targets/preprocessing/configuration.md b/rust-semantics/targets/preprocessing/configuration.md index d122260..014bdc4 100644 --- a/rust-semantics/targets/preprocessing/configuration.md +++ b/rust-semantics/targets/preprocessing/configuration.md @@ -14,10 +14,10 @@ module RUST-RUNNING-CONFIGURATION configuration - + endmodule From 0b7daa92d391dbc3572525879ea976f6c089f124 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 20:33:01 +0300 Subject: [PATCH 02/13] Create a list of traits to help with mx preprocessing --- rust-semantics/preprocessing/configuration.md | 1 + rust-semantics/preprocessing/initialization.md | 1 + 2 files changed, 2 insertions(+) diff --git a/rust-semantics/preprocessing/configuration.md b/rust-semantics/preprocessing/configuration.md index 01d33f6..fc3a6fd 100644 --- a/rust-semantics/preprocessing/configuration.md +++ b/rust-semantics/preprocessing/configuration.md @@ -14,6 +14,7 @@ module RUST-PREPROCESSING-CONFIGURATION tuple(.ValueList) + .List // List of TypePath my_identifier:TypePath diff --git a/rust-semantics/preprocessing/initialization.md b/rust-semantics/preprocessing/initialization.md index 83e0ad1..4828b65 100644 --- a/rust-semantics/preprocessing/initialization.md +++ b/rust-semantics/preprocessing/initialization.md @@ -10,6 +10,7 @@ module INITIALIZATION traitInitializer(Name:TypePath) => .K ... + .List => ListItem(Name) ... ... .Bag From 571f3ae42733d7ea7a0b230e648728a9e59b2ead Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 20:49:16 +0300 Subject: [PATCH 03/13] Static method calls --- rust-semantics/expression/calls.md | 103 ++++++++++++++++++++------- rust-semantics/representation.md | 6 ++ rust-semantics/rust-common-syntax.md | 11 +-- 3 files changed, 90 insertions(+), 30 deletions(-) diff --git a/rust-semantics/expression/calls.md b/rust-semantics/expression/calls.md index 32abd98..3c2d535 100644 --- a/rust-semantics/expression/calls.md +++ b/rust-semantics/expression/calls.md @@ -14,6 +14,16 @@ module RUST-EXPRESSION-CALLS , params: CallParamsList , reversedNormalizedParams: NormalizedCallParams ) + syntax Instruction ::= staticMethodCall + ( traitName: TypePath + , method: Identifier + , params: CallParamsList + , reversedNormalizedParams: NormalizedCallParams + ) + syntax Instruction ::= reverseNormalizeParams + ( params: CallParamsList + , reversedNormalizedParams: NormalizedCallParams + ) syntax NormalizedCallParams ::= reverse(NormalizedCallParams, NormalizedCallParams) [function, total] rule reverse(.NormalizedCallParams, R:NormalizedCallParams) => R @@ -28,35 +38,50 @@ module RUST-EXPRESSION-CALLS rule - methodCall - (... self: ptrValue(ptr(A) #as P, _) - , method: MethodName:Identifier - , params: Args:CallParamsList - ) - => methodCall - (... traitName: TraitName - , method: MethodName - , params: Args - , reversedNormalizedParams: P, .NormalizedCallParams - ) + ( .K + => reverseNormalizeParams + (... params: Args + , reversedNormalizedParams: P, .NormalizedCallParams + ) + ~> TraitName + ) + ~> methodCall + (... self: ptrValue(ptr(A) #as P, _) + , method: _MethodName:Identifier + , params: Args:CallParamsList + ) ... A |-> struct(TraitName:TypePath, _) ... requires isValueWithPtr(Args) - rule methodCall - (... traitName: _TraitName:TypePath - , method: _MethodName:Identifier - , params: (ptrValue(ptr(_) #as P:Ptr, _:Value) , Cps:CallParamsList) => Cps + rule + ( reverseNormalizeParams + (... params: .CallParamsList + , reversedNormalizedParams: Args:NormalizedCallParams + ) + ~> TraitName:TypePath + ~> methodCall + (... self: _ + , method: MethodName:Identifier + , params: _:CallParamsList + ) + ) + => normalizedMethodCall + ( TraitName + , MethodName + , reverse(Args, .NormalizedCallParams) + ) + + rule reverseNormalizeParams + (... params: (ptrValue(ptr(_) #as P:Ptr, _:Value) , Cps:CallParamsList) => Cps , reversedNormalizedParams: Args:NormalizedCallParams => P, Args ) rule - methodCall - (... traitName: _TraitName:TypePath - , method: _MethodName:Identifier - , params: (ptrValue(null, V:Value) , Cps:CallParamsList) => Cps + reverseNormalizeParams + (... params: (ptrValue(null, V:Value) , Cps:CallParamsList) => Cps , reversedNormalizedParams: Args:NormalizedCallParams => ptr(NextId), Args ) @@ -64,13 +89,41 @@ module RUST-EXPRESSION-CALLS NextId:Int => NextId +Int 1 Values:Map => Values[NextId <- V] + + rule TraitName:Identifier :: MethodName:Identifier :: .PathExprSegments ( ) + => staticMethodCall(... trait: TraitName, method: MethodName, params: .CallParamsList) + rule TraitName:Identifier :: MethodName:Identifier :: .PathExprSegments + ( Args:CallParamsList ) + => staticMethodCall(... trait: TraitName, method: MethodName, params: Args) + rule TraitName:Identifier :: MethodName:Identifier :: .PathExprSegments + ( Args:CallParamsList , ) + => staticMethodCall(... trait: TraitName, method: MethodName, params: Args) + rule - methodCall - (... traitName: TraitName:TypePath - , method: MethodName:Identifier - , params: .CallParamsList - , reversedNormalizedParams: Args:NormalizedCallParams - ) + ( .K + => reverseNormalizeParams + (... params: Args + , reversedNormalizedParams: .NormalizedCallParams + ) + ) + ~> staticMethodCall + (... trait: _TraitName:TypePath + , method: _MethodName:Identifier + , params: Args:CallParamsList + ) + requires isValueWithPtr(Args) + + rule + ( reverseNormalizeParams + (... params: .CallParamsList + , reversedNormalizedParams: Args:NormalizedCallParams + ) + ~> staticMethodCall + (... trait: TraitName:TypePath + , method: MethodName:Identifier + , params: _:CallParamsList + ) + ) => normalizedMethodCall ( TraitName , MethodName diff --git a/rust-semantics/representation.md b/rust-semantics/representation.md index e3f2506..a573790 100644 --- a/rust-semantics/representation.md +++ b/rust-semantics/representation.md @@ -66,6 +66,12 @@ module RUST-REPRESENTATION , params: CallParamsList ) [seqstrict(1, 3), result(ValueWithPtr)] + | staticMethodCall + ( trait: TypePath + , method: Identifier + , params: CallParamsList + ) + [strict(3), result(ValueWithPtr)] syntax NormalizedFunctionParameterListOrError ::= NormalizedFunctionParameterList | SemanticsError diff --git a/rust-semantics/rust-common-syntax.md b/rust-semantics/rust-common-syntax.md index e9de99b..c3747ab 100644 --- a/rust-semantics/rust-common-syntax.md +++ b/rust-semantics/rust-common-syntax.md @@ -324,7 +324,6 @@ https://doc.rust-lang.org/reference/items/extern-crates.html | BreakExpression | UnderscoreExpression - | CallExpression | ErrorPropagationExpression | TypeCastExpression // TODO: Removed because it causes ambiguities. @@ -340,7 +339,11 @@ https://doc.rust-lang.org/reference/items/extern-crates.html > Expression "." Identifier // FieldExpression - // > CallExpression + // https://doc.rust-lang.org/reference/expressions/call-expr.html + // TODO: Not implemented properly to avoid ambiguities + > PathExpression "(" ")" + > PathExpression "(" CallParams ")" + | Expression "[" Expression "]" // > ErrorPropagationExpression @@ -527,9 +530,6 @@ https://doc.rust-lang.org/reference/items/extern-crates.html ```k - // TODO: Not implemented properly to avoid ambiguities - syntax CallExpression ::= PathExpression "(" MaybeCallParams ")" - syntax MaybeCallParams ::= "" | CallParams syntax CallParams ::= CallParamsList | CallParamsList "," syntax CallParamsList ::= NeList{Expression, ","} @@ -582,6 +582,7 @@ https://doc.rust-lang.org/reference/items/extern-crates.html syntax MacroInvocation ::= SimplePath "!" DelimTokenTree // TODO: Not implemented properly syntax DelimTokenTree ::= "(" MaybeCallParams ")" + syntax MaybeCallParams ::= "" | CallParams // TODO: Not implemented properly syntax MacroInvocationSemi ::= MacroInvocation ";" From 48252287443a28405638a46b43c968391abf8a47 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 20:54:22 +0300 Subject: [PATCH 04/13] Integer - value conversions --- rust-semantics/expression/literals.md | 8 +++++++- rust-semantics/representation.md | 4 ++++ 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/rust-semantics/expression/literals.md b/rust-semantics/expression/literals.md index 437ab2e..71e7977 100644 --- a/rust-semantics/expression/literals.md +++ b/rust-semantics/expression/literals.md @@ -60,7 +60,6 @@ module RUST-EXPRESSION-INTEGER-LITERALS [owise] - syntax ValueOrError ::= integerToValue(Int, Type) [function, total] rule integerToValue(I:Int, i32) => i32(Int2MInt(I)) requires sminMInt(32) <=Int I andBool I <=Int smaxMInt(32) rule integerToValue(I:Int, u32) => u32(Int2MInt(I)) @@ -74,6 +73,13 @@ module RUST-EXPRESSION-INTEGER-LITERALS => error("integerToValue: unimplemented", ListItem(I:Int:KItem) ListItem(T:Type:KItem)) [owise] + rule valueToInteger(V:Value) => error("cannot convert to integer", ListItem(V)) [owise] + rule valueToInteger(i32(V:MInt{32})) => MInt2Signed(V) + rule valueToInteger(u32(V:MInt{32})) => MInt2Unsigned(V) + rule valueToInteger(i64(V:MInt{64})) => MInt2Signed(V) + rule valueToInteger(u64(V:MInt{64})) => MInt2Unsigned(V) + rule valueToInteger(u128(V:MInt{128})) => MInt2Unsigned(V) + syntax Bool ::= endsWith(containing:String, contained:String) [function, total] rule endsWith(Containing:String, Contained:String) => substrString diff --git a/rust-semantics/representation.md b/rust-semantics/representation.md index a573790..dee4d83 100644 --- a/rust-semantics/representation.md +++ b/rust-semantics/representation.md @@ -91,6 +91,10 @@ module RUST-REPRESENTATION syntax Bool ::= isLocalVariable(ValueName) [function, total] syntax Bool ::= isValueWithPtr(K) [function, total, symbol(isValueWithPtr)] + syntax IntOrError ::= Int | SemanticsError + syntax IntOrError ::= valueToInteger(Value) [function, total] + syntax ValueOrError ::= integerToValue(Int, Type) [function, total] + endmodule ``` From ee52e2f7b0b2ddea7bfcee3a13ecb84d98d02ddf Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 20:56:54 +0300 Subject: [PATCH 05/13] Ignore generic args when casting structs --- rust-semantics/expression/casts.md | 1 + 1 file changed, 1 insertion(+) diff --git a/rust-semantics/expression/casts.md b/rust-semantics/expression/casts.md index c7988eb..9138421 100644 --- a/rust-semantics/expression/casts.md +++ b/rust-semantics/expression/casts.md @@ -39,6 +39,7 @@ module RUST-CASTS rule implicitCast(V:Bool, bool) => V rule implicitCast(struct(T, _) #as V, T) => V + rule implicitCast(struct(T, _) #as V, T < _ >) => V // Rewrites From 69f16734f9fd48230435baa9d0cf39c95160551c Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 21:12:08 +0300 Subject: [PATCH 06/13] Framework for executing Mx+Rust --- Makefile | 17 ++++++++++++++- mx-rust-semantics/main/configuration.md | 17 +++++++++++++++ mx-rust-semantics/main/mx-rust-common.md | 6 ++++++ .../targets/blockchain/configuration.md | 21 +++++++++++++++++++ .../targets/blockchain/mx-rust.md | 21 +++++++++++++++++++ 5 files changed, 81 insertions(+), 1 deletion(-) create mode 100644 mx-rust-semantics/main/configuration.md create mode 100644 mx-rust-semantics/main/mx-rust-common.md create mode 100644 mx-rust-semantics/targets/blockchain/configuration.md create mode 100644 mx-rust-semantics/targets/blockchain/mx-rust.md diff --git a/Makefile b/Makefile index a9cdf29..2e961dd 100644 --- a/Makefile +++ b/Makefile @@ -27,12 +27,19 @@ MX_TESTING_OUTPUT_DIR ::= .build/mx/output MX_TESTING_INPUTS ::= $(wildcard $(MX_TESTING_INPUT_DIR)/**/*.mx) MX_TESTING_OUTPUTS ::= $(patsubst $(MX_TESTING_INPUT_DIR)/%,$(MX_TESTING_OUTPUT_DIR)/%.executed.kore,$(MX_TESTING_INPUTS)) +MX_RUST_SEMANTICS_FILES ::= $(shell find mx-rust-semantics/ -type f -a '(' -name '*.md' -or -name '*.k' ')') +MX_RUST_KOMPILED ::= .build/mx-rust-kompiled +MX_RUST_TIMESTAMP ::= $(MX_RUST_KOMPILED)/timestamp + .PHONY: clean build test syntax-test preprocessing-test execution-test mx-test clean: rm -r .build -build: $(RUST_PREPROCESSING_TIMESTAMP) $(RUST_EXECUTION_TIMESTAMP) $(MX_TESTING_TIMESTAMP) +build: $(RUST_PREPROCESSING_TIMESTAMP) \ + $(RUST_EXECUTION_TIMESTAMP) \ + $(MX_TESTING_TIMESTAMP) \ + $(MX_RUST_TIMESTAMP) test: syntax-test preprocessing-test execution-test mx-test @@ -59,6 +66,14 @@ $(MX_TESTING_TIMESTAMP): $(MX_SEMANTICS_FILES) -rm -r $(MX_TESTING_KOMPILED) $$(which kompile) mx-semantics/targets/testing/mx.md -o $(MX_TESTING_KOMPILED) --debug +$(MX_RUST_TIMESTAMP): $(MX_SEMANTICS_FILES) $(RUST_SEMANTICS_FILES) $(MX_RUST_SEMANTICS_FILES) + # Workaround for https://github.com/runtimeverification/k/issues/4141 + -rm -r $(MX_RUST_KOMPILED) + $$(which kompile) mx-rust-semantics/targets/blockchain/mx-rust.md \ + -o $(MX_RUST_KOMPILED) \ + -I . \ + --debug + $(RUST_SYNTAX_OUTPUT_DIR)/%.rs-parsed: $(RUST_SYNTAX_INPUT_DIR)/%.rs $(RUST_PREPROCESSING_TIMESTAMP) mkdir -p $(RUST_SYNTAX_OUTPUT_DIR) kast --definition $(RUST_PREPROCESSING_KOMPILED) $< --sort Crate > $@.tmp && mv -f $@.tmp $@ diff --git a/mx-rust-semantics/main/configuration.md b/mx-rust-semantics/main/configuration.md new file mode 100644 index 0000000..b7de223 --- /dev/null +++ b/mx-rust-semantics/main/configuration.md @@ -0,0 +1,17 @@ +```k + +requires "mx-semantics/main/configuration.md" +requires "rust-semantics/config.md" + +module MX-RUST-COMMON-CONFIGURATION + imports MX-COMMON-CONFIGURATION + imports RUST-CONFIGURATION + + configuration + + + + +endmodule + +``` diff --git a/mx-rust-semantics/main/mx-rust-common.md b/mx-rust-semantics/main/mx-rust-common.md new file mode 100644 index 0000000..c5b6c61 --- /dev/null +++ b/mx-rust-semantics/main/mx-rust-common.md @@ -0,0 +1,6 @@ +```k + +module MX-RUST-COMMON +endmodule + +``` diff --git a/mx-rust-semantics/targets/blockchain/configuration.md b/mx-rust-semantics/targets/blockchain/configuration.md new file mode 100644 index 0000000..8a1526a --- /dev/null +++ b/mx-rust-semantics/targets/blockchain/configuration.md @@ -0,0 +1,21 @@ +```k + +requires "../../main/configuration.md" + +module COMMON-K-CELL + configuration + .K +endmodule + +module MX-RUST-CONFIGURATION + imports COMMON-K-CELL + imports MX-RUST-COMMON-CONFIGURATION + + configuration + + + + +endmodule + +``` diff --git a/mx-rust-semantics/targets/blockchain/mx-rust.md b/mx-rust-semantics/targets/blockchain/mx-rust.md new file mode 100644 index 0000000..f12e9e3 --- /dev/null +++ b/mx-rust-semantics/targets/blockchain/mx-rust.md @@ -0,0 +1,21 @@ +```k + +requires "configuration.md" +requires "mx-semantics/main/mx-common.md" +requires "mx-semantics/main/syntax.md" +requires "rust-semantics/rust-common.md" +requires "rust-semantics/rust-common-syntax.md" +requires "../../main/mx-rust-common.md" + +module MX-RUST-SYNTAX + imports RUST-COMMON-SYNTAX +endmodule + +module MX-RUST + imports private MX-COMMON + imports private MX-RUST-COMMON + imports private MX-RUST-CONFIGURATION + imports private RUST-COMMON +endmodule + +``` From ad35c5a4c1db7ddb26b41b885c689cf23ad04633 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 21:24:20 +0300 Subject: [PATCH 07/13] Framework for testing Mx+Rust --- Makefile | 50 +++++++++++++++++-- mx-rust-semantics/main/representation.md | 7 +++ .../targets/testing/configuration.md | 30 +++++++++++ mx-rust-semantics/targets/testing/mx-rust.md | 31 ++++++++++++ mx-rust-semantics/test/configuration.md | 14 ++++++ mx-rust-semantics/test/execution.md | 13 +++++ parse-mx-rust-test.sh | 8 +++ parse-mx-rust.sh | 8 +++ 8 files changed, 157 insertions(+), 4 deletions(-) create mode 100644 mx-rust-semantics/main/representation.md create mode 100644 mx-rust-semantics/targets/testing/configuration.md create mode 100644 mx-rust-semantics/targets/testing/mx-rust.md create mode 100644 mx-rust-semantics/test/configuration.md create mode 100644 mx-rust-semantics/test/execution.md create mode 100755 parse-mx-rust-test.sh create mode 100755 parse-mx-rust.sh diff --git a/Makefile b/Makefile index 2e961dd..7478b43 100644 --- a/Makefile +++ b/Makefile @@ -31,7 +31,15 @@ MX_RUST_SEMANTICS_FILES ::= $(shell find mx-rust-semantics/ -type f -a '(' -name MX_RUST_KOMPILED ::= .build/mx-rust-kompiled MX_RUST_TIMESTAMP ::= $(MX_RUST_KOMPILED)/timestamp -.PHONY: clean build test syntax-test preprocessing-test execution-test mx-test +MX_RUST_TESTING_SEMANTICS_FILES ::= $(shell find mx-rust-semantics/ -type f -a '(' -name '*.md' -or -name '*.k' ')') +MX_RUST_TESTING_KOMPILED ::= .build/mx-rust-testing-kompiled +MX_RUST_TESTING_TIMESTAMP ::= $(MX_RUST_TESTING_KOMPILED)/timestamp +MX_RUST_TESTING_INPUT_DIR ::= tests/mx-rust +MX_RUST_TESTING_OUTPUT_DIR ::= .build/mx-rust/output +MX_RUST_TESTING_INPUTS ::= $(wildcard $(MX_RUST_TESTING_INPUT_DIR)/*.run) +MX_RUST_TESTING_OUTPUTS ::= $(patsubst $(MX_RUST_TESTING_INPUT_DIR)/%,$(MX_RUST_TESTING_OUTPUT_DIR)/%.executed.kore,$(MX_RUST_TESTING_INPUTS)) + +.PHONY: clean build test syntax-test preprocessing-test execution-test mx-test mx-rust-test clean: rm -r .build @@ -39,9 +47,10 @@ clean: build: $(RUST_PREPROCESSING_TIMESTAMP) \ $(RUST_EXECUTION_TIMESTAMP) \ $(MX_TESTING_TIMESTAMP) \ - $(MX_RUST_TIMESTAMP) + $(MX_RUST_TIMESTAMP) \ + $(MX_RUST_TESTING_TIMESTAMP) -test: syntax-test preprocessing-test execution-test mx-test +test: build syntax-test preprocessing-test execution-test mx-test mx-rust-test syntax-test: $(SYNTAX_OUTPUTS) @@ -51,6 +60,8 @@ execution-test: $(EXECUTION_OUTPUTS) mx-test: $(MX_TESTING_OUTPUTS) +mx-rust-test: $(MX_RUST_TESTING_OUTPUTS) + $(RUST_PREPROCESSING_TIMESTAMP): $(RUST_SEMANTICS_FILES) # Workaround for https://github.com/runtimeverification/k/issues/4141 -rm -r $(RUST_PREPROCESSING_KOMPILED) @@ -74,6 +85,14 @@ $(MX_RUST_TIMESTAMP): $(MX_SEMANTICS_FILES) $(RUST_SEMANTICS_FILES) $(MX_RUST_SE -I . \ --debug +$(MX_RUST_TESTING_TIMESTAMP): $(MX_SEMANTICS_FILES) $(RUST_SEMANTICS_FILES) $(MX_RUST_SEMANTICS_FILES) + # Workaround for https://github.com/runtimeverification/k/issues/4141 + -rm -r $(MX_RUST_TESTING_KOMPILED) + $$(which kompile) mx-rust-semantics/targets/testing/mx-rust.md \ + -o $(MX_RUST_TESTING_KOMPILED) \ + -I . \ + --debug + $(RUST_SYNTAX_OUTPUT_DIR)/%.rs-parsed: $(RUST_SYNTAX_INPUT_DIR)/%.rs $(RUST_PREPROCESSING_TIMESTAMP) mkdir -p $(RUST_SYNTAX_OUTPUT_DIR) kast --definition $(RUST_PREPROCESSING_KOMPILED) $< --sort Crate > $@.tmp && mv -f $@.tmp $@ @@ -90,7 +109,11 @@ $(PREPROCESSING_OUTPUT_DIR)/%.rs.preprocessed.kore: $(PREPROCESSING_INPUT_DIR)/% # TODO: Add $(shell echo "$<" | sed 's/\.[^.]*.run$$//').rs # as a dependency -$(EXECUTION_OUTPUT_DIR)/%.run.executed.kore: $(EXECUTION_INPUT_DIR)/%.run $(RUST_EXECUTION_TIMESTAMP) +$(EXECUTION_OUTPUT_DIR)/%.run.executed.kore: \ + $(EXECUTION_INPUT_DIR)/%.run \ + $(RUST_EXECUTION_TIMESTAMP) \ + parse-rust.sh \ + parse-test.sh mkdir -p $(EXECUTION_OUTPUT_DIR) krun \ "$(shell echo "$<" | sed 's/\.[^.]*.run$$//').rs" \ @@ -112,3 +135,22 @@ $(MX_TESTING_OUTPUT_DIR)/%.mx.executed.kore: $(MX_TESTING_INPUT_DIR)/%.mx $(MX_T --output-file $@.tmp cat $@.tmp | grep -q "Lbl'-LT-'k'-GT-'{}(dotk{}())" mv -f $@.tmp $@ + +# TODO: Add $(shell echo "$<" | sed 's/\.[^.]*.run$$//').rs +# as a dependency +$(MX_RUST_TESTING_OUTPUT_DIR)/%.run.executed.kore: \ + $(MX_RUST_TESTING_INPUT_DIR)/%.run \ + $(MX_RUST_TESTING_TIMESTAMP) \ + parse-mx-rust.sh \ + parse-mx-rust-test.sh + mkdir -p $(MX_RUST_TESTING_OUTPUT_DIR) + krun \ + "$(shell echo "$<" | sed 's/\.[^.]*.run$$//').rs" \ + --definition $(MX_RUST_TESTING_KOMPILED) \ + --parser $(CURDIR)/parse-mx-rust.sh \ + --output kore \ + --output-file $@.tmp \ + -cTEST='$(shell cat $<)' \ + -pTEST=$(CURDIR)/parse-mx-rust-test.sh + cat $@.tmp | grep -q "Lbl'-LT-'k'-GT-'{}(dotk{}())" + mv -f $@.tmp $@ diff --git a/mx-rust-semantics/main/representation.md b/mx-rust-semantics/main/representation.md new file mode 100644 index 0000000..0971fd2 --- /dev/null +++ b/mx-rust-semantics/main/representation.md @@ -0,0 +1,7 @@ +```k + +module MX-RUST-REPRESENTATION + syntax MxRustInstruction ::= "mxRustPreprocessTraits" +endmodule + +``` diff --git a/mx-rust-semantics/targets/testing/configuration.md b/mx-rust-semantics/targets/testing/configuration.md new file mode 100644 index 0000000..724e3ec --- /dev/null +++ b/mx-rust-semantics/targets/testing/configuration.md @@ -0,0 +1,30 @@ +```k + +requires "../../main/configuration.md" +requires "../../test/configuration.md" + +module COMMON-K-CELL + imports MX-RUST-REPRESENTATION + imports RUST-PREPROCESSING-SYNTAX + imports RUST-SHARED-SYNTAX + + syntax MxRustTest + + configuration + crateParser($PGM:Crate) ~> mxRustPreprocessTraits ~> ($TEST:MxRustTest):KItem +endmodule + +module MX-RUST-CONFIGURATION + imports COMMON-K-CELL + imports MX-RUST-COMMON-CONFIGURATION + imports MX-RUST-EXECUTION-TEST-CONFIGURATION + + configuration + + + + + +endmodule + +``` diff --git a/mx-rust-semantics/targets/testing/mx-rust.md b/mx-rust-semantics/targets/testing/mx-rust.md new file mode 100644 index 0000000..3acfae8 --- /dev/null +++ b/mx-rust-semantics/targets/testing/mx-rust.md @@ -0,0 +1,31 @@ +```k + +requires "configuration.md" +requires "mx-semantics/main/mx-common.md" +requires "mx-semantics/main/syntax.md" +requires "mx-semantics/test/configuration.md" +requires "mx-semantics/test/execution.md" +requires "rust-semantics/rust-common.md" +requires "rust-semantics/rust-common-syntax.md" +requires "rust-semantics/test/configuration.md" +requires "rust-semantics/test/execution.md" +requires "../../main/mx-rust-common.md" +requires "../../main/representation.md" +requires "../../test/execution.md" + +module MX-RUST-SYNTAX + imports RUST-COMMON-SYNTAX + imports MX-RUST-TESTING-PARSING-SYNTAX +endmodule + +module MX-RUST + imports private MX-COMMON + imports private MX-RUST-TEST + imports private MX-RUST-CONFIGURATION + imports private MX-RUST-COMMON + imports private MX-TEST-EXECUTION + imports private RUST-COMMON + imports private RUST-EXECUTION-TEST +endmodule + +``` diff --git a/mx-rust-semantics/test/configuration.md b/mx-rust-semantics/test/configuration.md new file mode 100644 index 0000000..3b0d2d1 --- /dev/null +++ b/mx-rust-semantics/test/configuration.md @@ -0,0 +1,14 @@ +```k + +module MX-RUST-EXECUTION-TEST-CONFIGURATION + imports MX-TEST-CONFIGURATION + imports RUST-EXECUTION-TEST-CONFIGURATION + + configuration + + + + +endmodule + +``` diff --git a/mx-rust-semantics/test/execution.md b/mx-rust-semantics/test/execution.md new file mode 100644 index 0000000..8a11b20 --- /dev/null +++ b/mx-rust-semantics/test/execution.md @@ -0,0 +1,13 @@ +```k + +module MX-RUST-TESTING-PARSING-SYNTAX + imports RUST-EXECUTION-TEST-PARSING-SYNTAX + + syntax MxRustTest ::= ExecutionTest + +endmodule + +module MX-RUST-TEST +endmodule + +``` diff --git a/parse-mx-rust-test.sh b/parse-mx-rust-test.sh new file mode 100755 index 0000000..abb0296 --- /dev/null +++ b/parse-mx-rust-test.sh @@ -0,0 +1,8 @@ +#! /bin/bash + +kast \ + --output kore \ + --definition .build/mx-rust-testing-kompiled \ + --module MX-RUST-SYNTAX \ + --sort MxRustTest \ + $1 diff --git a/parse-mx-rust.sh b/parse-mx-rust.sh new file mode 100755 index 0000000..c20b2ec --- /dev/null +++ b/parse-mx-rust.sh @@ -0,0 +1,8 @@ +#! /bin/bash + +kast \ + --output kore \ + --definition .build/mx-rust-testing-kompiled \ + --module RUST-COMMON-SYNTAX \ + --sort Crate \ + $1 From d2de1bb1ca9ce898afeaa7167de0dd00a97a6393 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 21:48:15 +0300 Subject: [PATCH 08/13] Implement storage functions --- mx-rust-semantics/main/expression.md | 9 ++ mx-rust-semantics/main/expression/strings.md | 34 +++++ mx-rust-semantics/main/mx-rust-common.md | 7 + mx-rust-semantics/main/preprocessing.md | 11 ++ .../main/preprocessing/methods.md | 124 ++++++++++++++++++ .../main/preprocessing/traits.md | 27 ++++ mx-rust-semantics/main/representation.md | 12 ++ rust-semantics/representation.md | 1 + 8 files changed, 225 insertions(+) create mode 100644 mx-rust-semantics/main/expression.md create mode 100644 mx-rust-semantics/main/expression/strings.md create mode 100644 mx-rust-semantics/main/preprocessing.md create mode 100644 mx-rust-semantics/main/preprocessing/methods.md create mode 100644 mx-rust-semantics/main/preprocessing/traits.md diff --git a/mx-rust-semantics/main/expression.md b/mx-rust-semantics/main/expression.md new file mode 100644 index 0000000..1e6a692 --- /dev/null +++ b/mx-rust-semantics/main/expression.md @@ -0,0 +1,9 @@ +```k + +requires "expression/strings.md" + +module MX-RUST-EXPRESSION + imports private MX-RUST-EXPRESSION-STRINGS +endmodule + +``` \ No newline at end of file diff --git a/mx-rust-semantics/main/expression/strings.md b/mx-rust-semantics/main/expression/strings.md new file mode 100644 index 0000000..5edf1a0 --- /dev/null +++ b/mx-rust-semantics/main/expression/strings.md @@ -0,0 +1,34 @@ +```k + +module MX-RUST-EXPRESSION-STRINGS + imports private BOOL + imports private INT + imports private MX-RUST-REPRESENTATION + imports private RUST-VALUE-SYNTAX + imports private STRING + + rule concatString(ptrValue(_, S1:String), ptrValue(_, S2:String)) + => ptrValue(null, S1 +String S2) + + rule toString(ptrValue(_, i32(Value:MInt{32}))) + => ptrValue(null, padLeftString(Base2String(MInt2Unsigned(Value), 16), "0", 32 divInt 4)) + rule toString(ptrValue(_, u32(Value:MInt{32}))) + => ptrValue(null, padLeftString(Base2String(MInt2Unsigned(Value), 16), "0", 32 divInt 4)) + rule toString(ptrValue(_, i64(Value:MInt{64}))) + => ptrValue(null, padLeftString(Base2String(MInt2Unsigned(Value), 16), "0", 64 divInt 4)) + rule toString(ptrValue(_, u64(Value:MInt{64}))) + => ptrValue(null, padLeftString(Base2String(MInt2Unsigned(Value), 16), "0", 64 divInt 4)) + rule toString(ptrValue(_, u128(Value:MInt{128}))) + => ptrValue(null, padLeftString(Base2String(MInt2Unsigned(Value), 16), "0", 128 divInt 4)) + rule toString(ptrValue(null, Value:String)) => ptrValue(null, Value) + // TODO: convert all Value entries to string + + syntax String ::= padLeftString(value:String, padding:String, count:Int) [function, total] + rule padLeftString(...value:S, padding:P, count:C) => S + requires C <=Int lengthString(S) orBool lengthString(P) =/=Int 1 + rule padLeftString(S:String => P +String S, P:String, _Count:Int) + [owise] + +endmodule + +``` diff --git a/mx-rust-semantics/main/mx-rust-common.md b/mx-rust-semantics/main/mx-rust-common.md index c5b6c61..57742b4 100644 --- a/mx-rust-semantics/main/mx-rust-common.md +++ b/mx-rust-semantics/main/mx-rust-common.md @@ -1,6 +1,13 @@ ```k +requires "expression.md" +requires "preprocessing.md" +requires "representation.md" + module MX-RUST-COMMON + imports private MX-RUST-EXPRESSION + imports private MX-RUST-PREPROCESSING + imports private MX-RUST-REPRESENTATION endmodule ``` diff --git a/mx-rust-semantics/main/preprocessing.md b/mx-rust-semantics/main/preprocessing.md new file mode 100644 index 0000000..812d0c0 --- /dev/null +++ b/mx-rust-semantics/main/preprocessing.md @@ -0,0 +1,11 @@ +```k + +requires "preprocessing/methods.md" +requires "preprocessing/traits.md" + +module MX-RUST-PREPROCESSING + imports private MX-RUST-PREPROCESSING-METHODS + imports private MX-RUST-PREPROCESSING-TRAITS +endmodule + +``` diff --git a/mx-rust-semantics/main/preprocessing/methods.md b/mx-rust-semantics/main/preprocessing/methods.md new file mode 100644 index 0000000..5d4d3f9 --- /dev/null +++ b/mx-rust-semantics/main/preprocessing/methods.md @@ -0,0 +1,124 @@ +```k + +module MX-RUST-PREPROCESSING-METHODS + imports private COMMON-K-CELL + imports private K-EQUAL-SYNTAX + imports private LIST + imports private MX-RUST-REPRESENTATION + imports private RUST-PREPROCESSING-CONFIGURATION + imports private RUST-REPRESENTATION + imports private RUST-SHARED-SYNTAX + imports private STRING + + syntax Identifier ::= "storage_mapper" [token] + + syntax MxRustInstruction ::= mxRustPreprocessMethods(trait: TypePath, methodNames: List) + | mxRustPreprocessMethod(trait: TypePath, methodName: Identifier) + | addStorageMethodBody + ( trait: TypePath + , methodName: Identifier + , storageName:String + , mapperValueType:MxRustTypeOrError + ) + + rule + mxRustPreprocessMethods(T:TypePath) + => mxRustPreprocessMethods(T, MethodNames) + ... + + T + MethodNames:List + + rule mxRustPreprocessMethods(_:TypePath, .List) => .K + rule mxRustPreprocessMethods(T:TypePath, ListItem(MethodName:Identifier) Names:List) + => mxRustPreprocessMethod(T, MethodName) ~> mxRustPreprocessMethods(T, Names) + + rule + + mxRustPreprocessMethod(Trait:TypePath, Method:Identifier) + => addStorageMethodBody + (... trait: Trait, methodName: Method + , storageName: getStorageName(Atts) + , mapperValueType: getMapperValueType(MapperValue) + ) + ... + + Trait + Method + empty + Atts:OuterAttributes + + #token("SingleValueMapper", "Identifier") < MapperValue:GenericArg , .GenericArgList > + + requires getStorageName(Atts) =/=K "" + [priority(50)] + rule mxRustPreprocessMethod(_Trait:TypePath, _Method:Identifier) => .K + [priority(100)] + + rule + + addStorageMethodBody + (... trait: Trait:TypePath, methodName: Method:Identifier + , storageName: StorageName:String + , mapperValueType: MapperValueType:MxRustType) => .K + ... + + Trait + Method + Params:NormalizedFunctionParameterList + + empty => block(buildStorageMethodBody(Params, StorageName, MapperValueType)) + + + syntax String ::= getStorageName(atts:OuterAttributes) [function, total] + rule getStorageName() => "" + rule getStorageName(.NonEmptyOuterAttributes) => "" + rule getStorageName + ( (#[ #token("storage_mapper", "Identifier") :: .SimplePathList + ( Name:String, .CallParamsList ) + ]) + _:NonEmptyOuterAttributes + ) => Name + rule getStorageName + ( (#[ #token("view", "Identifier") :: .SimplePathList + ( _Name:PathExprSegments, .CallParamsList ) + ]) + Atts:NonEmptyOuterAttributes + ) + => getStorageName(Atts) + + syntax BlockExpression ::= buildStorageMethodBody + ( params: NormalizedFunctionParameterList + , storageName: String + , mapperValueType: MxRustType + ) [function, total] + rule buildStorageMethodBody + (... params: (_S:SelfSort : _), Params:NormalizedFunctionParameterList + , storageName: StorageName:String + , mapperValueType: ValueType:MxRustType + ) + => { .InnerAttributes + #token("SingleValueMapper", "Identifier"):Identifier + :: #token("new", "Identifier"):PathIdentSegment + ( concatString(StorageName, buildParamsConcat(Params)) + , ptrValue(null, ValueType) + , .CallParamsList + ) + } + + syntax Expression ::= buildParamsConcat(params: NormalizedFunctionParameterList) [function , total] + rule buildParamsConcat(.NormalizedFunctionParameterList) => "" + rule buildParamsConcat(Param:NormalizedFunctionParameter , L:NormalizedFunctionParameterList) + => concatString(paramToString(Param), buildParamsConcat(L)) + + syntax Expression ::= paramToString(NormalizedFunctionParameter) [function, total] + rule paramToString(I:Identifier : _:Type) => toString(I) + rule paramToString(S:SelfSort : _:Type) => toString(S) + + syntax MxRustTypeOrError ::= getMapperValueType(GenericArg) [function, total] + rule getMapperValueType(Type:GenericArg) => error("unknown Mx-Rust type", Type) + [owise] + rule getMapperValueType(#token("BigUint", "Identifier")) => BigUint +endmodule + +``` diff --git a/mx-rust-semantics/main/preprocessing/traits.md b/mx-rust-semantics/main/preprocessing/traits.md new file mode 100644 index 0000000..e37339e --- /dev/null +++ b/mx-rust-semantics/main/preprocessing/traits.md @@ -0,0 +1,27 @@ +```k + +module MX-RUST-PREPROCESSING-TRAITS + imports private COMMON-K-CELL + imports private LIST + imports private MX-RUST-REPRESENTATION + imports private RUST-PREPROCESSING-CONFIGURATION + imports private RUST-SHARED-SYNTAX + + syntax MxRustInstruction ::= mxRustPreprocessTraits(List) + | mxRustPreprocessTrait(TypePath) + + rule + + mxRustPreprocessTraits => mxRustPreprocessTraits(Traits) + ... + + Traits:List + + rule mxRustPreprocessTraits(.List) => .K + rule mxRustPreprocessTraits(ListItem(Trait:TypePath) Traits:List) + => mxRustPreprocessTrait(Trait) ~> mxRustPreprocessTraits(Traits) + + rule mxRustPreprocessTrait(Trait:TypePath) => mxRustPreprocessMethods(Trait) +endmodule + +``` diff --git a/mx-rust-semantics/main/representation.md b/mx-rust-semantics/main/representation.md index 0971fd2..ed85ba2 100644 --- a/mx-rust-semantics/main/representation.md +++ b/mx-rust-semantics/main/representation.md @@ -1,7 +1,19 @@ ```k module MX-RUST-REPRESENTATION + imports RUST-SHARED-SYNTAX + syntax MxRustInstruction ::= "mxRustPreprocessTraits" + | mxRustPreprocessMethods(TypePath) + + syntax MxRustType ::= "BigUint" + syntax MxRustTypeOrError ::= MxRustType | SemanticsError + syntax Value ::= MxRustType + + syntax SemanticsError ::= unknownMxRustType(GenericArg) + + syntax Expression ::= concatString(Expression, Expression) [seqstrict] + | toString(Expression) [strict] endmodule ``` diff --git a/rust-semantics/representation.md b/rust-semantics/representation.md index dee4d83..0ff511e 100644 --- a/rust-semantics/representation.md +++ b/rust-semantics/representation.md @@ -24,6 +24,7 @@ module RUST-VALUE-SYNTAX | tuple(ValueList) | struct(TypePath, Map) // Map from field name (Identifier) to value ID (Int) | Bool + | String syntax ValueList ::= List{Value, ","} syntax ValueOrError ::= Value | SemanticsError From 008e67de0273f61e91f4173bc63b610f45b7dc81 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 22:05:21 +0300 Subject: [PATCH 09/13] Implement storage accessors --- mx-rust-semantics/main/glue.md | 37 +++++++++++ mx-rust-semantics/main/modules.md | 9 +++ mx-rust-semantics/main/modules/storage.md | 78 +++++++++++++++++++++++ mx-rust-semantics/main/mx-rust-common.md | 4 ++ mx-rust-semantics/main/representation.md | 8 +++ rust-semantics/expression/literals.md | 1 + 6 files changed, 137 insertions(+) create mode 100644 mx-rust-semantics/main/glue.md create mode 100644 mx-rust-semantics/main/modules.md create mode 100644 mx-rust-semantics/main/modules/storage.md diff --git a/mx-rust-semantics/main/glue.md b/mx-rust-semantics/main/glue.md new file mode 100644 index 0000000..db06ea7 --- /dev/null +++ b/mx-rust-semantics/main/glue.md @@ -0,0 +1,37 @@ +```k + +module MX-RUST-GLUE + imports private COMMON-K-CELL + imports private MX-COMMON-SYNTAX + imports private RUST-EXECUTION-CONFIGURATION + imports private RUST-VALUE-SYNTAX + imports private MX-RUST-REPRESENTATION + + rule + + storeHostValue + (... destination: rustDestination(ValueId) + , value: wrappedRust(V:Value) + ) + => .K + ... + + Values:Map => Values[ValueId <- V] + + rule + + mxRustLoadPtr(P:Int) => ptrValue(ptr(P), V) + ... + + P |-> V:Value ... + + rule + mxRustNewValue(V:Value) => ptrValue(ptr(NextId), V) ... + NextId:Int => NextId +Int 1 + Values:Map => Values[NextId <- V] + + rule mxIntValue(I:Int) ~> mxValueToRust(T:Type) + => mxRustNewValue(integerToValue(I, T)) +endmodule + +``` diff --git a/mx-rust-semantics/main/modules.md b/mx-rust-semantics/main/modules.md new file mode 100644 index 0000000..ca6e473 --- /dev/null +++ b/mx-rust-semantics/main/modules.md @@ -0,0 +1,9 @@ +```k + +requires "modules/storage.md" + +module MX-RUST-MODULES + imports private MX-RUST-MODULES-STORAGE +endmodule + +``` diff --git a/mx-rust-semantics/main/modules/storage.md b/mx-rust-semantics/main/modules/storage.md new file mode 100644 index 0000000..e7ea2ff --- /dev/null +++ b/mx-rust-semantics/main/modules/storage.md @@ -0,0 +1,78 @@ +```k + +module MX-RUST-MODULES-STORAGE + imports private COMMON-K-CELL + imports private MX-COMMON-SYNTAX + imports private MX-RUST-REPRESENTATION + imports private RUST-EXECUTION-CONFIGURATION + imports private RUST-REPRESENTATION + imports private RUST-SHARED-SYNTAX + + rule + normalizedMethodCall + ( #token("SingleValueMapper", "Identifier"):Identifier #as Type:Identifier + , #token("new", "Identifier"):Identifier + , ( ptr(KeyId:Int) + , ptr(ResultTypeId:Int) + , .NormalizedCallParams + ) + ) + => mxRustNewValue + ( struct + ( Type + , #token("storage_key", "Identifier"):Identifier |-> KeyId + #token("result_type", "Identifier"):Identifier |-> ResultTypeId + ) + ) + + rule + + normalizedMethodCall + ( #token("SingleValueMapper", "Identifier"):Identifier #as Type:Identifier + , #token("set", "Identifier"):Identifier + , ( ptr(SelfId:Int) + , ptr(ValueId:Int) + , .NormalizedCallParams + ) + ) + => MX#storageStore(mxStringValue(StorageKey), wrappedRust(V)) + ... + + + SelfId |-> struct + ( Type + , #token("storage_key", "Identifier"):Identifier |-> StorageKeyId:Int + _:Map + ) + StorageKeyId |-> StorageKey:String + ValueId |-> V:Value + ... + + + rule + + normalizedMethodCall + ( #token("SingleValueMapper", "Identifier"):Identifier #as Type:Identifier + , #token("get", "Identifier"):Identifier + , ( ptr(SelfId:Int) + , .NormalizedCallParams + ) + ) + => MX#storageLoad(mxStringValue(StorageKey), rustDestination(NextId)) + ~> mxRustLoadPtr(NextId) + ... + + + SelfId |-> struct + ( Type + , #token("storage_key", "Identifier"):Identifier |-> StorageKeyId:Int + _:Map + ) + StorageKeyId |-> StorageKey:String + ... + + NextId:Int => NextId +Int 1 + +endmodule + +``` diff --git a/mx-rust-semantics/main/mx-rust-common.md b/mx-rust-semantics/main/mx-rust-common.md index 57742b4..1758966 100644 --- a/mx-rust-semantics/main/mx-rust-common.md +++ b/mx-rust-semantics/main/mx-rust-common.md @@ -1,11 +1,15 @@ ```k requires "expression.md" +requires "glue.md" +requires "modules.md" requires "preprocessing.md" requires "representation.md" module MX-RUST-COMMON imports private MX-RUST-EXPRESSION + imports private MX-RUST-GLUE + imports private MX-RUST-MODULES imports private MX-RUST-PREPROCESSING imports private MX-RUST-REPRESENTATION endmodule diff --git a/mx-rust-semantics/main/representation.md b/mx-rust-semantics/main/representation.md index ed85ba2..2c15d7f 100644 --- a/mx-rust-semantics/main/representation.md +++ b/mx-rust-semantics/main/representation.md @@ -1,10 +1,14 @@ ```k module MX-RUST-REPRESENTATION + imports RUST-REPRESENTATION imports RUST-SHARED-SYNTAX syntax MxRustInstruction ::= "mxRustPreprocessTraits" | mxRustPreprocessMethods(TypePath) + | mxRustNewValue(ValueOrError) + | mxValueToRust(Type) + | mxRustLoadPtr(Int) syntax MxRustType ::= "BigUint" syntax MxRustTypeOrError ::= MxRustType | SemanticsError @@ -12,8 +16,12 @@ module MX-RUST-REPRESENTATION syntax SemanticsError ::= unknownMxRustType(GenericArg) + syntax MxWrappedValue ::= wrappedRust(Value) + syntax Expression ::= concatString(Expression, Expression) [seqstrict] | toString(Expression) [strict] + + syntax MxValue ::= rustDestination(Int) endmodule ``` diff --git a/rust-semantics/expression/literals.md b/rust-semantics/expression/literals.md index 71e7977..c47e0d0 100644 --- a/rust-semantics/expression/literals.md +++ b/rust-semantics/expression/literals.md @@ -18,6 +18,7 @@ module RUST-EXPRESSION-INTEGER-LITERALS rule I:IntegerLiteral => wrapPtrValueOrError(null, parseInteger(I)) rule B:Bool:LiteralExpression => ptrValue(null, B:Bool:Value) + rule S:String => ptrValue(null, S) syntax ValueOrError ::= parseInteger(IntegerLiteral) [function, total] | parseInteger(String) [function, total] From b38e5081270fd31b7557b10ad80e4a19ae1cffa8 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 22:12:38 +0300 Subject: [PATCH 10/13] Implement BigUint::from --- mx-rust-semantics/main/modules.md | 2 + mx-rust-semantics/main/modules/biguint.md | 46 +++++++++++++++++++++++ 2 files changed, 48 insertions(+) create mode 100644 mx-rust-semantics/main/modules/biguint.md diff --git a/mx-rust-semantics/main/modules.md b/mx-rust-semantics/main/modules.md index ca6e473..c9aa757 100644 --- a/mx-rust-semantics/main/modules.md +++ b/mx-rust-semantics/main/modules.md @@ -1,8 +1,10 @@ ```k +requires "modules/biguint.md" requires "modules/storage.md" module MX-RUST-MODULES + imports private MX-RUST-MODULES-BIGUINT imports private MX-RUST-MODULES-STORAGE endmodule diff --git a/mx-rust-semantics/main/modules/biguint.md b/mx-rust-semantics/main/modules/biguint.md new file mode 100644 index 0000000..ecaaa11 --- /dev/null +++ b/mx-rust-semantics/main/modules/biguint.md @@ -0,0 +1,46 @@ +```k + +module MX-RUST-MODULES-BIGUINT + imports private COMMON-K-CELL + imports private MX-COMMON-SYNTAX + imports private MX-RUST-REPRESENTATION + imports private RUST-EXECUTION-CONFIGURATION + imports private RUST-REPRESENTATION + imports private RUST-SHARED-SYNTAX + + rule + + normalizedMethodCall + ( #token("BigUint", "Identifier"):Identifier + , #token("from", "Identifier"):Identifier + , ( ptr(ValueId:Int) + , .NormalizedCallParams + ) + ) + // TODO: Should check that V >= 0 + => mxRustBigIntNew(valueToInteger(V)) + ... + + ValueId |-> V:Value ... + + // -------------------------------------- + + syntax MxRustInstruction ::= mxRustBigIntNew(IntOrError) + | "mxRustCreateBigUint" + + rule mxRustBigIntNew(V:Int) + => MX#bigIntNew(mxIntValue(V)) + ~> mxValueToRust(i32) + ~> mxRustCreateBigUint + + rule ptrValue(ptr(BigUintId:Int), _) ~> mxRustCreateBigUint + => mxRustNewValue + ( struct + ( #token("BigUint", "Identifier"):Identifier + , #token("mx_biguint_id", "Identifier"):Identifier |-> BigUintId + ) + ) + +endmodule + +``` From 87501fc2085e0bd1652c7d20299e071182d6f3ad Mon Sep 17 00:00:00 2001 From: Virgil Serbanuta Date: Wed, 11 Sep 2024 01:08:20 +0300 Subject: [PATCH 11/13] Default storage values --- mx-rust-semantics/main/glue.md | 14 +++++++++++++- mx-rust-semantics/main/modules/biguint.md | 2 ++ mx-rust-semantics/main/modules/storage.md | 4 +++- mx-rust-semantics/main/representation.md | 3 ++- mx-semantics/test/execution.md | 8 ++++---- 5 files changed, 24 insertions(+), 7 deletions(-) diff --git a/mx-rust-semantics/main/glue.md b/mx-rust-semantics/main/glue.md index db06ea7..0b07de7 100644 --- a/mx-rust-semantics/main/glue.md +++ b/mx-rust-semantics/main/glue.md @@ -10,7 +10,7 @@ module MX-RUST-GLUE rule storeHostValue - (... destination: rustDestination(ValueId) + (... destination: rustDestination(ValueId, _:MxRustType) , value: wrappedRust(V:Value) ) => .K @@ -18,6 +18,18 @@ module MX-RUST-GLUE Values:Map => Values[ValueId <- V] + rule + (.K => mxRustEmptyValue(T)) + ~> storeHostValue + (... destination: rustDestination(_, T:MxRustType) + , value: mxWrappedEmpty + ) + rule + (ptrValue(_, V:Value) => .K) + ~> storeHostValue + (... value: mxWrappedEmpty => wrappedRust(V) + ) + rule mxRustLoadPtr(P:Int) => ptrValue(ptr(P), V) diff --git a/mx-rust-semantics/main/modules/biguint.md b/mx-rust-semantics/main/modules/biguint.md index ecaaa11..1e4e363 100644 --- a/mx-rust-semantics/main/modules/biguint.md +++ b/mx-rust-semantics/main/modules/biguint.md @@ -41,6 +41,8 @@ module MX-RUST-MODULES-BIGUINT ) ) + rule mxRustEmptyValue(BigUint) => mxRustBigIntNew(0) + endmodule ``` diff --git a/mx-rust-semantics/main/modules/storage.md b/mx-rust-semantics/main/modules/storage.md index e7ea2ff..2d40490 100644 --- a/mx-rust-semantics/main/modules/storage.md +++ b/mx-rust-semantics/main/modules/storage.md @@ -58,7 +58,7 @@ module MX-RUST-MODULES-STORAGE , .NormalizedCallParams ) ) - => MX#storageLoad(mxStringValue(StorageKey), rustDestination(NextId)) + => MX#storageLoad(mxStringValue(StorageKey), rustDestination(NextId, ResultType)) ~> mxRustLoadPtr(NextId) ... @@ -66,9 +66,11 @@ module MX-RUST-MODULES-STORAGE SelfId |-> struct ( Type , #token("storage_key", "Identifier"):Identifier |-> StorageKeyId:Int + #token("result_type", "Identifier"):Identifier |-> ResultTypeId:Int _:Map ) StorageKeyId |-> StorageKey:String + ResultTypeId |-> ResultType:MxRustType ... NextId:Int => NextId +Int 1 diff --git a/mx-rust-semantics/main/representation.md b/mx-rust-semantics/main/representation.md index 2c15d7f..39c5be5 100644 --- a/mx-rust-semantics/main/representation.md +++ b/mx-rust-semantics/main/representation.md @@ -7,6 +7,7 @@ module MX-RUST-REPRESENTATION syntax MxRustInstruction ::= "mxRustPreprocessTraits" | mxRustPreprocessMethods(TypePath) | mxRustNewValue(ValueOrError) + | mxRustEmptyValue(MxRustType) | mxValueToRust(Type) | mxRustLoadPtr(Int) @@ -21,7 +22,7 @@ module MX-RUST-REPRESENTATION syntax Expression ::= concatString(Expression, Expression) [seqstrict] | toString(Expression) [strict] - syntax MxValue ::= rustDestination(Int) + syntax MxValue ::= rustDestination(Int, MxRustType) endmodule ``` diff --git a/mx-semantics/test/execution.md b/mx-semantics/test/execution.md index 2386f63..23a3d5c 100644 --- a/mx-semantics/test/execution.md +++ b/mx-semantics/test/execution.md @@ -18,7 +18,7 @@ module MX-TEST-EXECUTION-PARSING-SYNTAX | setCallee(String) | addAccount(String) | setBalance(account:String, token:String, nonce:Int, value:Int) - | setStorage(account:String, key:String, value:MxValue) + | setStorage(account:String, key:String, value:MxWrappedValue) | setBlockTimestamp(Int) | setMockCode(String, MxValue) @@ -238,7 +238,7 @@ module MX-ACCOUNTS-TEST setStorage (... account: Account:String , key: Key:String - , value: Value:MxValue + , value: Value:MxWrappedValue ) => .K ... @@ -251,7 +251,7 @@ module MX-ACCOUNTS-TEST setStorage (... account: Account:String , key: Key:String - , value: Value:MxValue + , value: Value:MxWrappedValue ) => .K ... @@ -260,7 +260,7 @@ module MX-ACCOUNTS-TEST .Bag => Key - wrappedMx(Value) + Value [priority(100)] From 29dc0722e302dbd7ae8e26efef33d5d966d940cb Mon Sep 17 00:00:00 2001 From: Virgil Date: Wed, 11 Sep 2024 11:58:51 +0300 Subject: [PATCH 12/13] Storage set_if_empty --- mx-rust-semantics/main/glue.md | 1 + mx-rust-semantics/main/modules/storage.md | 33 +++++++++++++++++++++++ mx-rust-semantics/main/representation.md | 2 +- 3 files changed, 35 insertions(+), 1 deletion(-) diff --git a/mx-rust-semantics/main/glue.md b/mx-rust-semantics/main/glue.md index 0b07de7..9b9162d 100644 --- a/mx-rust-semantics/main/glue.md +++ b/mx-rust-semantics/main/glue.md @@ -17,6 +17,7 @@ module MX-RUST-GLUE ... Values:Map => Values[ValueId <- V] + requires ValueId >=Int 0 rule (.K => mxRustEmptyValue(T)) diff --git a/mx-rust-semantics/main/modules/storage.md b/mx-rust-semantics/main/modules/storage.md index 2d40490..582f64b 100644 --- a/mx-rust-semantics/main/modules/storage.md +++ b/mx-rust-semantics/main/modules/storage.md @@ -49,6 +49,38 @@ module MX-RUST-MODULES-STORAGE ... + rule + + normalizedMethodCall + ( #token("SingleValueMapper", "Identifier"):Identifier #as Type:Identifier + , #token("set_if_empty", "Identifier"):Identifier + , ( ptr(SelfId:Int) + , ptr(ValueId:Int) + , .NormalizedCallParams + ) + ) + => MX#storageLoad(mxStringValue(StorageKey), rustDestination(-1, noType)) + ~> setIfEmpty + ~> MX#storageStore(mxStringValue(StorageKey), wrappedRust(V)) + ... + + + SelfId |-> struct + ( Type + , #token("storage_key", "Identifier"):Identifier |-> StorageKeyId:Int + _:Map + ) + StorageKeyId |-> StorageKey:String + ValueId |-> V:Value + ... + + + rule mxRustEmptyValue(noType) ~> storeHostValue(...) ~> setIfEmpty + => .K + rule storeHostValue(... value: wrappedRust(_)) + ~> setIfEmpty ~> MX#storageStore(_) + => .K + rule normalizedMethodCall @@ -75,6 +107,7 @@ module MX-RUST-MODULES-STORAGE NextId:Int => NextId +Int 1 + syntax MxRustInstruction ::= "setIfEmpty" endmodule ``` diff --git a/mx-rust-semantics/main/representation.md b/mx-rust-semantics/main/representation.md index 39c5be5..a17f947 100644 --- a/mx-rust-semantics/main/representation.md +++ b/mx-rust-semantics/main/representation.md @@ -11,7 +11,7 @@ module MX-RUST-REPRESENTATION | mxValueToRust(Type) | mxRustLoadPtr(Int) - syntax MxRustType ::= "BigUint" + syntax MxRustType ::= "noType" | "BigUint" syntax MxRustTypeOrError ::= MxRustType | SemanticsError syntax Value ::= MxRustType From a647365b302f3c7d39bd577264581b139bebded8 Mon Sep 17 00:00:00 2001 From: Virgil Date: Tue, 10 Sep 2024 22:18:00 +0300 Subject: [PATCH 13/13] Storage tests --- mx-rust-semantics/test/configuration.md | 1 + mx-rust-semantics/test/execution.md | 41 ++++++++++++++++++++++++ tests/mx-rust/storage.1.run | 12 +++++++ tests/mx-rust/storage.2.run | 9 ++++++ tests/mx-rust/storage.3.run | 20 ++++++++++++ tests/mx-rust/storage.rs | 33 +++++++++++++++++++ tests/mx/storage/get-existing-storage.mx | 2 +- tests/mx/storage/set-existing-storage.mx | 2 +- 8 files changed, 118 insertions(+), 2 deletions(-) create mode 100644 tests/mx-rust/storage.1.run create mode 100644 tests/mx-rust/storage.2.run create mode 100644 tests/mx-rust/storage.3.run create mode 100644 tests/mx-rust/storage.rs diff --git a/mx-rust-semantics/test/configuration.md b/mx-rust-semantics/test/configuration.md index 3b0d2d1..0701dcb 100644 --- a/mx-rust-semantics/test/configuration.md +++ b/mx-rust-semantics/test/configuration.md @@ -8,6 +8,7 @@ module MX-RUST-EXECUTION-TEST-CONFIGURATION + .Map endmodule diff --git a/mx-rust-semantics/test/execution.md b/mx-rust-semantics/test/execution.md index 8a11b20..267e32f 100644 --- a/mx-rust-semantics/test/execution.md +++ b/mx-rust-semantics/test/execution.md @@ -1,13 +1,54 @@ ```k module MX-RUST-TESTING-PARSING-SYNTAX + imports INT-SYNTAX + imports MX-TEST-EXECUTION-PARSING-SYNTAX imports RUST-EXECUTION-TEST-PARSING-SYNTAX + imports RUST-SHARED-SYNTAX + imports RUST-VALUE-SYNTAX + imports STRING-SYNTAX syntax MxRustTest ::= ExecutionTest + syntax ExecutionItem ::= "set_named" String + | "push_named" String + | "get_bigint_from_struct" + | "check_eq" Int + | TestInstruction endmodule module MX-RUST-TEST + imports private COMMON-K-CELL + imports private MX-RUST-EXECUTION-TEST-CONFIGURATION + imports private MX-RUST-TESTING-PARSING-SYNTAX + imports private RUST-EXECUTION-CONFIGURATION + + rule + set_named Name:String => .K ... + ListItem(Value) => .List ... + M:Map => M[Name <- Value] + + rule + push_named Name:String => .K ... + .List => ListItem(Value) ... + Name |-> Value ... + + rule + + ptrValue + ( _ + , struct + ( #token("BigUint", "Identifier") + , #token("mx_biguint_id", "Identifier"):Identifier |-> BigUintIdId _:Map + ) + ) + ~> get_bigint_from_struct ; Test:ExecutionTest + => push mxIntValue(MInt2Unsigned(BigUintId)) + ~> get_big_int + ~> Test + ... + + BigUintIdId |-> i32(BigUintId:MInt{32}) ... endmodule ``` diff --git a/tests/mx-rust/storage.1.run b/tests/mx-rust/storage.1.run new file mode 100644 index 0000000..911768f --- /dev/null +++ b/tests/mx-rust/storage.1.run @@ -0,0 +1,12 @@ + +addAccount("Owner"); +setCallee("Owner"); +new Storage; +set_named "self"; +push_named "self"; +push 10u64; +call Storage.set_no_arg; +push_named "self"; +call Storage.get_no_arg; +get_bigint_from_struct; +check_eq mxIntValue(10) diff --git a/tests/mx-rust/storage.2.run b/tests/mx-rust/storage.2.run new file mode 100644 index 0000000..bdefa78 --- /dev/null +++ b/tests/mx-rust/storage.2.run @@ -0,0 +1,9 @@ + +addAccount("Owner"); +setCallee("Owner"); +new Storage; +set_named "self"; +push_named "self"; +call Storage.get_no_arg; +get_bigint_from_struct; +check_eq mxIntValue(0) diff --git a/tests/mx-rust/storage.3.run b/tests/mx-rust/storage.3.run new file mode 100644 index 0000000..7881110 --- /dev/null +++ b/tests/mx-rust/storage.3.run @@ -0,0 +1,20 @@ +addAccount("Owner"); +setCallee("Owner"); +new Storage; +set_named "self"; + +push_named "self"; +push 10u64; +call Storage.set_no_arg_if_empty; +push_named "self"; +call Storage.get_no_arg; +get_bigint_from_struct; +check_eq mxIntValue(10); + +push_named "self"; +push 20u64; +call Storage.set_no_arg_if_empty; +push_named "self"; +call Storage.get_no_arg; +get_bigint_from_struct; +check_eq mxIntValue(10) diff --git a/tests/mx-rust/storage.rs b/tests/mx-rust/storage.rs new file mode 100644 index 0000000..0b16596 --- /dev/null +++ b/tests/mx-rust/storage.rs @@ -0,0 +1,33 @@ +#![no_std] + +#[allow(unused_imports)] +use multiversx_sc::imports::*; + +#[multiversx_sc::contract] +pub trait Storage { + #[view(noArg)] + #[storage_mapper("no_arg")] + fn no_arg_storage(&self) -> SingleValueMapper; + + #[view(getName)] + #[storage_mapper("name")] + fn one_arg_storage(&self, key: u64) -> SingleValueMapper; + + #[init] + fn init(&self) {} + + #[upgrade] + fn upgrade(&self) {} + + fn set_no_arg(&self, value: u64) { + self.no_arg_storage().set(BigUint::from(value)) + } + + fn get_no_arg(&self) -> BigUint { + self.no_arg_storage().get() + } + + fn set_no_arg_if_empty(&self, value: u64) { + self.no_arg_storage().set_if_empty(BigUint::from(value)) + } +} diff --git a/tests/mx/storage/get-existing-storage.mx b/tests/mx/storage/get-existing-storage.mx index 0ebcd78..23a3457 100644 --- a/tests/mx/storage/get-existing-storage.mx +++ b/tests/mx/storage/get-existing-storage.mx @@ -1,6 +1,6 @@ addAccount("Owner"); setCallee("Owner"); -setStorage("Owner", "MyKey", mxStringValue("Hello")); +setStorage("Owner", "MyKey", wrappedMx(mxStringValue("Hello"))); push mxIntValue(12); push mxStringValue("MyKey"); diff --git a/tests/mx/storage/set-existing-storage.mx b/tests/mx/storage/set-existing-storage.mx index 094fc9b..58be307 100644 --- a/tests/mx/storage/set-existing-storage.mx +++ b/tests/mx/storage/set-existing-storage.mx @@ -1,6 +1,6 @@ addAccount("Owner"); setCallee("Owner"); -setStorage("Owner", "MyKey", mxStringValue("Hello")); +setStorage("Owner", "MyKey", wrappedMx(mxStringValue("Hello"))); push wrappedMx(mxStringValue("World")); push mxStringValue("MyKey");