PancakeSwap
Launch App
Vietnamese
Vietnamese
  • PancakeSwap Intro
  • Get Started
    • Create a Wallet
    • Get BEP20 Tokens
    • Using PancakeSwap without Centralized Exchanges
    • Connect Your Wallet to PancakeSwap
  • Click Here for Help
    • Troubleshooting Errors
    • General FAQ
    • Fixing Stuck Pending Transactions on MetaMask
    • Binance Academy Guide
  • Contact Us
    • Business Partnerships
    • NFT Market Applications
    • Customer Support
    • Social Accounts & Communities
  • The Kitchen Team
  • Roadmap
  • Brand & Logos
  • Products
    • Exchange
      • Token Swaps
      • How to Trade
      • Liquidity Pools
      • How to Add/Remove Liquidity
      • 📝Limit Orders
        • Limit Orders FAQ
    • Yield Farming
      • How to Use Farms
      • How to Use Farms with BscScan
    • 🍯Syrup Pools
      • How to Stake in Syrup Pools
      • Auto CAKE Syrup Pool
      • Syrup Pool FAQ & Troubleshooting
    • Lottery v2
      • How to Play Lottery v2
      • Lottery FAQ
    • 🔮Prediction
      • How to Use Prediction
      • Prediction FAQ
      • Prediction Troubleshooting
    • 🖼️NFT Market
    • 🖼️NFT Profile System
      • How to Set Up an NFT Profile
      • Teams
    • IFO (Initial Farm Offering)
      • How to Participate in an IFO
      • How to Participate in an IFO with BscScan
      • Contract Details
    • Analytics (Info)
      • Analytics
    • Voting
      • How to Vote
      • How to Vote with SafePal Wallet
  • Tokenomics
    • CAKE
      • CAKE Tokenomics
      • Controlling CAKE supply
  • Developers
    • Contributing
      • Codebase Overview
    • Bug Bounty
    • Smart Contracts
      • PancakeSwap Exchange
        • Factory v2
        • Router v2
      • Main Staking/Syrup Pool/MasterChef Contract
      • Auto CAKE Syrup Pool (CakeVault)
      • Prediction V2
      • Lottery v2
Powered by GitBook
On this page
  • Contract info
  • Read functions
  • getPair
  • allPairs
  • allPairsLength
  • feeTo
  • feeToSetter
  • Write functions
  • createPair
  • setFeeTo
  • setFeeToSetter
  • Events
  • PairCreated
  • Interface

Was this helpful?

  1. Developers
  2. Smart Contracts
  3. PancakeSwap Exchange

Factory v2

PreviousPancakeSwap ExchangeNextRouter v2

Last updated 3 years ago

Was this helpful?

PancakeSwap is based on Uniswap v2. Read the . For more in-depth information on the core contract logic, read the .

Contract info

Contract name: PancakeFactory Contract address: 0xcA143Ce32Fe78f1f7019d7d551a6402fC5350c73

View .

View the .

Read functions

getPair

function getPair(address tokenA, address tokenB) external view returns (address pair);

Address for tokenA and address for tokenB return address of pair contract (where one exists).

tokenA and tokenB order is interchangeable.

Returns 0x0000000000000000000000000000000000000000 as address where no pair exists.

allPairs

function allPairs(uint) external view returns (address pair);

Returns the address of the nth pair (0-indexed) created through the Factory contract.

Returns 0x0000000000000000000000000000000000000000 where pair has not yet been created.

Begins at 0 for first created pair.

allPairsLength

function allPairsLength() external view returns (uint);

Displays the current number of pairs created through the Factory contract as an integer.

feeTo

function feeTo() external view returns (address);

The address to where non-LP-holder fees are sent.

feeToSetter

function feeToSetter() external view returns (address);

The address with permission to set the feeTo address.

Write functions

createPair

function createPair(address tokenA, address tokenB) external returns (address pair);

Creates a pair for tokenA and tokenB where a pair doesn't already exist.

tokenA and tokenB order is interchangeable.

Emits PairCreated (see Events).

setFeeTo

Sets address for feeTo.

setFeeToSetter

Sets address for permission to adjust feeTo.

Events

PairCreated

event PairCreated(address indexed token0, address indexed token1, address pair, uint);

Emitted whenever a createPair creates a new pair.

token0 will appear before token1 in sort order.

The final uint log value will be 1 for the first pair created, 2 for the second, etc.

Interface

import '@uniswap/v2-core/contracts/interfaces/IPancakeFactory.sol';
pragma solidity =0.5.16;


interface IPancakeFactory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

    function createPair(address tokenA, address tokenB) external returns (address pair);

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}
Uniswap v2 documentation
Uniswap v2 Core whitepaper
PancakeFactory.sol on GitHub
PancakeSwap: Factory v2 contract on BscScan