Compare commits

...

6 Commits

Author SHA1 Message Date
zxq9 295799435b Update meta 2025-01-22 14:28:38 +09:00
zxq9 7046b9625d Merge down master 2024-11-01 13:40:41 +09:00
zxq9 670fe59a21 Merge branch 'master' into zomp 2024-11-01 13:28:00 +09:00
zxq9 f37cec34da Merge down 2024-10-07 13:08:25 +09:00
zxq9 e24ddef246 Merge branch 'master' into zomp 2024-09-23 16:57:40 +09:00
zxq9 9124228ff4 Package for zomp 2023-05-30 15:41:16 +09:00
9 changed files with 46 additions and 5 deletions
+1
View File
@@ -0,0 +1 @@
{"src/*", [debug_info, {i, "include/"}, {outdir, "ebin/"}]}.
+1
View File
@@ -5,6 +5,7 @@
%%% @end %%% @end
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeser_api_encoder). -module(aeser_api_encoder).
-vsn("0.1.2").
-export([encode/2, -export([encode/2,
decode/1, decode/1,
+1
View File
@@ -7,6 +7,7 @@
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeser_chain_objects). -module(aeser_chain_objects).
-vsn("0.1.2").
-export([ serialize/4 -export([ serialize/4
, deserialize/4 , deserialize/4
+22 -5
View File
@@ -5,6 +5,7 @@
%%% @end %%% @end
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeser_contract_code). -module(aeser_contract_code).
-vsn("0.1.2").
-include("aeser_contract_code.hrl"). -include("aeser_contract_code.hrl").
@@ -16,15 +17,16 @@
serialize(CodeMap) -> serialize(CodeMap) ->
serialize(CodeMap, ?SOPHIA_CONTRACT_VSN_3). serialize(CodeMap, ?SOPHIA_CONTRACT_VSN_3).
-spec serialize(map(), non_neg_integer()) -> binary(). -spec serialize(map(), non_neg_integer()) -> binary().
serialize(CodeMap = #{ byte_code := ByteCode serialize(CodeMap = #{ byte_code := ByteCode
, type_info := TypeInfo }, SophiaContractVersion) -> , type_info := TypeInfo }, SophiaContractVersion) ->
%% Source hash %% Source hash
SourceHash = case CodeMap of SourceHash =
#{ source_hash := SHash } -> SHash; case CodeMap of
#{ contract_source := SrcStr } -> #{ source_hash := SHash } -> SHash;
enacl:generichash(32, list_to_binary(SrcStr)) #{ contract_source := SrcStr } -> blake2(32, list_to_binary(SrcStr))
end, end,
%% Compiler version %% Compiler version
Version = maps:get(compiler_version, CodeMap, <<"unknown">>), Version = maps:get(compiler_version, CodeMap, <<"unknown">>),
@@ -47,6 +49,21 @@ serialize(CodeMap = #{ byte_code := ByteCode
serialization_template(SophiaContractVersion), serialization_template(SophiaContractVersion),
Fields). Fields).
% NOTE:
% This form significantly favors the presence of enacl and slows fallback
% invokation of eblake2. `try' is really fast; the error throwing machinery
% is comparatively slow. The assumption here is that in cases where you want
% eblake2 performance isn't the problem you're solving (you're probably not
% syncing a new node, for example).
blake2(Size, Bin) ->
try
enacl:generichash(Size, Bin)
catch error:undef ->
{ok, Hash} = eblake2:blake2b(Size, Bin),
Hash
end.
-spec deserialize(binary()) -> map(). -spec deserialize(binary()) -> map().
deserialize(Binary) -> deserialize(Binary) ->
case aeser_chain_objects:deserialize_type_and_vsn(Binary) of case aeser_chain_objects:deserialize_type_and_vsn(Binary) of
+1
View File
@@ -5,6 +5,7 @@
%%% @end %%% @end
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeser_delegation). -module(aeser_delegation).
-vsn("0.1.2").
-export([ aens_preclaim_sig/3 -export([ aens_preclaim_sig/3
, aens_name_sig/4 , aens_name_sig/4
+1
View File
@@ -7,6 +7,7 @@
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeser_id). -module(aeser_id).
-vsn("0.1.2").
-export([ create/2 -export([ create/2
, specialize/1 , specialize/1
+1
View File
@@ -9,6 +9,7 @@
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeser_rlp). -module(aeser_rlp).
-vsn("0.1.2").
-export([ decode/1 -export([ decode/1
, decode_one/1 , decode_one/1
, encode/1 , encode/1
+1
View File
@@ -6,6 +6,7 @@
%%%------------------------------------------------------------------- %%%-------------------------------------------------------------------
-module(aeserialization). -module(aeserialization).
-vsn("0.1.2").
-export([ decode_fields/2 -export([ decode_fields/2
, deserialize/5 , deserialize/5
+17
View File
@@ -0,0 +1,17 @@
{name,"Gajumaru Serialization"}.
{type,lib}.
{modules,[]}.
{prefix,none}.
{author,"Hans Svensson"}.
{desc,"Serialization helpers for the Gajumaru."}.
{package_id,{"otpr","gmserialization",{0,1,2}}}.
{deps,[{"otpr","base58",{0,1,1}},{"otpr","eblake2",{1,0,0}}]}.
{key_name,none}.
{a_email,[]}.
{c_email,[]}.
{copyright,"Hans Svensson"}.
{file_exts,[]}.
{license,skip}.
{repo_url,"https://git.qpq.swiss/QPQ-AG/gmserialization"}.
{tags,["blockchain","crypto","gm", "gajumaru"]}.
{ws_url,[]}.