#uniswap #token #exchange #address #decimal #chain #ethereum

no-std uniswap-sdk-core

The Uniswap SDK Core in Rust provides essential functionality for interacting with the Uniswap decentralized exchange

35 releases (10 stable)

3.2.0 Nov 9, 2024
3.0.0 Oct 6, 2024
2.4.0 Oct 6, 2024
1.1.0 Aug 23, 2024
0.20.1 Mar 17, 2024

#1 in #uniswap

Download history 78/week @ 2024-08-04 103/week @ 2024-08-11 369/week @ 2024-08-18 54/week @ 2024-08-25 425/week @ 2024-09-01 237/week @ 2024-09-08 102/week @ 2024-09-15 259/week @ 2024-09-22 144/week @ 2024-09-29 369/week @ 2024-10-06 71/week @ 2024-10-13 48/week @ 2024-10-20 64/week @ 2024-10-27 230/week @ 2024-11-03 130/week @ 2024-11-10 79/week @ 2024-11-17

506 downloads per month
Used in 2 crates

MIT license

110KB
2.5K SLoC

Uniswap SDK Core Rust

Unit Tests Lint crates.io

A Custom Uniswap SDK Core in Rust provides essential functionality for interacting with the Uniswap decentralized exchange.

Note on no_std

By default, this library does not depend on the standard library (std). However, the std feature can be enabled to use thiserror for error handling.

Quickstart

Add this to your Cargo.toml

[dependencies]
uniswap-sdk-core = "3.0.0"

And this to your code:

use uniswap_sdk_core::prelude::*;

Examples

The code below shows an example of how to create a new Token instance for the DAI token on the Ethereum Mainnet using the token! macro.

// The `prelude` module provides a convenient way to import a number of common dependencies at 
// once. This can be useful if you are working with multiple parts of the library and want to avoid
// having to import each dependency individually.
// Import necessary preludes and types
use uniswap_sdk_core::{prelude::*, token};

fn main() {
    // Define the chain ID, address, decimals, symbol, and name for the token
    const CHAIN_ID: u64 = 1; // Ethereum Mainnet
    const TOKEN_ADDRESS: &str = "0x6B175474E89094C44Da98b954EedeAC495271d0F"; // DAI Token Address
    const DECIMALS: u8 = 18;
    const SYMBOL: &str = "DAI";
    const NAME: &str = "Dai Stablecoin";

    // Use the `token!` macro to create a new `Token` instance
    let dai_token = token!(CHAIN_ID, TOKEN_ADDRESS, DECIMALS, SYMBOL, NAME);

    // Example usage of the `Token` methods
    println!("Token Address: {}", dai_token.address());
    println!("Is Native: {}", dai_token.is_native());

    // Example of comparing two tokens
    let another_dai_token = token!(CHAIN_ID, TOKEN_ADDRESS, DECIMALS, SYMBOL, NAME);
    println!("Are the tokens equal? {}", dai_token.equals(&another_dai_token));

    // Example of sorting tokens
    let another_token = token!(CHAIN_ID, "0000000000000000000000000000000000000002", DECIMALS, "ETH", "Ethereum");
    match dai_token.sorts_before(&another_token) {
        Ok(true) => println!("DAI sorts before ETH"),
        Ok(false) => println!("DAI does not sort before ETH"),
        Err(e) => println!("Error comparing tokens: {:?}", e),
    }
}

This example demonstrates how to create a Token instance for DAI on the Ethereum Mainnet using the token! macro.

It then prints the token's address and checks if it's a native token (which it isn't, so it prints false).

It also compares the DAI token with another DAI token instance to show that two instances of the same token are considered equal.

Finally, it attempts to sort the DAI token before an Ethereum token, which should print that DAI sorts before ETH, assuming the addresses are correctly set up for this comparison.

Remember to replace "0x6B175474E89094C44Da98b954EedeAC495271d0F" with the actual address of the DAI token you're working with, and adjust the CHAIN_ID if you're working on a different network (e.g., a testnet).

Contribution

Contributions are welcome! If you find a bug or have suggestions for improvements, feel free to open an issue or submit a pull request on the GitHub repository.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

The Uniswap SDK Core in Rust is inspired by the original Uniswap SDK and aims to provide similar functionality in the Rust programming language.

Used by

  • Uniswap V3 SDK Rust: Opinionated Rust implementation of the Uniswap V3 SDK with a focus on readability and performance
  • Uniswap V2 SDK Rust: Opinionated Rust implementation of the Uniswap V2 SDK with a focus on readability and performance
  • ...

(If you want to add project to the list, dm or open a PR)

Dependencies

~5–7MB
~129K SLoC