1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
// This file is part of Gear.

// Copyright (C) 2022-2024 Gear Technologies Inc.
// SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0

// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.

// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.

// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.

use crate::{Error, Result};
pub use gear_utils::now_micros;
use gsdk::ext::sp_runtime::AccountId32;
use std::{fs, path::Path};
use wabt::Wat2Wasm;

/// Compile a source WebAssembly Text (WAT) to Wasm binary code.
pub fn wat2wasm(wat: impl AsRef<str>) -> Vec<u8> {
    Wat2Wasm::new()
        .convert(wat.as_ref())
        .expect("Failed to parse WAT")
        .as_ref()
        .to_vec()
}

/// Return the full path to the optimized Wasm binary file with the `demo_name`
/// name located in the `root_path` directory.
///
/// # Examples
///
/// ```
/// let wasm_path = gclient::wasm_target(".", "demo_ping");
/// assert_eq!(
///     wasm_path,
///     "./target/wasm32-unknown-unknown/release/demo_ping.opt.wasm"
/// );
/// ```
pub fn wasm_target(root_path: impl AsRef<str>, demo_name: impl AsRef<str>) -> String {
    format!(
        "{}/target/wasm32-unknown-unknown/release/{}.opt.wasm",
        root_path.as_ref(),
        demo_name.as_ref()
    )
}

/// Read and return contents of a Wasm file specified by the `path`.
pub fn code_from_os(path: impl AsRef<Path>) -> Result<Vec<u8>> {
    path.as_ref()
        .extension()
        .filter(|&extension| extension.eq("wasm"))
        .ok_or(Error::WrongBinaryExtension)?;

    fs::read(fs::canonicalize(path)?).map_err(Into::into)
}

/// Convert hex string to byte array.
pub fn hex_to_vec(string: impl AsRef<str>) -> Result<Vec<u8>> {
    hex::decode(string.as_ref().trim_start_matches("0x")).map_err(Into::into)
}

/// Returns default bank address.
pub fn bank_address() -> AccountId32 {
    const BANK_ADDRESS: [u8; 32] = *b"gearbankgearbankgearbankgearbank";

    BANK_ADDRESS.into()
}