Skip to content
Snippets Groups Projects
Select Git revision
  • master
  • graph
  • timeserie
  • v0.0.4
4 results

vite-env.d.ts

Blame
  • lib.rs 6.04 KiB
    //  Copyright (C) 2018  The Duniter Project Developers.
    //
    // This program is free software: you can redistribute it and/or modify
    // it under the terms of the GNU Affero 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 Affero General Public License for more details.
    //
    // You should have received a copy of the GNU Affero General Public License
    // along with this program.  If not, see <https://www.gnu.org/licenses/>.
    
    //! Implements the Duniter Documents Protocol.
    
    #![cfg_attr(feature = "strict", deny(warnings))]
    #![deny(missing_docs, missing_debug_implementations, missing_copy_implementations, trivial_casts,
            trivial_numeric_casts, unsafe_code, unstable_features, unused_import_braces,
            unused_qualifications)]
    
    extern crate base58;
    extern crate base64;
    extern crate crypto;
    extern crate duniter_crypto;
    #[macro_use]
    extern crate lazy_static;
    extern crate linked_hash_map;
    extern crate regex;
    
    use std::fmt::{Debug, Display, Error, Formatter};
    
    use duniter_crypto::keys::BaseConvertionError;
    
    pub mod blockchain;
    
    /// A block Id.
    #[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
    pub struct BlockId(pub u32);
    
    impl Display for BlockId {
        fn fmt(&self, f: &mut Formatter) -> Result<(), Error> {
            write!(f, "{}", self.0)
        }
    }
    
    /// A hash wrapper.
    ///
    /// A hash is often provided as string composed of 64 hexadecimal character (0 to 9 then A to F).
    #[derive(Copy, Clone, PartialEq, Eq, Hash)]
    pub struct Hash(pub [u8; 32]);
    
    impl Display for Hash {
        fn fmt(&self, f: &mut Formatter) -> Result<(), Error> {
            write!(f, "{}", self.to_hex())
        }
    }
    
    impl Debug for Hash {
        fn fmt(&self, f: &mut Formatter) -> Result<(), Error> {
            write!(f, "Hash({})", self)
        }
    }
    
    impl Default for Hash {
        fn default() -> Hash {
            let default: [u8; 32] = [0; 32];
            Hash(default)
        }